README.md•11.4 kB
# MCP RSS Aggregator
[](https://archestra.ai/mcp-catalog/imprvhub__mcp-rss-aggregator)
[](https://mseep.ai/app/51854dcf-6cb2-4bd0-a37f-5b87ba25d7c7)
[](https://smithery.ai/server/@imprvhub/mcp-rss-aggregator)
<table style="border-collapse: collapse; width: 100%; table-layout: fixed;">
<tr>
<td style="padding: 15px; vertical-align: middle; border: none; text-align: center;">
<a href="https://mseep.ai/app/imprvhub-mcp-rss-aggregator">
<img src="https://mseep.net/pr/imprvhub-mcp-rss-aggregator-badge.png" alt="MseeP.ai Security Assessment Badge" />
</a>
</td>
<td style="width: 40%; padding: 15px; vertical-align: middle; border: none;">An integration that allows Claude Desktop to fetch and read content from your favorite RSS feeds using the Model Context Protocol (MCP).</td>
<td style="width: 60%; padding: 0; vertical-align: middle; border: none; min-width: 300px; text-align: center;"><a href="https://glama.ai/mcp/servers/@imprvhub/mcp-rss-aggregator">
<img style="max-width: 100%; height: auto; min-width: 300px;" src="https://glama.ai/mcp/servers/@imprvhub/mcp-rss-aggregator/badge" alt="RSS Aggregator MCP server" />
</a></td>
</tr>
</table>
## Features
- Read articles from your favorite RSS feeds directly in Claude Desktop
- Support for OPML files to import your existing feed subscriptions
- Organize feeds by categories
- Get the latest articles across all your feeds
- Filter articles by feed source or category
- Well-formatted article presentation with titles, snippets, and links
## Demo
<p>
<a href="https://youtu.be/9pvm078fHkQ">
<img src="public/assets/preview.png" width="600" alt="Status Observer MCP Demo">
</a>
</p>
<details>
<summary> Timestamps </summary>
Click on any timestamp to jump to that section of the video
[00:00](https://youtu.be/9pvm078fHkQ&t=0s) - **Sample RSS Feed Demonstration**:
Using the default 'sample-feeds.opml' file included in the repository. This segment displays how Claude processes and presents news content from sources like TechCrunch, The Verge, and other technology publications through the MCP (Model Context Protocol).
[01:05](https://youtu.be/9pvm078fHkQ&t=65s) - **Configuration File Editing Process**:
Step-by-step walkthrough of accessing and modifying the claude_desktop_config.json file to change the OPML file path reference from the default sample to a customized 'my-feeds.opml' file.
[01:15](https://youtu.be/9pvm078fHkQ&t=75s) - **Application Restart Procedure**:
Illustrating the necessary step of closing and reopening the Claude Desktop application to properly load and apply the modified OPML file configuration changes.
[01:25](https://youtu.be/9pvm078fHkQ&t=85s) - **Custom RSS Feed Results**:
Demonstration of the results after implementing the custom OPML file. This section highlights the expanded and more diverse news sources now available through Claude Desktop, including Spanish-language content.
</details>
## Requirements
- Node.js 16 or higher
- Claude Desktop
- Internet connection to access RSS feeds
## Installation
### Installing Manually
1. Clone or download this repository:
```bash
git clone https://github.com/imprvhub/mcp-rss-aggregator
cd mcp-rss-aggregator
```
2. Install dependencies:
```bash
npm install
```
3. Build the project:
```bash
npm run build
```
## Feed Configuration
The RSS Aggregator supports both OPML and JSON formats for feed configuration.
### Using OPML (Recommended)
OPML (Outline Processor Markup Language) is a standard format used by most RSS readers to export and import feed subscriptions.
A sample OPML file with popular feeds is included in the `public/sample-feeds.opml` file. You can:
1. Use this file as-is
2. Edit it to add your own feeds
3. Replace it with an export from your existing RSS reader
Most RSS readers allow you to export your subscriptions as an OPML file.
### Using JSON
Alternatively, you can define your feeds in a JSON file with the following format:
```json
[
{
"title": "Hacker News",
"url": "https://news.ycombinator.com/rss",
"htmlUrl": "https://news.ycombinator.com/",
"category": "Tech News"
},
{
"title": "TechCrunch",
"url": "https://techcrunch.com/feed/",
"htmlUrl": "https://techcrunch.com/",
"category": "Tech News"
}
]
```
## Running the MCP Server
There are two ways to run the MCP server:
### Option 1: Running manually
1. Open a terminal or command prompt
2. Navigate to the project directory
3. Run the server directly:
```bash
node build/index.js
```
Keep this terminal window open while using Claude Desktop. The server will run until you close the terminal.
### Option 2: Auto-starting with Claude Desktop (recommended for regular use)
The Claude Desktop can automatically start the MCP server when needed. To set this up:
#### Configuration
The Claude Desktop configuration file is located at:
- **macOS**: `~/Library/Application Support/Claude/claude_desktop_config.json`
- **Windows**: `%APPDATA%\Claude\claude_desktop_config.json`
- **Linux**: `~/.config/Claude/claude_desktop_config.json`
Edit this file to add the RSS Aggregator MCP configuration. If the file doesn't exist, create it:
```json
{
"mcpServers": {
"rssAggregator": {
"command": "node",
"args": ["ABSOLUTE_PATH_TO_DIRECTORY/mcp-rss-aggregator/build/index.js"],
"feedsPath": "ABSOLUTE_PATH_TO_YOUR_FEEDS_FILE.opml"
}
}
}
```
**Important Notes**:
- Replace `ABSOLUTE_PATH_TO_DIRECTORY` with the **complete absolute path** where you installed the MCP
- macOS/Linux example: `/Users/username/mcp-rss-aggregator`
- Windows example: `C:\\Users\\username\\mcp-rss-aggregator`
- Replace `ABSOLUTE_PATH_TO_YOUR_FEEDS_FILE.opml` with the path to your OPML or JSON file
- If omitted, the sample feeds file will be used
If you already have other MCPs configured, simply add the "rssAggregator" section inside the "mcpServers" object:
```json
{
"mcpServers": {
"otherMcp1": {
"command": "...",
"args": ["..."]
},
"rssAggregator": {
"command": "node",
"args": [
"ABSOLUTE_PATH_TO_DIRECTORY/mcp-rss-aggregator/build/index.js"
],
"feedsPath": "ABSOLUTE_PATH_TO_YOUR_FEEDS_FILE.opml"
}
}
}
```
The MCP server will automatically start when Claude Desktop needs it, based on the configuration in your `claude_desktop_config.json` file.
## Usage
1. Restart Claude Desktop after modifying the configuration
2. In Claude, use the `rss` command to interact with the RSS Aggregator MCP Server
3. The MCP server runs as a subprocess managed by Claude Desktop
## Available Commands
The RSS Aggregator MCP provides a tool named `rss` with several commands:
| Command | Description | Parameters | Example |
|---------|-------------|------------|---------|
| `latest` | Show latest articles from all feeds | Optional limit (--N) | `rss latest --20` |
| `top` or `best` | Show top articles from all feeds | Optional limit (--N) | `rss top --15` |
| `list` | List all available feeds | None | `rss list` |
| `--[feed-id]` | Show articles from a specific feed | Optional limit (--N) | `rss --hackernews --10` |
| `[category]` | Show articles from a specific category | Optional limit (--N) | `rss "Tech News" --20` |
| `set-feeds-path --[path]` | Set path to OPML/JSON file | Path to file | `rss set-feeds-path --/path/to/feeds.opml` |
## Example Usage
Here are various examples of how to use the RSS Aggregator with Claude:
### Direct Commands:
```
rss latest
rss top --20
rss list
rss "Tech News"
rss --hackernews
rss --techcrunch --15
```
### Natural Language Queries:
You can also interact with the MCP using natural language. Claude will interpret these requests and use the appropriate commands:
- "What are the latest news on Hacker News?"
- "Show me the top tech articles today"
- "Fetch the latest articles from my programming feeds"
- "List all my RSS feeds"
## Extended Usage Examples
### Daily News Briefing
Get your news briefing from all your sources:
```
rss latest --25
```
This will fetch the 25 most recent articles across all your feeds, giving you a quick overview of the latest news.
### Exploring Top Content
Find the most important or popular articles:
```
rss top --20
```
### Category-Based Reading
Focus on specific content categories:
```
rss "Tech News" --30
rss "Politics" --15
rss "Science" --10
```
### Source-Specific Updates
Read updates from specific sources you follow:
```
rss --hackernews --20
rss --nytimes
rss --techcrunch --15
```
### Discover Your Available Feeds
Find out what feeds you have configured:
```
rss list
```
### Combining Multiple Requests
You can make multiple sequential requests to build a comprehensive view:
```
rss "Tech News" --10
rss "Finance" --10
rss top --5
```
### Practical Workflows
1. **Morning Routine**:
```
rss top --10
rss "News" --5
```
2. **Industry Research**:
```
rss "Industry News" --15
rss --bloomberg --5
```
3. **Tech Updates**:
```
rss --hackernews --10
rss --techcrunch --5
```
### Working with Claude
You can ask Claude to analyze or summarize the articles:
1. After running: `rss latest --10`
Ask: "Can you summarize these articles?"
2. After running: `rss "Tech News" --15`
Ask: "What are the key trends in these tech articles?"
3. After running: `rss --nytimes --washingtonpost --10`
Ask: "Compare how these sources cover current events"
## Troubleshooting
### "Server disconnected" error
If you see the error "MCP RSS Aggregator: Server disconnected" in Claude Desktop:
1. **Verify the server is running**:
- Open a terminal and manually run `node build/index.js` from the project directory
- If the server starts successfully, use Claude while keeping this terminal open
2. **Check your configuration**:
- Ensure the absolute path in `claude_desktop_config.json` is correct for your system
- Double-check that you've used double backslashes (`\\`) for Windows paths
- Verify you're using the complete path from the root of your filesystem
### Tools not appearing in Claude
If the RSS Aggregator tools don't appear in Claude:
- Make sure you've restarted Claude Desktop after configuration
- Check the Claude Desktop logs for any MCP communication errors
- Ensure the MCP server process is running (run it manually to confirm)
### Feeds not loading
If your feeds aren't loading properly:
- Make sure your OPML/JSON file is correctly formatted
- Check if the `feedsPath` in your configuration is correct
- Try running the server manually with a known good feeds file
## Contributing
Contributions to improve the RSS Aggregator are welcome! Here are some ways you can contribute:
1. Add support for more feed formats
2. Improve feed parsing and error handling
3. Add more visualization options for articles
4. Improve categorization and filtering capabilities
## License
This project is licensed under the Mozilla Public License 2.0 - see the [LICENSE](https://github.com/imprvhub/mcp-rss-aggregator/blob/main/LICENSE) file for details.
## Related Links
- [Model Context Protocol](https://modelcontextprotocol.io/)
- [Claude Desktop](https://claude.ai/download)
- [MCP Series](https://github.com/mcp-series)