@mcpflow.io/mcp-mapbox-mcp-server

1.0.0 • Public • Published

Mapbox MCP Server

此包由 MCPFlow 打包并发布到npm仓库。

Mapbox API 的 MCP 服务器。

安装与使用

直接使用npx运行:

npx @mcpflow.io/mcp-mapbox-mcp-server

或者先安装后使用:

# 安装
npm install @mcpflow.io/mcp-mapbox-mcp-server

# 使用
npx @mcpflow.io/mcp-mapbox-mcp-server

使用方法

请参考原始仓库的使用说明。

工具函数

getApiKey

获取Mapbox访问令牌

参数:

  • apiKey: Mapbox访问令牌

runServer

运行Mapbox MCP服务器

参数:

DirectionsByPlacesArgsSchema

方向通过地点的参数模式

参数:

  • places: 地点名称数组
  • profile: 导航配置文件
  • language: 语言代码

CoordinateSchema

坐标模式

参数:

  • latitude: 纬度
  • longitude: 经度

CoordinatesSchema

坐标数组模式

参数:

  • coordinates: 坐标数组

DirectionsArgsSchema

方向参数模式

参数:

  • profile: 导航配置文件
  • coordinates: 坐标数组

MatrixByPlacesArgsSchema

通过地点的矩阵参数模式

参数:

  • places: 地点名称数组
  • profile: 导航模式
  • sources: 源地点索引数组
  • language: 语言代码
  • depart_at: 出发时间
  • annotations: 矩阵类型
  • destinations: 目标地点索引数组
  • fallback_speed: 回退速度

MatrixArgsSchema

矩阵参数模式

参数:

  • profile: 导航模式
  • sources: 源坐标索引数组
  • bearings: 航向
  • depart_at: 出发时间
  • approaches: 接近方式
  • annotations: 矩阵类型
  • coordinates: 坐标数组
  • destinations: 目标坐标索引数组
  • fallback_speed: 回退速度

GeocodingArgsSchema

地理编码参数模式

参数:

  • limit: 结果限制
  • types: 类型过滤器
  • language: 语言代码
  • fuzzyMatch: 模糊匹配
  • searchText: 搜索文本

BaseHandler

基础处理器类

参数:

原始信息

原始README

Mapbox MCP Server

MCP Server for the Mapbox API.

Features

Navigation Tools

  1. mapbox_directions

    • Get directions between coordinates
    • Inputs:
      • coordinates ({latitude: number, longitude: number}[])
      • profile (optional): "driving-traffic", "driving", "walking", "cycling"
    • Returns: route details with steps, distance, duration
  2. mapbox_directions_by_places

    • Get directions between places using their names
    • Inputs:
      • places (string[]): Array of place names
      • profile (optional): "driving-traffic", "driving", "walking", "cycling"
      • language (optional): Two-letter language code (e.g., "zh", "en")
    • Returns:
      • Geocoding results for each place
      • Route details with steps, distance, duration
      • Any errors that occurred during processing
  3. mapbox_matrix

    • Calculate travel time and distance matrices between coordinates
    • Inputs:
      • coordinates ({latitude: number, longitude: number}[])
      • profile (optional): "driving", "walking", "cycling"
      • annotations (optional): "duration", "distance", "duration,distance"
      • sources (optional): Indices of source coordinates
      • destinations (optional): Indices of destination coordinates
    • Returns: Matrix of durations and/or distances between points
  4. mapbox_matrix_by_places

    • Calculate travel time and distance matrices between places using their names
    • Inputs:
      • places (string[]): Array of place names (2-25 places)
      • profile (optional): "driving", "walking", "cycling"
      • annotations (optional): "duration", "distance", "duration,distance"
      • language (optional): Two-letter language code
      • sources (optional): Indices of source places
      • destinations (optional): Indices of destination places
    • Returns:
      • Geocoding results for each place
      • Matrix of durations and/or distances
      • Any errors that occurred during processing

Search Tools

  1. mapbox_geocoding
    • Search for places and convert addresses into coordinates
    • Inputs:
      • searchText (string): The place or address to search for
      • limit (optional): Maximum number of results (1-10)
      • types (optional): Filter by place types (country, region, place, etc.)
      • language (optional): Two-letter language code
      • fuzzyMatch (optional): Enable/disable fuzzy matching
    • Returns: Detailed location information including coordinates and properties

Claude Desktop Integration

Add this configuration to your Claude Desktop config file (typically located at ~/Library/Application Support/Claude/claude_desktop_config.json):

{
  "mcpServers": {
    "mapbox-mcp-server": {
      "command": "node",
      "args": ["/absolute/path/to/mapbox-mcp-server/build/index.js"],
      "env": {
        "MAPBOX_ACCESS_TOKEN": "your-api-key"
      }
    }
  }
}

Setup

Prerequisites

  • Node.js 16 or higher
  • TypeScript 4.5 or higher
  • A valid Mapbox API key

API Key

Get a Mapbox API key by following the instructions here.

Set your API key as an environment variable:

export MAPBOX_ACCESS_TOKEN=your_api_key_here

Rate Limits

  • Directions API: 300 requests per minute
  • Matrix API:
    • 60 requests per minute for driving/walking/cycling
    • 30 requests per minute for driving-traffic
  • Geocoding API: 600 requests per minute

Deployment

Structure

In mapbox-mcp-server, we use the following structure to manage the server's handlers:

  • src/server/handlers/base.ts: Base class for all handlers
  • src/server/registry.ts: Registry for all handlers
  • src/server/main.ts: Main entry point for the server

Each feature module follows this structure:

src/
├── types/          # Type definitions
├── schemas/        # Zod schemas for validation
├── tools/
│   ├── definitions/  # Tool definitions
│   └── handlers/     # Tool implementations
└── server/
    └── handlers/     # Handler classes

Class Diagram: mapbox-mcp-server-class-diagram


Process Diagram: mapbox-mcp-server-process-diagram

Error Handling

All tools implement comprehensive error handling:

  • Input validation errors
  • API request failures
  • Rate limit errors
  • Service-specific errors (e.g., no routes found, invalid coordinates)

License

This MCP server is licensed under the MIT License. This means you are free to use, modify, and distribute the software, subject to the terms and conditions of the MIT License. For more details, please see the LICENSE file in the project repository.

Package Sidebar

Install

npm i @mcpflow.io/mcp-mapbox-mcp-server

Weekly Downloads

3

Version

1.0.0

License

MIT License

Unpacked Size

9.23 kB

Total Files

3

Last publish

Collaborators

  • mcpflow.io