@theyahia/cdek-mcp
v2.0.2
Published
MCP server for CDEK — delivery, tariffs, tracking, order management (Russia)
Maintainers
Readme
cdek-mcp
MCP server for the CDEK delivery API (v2). 14 tools covering the full delivery lifecycle: tariff calculation, order management, shipment tracking, location search, courier pickup, barcode/receipt generation, and webhooks.
Tools (14)
Tariffs
| Tool | Description |
|------|-------------|
| calculate_tariff | Calculate delivery cost and time for a specific tariff |
| calculate_tariff_list | Get all available tariffs with prices for a route |
Orders
| Tool | Description |
|------|-------------|
| create_order | Create a delivery order with sender, recipient, packages |
| get_order | Get order details and status by UUID |
| delete_order | Cancel/delete an order by UUID |
Tracking
| Tool | Description |
|------|-------------|
| track_shipment | Track shipment by CDEK waybill number |
Locations
| Tool | Description |
|------|-------------|
| get_cities | Search city directory by name, postal code, or country |
| get_regions | Search region directory by country or name |
| list_delivery_points | Find pickup points and parcel lockers by city or GPS coordinates |
Barcode & Print
| Tool | Description |
|------|-------------|
| generate_barcode | Generate barcode/label for an order |
| print_receipt | Generate receipt/waybill PDF for an order |
Courier Pickup
| Tool | Description |
|------|-------------|
| create_courier_pickup | Schedule a courier pickup for an order |
| get_courier_pickup | Check courier pickup request status |
Webhooks
| Tool | Description |
|------|-------------|
| create_webhook | Register webhook for order status updates or delivery photos |
Quick Start
Claude Desktop
~/.config/claude/claude_desktop_config.json (macOS) or %APPDATA%\Claude\claude_desktop_config.json (Windows):
{
"mcpServers": {
"cdek": {
"command": "npx",
"args": ["-y", "@theyahia/cdek-mcp"],
"env": {
"CDEK_CLIENT_ID": "<YOUR_CLIENT_ID>",
"CDEK_CLIENT_SECRET": "<YOUR_CLIENT_SECRET>",
"CDEK_SANDBOX": "true"
}
}
}
}Cursor / Windsurf
.cursor/mcp.json or .windsurf/mcp.json:
{
"mcpServers": {
"cdek": {
"command": "npx",
"args": ["-y", "@theyahia/cdek-mcp"],
"env": {
"CDEK_CLIENT_ID": "<YOUR_CLIENT_ID>",
"CDEK_CLIENT_SECRET": "<YOUR_CLIENT_SECRET>",
"CDEK_SANDBOX": "true"
}
}
}
}VS Code (Copilot)
.vscode/mcp.json:
{
"servers": {
"cdek": {
"command": "npx",
"args": ["-y", "@theyahia/cdek-mcp"],
"env": {
"CDEK_CLIENT_ID": "<YOUR_CLIENT_ID>",
"CDEK_CLIENT_SECRET": "<YOUR_CLIENT_SECRET>",
"CDEK_SANDBOX": "true"
}
}
}
}Streamable HTTP Transport
For web deployments, use the --http flag or HTTP_PORT env var:
HTTP_PORT=3000 npx @theyahia/cdek-mcp --httpEndpoints:
POST /mcp— MCP JSON-RPCGET /mcp— SSE streamDELETE /mcp— session terminationGET /health— health check
Environment Variables
| Variable | Required | Description |
|----------|----------|-------------|
| CDEK_CLIENT_ID | Yes | Client ID from CDEK dashboard |
| CDEK_CLIENT_SECRET | Yes | Client Secret from CDEK dashboard |
| CDEK_SANDBOX | No | true to use sandbox (api.edu.cdek.ru) |
| HTTP_PORT | No | Port for HTTP transport (enables HTTP mode) |
Get your API keys: CDEK Dashboard > Integration > API Keys.
Sandbox Mode
Set CDEK_SANDBOX=true to use the CDEK test environment. Sandbox uses test credentials and the api.edu.cdek.ru endpoint.
Test credentials for sandbox:
- Client ID:
EMscd6r9JnFiQ3bLoyjJY6eM78JrJceI - Client Secret:
PjLZkKBHEiLK3YsjtNrt3TGNG0ahs3kh
Production uses api.cdek.ru.
Authentication
OAuth 2.0 Client Credentials flow. TokenManager handles:
- Automatic token acquisition on first request
- Token caching (3600s TTL)
- Proactive refresh 60s before expiry
- Concurrent request deduplication
- Automatic retry on 401 with token invalidation
E-commerce Stack
Pair with other russian-mcp servers for a complete e-commerce AI stack:
| Server | Purpose | |--------|---------| | cdek-mcp | Shipping & logistics | | dadata-mcp | Address validation, company lookup |
Part of the russian-mcp series.
Demo Prompts
"How much does it cost to ship a 2kg parcel from Moscow to Saint Petersburg?" Uses
get_citiesto find city codes, thencalculate_tariff_listto compare all available tariffs."Find the nearest CDEK pickup point to Red Square" Uses
list_delivery_pointswith GPS coordinates (latitude: 55.7539, longitude: 37.6208) to find nearby locations."Create an order to send a book from Kazan to Novosibirsk, schedule courier pickup, and print the receipt" Uses
create_order, thencreate_courier_pickupto schedule collection, andprint_receiptfor the waybill.
Development
git clone https://github.com/theYahia/cdek-mcp.git
cd cdek-mcp
npm install
npm run build
npm testLicense
MIT
