mcp-jinaai-reader
A Model Context Protocol (MCP) server for integrating Jina.ai's ReaderAPI with LLMs. This server provides efficient and comprehensive webcontent extraction capabilities, optimized for documentation and webcontent 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 areexamples 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 forwebpage loadtarget_selector
(string, optional): CSS selector to focus onspecific elementswait_for_selector
(string, optional): CSS selector to wait forspecific elementsremove_selector
(string, optional): CSS selector to excludespecific elementswith_links_summary
(boolean, optional): Gather all links at theend of responsewith_images_summary
(boolean, optional): Gather all images at theend of responsewith_generated_alt
(boolean, optional): Add alt text to imageslacking captionswith_iframe
(boolean, optional): Include iframe content inresponse
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 theModel Context Protocol
- Powered by Jina.ai Reader API