Tagny MCP Server
Enables web browsing capabilities for locally served LLMs through URL text fetching, link extraction, and web search using Brave and DuckDuckGo engines. Designed to enhance LLMs with real-time web access through the MCP protocol.
README
tagny-mcp-server
An MCP server with web search, URL text fetching, and more tools to enhance locally served LLMs.
Features
- Fetch plain text content from URLs
- Extract all links from a webpage
- Designed to work with locally served LLMs via MCP protocol
Installation
- from source
uv pip install -e .
# with dev dependencies
uv sync
- from PyPI repository
pip install tagny-mcp-server
Usage
Start the MCP server:
- from source code:
uv run -m tagny_mcp_server
- after proper installation:
- as described in the pyproject.toml at
project.scripts, you can run the with the default arguments :
- as described in the pyproject.toml at
tagny-mcp-server
- customize the arguments by running like this for example:
# see the help
uv run -m tagny_mcp_server --help
# see the version
uv run -m tagny_mcp_server --version
# change the default port
uv run -m tagny_mcp_server --port 5002
The server will run using Server-Sent Events (SSE) transport.
Tools
fetch_url_text
Downloads and parses HTML content from a URL, returning only the visible text.
fetch_page_links
Returns a list of all hyperlinks found on a webpage.
search_web_with_brave
An MCP tool that performs web searches using Brave search engine
search_web_with_duckduckgo
An MCP tool that performs web searches using DuckDuckGo
Project Structure
src/tagny_mcp_server/__init__.py- Main package initializer that exports the versionsrc/tagny_mcp_server/__main__.py- Entry point that launches the MCP server with command-line argumentssrc/tagny_mcp_server/__version__.py- Contains the package version stringsrc/tagny_mcp_server/config.py- Configures the FastMCP server instance with name, instructions, and versionsrc/tagny_mcp_server/web_access/__init__.py- Package initializer for web access tools that exports URL text fetching functionssrc/tagny_mcp_server/web_access/url_text_fetcher.py- Implements tools for fetching URL text and extracting links from web pagessrc/tagny_mcp_server/web_access/web_search.py- Implements Brave and DuckDuckGo search toolspyproject.toml- Project metadata, dependencies, and build configurationtests/scripts/client.py- Example client script for testing the servertests/test_web_access_tools.py- Tests for the web access tools.gitignore- Git ignore rulesREADME.md- Project documentationLICENSE- License informationCHANGELOG.md- Release notes and version historyCONTRIBUTING.md- Guidelines for contributing to the project.pre-commit-config.yaml- Pre-commit hooks configuration.python-version- Python version specification.bumpversion.toml- Configuration for version bumping tool.github/- GitHub workflow and issue template files
Dependencies
beautifulsoup4- HTML parsingfastmcp- MCP server frameworkrequests- HTTP requests
Testing
Tests are located in tests/ and can be run with pytest:
pytest
Example client usage is shown in scripts/client.py.
License
This project is licensed under the MIT License - see the LICENSE file for details.
Contributing
Contributions are welcome! Please read the CONTRIBUTING.md file for details on our code of conduct and the process for submitting pull requests.
Changelog
See CHANGELOG.md for a history of changes to this project.
Code Quality
This project uses pre-commit hooks to maintain code quality. Install them with:
pre-commit install
The following tools are used:
- black (code formatting)
- flake8 (linting)
- isort (import sorting)
- detect-secrets (secret detection)
- ruff (linting and fixing)
For more information, see .pre-commit-config.yaml.
CI/CD
This project uses GitHub Actions for continuous integration and deployment:
- Build workflow - runs tests and code quality checks
- Publish to Docker Hub - publishes the Docker image on release
- Publish to PyPI - publishes to PyPI on release
For more information, see .github/workflows.
Running with Docker
You can build and run the Docker container using the provided Dockerfile. To test locally, you can use act following the instructions at https://nektos.github.io/act/.
# Build the Docker image
docker build -t tagny-mcp-server .
# Run the Docker container
docker run -p 8000:8000 tagny-mcp-server
This will start the MCP server inside a Docker container, accessible at http://localhost:8000/sse.
That you can integrate in a mcp.json file like this:
{
"mcpServers": {
"tagny-mcp-server": {
"url": "http://localhost:8000/sse"
}
}
}
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.