Integrations
Supports containerized deployment using Docker for easier setup and configuration of the soccer data server
Provides access to Premier League data including standings, fixtures, schedules, team information, and match statistics
Uses Pydantic for input validation of football data requests and responses
Soccer MCP Server
A Python server implementing Model Context Protocol (MCP) for football (soccer) statistics and live match data using the API-Football service.
Overview
This server provides a comprehensive set of tools for accessing football data through the API-Football API. It serves as a bridge between applications and football data services, offering both live match information and historical statistics for leagues, teams, and players worldwide.
Features
- League data (standings, fixtures, schedules)
- Team information and fixtures
- Player statistics and profiles
- Live match data (events, statistics, timelines)
- Match analysis (statistics, events)
Configuration
This server requires an API key from RapidAPI for the API-Football service:
- Create an account on RapidAPI
- Subscribe to the API-Football API
- Set the environment variable:Copy
Tools
League Data
- get_league_id_by_name
- Retrieve the league ID for a given league name
- Example:
get_league_id_by_name(league_name="Premier League")
- get_all_leagues_id
- Retrieve a list of all football leagues with IDs
- Can be filtered by country
- Example:
get_all_leagues_id(country=["England", "Spain"])
- get_standings
- Retrieve league standings for multiple leagues and seasons
- Can be filtered by team
- Example:
get_standings(league_id=[39, 140], season=[2022, 2023])
- get_league_info
- Retrieve information about a specific football league
- Example:
get_league_info(league_name="Champions League")
- get_league_fixtures
- Retrieves all fixtures for a given league and season
- Example:
get_league_fixtures(league_id=39, season=2023)
- get_league_schedule_by_date
- Retrieves the schedule for a league on specified dates
- Example:
get_league_schedule_by_date(league_name="Premier League", date=["2024-03-08", "2024-03-09"], season="2023")
Player Data
- get_player_id
- Retrieve player IDs and information for players matching a name
- Example:
get_player_id(player_name="Messi")
- get_player_profile
- Retrieve a player's profile by their last name
- Example:
get_player_profile(player_name="Messi")
- get_player_statistics
- Retrieve detailed player statistics by seasons and league name
- Example:
get_player_statistics(player_id=154, seasons=[2022, 2023], league_name="La Liga")
- get_player_statistics_2
- Retrieve detailed player statistics by seasons and league ID
- Example:
get_player_statistics_2(player_id=154, seasons=[2022, 2023], league_id=140)
Team Data
- get_team_fixtures
- Returns past or upcoming fixtures for a team
- Example:
get_team_fixtures(team_name="Manchester United", type="past", limit=3)
- get_team_fixtures_by_date_range
- Retrieve fixtures for a team within a date range
- Example:
get_team_fixtures_by_date_range(team_name="Liverpool", from_date="2023-09-01", to_date="2023-09-30", season="2023")
- get_team_info
- Retrieve basic information about a specific team
- Example:
get_team_info(team_name="Real Madrid")
Match/Fixture Data
- get_fixture_statistics
- Retrieves detailed statistics for a specific fixture
- Example:
get_fixture_statistics(fixture_id=867946)
- get_fixture_events
- Retrieves all in-game events for a fixture (goals, cards, subs)
- Example:
get_fixture_events(fixture_id=867946)
- get_multiple_fixtures_stats
- Retrieves statistics for multiple fixtures at once
- Example:
get_multiple_fixtures_stats(fixture_ids=[867946, 867947, 867948])
Live Match Data
- get_live_match_for_team
- Checks if a team is currently playing live
- Example:
get_live_match_for_team(team_name="Chelsea")
- get_live_stats_for_team
- Retrieves live in-game stats for a team in a match
- Example:
get_live_stats_for_team(team_name="Liverpool")
- get_live_match_timeline
- Retrieves real-time timeline of events for a team's live match
- Example:
get_live_match_timeline(team_name="Manchester City")
Usage
The server is implemented using the Fast MCP framework and can be run as a standalone service.
Configuration
- The server runs with a 30-second timeout for more reliable operation
- Signal handlers are implemented for graceful shutdown (Ctrl+C)
Usage with Claude Desktop
Option 1: Using Docker (Recommended)
- Clone this repository
- Install dependencies
- Build the Docker image
- Run the Docker container (ensure your API key is passed as an environment variable)
- Add this to your
claude_desktop_config.json
:
Option 2: Direct Python Execution
- Clone this repository
- Install dependencies
- Set the API key environment variable
- Add this to your
claude_desktop_config.json
, adjusting the Python path as needed:
After adding your chosen configuration, restart Claude Desktop to load the soccer server. You'll then be able to use all the football data tools in your conversations with Claude.
Technical Details
The server is built on:
- API-Football via RapidAPI
- MCP for API interface
- Pydantic for input validation
- Requests for API communication
License
This MCP server is available under the MIT License.
This server cannot be installed
remote-capable server
The server can be hosted and run remotely because it primarily relies on remote services or has no dependency on the local environment.
Provides programmatic access to comprehensive football statistics and live match data via API-Football, enabling applications to retrieve league standings, team fixtures, player statistics, and real-time match events.
Related MCP Servers
- AsecurityAlicenseAqualityAn MCP server providing access to college football statistics sourced from the College Football Data API within Claude Desktop.Last updated -99PythonMIT License
- -securityFlicense-qualityProvides structured access to NHL data including teams, players, standings, schedules, and statistics through the Model-Context Protocol pattern.Last updated -TypeScript
- -securityFlicense-qualityThis server enables Claude to access Team Fight Tactics (TFT) game data, allowing users to retrieve match histories and detailed match information through the Riot Games API.Last updated -2TypeScript
opgg-esportsofficial
AsecurityFlicenseAqualityConnect AI agents to OP.GG Esports data and retrieve upcoming League of Legends match schedules effortlessly. Access structured match information through a standardized interface, enhancing your AI's capabilities with real-time esports data.Last updated -1TypeScript