
tavily anet mcp
A Rust implementation of the Model Control Protocol (MCP) server that integrates Tavily's powerful search and web content extraction capabilities. This server enables AI agents and LLM systems to perform real-time web searches and extract content from URLs via a standardized JSON-RPC interface, making it ideal for building AI tools.
Repository Info
About This Server
A Rust implementation of the Model Control Protocol (MCP) server that integrates Tavily's powerful search and web content extraction capabilities. This server enables AI agents and LLM systems to perform real-time web searches and extract content from URLs via a standardized JSON-RPC interface, making it ideal for building AI tools.
Model Context Protocol (MCP) - This server can be integrated with AI applications to provide additional context and capabilities, enabling enhanced AI interactions and functionality.
Documentation
Tavily-Anet-MCP Server
A Rust implementation of the Model Control Protocol (MCP) server that provides Tavily search and content extraction capabilities via a standardized protocol.
This server integrates the powerful Tavily API with the Anet MCP framework, enabling AI agents to perform web searches and extract content from URLs. It is designed for developers building AI agent systems, LLM-based tools, or research automation that requires up-to-date web information.
Features
- ✅ Tavily Search integration with comprehensive parameters
- 📄 Tavily Extract for content retrieval from URLs
- 🔄 NATS transport layer for message passing
- 🛠️ JSON-RPC 2.0 compatible API
- ⚡ Asynchronous request handling with Tokio
- 🔍 Advanced search capabilities including domain filtering, time ranges, and topic selection
Requirements
- Rust 1.70+
- NATS server running locally or accessible via network
- Tavily API Key (get one from Tavily's website)
Installation
Clone the repository and build the server:
git clone https://github.com/yourusername/tavily-anet-mcp.git
cd tavily-anet-mcp
Add your Tavily API key to a .env file:
TAVILY_API_KEY=your_api_key_here
NATS_URL=nats://localhost:4222
MCP_SUBJECT=mcp.requests
Getting Started
Running the Server
# Start a NATS server in another terminal or ensure one is already running
# Example:
nats-server
# Run the Tavily MCP server
cargo run
Testing the Server
You can test the server using the included test client:
cargo run --example test_client
This will send various requests to the server (initialize, listTools, search, extract) and print the responses.
Available Tools
1. Tavily Search
A powerful web search tool that provides comprehensive, real-time results using Tavily's AI search engine.
Parameters:
query(required): Search query stringsearch_depth: "basic" or "advanced" (default: "basic")topic: "general" or "news" (default: "general")days: Number of days back for results (for news topic)time_range: "day", "week", "month", "year"max_results: 5-20 (default: 10)include_images: Booleaninclude_raw_content: Booleaninclude_domains: Array of domains to includeexclude_domains: Array of domains to exclude
Example:
{
"name": "tavily-search",
"arguments": {
"query": "Latest developments in AI",
"max_results": 5,
"topic": "news",
"days": 7
}
}
2. Tavily Extract
A tool for extracting raw content from web pages.
Parameters:
urls(required): Array of URLs to extract content fromextract_depth: "basic" or "advanced" (default: "basic")include_images: Boolean (default: false)
Example:
{
"name": "tavily-extract",
"arguments": {
"urls": ["https://www.rust-lang.org/"],
"extract_depth": "advanced",
"include_images": true
}
}
Architecture
The server follows a modular design:
- tools – Tavily Search and Extract implementations
- models – Tavily API response structures
- utils – Formatting and helper functions
- transport – NATS message transport layer
Development
Adding New Features
To extend the server with additional Tavily capabilities:
- Define response structures in
src/models/tavily.rs - Implement the tool in
src/tools/following the Tool trait - Add formatting functions in
src/utils/formatter.rs - Register the tool in
src/main.rs
Troubleshooting
- Ensure your Tavily API key is valid and correctly set in the environment variables
- Check that the NATS server is running and accessible
- Verify the request format matches the expected input schema for each tool
License
MIT License
Acknowledgements
This project is built on top of the Anet MCP Server framework and integrates with the Tavily API.
Quick Start
Clone the repository
git clone https://github.com/marekkucak/tavily-anet-mcpInstall dependencies
cd tavily-anet-mcp
npm installFollow the documentation
Check the repository's README.md file for specific installation and usage instructions.
Repository Details
Recommended MCP Servers
Discord MCP
Enable AI assistants to seamlessly interact with Discord servers, channels, and messages.
Knit MCP
Connect AI agents to 200+ SaaS applications and automate workflows.
Apify MCP Server
Deploy and interact with Apify actors for web scraping and data extraction.
BrowserStack MCP
BrowserStack MCP Server for automated testing across multiple browsers.
Zapier MCP
A Zapier server that provides automation capabilities for various apps.