OpenRoute MCP
πΊοΈ MCP server to help plan routes using OpenRouteService.org, for activities such as hiking or mountain biking.
πΊοΈ OpenRoute MCP
Model Context Protocol (MCP) server to plan routes using the OpenRouteService API, for activities such as hiking or mountain biking.
[!CAUTION]
DISCLAIMER: The routes generated by this service are provided for informational purposes only and are not guaranteed to be safe, legal, or suitable for your intended use. Always verify routes independently using official maps, local authorities, and current conditions before attempting any journey. Users assume all risks and responsibilities for their safety and compliance with local laws and regulations.
[!TIP]
Copy the whole GPX file returned as part of the tool call results, and use a service such as gpx.studio to load the generated GPX file on a map.
π οΈ Available tools
- π Find possible coordinates for a location
- Arguments:
location(string): location to get coordinates for
- Returns: list of 10 coordinates with available description to enable the agent figure out the right one
- Arguments:
- π Find possible locations (addresses) for given coordinates.
- Arguments:
lon(float): Longitude of the locationlat(float): Latitude of the location
- Returns: list of objects close to the given coordinates
- Arguments:
- πΊοΈ Create a route from a starting location to a destination, optionally with waypoints
- Arguments:
route_type(string): Type of route, e.g. "cycling-mountain", "cycling-regular", "foot-hiking", "driving-car"from_coordinates(list[float]): Starting location as [longitude, latitude]from_coordinates(list[float]): Destination location as [longitude, latitude]waypoints(list[list[float]]): optional list of waypoints coordinates as [[lon, lat], ...]
- Returns:
- a resource file containing the route GPX (e.g.
route://foot-hiking-98.gpx) - a resource file containing a PNG image visualization of the route (e.g.
route://foot-hiking-98.png) - a resource file containing a HTML interactive visualization of the route (e.g.
route://foot-hiking-98.html) that can be directly opened with your browser
- a resource file containing the route GPX (e.g.
- Arguments:
- π Search for Points of Interest (POIs) in an area
- Arguments:
bounding_box_coordinates(list[list[float]]): coordinates defining a bounding box as [[min_lon, min_lat], [max_lon, max_lat]]filters_name(list[string]): optional list of names to filter POIs, e.g. ["Gas station", "Restaurant"]
- Returns: found POIs information
- Arguments:
- π Search for known routes close to a given start and end coordinates, this enables to suggest waypoints to go through known trails when creating a route. It is only working in Switzerland for now thanks to the Swiss Confederation api3.geo.admin.ch π¨π
- Arguments:
route_type(string): Type of route, e.g. "cycling-mountain", "cycling-regular", "foot-hiking", "driving-car"from_coordinates(list[float]): Starting location as [longitude, latitude]from_coordinates(list[float]): Destination location as [longitude, latitude]
- Returns: known trails trace and description when available to help the agent build a nice route
- Arguments:
- β±οΈ Computes the area that can be reached within a given time or distance from one or more starting points.
-
Arguments:
coordinates_list: 1 or more coordinates to compute reachable area from as [[lon, lat], ...]route_type: Type of route, e.g. "cycling-mountain", "cycling-regular", "foot-hiking", "driving-car"range_type: Type of range, eithertime(in seconds) ordistance(in metres)area_range: maximum range value of the analysis in seconds for time and metres for distance. Or a comma separated list of specific range values
-
Returns: Reachable area information in GeoJSON format
-
ποΈ Available Resources
- π Route files
- URL pattern:
route://{filename} - Type: GPX (
.gpx), HTML (.html), or PNG (.png) - Description: Returns a previously generated route file by filename.
- Produced by:
create_route_from_totool
- URL pattern:
π Connect client to MCP server
Follow the instructions of your client, and use the /mcp URL of your deployed server (e.g. http://localhost:8888/mcp)
For example, for GitHub Copilot in VSCode, to add a new MCP server through the VSCode UI:
- Open side panel chat (
ctrl+shift+iorcmd+shift+i), and make sure the mode is set toAgentin the bottom right - Open command palette (
ctrl+shift+porcmd+shift+p), and search forMCP: Open User Configuration, this will open amcp.jsonfile
β¨οΈ Use stdio transport
[!IMPORTANT]
Login with GitHub to openrouteservice.org and get an API key that you can provide through the
OPENROUTESERVICE_API_KEYenvironment variable.
OPENROUTESERVICE_API_KEY=YYY uvx openroute-mcp
In VSCode mcp.json file you should have:
{
"servers": {
"openroute-mcp": {
"command": "uvx",
"args": [
"openroute-mcp"
],
"env": {
"OPENROUTESERVICE_API_KEY": "YOUR_API_KEY"
}
}
}
}
[!IMPORTANT]
Click on
Startjust on top of"openroute-mcp"to start the connection to the MCP server.You can click the wrench and screwdriver button π οΈ (
Configure Tools...) to enable/disable specific tools
Full details of the CLI options:
usage: openroute-mcp [-h] [--http] [--port PORT] [--openroute-api OPENROUTE_API] [--openroute-api-key OPENROUTE_API_KEY]
[--data-folder DATA_FOLDER] [--no-save] [--no-img] [--add-html]
A Model Context Protocol (MCP) server for building routes using OpenRouteService.
options:
-h, --help show this help message and exit
--http Use Streamable HTTP transport
--port PORT Port to run the server on
--openroute-api OPENROUTE_API
OpenRouteService API URL (default: https://api.openrouteservice.org)
--openroute-api-key OPENROUTE_API_KEY
OpenRouteService API key (default: taken from env var OPENROUTESERVICE_API_KEY)
--data-folder DATA_FOLDER
Folder to save generated routes
--no-save Don't save generated routes to disk (also disable image and HTML generation)
--no-img Do not add PNG image visualization of the routes to the response (image not supported by all LLMs)
--add-html Add HTML interactive map for routes to the response (larger context used)
π‘ Use streamable HTTP server
Connect to a running streamable HTTP MCP server, such as openroute-mcp.onrender.com/mcp
In VSCode mcp.json you should have the following:
{
"servers": {
"openroute-mcp-http": {
"url": "https://openroute-mcp.onrender.com/mcp",
"type": "http"
}
}
}
[!CAUTION]
The routes created on a public MCP server will be publicly available to anyone.
More details available in the VSCode MCP official docs.
π§βπ» Development
Checkout the CONTRIBUTING.md page for more details on running in development and contributing.
Related Servers
Tokyo WBGT MCP Server
Provides real-time and forecast WBGT (Heat Index) data for Tokyo from Japan's Ministry of the Environment.
Sitecore MCP server
MCP server for work with Sitecore
MCP Time Server
A simple server that provides the current UTC time.
Salaah MCP
FastAPI and MCP service providing Islamic prayer times and other useful calculations.
Minecraft MCP Integration
Enables AI assistants to interact with a Minecraft server using the Model Context Protocol (MCP).
Zomato MCP
An mcp server for your food ordering needs.
MCP Weather Server
Provides real-time weather information and forecasts using the OpenWeatherMap API.
Pokemon MCP
An MCP server for Pokemon-related functionality.
CYAN ARROW Trading System
A high-performance trading system for Claude Desktop, providing real-time market data via Tiingo and optional Telegram alerts.
Latinum Wallet MCP
An MCP server enabling AI agents to pay for services using HTTP 402 requests and MCP tools.