StatsPlus MCP Server

StatsPlus MCP Server

Exposes the StatsPlus API as tools for MCP-compatible clients, enabling users to query player/team statistics, contracts, ratings, and game history via natural language.

Category
Visit Server

README

StatsPlus MCP Server

An MCP server that exposes the StatsPlus API as tools for use with Claude and other MCP-compatible clients.

Prerequisites

  • Node.js 18+
  • A StatsPlus league account linked to a team

Installation

git clone https://github.com/joshuarichard/StatsPlus-MCP.git
cd StatsPlus-MCP
npm install
npm run build

Configuration

Getting your session cookie

The StatsPlus API requires an active browser session. To get your cookie:

  1. Log into https://statsplus.net/<your-league-url> in your browser
  2. Open DevTools (Cmd+Option+I on Mac, F12 on Windows/Linux)
  3. Go to ApplicationCookieshttps://statsplus.net
  4. Copy the sessionid and csrftoken values and combine them:
    sessionid=<value>;csrftoken=<value>
    

Adding to your MCP client

Add the following to your MCP client config (e.g. ~/.claude/mcp.json for Claude Code):

{
  "mcpServers": {
    "statsplus": {
      "command": "node",
      "args": ["/path/to/StatsPlus-MCP/dist/index.js"],
      "env": {
        "STATSPLUS_LEAGUE_URL": "<your-league-url>",
        "STATSPLUS_COOKIE": "sessionid=<sessionid>;csrftoken=<csrftoken>"
      }
    }
  }

Replace:

  • /path/to/StatsPlus-MCP — the absolute path where you cloned this repo
  • <your-league-url> — your league's URL slug (e.g. myleague, mlb2025)
  • <sessionid> — the sessionid cookie value from your browser
  • <csrftoken> — the csrftoken cookie value from your browser

Alternatively, with the Claude Code CLI:

claude mcp add statsplus \
  -e STATSPLUS_LEAGUE_URL=<your-league-url> \
  -e "STATSPLUS_COOKIE=sessionid=<sessionid>;csrftoken=<csrftoken>" \
  -- node /path/to/StatsPlus-MCP/dist/index.js

Available Tools

Tool Description Parameters
get_player_batting_stats Player batting statistics year?, pid?, split?
get_player_pitching_stats Player pitching statistics year?, pid?, split?
get_player_fielding_stats Player fielding statistics by position year?, pid?, split?
get_team_batting_stats Team batting statistics with rate stats year?, split?
get_team_pitching_stats Team pitching statistics with rate stats year?, split?
get_players Player roster with names and team assignments team_id?, org_id?
find_player Search players by name (partial, case-insensitive) name
start_ratings_job Start the async ratings export; returns poll_url immediately
get_ratings Collect ratings results (pass poll_url to avoid re-starting the job) poll_url?, player_ids?
get_game_history All major league games with scores, hits, errors, and pitcher IDs
get_contracts All current and active player contracts team_id?, player_id?
get_contract_extensions Signed extensions taking effect in future seasons
get_teams Team list with IDs and abbreviations
get_draft Draft picks lid?
get_exports CSV export of all league games

Split IDs: 1 = Overall, 2 = vs Left-handed, 3 = vs Right-handed

Usage tips

  • Name-to-ID resolution: Use find_player(name) for quick name → ID lookups without downloading the full roster. For a full org's players, use get_players(org_id) which filters by Parent Team ID.

  • Ratings workflow: The ratings export is an async job that takes 60–90 seconds. To avoid blocking mid-workflow, call start_ratings_job() first, do your other lookups while it processes, then call get_ratings(poll_url) to collect results:

    start_ratings_job()              → { poll_url: "..." }
    get_player_batting_stats(...)    ← runs concurrently
    get_contracts(team_id: ...)
    get_ratings(poll_url: "...")     → results ready, no extra wait
    

    Calling get_ratings() without a poll_url starts a new job and blocks until complete. Ratings columns include batting attributes (Cntct, Gap, Pow, Eye, Ks) with L/R splits, Pot* potential counterparts, and positional grades. Key encoding notes:

    • Star ratings are stored as stars × 2 — e.g. 3.5 stars = 7, 5 stars = 10
    • International complex players have a negative League value (e.g. -100)
    • Column names are not guaranteed to be stable across OOTP versions
  • Preseason / empty responses: During preseason, all stat endpoints return HTTP 204 with no data for the upcoming year. Always pass year=<most recent completed season> to get data.

  • Fielding: get_player_fielding_stats returns one row per player per position per split. A player who appeared at multiple positions will have multiple rows — one for each.

  • Game history: runs0/hits0/errors0 are the home team; runs1/hits1/errors1 are the away team. winning_pitcher, losing_pitcher, starter0, and starter1 are numeric player IDs. save_pitcher is 0 when there is no save pitcher.

  • Contracts: salary0 is the current season salary, salary1 is next season, and so on through salary14. Unpopulated years are 0. is_major and no_trade are 0/1 integers. contract_team_id is the MLB org that holds the contract (use this with the team_id filter). get_contract_extensions uses the same schema for deals already signed but not yet in effect.

  • Splits: All stat endpoints that accept a split parameter use 1 = Overall, 2 = vs Left-handed, 3 = vs Right-handed. Omitting split returns all three rows per player/team.

Development

npm run build       # Compile TypeScript
npm test            # Run tests
npm run test:watch  # Run tests in watch mode
npm run lint        # Type-check without emitting

License

MIT

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

Qdrant Server

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

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