Strava MCP Server
An MCP server that enables interaction with the Strava API v3 to manage fitness activities, athlete profiles, segments, and routes. It supports retrieving detailed performance metrics, exploring geographic data, and managing club information through natural language.
README
Strava MCP Server
An MCP (Model Context Protocol) server that provides tools for interacting with the Strava API v3. Built with TypeScript and the MCP SDK.
Tools
Activities
- strava_list_activities - List the authenticated athlete's activities with date range filtering and pagination
- strava_get_activity - Get detailed activity info including splits, laps, segment efforts, and gear
- strava_create_activity - Create a manual activity entry
- strava_update_activity - Update an activity's mutable properties
- strava_list_activity_comments - List comments on an activity
- strava_list_activity_kudoers - List athletes who gave kudos
- strava_list_activity_laps - List laps with distance, time, speed, heart rate, watts, and elevation
- strava_list_activity_zones - Get heart rate and power zone distribution
Athletes
- strava_get_authenticated_athlete - Get the authenticated athlete's profile
- strava_get_athlete_zones - Get heart rate and power zones
- strava_get_athlete_stats - Get year-to-date and all-time totals for runs, rides, and swims
Segments
- strava_get_segment - Get segment details including distance, elevation, grade, and effort count
- strava_list_segment_efforts - List efforts on a segment with date range filtering
- strava_get_segment_effort - Get a specific segment effort with achievements
- strava_explore_segments - Find popular segments within a geographic bounding box
- strava_star_segment - Star or unstar a segment
Routes
- strava_list_athlete_routes - List routes created by an athlete
- strava_get_route - Get detailed route information
- strava_export_route_gpx - Export a route as GPX
- strava_export_route_tcx - Export a route as TCX
Streams (Time-Series Data)
- strava_get_activity_streams - Get activity streams (heart rate, power, cadence, altitude, GPS, etc.)
- strava_get_segment_effort_streams - Get segment effort streams
- strava_get_segment_streams - Get segment GPS/altitude data
- strava_get_route_streams - Get route GPS/altitude data
Clubs
- strava_list_athlete_clubs - List clubs the athlete belongs to
- strava_get_club - Get club details
- strava_list_club_activities - List recent club member activities
- strava_list_club_members - List club members
- strava_list_club_admins - List club admins
Gear
- strava_get_gear - Get equipment details (bikes, shoes)
Uploads
- strava_create_upload - Upload a FIT/TCX/GPX file to create an activity
- strava_get_upload - Check upload processing status
Setup
1. Create a Strava API Application
Go to Strava API Settings and create an application. Note your Client ID and Client Secret.
2. Get an Access Token
You need an access token with the appropriate scopes. For read-only access use read,activity:read_all. For write access add activity:write.
You can obtain tokens through Strava's OAuth flow. The server will automatically refresh expired tokens if STRAVA_REFRESH_TOKEN, STRAVA_CLIENT_ID, and STRAVA_CLIENT_SECRET are set.
3. Configure Environment Variables
export STRAVA_CLIENT_ID="your_client_id"
export STRAVA_CLIENT_SECRET="your_client_secret"
export STRAVA_ACCESS_TOKEN="your_access_token"
export STRAVA_REFRESH_TOKEN="your_refresh_token"
4. Add to Claude Desktop
Add to your claude_desktop_config.json:
{
"mcpServers": {
"strava": {
"command": "npx",
"args": ["-y", "strava-mcp-server"],
"env": {
"STRAVA_CLIENT_ID": "your_client_id",
"STRAVA_CLIENT_SECRET": "your_client_secret",
"STRAVA_ACCESS_TOKEN": "your_access_token",
"STRAVA_REFRESH_TOKEN": "your_refresh_token"
}
}
}
}
Or if installed locally:
{
"mcpServers": {
"strava": {
"command": "node",
"args": ["/path/to/strava-mcp/dist/index.js"],
"env": {
"STRAVA_CLIENT_ID": "your_client_id",
"STRAVA_CLIENT_SECRET": "your_client_secret",
"STRAVA_ACCESS_TOKEN": "your_access_token",
"STRAVA_REFRESH_TOKEN": "your_refresh_token"
}
}
}
}
Development
npm install
npm run build
npm run dev # watch mode with tsx
License
MIT
Recommended Servers
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.
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.
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.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
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.
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.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.