@Loucienne @leotrois @gregoire-rouviere @Ulysse6307 @colinfrisch
A Model Context Protocol (MCP) server that provides AI assistants with access to Strava running data, route planning, and weather information. This server enables intelligent running coaching by combining Strava activity analysis with real-time weather data and route generation capabilities.
- Python 3.13+
- Active Strava account with API access
- OpenWeatherMap API key
- OpenRouteService API key
Create a .env file in the project root with the following variables:
STRAVA_ACCESS_TOKEN=your_strava_access_token
WEATHER_API_KEY=your_openweathermap_api_key
ORS_KEY=your_openrouteservice_api_keyStrava API Token:
- Go to Strava API Settings
- Create an application if you haven't already
- Use the "Create & View a Refresh Token" tool or follow Strava's OAuth flow
- Copy the access token
OpenWeatherMap API Key:
- Sign up at OpenWeatherMap
- Subscribe to the 5 Day / 3 Hour Forecast API (free tier available)
- Copy your API key
OpenRouteService API Key:
- Register at OpenRouteService
- Get your free API key from the dashboard
- Clone and setup:
git clone <your-repo-url>
cd chathletique-mcp- Install Python dependencies:
# Install project dependencies
pip install -e .
# Install development dependencies (for contributing)
pip install -e ".[dev]"- Configure environment:
# Create .env file with your API keys
cp .env.example .env
# Edit .env with your actual API keys- Set up code quality tools (for contributors):
# Install pre-commit hooks for automatic code quality checks
pre-commit install
# Optional: Run pre-commit on all files to check everything
pre-commit run --all-filesThe server is built using:
- FastMCP: For MCP protocol implementation
- Stravalib: For Strava API integration
- OpenRouteService: For route generation
- OpenWeatherMap API: For weather data
- Matplotlib: For data visualization
chathletique-mcp/
βββ src/strava_mcp/
β βββ __init__.py # Package initialization
β βββ main.py # MCP server entry point
β βββ strava_tools.py # Strava API integration tools
β βββ weather_tools.py # Weather prediction tools
β βββ mcp_utils.py # MCP server configuration
βββ tests/ # Test suite
βββ .pre-commit-config.yaml # Code quality configuration
βββ pyproject.toml # Project configuration and dependencies
βββ uv.lock # Lock file for reproducible installs
βββ README.md # This file
This project uses modern Python development tools for maintaining high code quality:
- Ruff: Ultra-fast Python linter and formatter with comprehensive rules
- MyPy: Static type checking for better code reliability
- Pre-commit: Automatic code quality checks before each commit
- Pytest: Testing framework with coverage reporting
- Black: Code formatting (integrated with Ruff)
The project includes automatic quality checks that run before each commit:
- Code formatting: Automatic code formatting with Ruff
- Import sorting: Organize imports consistently
- Linting: Check for bugs, security issues, and style problems
- Type checking: Verify type annotations with MyPy
- Docstring validation: Enforce Google-style docstrings
- Security scanning: Detect potential security vulnerabilities
- Spell checking: Catch typos in code and documentation
- AI Running Coach: Integrate with Le Chat or other AI assistants for personalized running advice
- Training Analysis: Analyze performance trends and provide insights
- Route Discovery: Generate new running routes based on preferences and weather
- Weather-aware Planning: Plan runs based on upcoming weather conditions