Node.js server implementing Model Context Protocol (MCP) for Mapbox APIs.
The Mapbox MCP Server transforms any AI agent or application into a geospatially-aware system by providing seamless access to Mapbox's comprehensive location intelligence platform. With this server, your AI can understand and reason about places, navigate the physical world, and access rich geospatial data including:
- Global geocoding to convert addresses and place names to coordinates and vice versa
- Points of interest (POI) search across millions of businesses, landmarks, and places worldwide
- Multi-modal routing for driving, walking, and cycling with real-time traffic
- Travel time matrices to analyze accessibility and optimize logistics
- Isochrone generation to visualize areas reachable within specific time or distance constraints
- Static map images to create visual representations of locations, routes, and geographic data
Whether you're building an AI travel assistant, logistics optimizer, location-based recommender, or any application that needs to understand "where", the Mapbox MCP Server provides the spatial intelligence to make it possible. You can also enable it on popular clients like Claude Desktop and VS Code. See below for details
A Mapbox access token is required to use this MCP server.
For quick access, you can use our hosted MCP endpoint:
Endpoint: https://mcp.mapbox.com/mcp
For detailed setup instructions for different clients and API usage, see the Hosted MCP Server Guide.
To get a Mapbox access token:
- Sign up for a free Mapbox account at mapbox.com/signup
- Navigate to your Account page
- Create a new token or use the default public token
For more information about Mapbox access tokens, see the Mapbox documentation on access tokens.
For detailed setup instructions for different integrations, refer to the following guides:
- Claude Desktop Setup - Instructions for configuring Claude Desktop to work with this MCP server
- VS Code Setup - Setting up a development environment in Visual Studio Code
- Cursor AI IDE Setup - Setting up a development environment in Cursor AI IDE
- Smolagents Integration - Example showing how to connect Smolagents AI agents to Mapbox's tools
Try these prompts with Claude Desktop or other MCP clients after setup:
- "Find coffee shops within walking distance of the Empire State Building"
- "Show me gas stations along the route from Boston to New York"
- "What restaurants are near Times Square?"
- "Get driving directions from LAX to Hollywood with current traffic"
- "How long would it take to walk from Central Park to Times Square?"
- "Calculate travel time from my hotel (Four Seasons) to JFK Airport by taxi during rush hour"
- "Create a map image showing the route from Golden Gate Bridge to Fisherman's Wharf with markers at both locations"
- "Show me a satellite view of Manhattan with key landmarks marked"
- "Generate a map highlighting all Starbucks locations within a mile of downtown Seattle"
- "Show me areas reachable within 30 minutes of downtown Portland by car"
- "Calculate a travel time matrix between these 3 hotel locations (Marriott, Sheraton and Hilton) and the convention center in Denver"
- "Find the optimal route visiting these 3 tourist attractions (Golden Gate, Musical Stairs and Fisherman's Wharf) in San Francisco"
- Be specific about locations (use full addresses or landmark names)
- Specify your preferred travel method (driving, walking, cycling)
- Include time constraints when relevant ("during rush hour", "at 3 PM")
- Ask for specific output formats when needed ("as a map image", "in JSON format")
Calculates travel times and distances between multiple points using Mapbox Matrix API. Features include:
- Efficient one-to-many, many-to-one or many-to-many routing calculations
- Support for different travel profiles (driving-traffic, driving, walking, cycling)
- Departure time specification for traffic-aware calculations
- Route summarization with distance and duration metrics
- Control approach (curb/unrestricted) and range of allowed departure bearings
Generates static map images using the Mapbox static image API. Features include:
- Custom map styles (streets, outdoors, satellite, etc.)
- Adjustable image dimensions and zoom levels
- Support for multiple markers with custom colors and labels
- Overlay options including polylines and polygons
- Auto-fitting to specified coordinates
Performs a category search using the Mapbox Search Box category search API. Features include:
- Search for points of interest by category (restaurants, hotels, gas stations, etc.)
- Filtering by geographic proximity
- Customizable result limits
- Rich metadata for each result
- Support for multiple languages
Performs reverse geocoding using the Mapbox geocoding V6 API. Features include:
- Convert geographic coordinates to human-readable addresses
- Customizable levels of detail (street, neighborhood, city, etc.)
- Results filtering by type (address, poi, neighborhood, etc.)
- Support for multiple languages
- Rich location context information
Fetches routing directions using the Mapbox Directions API. Features include:
- Support for different routing profiles: driving (with live traffic or typical), walking, and cycling
- Route from multiple waypoints (2-25 coordinate pairs)
- Alternative routes option
- Route annotations (distance, duration, speed, congestion)
- Scheduling options:
- Future departure time (depart_at) for driving and driving-traffic profiles
- Desired arrival time (arrive_by) for driving profile only
 
- Future departure time (
- Profile-specific optimizations:
- Driving: vehicle dimension constraints (height, width, weight)
 
- Exclusion options for routing:
- Common exclusions: ferry routes, cash-only tolls
- Driving-specific exclusions: tolls, motorways, unpaved roads, tunnels, country borders, state borders
- Custom point exclusions (up to 50 geographic points to avoid)
 
- GeoJSON geometry output format
Computes areas that are reachable within a specified amount of times from a location using Mapbox Isochrone API. Features include:
- Support for different travel profiles (driving, walking, cycling)
- Customizable travel times or distances
- Multiple contour generation (e.g., 15, 30, 45 minute ranges)
- Optional departure or arrival time specification
- Color customization for visualization
Uses the Mapbox Search Box Text Search API endpoint to power searching for and geocoding POIs, addresses, places, and any other types supported by that API. This tool consolidates the functionality that was previously provided by the ForwardGeocodeTool and PoiSearchTool (from earlier versions of this MCP server) into a single tool.
# Build
npm run build
# Inspect
npx @modelcontextprotocol/inspector node dist/esm/index.js# Build the Docker image
docker build -t mapbox-mcp-server .
# Run and inspect the server
npx @modelcontextprotocol/inspector docker run -i --rm --env MAPBOX_ACCESS_TOKEN="YOUR_TOKEN" mapbox-mcp-servernpx plop create-tool
# provide tool name without suffix (e.g. Search)This MCP server includes comprehensive OpenTelemetry tracing for production observability:
# Run tracing demo with console output
npm run demo:tracing# Run tests with tracing enabled
npm run test:tracingSee docs/tracing.md for complete setup instructions including:
- π§ Environment variable configuration
- π Supported backends (Jaeger, AWS X-Ray, Google Cloud, etc.)
- π― Custom trace attributes and context
- π Performance optimization (minimal overhead)
- π Troubleshooting and debugging
Tracing Features:
- β Automatic tool execution tracing
- β HTTP request instrumentation
- β Configurable exporters (console, OTLP)
- β Security-conscious (data protection, JWT validation)
- β Production-ready (<1% CPU overhead)
We welcome contributions to the Mapbox MCP Server! Please review our standards and guidelines before contributing:
- Engineering Standards (CLAUDE.md) - Code quality, testing, documentation, and collaboration standards for all contributors
- AI Agent Instructions (AGENTS.md) - Comprehensive guide for AI agents working with this codebase
- GitHub Copilot Guidelines - Best practices for using GitHub Copilot responsibly in this project
- Fork the repository and clone your fork
- Follow the development setup in our Engineering Standards
- Make your changes following our coding standards
- Add tests for any new functionality
- Submit a pull request with a clear description
All contributions must pass our CI checks and code review process. See CLAUDE.md for detailed requirements.
When you use the MCP server tools, the following data is sent directly from your environment to Mapbox APIs:
- Geocoding tools: Address/location text, coordinates, country/region filters
- Search tools: Search queries, location coordinates for proximity, category filters
- Directions tool: Start/end coordinates, waypoints, routing preferences, vehicle constraints
- Matrix tool: Multiple coordinate pairs, travel profile, departure times
- Static map tool: Coordinates, zoom level, styling preferences, marker information
- Isochrone tool: Origin coordinates, time/distance parameters, travel profile
- Local execution: All API calls are made directly from your environment to Mapbox APIs
- Token security: Your Mapbox API token remains on your local machine and is never transmitted to or stored by this MCP server
- No data storage: This MCP server does not store, log, or collect any of your data or API requests
- Direct communication: There is no intermediary server between you and Mapbox APIs
- Mapbox's privacy policy governs data sent to their APIs: https://www.mapbox.com/legal/privacy/
- API usage: Standard Mapbox API terms apply to all requests made through these tools
- Data retention: Refer to Mapbox's documentation for their data retention policies
- Email: [email protected]
- GitHub Issues: Report bugs and feature requests
- Mapbox Support: https://support.mapbox.com/
- Documentation: https://docs.mapbox.com/
- API Status: https://status.mapbox.com/
This MCP server is officially maintained by Mapbox, Inc. We provide:
- Regular updates for new Mapbox API features
- Bug fixes and security updates
- Compatibility with latest MCP protocol versions
- Community support through GitHub issues