mcp-rss-feed-searcher

mcp-rss-feed-searcher

An MCP server that enables searching across multiple RSS feed sources simultaneously, with support for extensible feed sources and both STDIO and HTTP modes.

Category
Visit Server

README

MCP RSS Feed Searcher

MCP Python License FastMCP RSS Open Source Contributions Welcome

An extensible Model Context Protocol (MCP) server for searching across multiple RSS feed sources. Built for developers who want to aggregate content from various sources through a unified interface.

🌟 Features

  • Multi-Source Search: Search across multiple RSS feeds simultaneously
  • Extensible Architecture: Easy to add new feed sources
  • MCP Protocol Support: Compatible with MCP Inspector and other MCP clients
  • Multiple Transport Modes: STDIO and HTTP support
  • Built-in Feeds:
    • FreeCodeCamp News (programming tutorials)
    • FreeCodeCamp YouTube (video content)
    • Bing News (general news search)

šŸš€ Quick Start

Installation

# Clone the repository
git clone https://github.com/yourusername/mcp-rss-feed-searcher.git
cd mcp-rss-feed-searcher

# Create virtual environment
python -m venv venv
source venv/bin/activate  # On Windows: venv\Scripts\activate

# Install dependencies
pip install -r requirements.txt

Running the Server

STDIO Mode (Default):

python main.py

HTTP Mode:

python main.py --mode http

Testing with MCP Inspector

# STDIO mode
npx @modelcontextprotocol/inspector python main.py --mode stdio

# HTTP mode (run in background)
python main.py --mode http &
npx @modelcontextprotocol/inspector http://localhost:8003/mcp

šŸ“š Available MCP Tools

Tool Description
list_feeds List all available feed sources
search_feed Search a specific feed by name
search_all_feeds Search across all feeds simultaneously
search_multiple_feeds Search specific multiple feeds

Example Usage

List available feeds:

{
  "tool": "list_feeds"
}

Search a specific feed:

{
  "tool": "search_feed",
  "arguments": {
    "feed_name": "freecodecamp_news",
    "query": "python tutorial",
    "max_results": 5
  }
}

Search all feeds:

{
  "tool": "search_all_feeds",
  "arguments": {
    "query": "machine learning",
    "max_results": 3
  }
}

Search multiple specific feeds:

{
  "tool": "search_multiple_feeds",
  "arguments": {
    "feed_names": ["freecodecamp_news", "bing_news"],
    "query": "artificial intelligence",
    "max_results": 5
  }
}

šŸ—ļø Project Structure

mcp-rss-feed-searcher/
ā”œā”€ā”€ src/
│   ā”œā”€ā”€ __init__.py
│   ā”œā”€ā”€ mcp_server.py        # MCP server implementation
│   └── feeds/
│       ā”œā”€ā”€ __init__.py      # Feed package initialization
│       ā”œā”€ā”€ base.py          # BaseFeed abstract class
│       ā”œā”€ā”€ registry.py      # Feed registry system
│       ā”œā”€ā”€ freecodecamp.py  # FreeCodeCamp feeds
│       └── bing_news.py     # Bing News feed
ā”œā”€ā”€ input_data/              # Input data directory
ā”œā”€ā”€ output_data/             # Output data directory
ā”œā”€ā”€ main.py                  # Entry point
ā”œā”€ā”€ requirements.txt         # Dependencies
└── README.md               # This file

šŸ”§ Available Feed Sources

FreeCodeCamp News

  • Name: freecodecamp_news
  • Content: Programming tutorials, tech articles, coding guides
  • Source: https://www.freecodecamp.org/news/rss/

FreeCodeCamp YouTube

  • Name: freecodecamp_youtube
  • Content: Video tutorials, full courses, programming walkthroughs
  • Source: YouTube channel RSS feed

Bing News

  • Name: bing_news
  • Content: Latest news articles across all topics
  • Source: Bing News RSS search
  • Note: Dynamic feed based on search query

šŸ› ļø Troubleshooting

Common Issues and Solutions

MCP Inspector won't connect

Issue: MCP Inspector fails to connect to the server Solutions:

  • Ensure you're using the correct command for your mode:
    # STDIO mode
    npx @modelcontextprotocol/inspector python main.py --mode stdio
    
    # HTTP mode (server must be running)
    python main.py --mode http
    # Then in another terminal:
    npx @modelcontextprotocol/inspector http://localhost:8003/mcp
    
  • Check that all dependencies are installed: pip install -r requirements.txt
  • Verify Python version is 3.8 or higher: python --version

No search results returned

Issue: search_feed returns empty results Solutions:

  • Verify the feed name is correct (use list_feeds to see available feeds)
  • Check your internet connection
  • Some feeds may be temporarily unavailable - try again later
  • Ensure your query isn't too specific; try broader search terms

ModuleNotFoundError when running

Issue: ModuleNotFoundError: No module named 'src' or similar Solutions:

  • Make sure you're running from the project root directory
  • Ensure the virtual environment is activated
  • Reinstall dependencies: pip install -r requirements.txt

HTTP mode connection refused

Issue: Connection refused when connecting to HTTP server Solutions:

  • Verify the server is running: python main.py --mode http
  • Check the port isn't in use: lsof -i :8003 (Linux/Mac) or netstat -ano | findstr :8003 (Windows)
  • Try a different port: python main.py --mode http --port 8004

Feed parsing errors

Issue: Errors parsing RSS feeds Solutions:

  • Check your internet connection
  • Some RSS feeds may have temporary issues - wait a few minutes and retry
  • Verify the feed URL is accessible in a browser
  • Check console output for specific error messages

Getting Help

If you encounter an issue not listed here:

  1. Check existing GitHub Issues
  2. Review the Contributing Guide for development setup details
  3. Create a new issue with:
    • Clear description of the problem
    • Steps to reproduce
    • Error messages or logs
    • Your environment (OS, Python version)

šŸ¤ Contributing

We welcome contributions! Whether you want to add a new feed source, fix a bug, or improve documentation, please check out our Contributing Guide.

Quick Contribution Ideas

  • Add new RSS feed sources (Reddit, Hacker News, Dev.to, Medium, GitHub Trending, ArXiv, Stack Overflow, etc.)
  • Implement feed caching for better performance
  • Add result filtering and sorting options (by date, source, relevance)
  • Create output formatting options (JSON, Markdown, HTML)
  • Add more comprehensive tests and test coverage
  • Improve documentation with examples and tutorials
  • Add Docker support for easy deployment
  • Implement rate limiting awareness for feeds
  • Add result deduplication across multiple sources
  • Create a CLI interface for standalone usage
  • Add feed result pagination support
  • Implement async/await support for concurrent searches
  • Add support for private/authenticated feeds
  • Create a web dashboard for feed management
  • Add export functionality (CSV, PDF, etc.)

šŸ“„ License

This project is licensed under the MIT License - see the LICENSE file for details.

šŸ™ Acknowledgments

šŸ’¬ Support

  • Open an issue for bugs or feature requests
  • Check existing issues for solutions
  • Read the Contributing Guide for development setup

šŸ”® Roadmap

  • [ ] Add caching layer for feed results
  • [ ] Support for feed authentication
  • [ ] More built-in feed sources
  • [ ] Result deduplication across sources
  • [ ] Advanced filtering options
  • [ ] REST API mode
  • [ ] Docker support

Happy searching! šŸ”

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured
Exa Search

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.

Official
Featured