Fetches documentation and crate information for the Actix Rust framework via crates.io.
Provides documentation and version information for Ansible.
Retrieves package metadata and documentation for the Django framework via PyPI integration.
Fetches details and documentation for images hosted on Docker Hub.
Retrieves metadata and documentation for the Express.js framework via the npm registry.
Provides documentation and package information for the Gin web framework from official Go sources.
Fetches documentation and metadata for GitHub Actions.
Provides documentation and version information for Helm.
Fetches package metadata and documentation for JavaScript libraries through npm integration.
Retrieves documentation for Jenkins versions and automation topics.
Provides documentation and version information for Kubernetes.
Fetches documentation and version details for the Next.js framework.
Retrieves Node.js version information and official documentation.
Fetches package metadata and installation instructions from the npm registry.
Retrieves package metadata and documentation for the NumPy library via PyPI integration.
Fetches metadata and documentation for Python packages from the Python Package Index.
Retrieves package metadata and documentation for Python libraries.
Provides documentation and version information for the React library.
Fetches documentation and crate information for Rust libraries from crates.io.
Provides documentation and version information for Terraform.
Fetches documentation and version details for TypeScript.
Open Context
A high-performance MCP (Model Context Protocol) server that provides up-to-date documentation for programming languages, frameworks, and tools. Built in Go for speed and simplicity.
What is Open Context?
Open Context fetches and caches documentation from official sources, making it instantly available to AI assistants like Claude. Instead of relying on outdated training data, get real-time access to:
Go: Standard library docs, third-party packages, version release notes
JavaScript/TypeScript: npm packages, Node.js, React, Next.js versions
Python: PyPI packages with installation instructions and package metadata
Rust: Crates.io packages with version info and documentation links
DevOps Tools: Docker, Kubernetes, Helm, Terraform, Ansible, Jenkins, GitHub Actions
And more: Easy to extend with any language or framework
Key Features
Always Up-to-Date: Fetches from official sources (pkg.go.dev, npm registry, PyPI, crates.io, GitHub releases, GitHub API, Docker Hub)
Smart Caching: Local cache with configurable TTL (default: 7 days)
Fast & Lightweight: Written in Go, starts in milliseconds
Two Transport Modes: stdio for local use, HTTP for remote servers
MCP Native: Seamless integration with Claude Desktop, Cursor, and Claude Code
Quick Start
1. Install
Using the install script (recommended):
curl -fsSL https://raw.githubusercontent.com/incu6us/open-context/master/install.sh | bashOr build from source:
git clone https://github.com/incu6us/open-context
cd open-context
go build -o open-contextPrerequisites: Go 1.25 or higher
2. Configure Your MCP Client
Choose your client and follow the setup instructions:
Find your config file:
macOS:
~/Library/Application Support/Claude/claude_desktop_config.jsonWindows:
%APPDATA%\Claude\claude_desktop_config.json
Add open-context:
{ "mcpServers": { "open-context": { "command": "/path/to/open-context" } } }Restart Claude Desktop
Go to Settings > Tools & Integrations > MCP Servers
Add this configuration:
{ "open-context": { "command": "/path/to/open-context" } }Restart Cursor
Option A: Local binary (stdio transport)
claude-code mcp add open-context /path/to/open-contextOption B: Remote server (HTTP transport)
Start the server on your remote machine:
./open-context --transport http --host 0.0.0.0 --port 9011Install via Claude CLI:
claude mcp add --transport http open-context http://your-server.com:9011
3. Start Using It
In your conversation with Claude, just type:
use open-context for goor
create dockerfile using latest alpine image. use open-contextClaude will automatically fetch and use the documentation to answer your questions!
Installation Options
Quick Install Script
The installation script automates everything:
curl -fsSL https://raw.githubusercontent.com/incu6us/open-context/master/install.sh | bashManual Installation
# Clone repository
git clone https://github.com/incu6us/open-context
cd open-context
# Option 1: Build manually
go build -o open-context
# Option 2: Use make
make build
# Or: make setup (builds + shows next steps)Install via go install
go install github.com/incu6us/open-context@latestThe binary will be in $GOPATH/bin/open-context (usually ~/go/bin/open-context).
Configuration
Open Context creates a config file at ~/.open-context/config.yaml on first run.
Cache Configuration
# How long to keep cached documentation
# Formats: "7d" (days), "24h" (hours), "30m" (minutes), "0" (never expire)
cache_ttl: 7dExample configurations:
Offline work:
cache_ttl: 0(never expires)Daily updates:
cache_ttl: 24hWeekly updates:
cache_ttl: 7d(default)
Edit Configuration
# Use your preferred editor
nano ~/.open-context/config.yaml
code ~/.open-context/config.yaml
vim ~/.open-context/config.yamlChanges take effect on next server start.
Usage
Server Modes
stdio transport (default) - For local MCP clients:
./open-contextHTTP transport - For remote access or HTTP-based clients:
# Default (localhost:9011)
./open-context --transport http
# Custom host and port
./open-context --transport http --host 0.0.0.0 --port 3000
# Short flags
./open-context -t http -H 0.0.0.0 -p 9011HTTP endpoints:
GET /health- Health checkPOST /message- MCP JSON-RPC messagesGET /sse- Server-Sent Events stream
Cache Management
# Clear cache (full flag)
./open-context --clear-cache
# Clear cache (short alias)
./open-context --ccThis removes ~/.open-context/cache/. Data will be refetched on next use.
Other Commands
# Show help
./open-context --help
# Show version
./open-context --versionUsing with Claude
Simple Activation
Once configured, activate documentation in your conversation:
use open-context for go
use open-context for typescript
use open-contextClaude will automatically:
Discover available documentation
Use the appropriate tools
Fetch information from official sources
Cache results locally
Example Queries
Go package documentation:
What's new in Go 1.21?
Show me how to use github.com/gin-gonic/ginnpm packages:
Get the latest version of express
Show me React 18 featuresDevOps tools:
What's in Kubernetes 1.28?
Show me Terraform 1.6 changes
Get the golang:1.25-alpine Docker image detailsSee USING_PROMPTS.md for more examples.
Available Tools
The server provides 15 MCP tools for fetching documentation:
Documentation Tools
Tool | Description |
| Search across all documentation |
| Get specific documentation topic |
| List all available documentation |
Version & Package Fetchers
Tool | What it Fetches | Example |
| Go versions & packages | Go 1.21, github.com/gin-gonic/gin |
| npm packages | express, react |
| Python packages (PyPI) | requests, django, numpy |
| Rust crates (crates.io) | serde, tokio, actix-web |
| Node.js versions | 20.0.0, 18.17.0 |
| TypeScript versions | 5.0.0, 4.9.5 |
| React versions | 18.0.0, 17.0.2 |
| Next.js versions | 14.0.0, 13.5.0 |
| Ansible versions | 2.15.0 |
| Terraform versions | 1.6.0 |
| Jenkins versions | 2.420 |
| Kubernetes versions | 1.28.0 |
| Helm versions | 3.13.0 |
| Docker Hub images | golang:1.25-alpine |
| GitHub Actions | actions/checkout, docker/setup-buildx-action |
All tools automatically:
Fetch from official sources
Cache results locally
Return markdown-formatted documentation
Include installation/usage examples
For detailed tool documentation, see the Tools Reference below.
Advanced Topics
Adding Custom Documentation
You can add custom documentation for any language or framework.
1. Create directory structure:
mkdir -p data/jenkins/topics2. Create metadata file (data/jenkins/metadata.json):
{
"name": "jenkins",
"displayName": "Jenkins",
"description": "Jenkins CI/CD automation documentation"
}3. Add documentation topics (data/jenkins/topics/pipeline-basics.json):
{
"id": "pipeline-basics",
"title": "Jenkins Pipeline Basics",
"description": "Introduction to Jenkins declarative pipelines",
"keywords": ["pipeline", "jenkinsfile", "ci", "cd"],
"content": "# Jenkins Pipeline Basics\n\n[Your markdown content here]"
}4. Restart the server
See data/README.md for complete documentation format guide.
Development
Run tests:
# Quick automated test
./test.sh
# Unit tests
go test ./...
# With race detector
go test -race ./...Add a new MCP tool:
Add tool definition in
server/server.go→handleToolsList()Implement handler in
server/server.go→handleToolCall()Add provider method in
docs/provider.go(if needed)
Project structure:
open-context/
├── main.go # Entry point & CLI
├── server/
│ ├── server.go # MCP protocol & tool handlers
│ └── http.go # HTTP transport
├── docs/
│ └── provider.go # Documentation search & retrieval
├── fetcher/ # External source fetchers
│ ├── go_fetcher.go
│ ├── npm_fetcher.go
│ └── ...
├── cache/ # Cache management
└── data/ # Local documentation storageTools Reference
open-context_search_docs
Search for documentation topics across all languages.
Parameters:
query(required): Search querylanguage(optional): Filter by language (e.g., "go", "typescript")
Example:
Search for "goroutines" in Go documentationopen-context_get_docs
Get detailed documentation for a specific topic.
Parameters:
id(optional): Topic ID from search resultslanguage(optional): Programming languagetopic(optional): Topic name (alternative to ID)
Example:
Get documentation for topic "basics" in Goopen-context_list_docs
List all available documentation languages and topics.
Example:
List all available documentationopen-context_get_go_info
Fetch Go version information or package documentation.
Parameters:
type(required):"version"or"library"version(conditional): Go version (e.g., "1.21") for versions, or library versionimportPath(conditional): Import path (e.g., "github.com/gin-gonic/gin") for libraries
Examples:
Get information about Go version 1.21
Get information about github.com/gin-gonic/gin
Get information about github.com/spf13/cobra version v1.8.0Sources:
Versions: go.dev release notes
Libraries: pkg.go.dev package documentation
See GO_VERSION_LIBRARY_FEATURE.md for details.
open-context_get_npm_info
Fetch npm package information.
Parameters:
packageName(required): Package name (e.g., "express", "react")
Source: npm registry
open-context_get_python_info
Fetch Python package information from PyPI.
Parameters:
packageName(required): Package name (e.g., "requests", "django", "numpy")version(optional): Specific version (defaults to latest)
Source: PyPI (Python Package Index)
open-context_get_rust_info
Fetch Rust crate information from crates.io.
Parameters:
crateName(required): Crate name (e.g., "serde", "tokio", "actix-web")version(optional): Specific version (defaults to latest)
Source: crates.io
open-context_get_node_info
Fetch Node.js version information.
Parameters:
version(required): Node.js version (e.g., "20.0.0")
Source: GitHub releases
open-context_get_typescript_info
Fetch TypeScript version information.
Parameters:
version(required): TypeScript version (e.g., "5.0.0")
Source: GitHub releases
open-context_get_react_info
Fetch React version information.
Parameters:
version(required): React version (e.g., "18.0.0")
Source: GitHub releases
open-context_get_nextjs_info
Fetch Next.js version information.
Parameters:
version(required): Next.js version (e.g., "14.0.0")
Source: GitHub releases
open-context_get_ansible_info
Fetch Ansible version information.
Parameters:
version(required): Ansible version (e.g., "2.15.0")
Source: GitHub releases
open-context_get_terraform_info
Fetch Terraform version information.
Parameters:
version(required): Terraform version (e.g., "1.6.0")
Source: GitHub releases
open-context_get_jenkins_info
Fetch Jenkins version information.
Parameters:
version(required): Jenkins version (e.g., "2.420")
Source: GitHub releases
open-context_get_kubernetes_info
Fetch Kubernetes version information.
Parameters:
version(required): Kubernetes version (e.g., "1.28.0")
Source: GitHub releases
open-context_get_helm_info
Fetch Helm version information.
Parameters:
version(required): Helm version (e.g., "3.13.0")
Source: GitHub releases
open-context_get_docker_image
Fetch Docker image information from Docker Hub.
Parameters:
image(required): Image name (e.g., "golang", "nginx", "myuser/myapp")tag(required): Image tag (e.g., "1.25-alpine", "latest")
Example:
Get Docker image golang:1.25-alpineSource: Docker Hub API
open-context_get_github_action
Fetch GitHub Action information from GitHub API.
Parameters:
repository(required): GitHub repository in format "owner/repo" (e.g., "actions/checkout", "docker/setup-buildx-action")version(optional): Specific version/tag of the action (defaults to latest release)
Example:
Get GitHub Action actions/checkout
Get GitHub Action docker/setup-buildx-action with version v2.10.0Source: GitHub API
Roadmap
Go package fetching from pkg.go.dev
HTTP transport for remote servers
Version fetchers for major tools
Python packages (PyPI)
Rust crates (crates.io)
Version-specific documentation
Web UI for browsing docs
Contributing
Contributions welcome! Areas where you can help:
Add new language/framework fetchers
Improve documentation
Add test coverage
Report bugs or suggest features
Share your use cases
Testing
See TESTING.md for comprehensive testing guide.
License
MIT License - see LICENSE file for details.
Acknowledgments
Inspired by context7 by Upstash.
Questions? Open an issue on GitHub