context7/README.md

552 lines
16 KiB
Markdown
Raw Normal View History

2025-04-30 09:37:08 -07:00
# Context7 MCP - Up-to-date Code Docs For Any Prompt
[![Website](https://img.shields.io/badge/Website-context7.com-blue)](https://context7.com) [![smithery badge](https://smithery.ai/badge/@upstash/context7-mcp)](https://smithery.ai/server/@upstash/context7-mcp) [<img alt="Install in VS Code (npx)" src="https://img.shields.io/badge/VS_Code-VS_Code?style=flat-square&label=Install%20Context7%20MCP&color=0098FF">](https://insiders.vscode.dev/redirect?url=vscode%3Amcp%2Finstall%3F%7B%22name%22%3A%22context7%22%2C%22command%22%3A%22npx%22%2C%22args%22%3A%5B%22-y%22%2C%22%40upstash%2Fcontext7-mcp%40latest%22%5D%7D)
2025-04-23 20:00:50 +03:00
2025-05-30 13:58:16 -07:00
[![中文文档](https://img.shields.io/badge/docs-中文版-yellow)](./docs/README.zh-CN.md) [![한국어 문서](https://img.shields.io/badge/docs-한국어-green)](./docs/README.ko.md) [![Documentación en Español](https://img.shields.io/badge/docs-Español-orange)](./docs/README.es.md) [![Documentation en Français](https://img.shields.io/badge/docs-Français-blue)](./docs/README.fr.md) [![Documentação em Português (Brasil)](<https://img.shields.io/badge/docs-Português%20(Brasil)-purple>)](./docs/README.pt-BR.md) [![Documentazione in italiano](https://img.shields.io/badge/docs-Italian-red)](./docs/README.it.md) [![Dokumentasi Bahasa Indonesia](https://img.shields.io/badge/docs-Bahasa%20Indonesia-pink)](./docs/README.id-ID.md) [![Dokumentation auf Deutsch](https://img.shields.io/badge/docs-Deutsch-darkgreen)](./docs/README.de.md) [![Документация на русском языке](https://img.shields.io/badge/docs-Русский-darkblue)](./docs/README.ru.md) [![Türkçe Doküman](https://img.shields.io/badge/docs-Türkçe-blue)](./docs/README.tr.md) [![Arabic Documentation](https://img.shields.io/badge/docs-Arabic-white)](./docs/README.ar.md)
2025-04-11 10:44:37 +02:00
## ❌ Without Context7
2025-04-11 10:44:37 +02:00
LLMs rely on outdated or generic information about the libraries you use. You get:
2025-04-11 10:44:37 +02:00
- ❌ Code examples are outdated and based on year-old training data
- ❌ Hallucinated APIs don't even exist
- ❌ Generic answers for old package versions
2025-04-11 10:44:37 +02:00
## ✅ With Context7
Context7 MCP pulls up-to-date, version-specific documentation and code examples straight from the source — and places them directly into your prompt.
2025-04-21 21:15:58 -07:00
Add `use context7` to your prompt in Cursor:
2025-04-11 10:44:37 +02:00
```txt
2025-04-21 21:15:58 -07:00
Create a basic Next.js project with app router. use context7
2025-04-11 10:44:37 +02:00
```
```txt
2025-04-21 21:15:58 -07:00
Create a script to delete the rows where the city is "" given PostgreSQL credentials. use context7
2025-04-11 10:44:37 +02:00
```
2025-04-21 21:15:58 -07:00
Context7 fetches up-to-date code examples and documentation right into your LLM's context.
2025-04-11 10:44:37 +02:00
2025-04-21 21:15:58 -07:00
- 1⃣ Write your prompt naturally
2025-04-11 10:44:37 +02:00
- 2⃣ Tell the LLM to `use context7`
- 3⃣ Get working code answers
No tab-switching, no hallucinated APIs that don't exist, no outdated code generations.
2025-05-30 13:58:16 -07:00
## 📚 Adding Projects
Check out our [project addition guide](./docs/adding-projects.md) to learn how to add (or update) your favorite libraries to Context7.
## 🛠️ Installation
### Requirements
- Node.js >= v18.0.0
- Cursor, Windsurf, Claude Desktop or another MCP Client
<details>
2025-06-01 09:56:18 +03:00
<summary><b>Installing via Smithery</b></summary>
2025-04-20 08:05:25 +00:00
2025-05-28 12:32:10 +03:00
To install Context7 MCP Server for any client automatically via [Smithery](https://smithery.ai/server/@upstash/context7-mcp):
2025-04-20 08:05:25 +00:00
```bash
2025-05-28 12:32:10 +03:00
npx -y @smithery/cli@latest install @upstash/context7-mcp --client <CLIENT_NAME> --key <YOUR_SMITHERY_KEY>
2025-04-20 08:05:25 +00:00
```
2025-05-28 12:32:10 +03:00
You can find your Smithery key in the [Smithery.ai webpage](https://smithery.ai/server/@upstash/context7-mcp).
</details>
<details>
2025-06-01 09:56:18 +03:00
<summary><b>Install in Cursor</b></summary>
2025-04-11 10:44:37 +02:00
Go to: `Settings` -> `Cursor Settings` -> `MCP` -> `Add new global MCP server`
Pasting the following configuration into your Cursor `~/.cursor/mcp.json` file is the recommended approach. You may also install in a specific project by creating `.cursor/mcp.json` in your project folder. See [Cursor MCP docs](https://docs.cursor.com/context/model-context-protocol) for more info.
2025-05-28 12:32:10 +03:00
#### Cursor Remote Server Connection
2025-04-11 10:44:37 +02:00
```json
{
"mcpServers": {
"context7": {
2025-05-28 00:37:30 +03:00
"url": "https://mcp.context7.com/mcp"
2025-04-11 10:44:37 +02:00
}
}
}
```
2025-05-28 12:32:10 +03:00
#### Cursor Local Server Connection
```json
{
"mcpServers": {
"context7": {
"command": "npx",
"args": ["-y", "@upstash/context7-mcp"]
}
}
}
```
<details>
<summary>Alternative: Use Bun</summary>
```json
{
"mcpServers": {
"context7": {
"command": "bunx",
2025-05-19 23:24:26 +03:00
"args": ["-y", "@upstash/context7-mcp"]
}
}
}
```
</details>
<details>
<summary>Alternative: Use Deno</summary>
```json
{
"mcpServers": {
"context7": {
"command": "deno",
2025-05-06 13:45:05 +03:00
"args": ["run", "--allow-env", "--allow-net", "npm:@upstash/context7-mcp"]
}
}
}
```
</details>
</details>
<details>
2025-06-01 09:56:18 +03:00
<summary><b>Install in Windsurf</b></summary>
Add this to your Windsurf MCP config file. See [Windsurf MCP docs](https://docs.windsurf.com/windsurf/mcp) for more info.
2025-05-28 12:32:10 +03:00
#### Windsurf Remote Server Connection
```json
{
"mcpServers": {
"context7": {
"serverUrl": "https://mcp.context7.com/sse"
}
}
}
```
#### Windsurf Local Server Connection
```json
{
"mcpServers": {
"context7": {
2025-05-28 12:32:10 +03:00
"command": "npx",
"args": ["-y", "@upstash/context7-mcp"]
}
}
}
```
</details>
<details>
2025-06-01 09:56:18 +03:00
<summary><b>Install in VS Code</b></summary>
[<img alt="Install in VS Code (npx)" src="https://img.shields.io/badge/VS_Code-VS_Code?style=flat-square&label=Install%20Context7%20MCP&color=0098FF">](https://insiders.vscode.dev/redirect?url=vscode%3Amcp%2Finstall%3F%7B%22name%22%3A%22context7%22%2C%22command%22%3A%22npx%22%2C%22args%22%3A%5B%22-y%22%2C%22%40upstash%2Fcontext7-mcp%40latest%22%5D%7D)
[<img alt="Install in VS Code Insiders (npx)" src="https://img.shields.io/badge/VS_Code_Insiders-VS_Code_Insiders?style=flat-square&label=Install%20Context7%20MCP&color=24bfa5">](https://insiders.vscode.dev/redirect?url=vscode-insiders%3Amcp%2Finstall%3F%7B%22name%22%3A%22context7%22%2C%22command%22%3A%22npx%22%2C%22args%22%3A%5B%22-y%22%2C%22%40upstash%2Fcontext7-mcp%40latest%22%5D%7D)
Add this to your VS Code MCP config file. See [VS Code MCP docs](https://code.visualstudio.com/docs/copilot/chat/mcp-servers) for more info.
#### VS Code Remote Server Connection
```json
"mcp": {
"servers": {
"context7": {
"type": "http",
"url": "https://mcp.context7.com/mcp"
}
}
}
```
#### VS Code Local Server Connection
```json
"mcp": {
"servers": {
"context7": {
"type": "stdio",
"command": "npx",
2025-05-19 23:24:26 +03:00
"args": ["-y", "@upstash/context7-mcp"]
}
}
}
```
</details>
<details>
2025-06-01 09:56:18 +03:00
<summary><b>Install in Zed</b></summary>
It can be installed via [Zed Extensions](https://zed.dev/extensions?query=Context7) or you can add this to your Zed `settings.json`. See [Zed Context Server docs](https://zed.dev/docs/assistant/context-servers) for more info.
```json
{
"context_servers": {
"Context7": {
"command": {
"path": "npx",
2025-05-19 23:24:26 +03:00
"args": ["-y", "@upstash/context7-mcp"]
},
"settings": {}
}
}
}
```
</details>
<details>
2025-06-01 09:56:18 +03:00
<summary><b>Install in Claude Code</b></summary>
Run this command. See [Claude Code MCP docs](https://docs.anthropic.com/en/docs/agents-and-tools/claude-code/tutorials#set-up-model-context-protocol-mcp) for more info.
#### Claude Code Remote Server Connection
```sh
claude mcp add --transport sse context7 https://mcp.context7.com/sse
```
#### Claude Code Local Server Connection
```sh
2025-05-19 23:24:26 +03:00
claude mcp add context7 -- npx -y @upstash/context7-mcp
```
</details>
<details>
2025-06-01 09:56:18 +03:00
<summary><b>Install in Claude Desktop</b></summary>
Add this to your Claude Desktop `claude_desktop_config.json` file. See [Claude Desktop MCP docs](https://modelcontextprotocol.io/quickstart/user) for more info.
```json
{
"mcpServers": {
"Context7": {
"command": "npx",
2025-05-19 23:24:26 +03:00
"args": ["-y", "@upstash/context7-mcp"]
}
}
}
```
</details>
<details>
2025-06-01 09:56:18 +03:00
<summary><b>Install in BoltAI</b></summary>
Open the "Settings" page of the app, navigate to "Plugins," and enter the following JSON:
```json
{
"mcpServers": {
"context7": {
"command": "npx",
2025-05-19 23:24:26 +03:00
"args": ["-y", "@upstash/context7-mcp"]
}
}
}
```
Once saved, enter in the chat `get-library-docs` followed by your Context7 documentation ID (e.g., `get-library-docs /nuxt/ui`). More information is available on [BoltAI's Documentation site](https://docs.boltai.com/docs/plugins/mcp-servers). For BoltAI on iOS, [see this guide](https://docs.boltai.com/docs/boltai-mobile/mcp-servers).
</details>
<details>
2025-06-01 09:56:18 +03:00
<summary><b>Using Docker</b></summary>
If you prefer to run the MCP server in a Docker container:
2025-05-28 12:32:10 +03:00
1. **Build the Docker Image:**
First, create a `Dockerfile` in the project root (or anywhere you prefer):
<details>
<summary>Click to see Dockerfile content</summary>
```Dockerfile
FROM node:18-alpine
WORKDIR /app
# Install the latest version globally
RUN npm install -g @upstash/context7-mcp
# Expose default port if needed (optional, depends on MCP client interaction)
# EXPOSE 3000
# Default command to run the server
CMD ["context7-mcp"]
```
</details>
Then, build the image using a tag (e.g., `context7-mcp`). **Make sure Docker Desktop (or the Docker daemon) is running.** Run the following command in the same directory where you saved the `Dockerfile`:
```bash
docker build -t context7-mcp .
```
2. **Configure Your MCP Client:**
Update your MCP client's configuration to use the Docker command.
_Example for a cline_mcp_settings.json:_
```json
{
"mcpServers": {
"Сontext7": {
"autoApprove": [],
"disabled": false,
"timeout": 60,
"command": "docker",
"args": ["run", "-i", "--rm", "context7-mcp"],
"transportType": "stdio"
}
}
}
```
_Note: This is an example configuration. Please refer to the specific examples for your MCP client (like Cursor, VS Code, etc.) earlier in this README to adapt the structure (e.g., `mcpServers` vs `servers`). Also, ensure the image name in `args` matches the tag used during the `docker build` command._
</details>
<details>
2025-06-01 09:56:18 +03:00
<summary><b>Install in Windows</b></summary>
2025-05-28 12:32:10 +03:00
2025-05-30 13:58:16 -07:00
The configuration on Windows is slightly different compared to Linux or macOS (_`Cline` is used in the example_). The same principle applies to other editors; refer to the configuration of `command` and `args`.
2025-05-28 12:32:10 +03:00
```json
{
"mcpServers": {
"github.com/upstash/context7-mcp": {
"command": "cmd",
2025-05-30 13:58:16 -07:00
"args": ["/c", "npx", "-y", "@upstash/context7-mcp@latest"],
"disabled": false,
"autoApprove": []
}
}
}
```
</details>
<details>
<summary><b>Install in Augment Code</b></summary>
To configure Context7 MCP in Augment Code, follow these steps:
1. Press Cmd/Ctrl Shift P or go to the hamburger menu in the Augment panel
2. Select Edit Settings
3. Under Advanced, click Edit in settings.json
4. Add the server configuration to the `mcpServers` array in the `augment.advanced` object
```json
"augment.advanced": {
"mcpServers": [
{
"name": "context7",
"command": "npx",
"args": ["-y", "@upstash/context7-mcp"]
}
]
}
```
Once the MCP server is added, restart your editor. If you receive any errors, check the syntax to make sure closing brackets or commas are not missing.
</details>
2025-06-01 09:56:18 +03:00
## 🔧 Environment Variables
The Context7 MCP server supports the following environment variables:
- `DEFAULT_MINIMUM_TOKENS`: Set the minimum token count for documentation retrieval (default: 10000)
2025-05-28 12:32:10 +03:00
Example configuration with environment variables:
```json
{
"mcpServers": {
"context7": {
"command": "npx",
2025-05-19 23:24:26 +03:00
"args": ["-y", "@upstash/context7-mcp"],
"env": {
2025-05-28 12:32:10 +03:00
"DEFAULT_MINIMUM_TOKENS": "6000"
}
}
}
}
```
2025-06-01 09:56:18 +03:00
## 🔨 Available Tools
2025-05-28 12:32:10 +03:00
Context7 MCP provides the following tools that LLMs can use:
2025-04-11 15:10:59 +02:00
- `resolve-library-id`: Resolves a general library name into a Context7-compatible library ID.
2025-05-28 12:32:10 +03:00
- `libraryName` (required): The name of the library to search for
2025-04-11 10:44:37 +02:00
- `get-library-docs`: Fetches documentation for a library using a Context7-compatible library ID.
2025-05-28 12:32:10 +03:00
- `context7CompatibleLibraryID` (required): Exact Context7-compatible library ID (e.g., `/mongodb/docs`, `/vercel/next.js`)
2025-04-11 10:44:37 +02:00
- `topic` (optional): Focus the docs on a specific topic (e.g., "routing", "hooks")
- `tokens` (optional, default 10000): Max number of tokens to return. Values less than the configured `DEFAULT_MINIMUM_TOKENS` value or the default value of 10000 are automatically increased to that value.
2025-06-01 09:56:18 +03:00
## 💻 Development
2025-04-11 11:03:46 +02:00
Clone the project and install dependencies:
```bash
2025-04-11 11:03:46 +02:00
bun i
```
2025-04-11 10:44:37 +02:00
Build:
```bash
2025-04-11 11:03:46 +02:00
bun run build
```
2025-06-01 09:56:18 +03:00
<details>
<summary><b>Local Configuration Example</b></summary>
2025-04-08 20:29:04 +03:00
```json
{
"mcpServers": {
"context7": {
2025-04-11 10:44:37 +02:00
"command": "npx",
"args": ["tsx", "/path/to/folder/context7-mcp/src/index.ts"]
2025-04-08 20:29:04 +03:00
}
}
}
```
2025-06-01 09:56:18 +03:00
</details>
<details>
<summary><b>Testing with MCP Inspector</b></summary>
```bash
2025-05-19 23:24:26 +03:00
npx -y @modelcontextprotocol/inspector npx @upstash/context7-mcp
```
2025-06-01 09:56:18 +03:00
</details>
2025-06-01 09:56:18 +03:00
## 🚨 Troubleshooting
<details>
<summary><b>Module Not Found Errors</b></summary>
2025-05-28 12:32:10 +03:00
If you encounter `ERR_MODULE_NOT_FOUND`, try using `bunx` instead of `npx`:
```json
{
"mcpServers": {
"context7": {
"command": "bunx",
2025-05-19 23:24:26 +03:00
"args": ["-y", "@upstash/context7-mcp"]
}
}
}
```
2025-05-28 12:32:10 +03:00
This often resolves module resolution issues in environments where `npx` doesn't properly install or resolve packages.
2025-06-01 09:56:18 +03:00
</details>
<details>
<summary><b>ESM Resolution Issues</b></summary>
2025-05-28 12:32:10 +03:00
For errors like `Error: Cannot find module 'uriTemplate.js'`, try the `--experimental-vm-modules` flag:
```json
{
"mcpServers": {
"context7": {
"command": "npx",
2025-05-30 13:58:16 -07:00
"args": ["-y", "--node-options=--experimental-vm-modules", "@upstash/context7-mcp@1.0.6"]
}
}
}
```
2025-06-01 09:56:18 +03:00
</details>
<details>
<summary><b>TLS/Certificate Issues</b></summary>
2025-05-19 23:22:30 +03:00
2025-05-28 12:32:10 +03:00
Use the `--experimental-fetch` flag to bypass TLS-related problems:
2025-05-19 23:22:30 +03:00
```json
{
"mcpServers": {
"context7": {
"command": "npx",
"args": ["-y", "--node-options=--experimental-fetch", "@upstash/context7-mcp"]
2025-05-19 23:22:30 +03:00
}
}
}
```
2025-06-01 09:56:18 +03:00
</details>
<details>
<summary><b>General MCP Client Errors</b></summary>
2025-05-28 12:32:10 +03:00
1. Try adding `@latest` to the package name
2. Use `bunx` as an alternative to `npx`
3. Consider using `deno` as another alternative
4. Ensure you're using Node.js v18 or higher for native fetch support
2025-04-26 17:34:59 +03:00
2025-06-01 09:56:18 +03:00
</details>
## ⚠️ Disclaimer
2025-04-28 02:22:02 +03:00
Context7 projects are community-contributed and while we strive to maintain high quality, we cannot guarantee the accuracy, completeness, or security of all library documentation. Projects listed in Context7 are developed and maintained by their respective owners, not by Context7. If you encounter any suspicious, inappropriate, or potentially harmful content, please use the "Report" button on the project page to notify us immediately. We take all reports seriously and will review flagged content promptly to maintain the integrity and safety of our platform. By using Context7, you acknowledge that you do so at your own discretion and risk.
2025-06-01 09:56:18 +03:00
## 🤝 Connect with Us
2025-05-17 16:04:01 -07:00
Stay updated and join our community:
2025-05-28 12:32:10 +03:00
2025-05-17 16:04:01 -07:00
- 📢 Follow us on [X](https://x.com/contextai) for the latest news and updates
- 🌐 Visit our [Website](https://context7.com)
2025-05-28 12:32:10 +03:00
- 💬 Join our [Discord Community](https://upstash.com/discord)
2025-05-17 16:04:01 -07:00
2025-06-01 09:56:18 +03:00
## 📺 Context7 In Media
- [Better Stack: "Free Tool Makes Cursor 10x Smarter"](https://youtu.be/52FC3qObp9E)
2025-04-23 00:11:04 +03:00
- [Cole Medin: "This is Hands Down the BEST MCP Server for AI Coding Assistants"](https://www.youtube.com/watch?v=G7gK8H6u7Rs)
2025-05-28 12:32:10 +03:00
- [Income Stream Surfers: "Context7 + SequentialThinking MCPs: Is This AGI?"](https://www.youtube.com/watch?v=-ggvzyLpK6o)
2025-04-23 00:11:04 +03:00
- [Julian Goldie SEO: "Context7: New MCP AI Agent Update"](https://www.youtube.com/watch?v=CTZm6fBYisc)
- [JeredBlu: "Context 7 MCP: Get Documentation Instantly + VS Code Setup"](https://www.youtube.com/watch?v=-ls0D-rtET4)
2025-05-28 12:32:10 +03:00
- [Income Stream Surfers: "Context7: The New MCP Server That Will CHANGE AI Coding"](https://www.youtube.com/watch?v=PS-2Azb-C3M)
- [AICodeKing: "Context7 + Cline & RooCode: This MCP Server Makes CLINE 100X MORE EFFECTIVE!"](https://www.youtube.com/watch?v=qZfENAPMnyo)
- [Sean Kochel: "5 MCP Servers For Vibe Coding Glory (Just Plug-In & Go)"](https://www.youtube.com/watch?v=LqTQi8qexJM)
2025-06-01 09:56:18 +03:00
## ⭐ Star History
[![Star History Chart](https://api.star-history.com/svg?repos=upstash/context7&type=Date)](https://www.star-history.com/#upstash/context7&Date)
2025-06-01 09:56:18 +03:00
## 📄 License
MIT