mcp-jinaai-reader
A Model Context Protocol (MCP) server for integrating Jina.aiβs Reader API with LLMs. This server provides efficient and comprehensive web content extraction capabilities, optimized for documentation and web content analysis.
Features
- π Advanced web content extraction through Jina.ai Reader API
- π Fast and efficient content retrieval
- π Complete text extraction with preserved structure
- π Clean format optimized for LLMs
- π Support for various content types including documentation
- ποΈ Built on the Model Context Protocol
Configuration
This server requires configuration through your MCP client. Here are examples for different environments:
Cline Configuration
Add this to your Cline MCP settings:
{
"mcpServers": {
"jinaai-reader": {
"command": "node",
"args": ["-y", "mcp-jinaai-reader"],
"env": {
"JINAAI_API_KEY": "your-jinaai-api-key"
}
}
}
}
Claude Desktop with WSL Configuration
For WSL environments, add this to your Claude Desktop configuration:
{
"mcpServers": {
"jinaai-reader": {
"command": "wsl.exe",
"args": [
"bash",
"-c",
"JINAAI_API_KEY=your-jinaai-api-key npx mcp-jinaai-reader"
]
}
}
}
Environment Variables
The server requires the following environment variable:
JINAAI_API_KEY
: Your Jina.ai API key (required)
API
The server implements a single MCP tool with configurable parameters:
read_url
Convert any URL to LLM-friendly text using Jina.ai Reader.
Parameters:
url
(string, required): URL to processno_cache
(boolean, optional): Bypass cache for fresh results. Defaults to falseformat
(string, optional): Response format (βjsonβ or βstreamβ). Defaults to βjsonβtimeout
(number, optional): Maximum time in seconds to wait for webpage loadtarget_selector
(string, optional): CSS selector to focus on specific elementswait_for_selector
(string, optional): CSS selector to wait for specific elementsremove_selector
(string, optional): CSS selector to exclude specific elementswith_links_summary
(boolean, optional): Gather all links at the end of responsewith_images_summary
(boolean, optional): Gather all images at the end of responsewith_generated_alt
(boolean, optional): Add alt text to images lacking captionswith_iframe
(boolean, optional): Include iframe content in response
Development
Setup
- Clone the repository
- Install dependencies:
npm install
- Build the project:
npm run build
- Run in development mode:
npm run dev
Publishing
- Update version in package.json
- Build the project:
npm run build
- Publish to npm:
npm publish
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
License
MIT License - see the LICENSE file for details.
Acknowledgments
- Built on the Model Context Protocolβ
- Powered by Jina.ai Reader APIβ
Last updated on