gnews-mcp-server

gnews-mcp-server

MCP server providing access to the GNews API for fetching news articles and headlines. Supports search and top headlines with advanced filtering by language, country, category, and date.

Category
Visit Server

README

GNews API MCP Server

A Model Context Protocol (MCP) server that provides access to the GNews API for fetching news articles and headlines. This server enables AI applications to search for news, get trending headlines, and access comprehensive news data through a standardized interface.

Features

🔧 Tools

  • search_news - Search for news articles using keywords with advanced filtering
  • get_top_headlines - Get trending news articles by category

📚 Resources

  • gnews://supported-languages - List of supported language codes
  • gnews://supported-countries - List of supported country codes
  • gnews://query-syntax - Comprehensive guide to search query syntax

🎯 Prompts

  • create_news_search_prompt - Generate comprehensive news research prompts for specific topics

Installation

  1. Clone or download this repository

    git clone <repository-url>
    cd gnews-server
    
  2. Install dependencies

    pip install -r requirements.txt
    # or using uv
    uv sync
    
  3. Get a GNews API key

    • Visit gnews.io
    • Sign up for a free account
    • Get your API key from the dashboard
  4. Set up environment variables

    export GNEWS_API_KEY="your_api_key_here"
    

Usage

Running the Server

Development mode (stdio):

python main.py

Using uv:

uv run main.py

Integration with Claude Desktop

Add to your Claude Desktop configuration file (claude_desktop_config.json):

{
  "mcpServers": {
    "gnews": {
      "command": "python",
      "args": ["/absolute/path/to/gnews-server/main.py"],
      "env": {
        "GNEWS_API_KEY": "your_api_key_here"
      }
    }
  }
}

Integration with Other MCP Clients

The server supports the standard MCP protocol and can be used with any MCP-compatible client. Use the stdio transport for local connections.

API Reference

Tools

search_news

Search for news articles using specific keywords.

Parameters:

  • q (required): Search keywords with support for logical operators
  • lang (optional): Language code (2 letters, e.g., "en", "es")
  • country (optional): Country code (2 letters, e.g., "us", "gb")
  • max (optional): Number of articles to return (1-100, default: 10)
  • in (optional): Search in specific fields: "title", "description", "content"
  • nullable (optional): Allow null values for: "description", "content", "image"
  • from (optional): Filter from date (ISO 8601 format)
  • to (optional): Filter until date (ISO 8601 format)
  • sortby (optional): Sort by "publishedAt" or "relevance"
  • page (optional): Page number for pagination

Example queries:

- "Apple iPhone"
- "Apple AND iPhone"
- "Apple OR Microsoft" 
- "(Apple AND iPhone) OR Microsoft"
- "Apple NOT iPhone"
- "Apple iPhone 15" AND NOT "Apple iPhone 14"

Returns:

{
  "success": true,
  "query": "search terms",
  "totalArticles": 150,
  "articles": [
    {
      "title": "Article Title",
      "description": "Article description...",
      "content": "Full article content...",
      "url": "https://example.com/article",
      "image": "https://example.com/image.jpg",
      "publishedAt": "2024-01-01T12:00:00Z",
      "source": {
        "name": "Source Name",
        "url": "https://source.com"
      }
    }
  ],
  "parameters_used": {...}
}

get_top_headlines

Get current trending news articles by category.

Parameters:

  • category (optional): News category (default: "general")
    • Available: "general", "world", "nation", "business", "technology", "entertainment", "sports", "science", "health"
  • lang (optional): Language code
  • country (optional): Country code
  • max (optional): Number of articles (1-100, default: 10)
  • nullable (optional): Allow null values
  • from (optional): Filter from date
  • to (optional): Filter until date
  • q (optional): Additional search keywords
  • page (optional): Page number

Returns: Similar structure to search_news with category-specific trending articles.

Resources

gnews://supported-languages

Returns a formatted list of all supported language codes and names.

gnews://supported-countries

Returns a formatted list of all supported country codes and names.

gnews://query-syntax

Returns comprehensive documentation on search query syntax including logical operators, phrase search, and examples.

Prompts

create_news_search_prompt

Creates a structured prompt for comprehensive news research on a specific topic.

Parameters:

  • topic (required): The topic to research
  • days_back (optional): Number of days to look back (default: 7)

Advanced Query Syntax

The GNews API supports sophisticated search queries:

Logical Operators

  • AND: Apple AND iPhone (both terms must appear)
  • OR: Apple OR Microsoft (either term can appear)
  • NOT: Apple NOT iPhone (exclude articles with "iPhone")

Phrase Search

  • Exact phrases: "Apple iPhone 15" (exact sequence)

Operator Precedence

  • OR has higher precedence than AND
  • Use parentheses for grouping: (Apple AND iPhone) OR Microsoft

Complex Examples

- Intel AND (i7 OR i9)
- (Windows 7) AND (Windows 10)
- "breaking news" AND NOT "rumor"
- (Tesla OR "electric vehicle") AND NOT "stock price"

Supported Languages

Arabic (ar), Chinese (zh), Dutch (nl), English (en), French (fr), German (de), Greek (el), Hindi (hi), Italian (it), Japanese (ja), Malayalam (ml), Marathi (mr), Norwegian (no), Portuguese (pt), Romanian (ro), Russian (ru), Spanish (es), Swedish (sv), Tamil (ta), Telugu (te), Ukrainian (uk)

Supported Countries

Australia (au), Brazil (br), Canada (ca), China (cn), Egypt (eg), France (fr), Germany (de), Greece (gr), Hong Kong (hk), India (in), Ireland (ie), Italy (it), Japan (jp), Netherlands (nl), Norway (no), Pakistan (pk), Peru (pe), Philippines (ph), Portugal (pt), Romania (ro), Russian Federation (ru), Singapore (sg), Spain (es), Sweden (se), Switzerland (ch), Taiwan (tw), Ukraine (ua), United Kingdom (gb), United States (us)

Error Handling

The server includes comprehensive error handling:

  • API Key Validation: Checks for required environment variable
  • Parameter Validation: Validates language codes, country codes, and numeric ranges
  • Network Error Handling: Graceful handling of connection issues
  • API Error Responses: Clear error messages from GNews API

Error responses include:

{
  "success": false,
  "error": "Error description",
  "query": "original query",
  "parameters_used": {...}
}

Rate Limits

GNews API has rate limits based on your subscription plan:

  • Free Plan: 100 requests per day
  • Paid Plans: Higher limits available

The server will return appropriate error messages if rate limits are exceeded.

Contributing

  1. Fork the repository
  2. Create a feature branch
  3. Make your changes
  4. Add tests if applicable
  5. Submit a pull request

License

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

Support

  • GNews API Documentation: https://docs.gnews.io/
  • MCP Specification: https://modelcontextprotocol.io/
  • Issues: Please report bugs and feature requests through the repository's issue tracker

Example Usage in Claude

After setting up the server, you can use it in Claude Desktop:

"Search for recent news about artificial intelligence developments in the last 3 days"

"Get the top technology headlines from the United States"

"Find news articles about climate change, but exclude articles about politics"

"Show me breaking news about electric vehicles from European sources"

The server will automatically use the appropriate tools and provide structured, comprehensive news results.

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
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
Qdrant Server

Qdrant Server

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

Official
Featured