npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

context-processor

v1.0.2

Published

Intelligent context management MCP server with pre-processing strategies for enhanced content processing

Readme

Context Processor

⚠️ DISCLAIMER: This MCP server is entirely written and maintained by AI (Claude/Gemini) with manual supervision. It is a personal test project created to explore AI-assisted development. Use at your own discretion.

An intelligent Model Context Protocol (MCP) server for saving, managing, and enhancing context with pre-processing strategies. This server helps you organize information efficiently by applying smart transformations like clarification, analysis, and search optimization.

Features

  • Intelligent Context Storage: Save and organize contexts with metadata and tags

  • Pre-processing Strategies: Multiple configurable strategies to enhance context quality:

    • Clarify: Improve content clarity by detecting and fixing ambiguous language
    • Analyze: Comprehensive content analysis (word count, complexity, structure)
    • Search: Extract keywords and enhance searchability
    • Fetch: Detect and manage URLs and external data references
    • Custom: Support for custom processing strategies
  • Context Models: Pre-configured models combining multiple strategies:

    • clarify: Focus on clarity improvement
    • search_optimized: Optimize for searchability
    • analysis: Detailed content analysis
    • comprehensive: All strategies enabled
    • web_enhanced: For web content with URL handling
  • Context Management Tools:

    • Save contexts with automatic or model-based processing
    • Load contexts and discover related content
    • List contexts with filtering by tags
    • Delete contexts
    • Query available models

Installation

npm install context-processor

Building

npm run build

Running

npm start

Or in development mode:

npm run dev

Configuration

Models Configuration

Create a context-models.json file in the project root to define custom models:

{
  "models": [
    {
      "name": "my_model",
      "description": "My custom context model",
      "strategies": [
        {
          "name": "clarify",
          "type": "clarify",
          "enabled": true,
          "config": {}
        },
        {
          "name": "search",
          "type": "search",
          "enabled": true,
          "config": {
            "maxKeywords": 10
          }
        }
      ]
    }
  ]
}

Available Tools

save_context

Save content as context with optional pre-processing.

Parameters:

  • title (string, required): Title for the context
  • content (string, required): Content to save
  • tags (string[], optional): Tags for organizing context
  • metadata (object, optional): Additional metadata
  • modelName (string, optional): Context model to use for pre-processing

Example:

{
  "title": "API Documentation",
  "content": "This is an API with multiple endpoints...",
  "tags": ["api", "documentation"],
  "metadata": { "version": "1.0" },
  "modelName": "comprehensive"
}

load_context

Load a previously saved context and discover related contexts.

Parameters:

  • contextId (string, required): ID of the context to load

Response:

{
  "context": { /* ContextItem */ },
  "relatedContexts": [ /* ContextItem[] */ ]
}

list_contexts

List all saved contexts with optional filtering.

Parameters:

  • tags (string[], optional): Filter by tags
  • limit (number, optional): Maximum number of contexts
  • offset (number, optional): Number of contexts to skip

list_models

List all available context models.

Response:

{
  "models": [
    {
      "name": "clarify",
      "description": "Model focused on clarifying content",
      "strategyCount": 1
    }
  ],
  "total": 5
}

get_model_info

Get detailed information about a specific model.

Parameters:

  • modelName (string, required): Name of the model

delete_context

Delete a context by ID.

Parameters:

  • contextId (string, required): ID of the context to delete

Processing Strategies

Clarify Strategy

Analyzes content for:

  • Ambiguous pronouns (it, this, that)
  • Passive voice usage
  • Vague language (basically, kind of, sort of)

Provides a clarity score and suggestions for improvement.

Search Strategy

  • Extracts 10 most frequent meaningful keywords
  • Filters out common stop words
  • Recommends search queries for the content

Analyze Strategy

Provides metrics:

  • Word count and average word length
  • Sentence and paragraph counts
  • Content complexity assessment (low/medium/high)

Fetch Strategy

  • Detects URLs in content
  • Identifies up to 5 external references
  • Metadata about data sources

Storage

Contexts are stored as JSON files in the ./contexts directory. Each context file is named using its UUID:

contexts/
├── a1b2c3d4-e5f6-7g8h-9i0j-1k2l3m4n5o6p.json
├── b2c3d4e5-f6g7-h8i9-j0k1-l2m3n4o5p6q.json
└── ...

Example Usage

Saving a context with comprehensive processing:

{
  "title": "User Authentication Design",
  "content": "The authentication system basically allows users to log in with their credentials. This approach is generally more secure than storing passwords in plain text. That said, the system needs better error handling.",
  "tags": ["security", "authentication"],
  "modelName": "comprehensive"
}

This will:

  1. Clarify the vague language
  2. Analyze the content structure
  3. Extract key topics (authentication, security, passwords, etc.)
  4. Save all results to context storage

Loading and discovering related contexts:

{
  "contextId": "a1b2c3d4-e5f6-7g8h-9i0j-1k2l3m4n5o6p"
}

Returns the saved context plus up to 5 related contexts that share tags.

Architecture

ContextMCPServer
├── ContextStorage: File-based persistence
├── ContextPreprocessor: Strategy execution engine
└── MCP Protocol Handler: Tool definitions and execution

Data Flow

User Request
    ↓
MCP Server (Tool Handler)
    ↓
ContextPreprocessor (if model specified)
    ├─→ Strategy 1 (Clarify)
    ├─→ Strategy 2 (Analyze)
    └─→ Strategy 3 (Search)
    ↓
ContextStorage (Save/Load)
    ↓
Response

Development

Type Definitions

All types are defined in src/types.ts:

  • ContextItem: Core context data structure
  • PreProcessingStrategy: Strategy configuration
  • ContextModel: Model definition
  • Request/Response types for each tool

Adding Custom Strategies

  1. Define the strategy type in types.ts
  2. Add a handler method in ContextPreprocessor
  3. Add the strategy to a model in context-models.json

Example:

private customStrategy(
  content: string,
  config?: Record<string, unknown>
): PreProcessingResult {
  // Your custom logic here
  return {
    strategy: "custom",
    processed: true,
    result: transformedContent,
  };
}

File Structure

.
├── src/
│   ├── index.ts           # Main MCP server
│   ├── types.ts           # Type definitions
│   ├── storage.ts         # Context persistence
│   └── preprocessor.ts    # Processing strategies
├── contexts/              # Stored contexts (auto-created)
├── dist/                  # Compiled output
├── context-models.json    # Model configurations
├── package.json           # Dependencies
└── tsconfig.json          # TypeScript config

Testing

Run the built-in tests:

npm test

Future Enhancements

  • Database backend support (MongoDB, PostgreSQL)
  • Vector embeddings for semantic search
  • Machine learning-based categorization
  • Multi-user context sharing
  • Version control for contexts
  • Integration with external APIs
  • Real-time collaboration features

License

MIT