Skip to main content

MCP server for FIFA World Cup 2026 football, Formula 1, and IPL cricket intelligence tools.

Project description

sportiq-mcp

CI PyPI Python License: MIT MCP Registry

MCP server that turns any AI assistant into a sports analyst across FIFA World Cup 2026 football, Formula 1, and IPL cricket — 44 AI-callable tools.

SportIQ demo — Claude calling football_simulate_bracket for World Cup 2026 title probabilities

SportIQ running live in Claude — Monte Carlo World Cup bracket, F1 pit strategy, and Dream11 optimisation, each a visible MCP tool call. (1-min demo)

Sponsor SportIQ   Website

Every tool is free — the three flagships and everything in the INTEL columns below, no key, no account. If SportIQ is useful to you, sponsor the project to support ongoing development. It's a donation, not a paywall — nothing is locked behind it.

What it does

Raw-data tools are table stakes; the intelligence layer is the product. Three flagships:

  • football_simulate_bracket — Monte Carlo with Poisson xG over the 48-team WC 2026 format → per-team round + title probabilities.
  • f1_predict_pit_strategy — tyre-degradation model on OpenF1 telemetry → optimal stop laps + compound sequence.
  • cricket_build_dream11_team — PuLP constraint solver → a valid fantasy XI under credit/role/team caps.

Tools (44 total)

Sport RAW data INTEL
Football (WC 2026) groups, fixtures, standings, squad, match stats, top scorers, odds xg_model, match_predictor, simulate_group, simulate_bracket, knockout_path, form_trends, find_value_bets, build_accumulator
F1 sessions, drivers, lap_times, standings, race_results, weather tyre_degradation, undercut_window, head_to_head_pace, weather_strategy_impact, qualifying_analysis, race_pace_compare, predict_pit_strategy
Cricket (IPL) live_matches, scorecard, points_table, schedule, squad, live_odds build_dream11_team, captain_recommendation, differential_picks, player_form_index, pitch_report, head_to_head, player_matchup, find_value_bets
Cross-sport build_accumulator

Plus sportiq_health (cache backend + per-adapter status and remaining API quota).

Data sources (per chain, with keyless fallbacks): football → API-Footballfootball-data.org → bundled wc2026.json. F1 → OpenF1Jolpicafastf1. Cricket → CricAPI + static seeds (NDTV/Cricbuzz scrapers opt-in).

Where it works

Anywhere that speaks MCP — Claude (Desktop + web), ChatGPT, Cursor, and any MCP client. Two ways to run it:

  • Hosted (no install): add a custom connector — works in claude.ai web & ChatGPT.
  • Local (uvx/Desktop config/IDEs): install from PyPI.

How it works

Hosted — no install

A public instance runs on Google Cloud Run. Add this as a custom connector with No authentication:

https://sportiq-mcp-329580761892.us-central1.run.app/mcp
  • claude.ai (web): Settings → Connectors → Add custom connector → paste URL → Save.
  • ChatGPT: Settings → Apps & Connectors → enable Developer mode → Create app (MCP) → paste URL → No authentication → Connect.

All 44 tools work out of the box on the plain URL above — data tools and the full intelligence layer (bracket simulation, pit strategy, Dream11, value bets). No key, no account, nothing to unlock.

First request after idle takes ~5–10s (the server scales to zero, so it wakes up); fast after that.

Local install

uvx sportiq-mcp                       # from PyPI
# or from source:
git clone https://github.com/Ninjabeam20/SportIQ-MCP && cd sportiq-mcp
uv sync && uv run python -m sportiq.server

Claude Desktop config:

{
  "mcpServers": {
    "sportiq": {
      "command": "uvx",
      "args": ["sportiq-mcp"],
      "env": {
        "CRICAPI_KEY": "your_cricapi_key",
        "APIFOOTBALL_KEY": "your_apifootball_key",
        "THEODDS_KEY": "your_theodds_key"
      }
    }
  }
}

Every tool works with no keys — the server boots and serves seed/free-source data, and the whole intelligence layer runs locally. Data-source keys are optional and only upgrade the source a tool reads from (fresher/live data); they never unlock tools.

Var Unlocks Free tier
APIFOOTBALL_KEY Live football fixtures / standings / squads / scorers 100 req/day
THEODDS_KEY Market odds (football + cricket probability tools) 500 req/month
FOOTBALLDATA_KEY football-data.org fallback (token optional) 10 req/min
CRICAPI_KEY Live cricket scores / scorecards / schedules / squads 100 req/day
RAPIDAPI_KEY Paid Cricbuzz fallback (player career stats) plan-dependent
SPORTIQ_ENABLE_NDTV / SPORTIQ_ENABLE_CRICBUZZ Opt-in cricket scrapers (off by default — ToS)
REDIS_URL Shared cache backend (defaults to local diskcache)
SPORTIQ_TRANSPORT stdio (default, local) or http (remote/Cloud Run)

macOS arm64: the Dream11 solver needs CBC — brew install cbc (the binary bundled with PuLP is x86-only).

Self-host

Set SPORTIQ_TRANSPORT=http and the server serves the MCP endpoint at /mcp (binds 0.0.0.0:$PORT). A ready-to-build Dockerfile is included; see cloud.md for a Google Cloud Run deploy (free tier). With your own keys set, the live-score and odds tools come online too.

Support SportIQ

Every tool is free and open source — the raw-data tools, sportiq_health, and the full intelligence layer (the three flagships + everything in the INTEL columns). No key, no account, nothing gated.

If SportIQ saves you time, sponsor the project at github.com/sponsors/Ninjabeam20 to help fund hosting and ongoing development. It's a voluntary donation — you get the same fully-unlocked server either way.

Is it safe?

  • Open source, MIT licensed, published on PyPI with signed build attestations — read the code before you connect it.
  • Read-only. Tools only fetch and analyse public sports data — no write, delete, payment, email, or file-system tools.
  • No data collection. It answers a tool call and forgets it.
  • The hosted instance holds no secrets — it runs with zero API keys.
  • Independently reviewed by AI code-audit agents (verdict: ship-ready, clean) — see SECURITY.md for the full trust model.

Every response carries a meta.is_stale flag + data age, so the AI tells you how fresh each answer is. Live scores refresh ~30s, F1 telemetry ~10s, standings ~10min, fixtures ~6h.

Develop

uv sync --extra dev
uv run pytest
uv run ruff check .
npx @modelcontextprotocol/inspector uv run python -m sportiq.server

See CLAUDE.md for collaboration rules and docs/index.md for the wiki entry point.

Data sources & credits

SportIQ derives some model constants offline from open datasets. Raw datasets are never shipped or fetched at runtime — only small derived seeds (circuits.json, venues.json, elo_seed.json) are committed.

License & author

Created and maintained by Utkarsh Gupta (@Ninjabeam20). Licensed under the MIT License — © 2026 Utkarsh Gupta. Canonical package: sportiq-mcp on PyPI / io.github.Ninjabeam20/sportiq-mcp in the official MCP registry.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

sportiq_mcp-0.3.1.tar.gz (12.0 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

sportiq_mcp-0.3.1-py3-none-any.whl (146.6 kB view details)

Uploaded Python 3

File details

Details for the file sportiq_mcp-0.3.1.tar.gz.

File metadata

  • Download URL: sportiq_mcp-0.3.1.tar.gz
  • Upload date:
  • Size: 12.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for sportiq_mcp-0.3.1.tar.gz
Algorithm Hash digest
SHA256 d6ef94955427358ddb79c79203ea5f6fb4c84c390c7c4936437b814d9bd9423b
MD5 e63a3bba13209cb78d0aaee5503b812f
BLAKE2b-256 8c9185d6a040a009025487d90f463c7ab0a0602fdb3f739a550485561c53d37e

See more details on using hashes here.

Provenance

The following attestation bundles were made for sportiq_mcp-0.3.1.tar.gz:

Publisher: release.yml on Ninjabeam20/SportIQ-MCP

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file sportiq_mcp-0.3.1-py3-none-any.whl.

File metadata

  • Download URL: sportiq_mcp-0.3.1-py3-none-any.whl
  • Upload date:
  • Size: 146.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for sportiq_mcp-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 5d54ca03176516fdd64705a21a67b338bdfd49e2077030a52e299523b26321b3
MD5 6c81ab170897c88ae3e5cf0097cdac5e
BLAKE2b-256 87685034f6f0d17c217fb4ddc74bb255f85364651ecffb70cfbe838a929be71c

See more details on using hashes here.

Provenance

The following attestation bundles were made for sportiq_mcp-0.3.1-py3-none-any.whl:

Publisher: release.yml on Ninjabeam20/SportIQ-MCP

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page