The official MCP server for the Newsdata.io News API. It exposes real-time, historical, crypto, and market news — plus source discovery and aggregate counts — as tools for Claude Desktop, Claude Code, Cursor, Zed, Cline, VS Code Copilot, Windsurf, ChatGPT Desktop, and any other MCP-compatible AI assistant. Ask questions in natural language; the assistant calls the right tool and returns formatted news.
What's breaking in US politics today? Summarize the top 5 stories.
Find positive-sentiment crypto news about Bitcoin from the last 24 hours.
How many articles mentioned "interest rates" each day in January 2025?
Pull all market news on AAPL and NVDA, then list the headlines with publication dates.
Which English-language news sources cover both technology and business in the US?
The assistant maps these requests to the appropriate tool (get_latest_news, get_crypto_news, get_news_counts, get_market_news, get_news_sources, etc.) — no manual API calls needed.
The server is published on PyPI as newsdata-mcp. The recommended path is to let your MCP client launch it via uvx — no clone, no uv sync, no virtualenv to manage. The package is downloaded and cached on first launch.
# verify uvx + the server work end-to-end (optional)
uvx newsdata-mcp --versionThen add the server to your MCP client (see Editor & Client Integrations below). Every client config uses the same launch command:
"command": "uvx",
"args": ["newsdata-mcp"]For a local development checkout, see Development below.
Set NEWSDATA_API_KEY in your client config's env block (per the per-client examples below). Get an API key at newsdata.io — the free tier is generous enough to evaluate. When running the server outside an MCP client (development, Docker, streamable-http), use a .env file:
cp .env.example .env
# then edit .env| Variable | Default | Notes |
|---|---|---|
NEWSDATA_API_KEY |
(required) | Newsdata.io credential. Missing key returns an error envelope on every call. |
REQUEST_TIMEOUT |
30 |
Per-request timeout in seconds. |
NEWSDATA_BASE_URL |
https://newsdata.io/api/1 |
Override for staging or a local mock. |
NEWSDATA_MAX_RETRIES |
5 |
Maximum attempts for transient failures (network, 5xx, 429). |
NEWSDATA_RETRY_BACKOFF |
2.0 |
Base for exponential backoff (base * 2^(attempt-1)). Seconds. |
NEWSDATA_RETRY_BACKOFF_MAX |
60.0 |
Cap on a single retry sleep, seconds. |
NEWSDATA_INTEGRATION_KEY |
(unset) | Used only by pytest -m integration. Without it, live-API tests skip. |
All values are read at module import time; restart the server after changing them.
The simplest way is to add the server to your MCP client's JSON config. Each client picks up the config on restart. All examples use uvx, which downloads + caches the published package — no local clone required.
Either edit ~/.claude/mcp.json (global) or .claude/mcp.json (per-project):
{
"mcpServers": {
"newsdata-mcp": {
"command": "uvx",
"args": ["newsdata-mcp"],
"env": {
"NEWSDATA_API_KEY": "your_newsdata_api_key"
}
}
}
}Then restart Claude Code.
Edit ~/Library/Application Support/Claude/claude_desktop_config.json (macOS) or %APPDATA%\Claude\claude_desktop_config.json (Windows) — same JSON block as above. Restart Claude Desktop.
Create or edit .cursor/mcp.json in your project root (or ~/.cursor/mcp.json globally) — same JSON block. Restart Cursor; the server appears under Cursor Settings → MCP.
Create .vscode/mcp.json in your workspace (or add an mcp key to user settings):
{
"servers": {
"newsdata-mcp": {
"type": "stdio",
"command": "uvx",
"args": ["newsdata-mcp"],
"env": {
"NEWSDATA_API_KEY": "your_newsdata_api_key"
}
}
}
}Reload VS Code. Picked up by Copilot Chat in agent mode.
Edit ~/.codeium/windsurf/mcp_config.json — same JSON block as the Claude Code example. Restart Windsurf.
Run the server in HTTP mode locally:
NEWSDATA_API_KEY=your_key uvx newsdata-mcp \
--transport streamable-http --host 127.0.0.1 --port 8000Then in ChatGPT → Settings → Connectors → Add custom connector, register http://127.0.0.1:8000/mcp as the connector endpoint.
| Tool | Endpoint | Description |
|---|---|---|
get_latest_news |
/api/1/latest |
Recent and breaking news (last 48h) |
get_archive_news |
/api/1/archive |
Historical news, filterable by from_date / to_date |
get_crypto_news |
/api/1/crypto |
Crypto and blockchain-focused coverage |
get_market_news |
/api/1/market |
Stock, financial, and market-related news |
get_news_sources |
/api/1/sources |
Source discovery by country, category, or language |
get_news_counts |
/api/1/count |
Aggregate article counts over a date range (hour / day buckets or single all total) |
get_crypto_counts |
/api/1/crypto/count |
Aggregate crypto article counts over a date range |
get_market_counts |
/api/1/market/count |
Aggregate market article counts over a date range |
All tools are read-only and idempotent; the MCP-protocol annotations let compatible clients (Claude Code, MCP Inspector, etc.) cache and parallelize calls.
get_latest_news(
q="((pizza OR burger) AND healthy)",
country=["us", "gb"],
language="en",
size=10
)
get_archive_news(
q="ukraine war",
from_date="2025-01-01",
to_date="2025-01-31",
language="en"
)
get_crypto_news(
coin=["btc", "eth"],
sentiment="positive"
)
get_market_news(
symbol=["AAPL", "NVDA"],
country="us"
)
get_news_sources(
language="en",
priority_domain="top"
)
get_news_counts(
from_date="2024-01-01",
to_date="2024-01-31",
q="bitcoin",
interval="day"
)
get_market_counts(
from_date="2024-01-01",
to_date="2024-03-31",
symbol=["AAPL", "NVDA"],
interval="hour"
)
get_latest_news(
q="elections",
sentiment="positive",
sentiment_score=70
)
Notes on parameter shapes:
- CSV-style filters accept either a Python list (preferred) or a comma-separated string.
- Boolean flags accept
True/Falseor1/0. timeframeaccepts an integer for hours (e.g.24) or a string withmsuffix for minutes (e.g.90m).interval(count tools only) acceptshour,day, orall(allreturns a single aggregate count instead of buckets).sentiment_scoreis a 0–100 minimum confidence percentage and requiressentimentto also be set — e.g.sentiment="positive", sentiment_score=70returns only articles whose positive-sentiment score is at least 70.
- Latest, crypto, and market endpoints return recent coverage — typically up to 48 hours.
- Free plan results are delayed relative to paid plans.
- Result
sizeis capped by plan tier: commonly 10 results on free, up to 50 on paid plans. - The count endpoints return aggregate buckets (one per
intervalslot) rather than article content. - Every tool returns plain text (the MCP-protocol return type). Errors come back as
Error (HTTP 4xx): …with the status code and a friendly message; HTTP 429 errors include aretry after Nshint when the upstreamRetry-Afterheader was parseable.
Full API reference: https://newsdata.io/documentation.
For HTTP-mode deployments (e.g. behind a reverse proxy, or backing the ChatGPT Desktop connector):
docker build -t newsdata-mcp .
docker run --rm -p 8000:8000 -e NEWSDATA_API_KEY=your_newsdata_api_key newsdata-mcpThe image is a multistage build on python:3.12-slim and runs as a non-root user — see the Dockerfile for details.
git clone https://github.com/newsdataapi/newsdata.io-mcp.git
cd newsdata.io-mcp
uv sync --all-groups # install runtime + dev deps
uv run pytest # unit tests only (default)
NEWSDATA_INTEGRATION_KEY=<key> uv run pytest -m integration # live-API tests
uv run pytest --cov=newsdata_mcp --cov-report=term-missing # with coverage
uv run ruff check src/ tests/
uv run mypyCI (.github/workflows/ci.yml) runs the same four commands on every push/PR to main.
- Bump
__version__insrc/newsdata_mcp/__init__.py. - Commit and tag:
git tag vX.Y.Z && git push --tags. .github/workflows/release.ymlbuilds the sdist + wheel, publishes to PyPI via Trusted Publishing (no token), and creates a GitHub Release with auto-generated notes.
One-time PyPI setup: configure a Trusted Publisher on the newsdata-mcp project pointing at newsdataapi/newsdata.io-mcp, workflow release.yml, environment pypi.
Official Newsdata.io clients for direct REST access (no MCP layer):
| Language / Runtime | Repo |
|---|---|
| Python | newsdataapi/python-client (PyPI) |
| Node.js | newsdataapi/newsdata-nodejs-client (npm) |
| React (hooks) | newsdataapi/newsdata-reactjs-client (npm) |
| PHP | newsdataapi/php-client (Packagist) |
| Java | newsdataapi/newsdata-java-sdk (Maven Central) |
| .NET | newsdataapi/newsdata-dotnet-sdk (NuGet) |
| Go | newsdataapi/newsdata-go-client (pkg.go.dev) |
| Dart / Flutter | newsdataapi/newsdata-flutter-client (pub.dev) |
Also see free news datasets for ML / NLP work.
MIT. See the LICENSE file.
