MCP server for CDEK delivery service API — create orders, track shipments, search delivery points
Project description
mcp-server-cdek
MCP-сервер для работы с API СДЭК v2 через Claude Code, Claude Desktop и другие MCP-совместимые клиенты.
Все данные остаются на вашем компьютере — ключи никуда не передаются.
Возможности
Доставка
| Инструмент | Описание |
|---|---|
cdek_create_order |
Создать заказ на доставку (от меня / ко мне, на ПВЗ / до двери) |
cdek_track |
Отследить заказ по номеру СДЭК |
cdek_barcode |
Скачать PDF штрихкода для заказа |
cdek_label |
Скачать этикетку (A4/A5/A6/A7, по умолчанию A6 ~70x120мм) |
cdek_waybill |
Скачать PDF накладной для заказа |
cdek_delivery_points |
Поиск ПВЗ в городе |
cdek_cities |
Поиск городов СДЭК по названию |
Локальный справочник товаров
| Инструмент | Описание |
|---|---|
goods_list |
Список всех товаров |
goods_add |
Добавить товар (название, вес, габариты, цена) |
goods_remove |
Удалить товар по названию |
Товары хранятся локально в ~/.config/mcp-server-cdek/goods.json. При создании заказа параметры берутся из справочника (если не указаны явно).
Настройки
| Инструмент | Описание |
|---|---|
config_show |
Показать текущую конфигурацию (отправитель, ПВЗ, дефолты товара) |
config_set |
Установить значение конфигурации |
Настройки хранятся в ~/.config/mcp-server-cdek/config.json. Можно настроить через Claude: «установи компанию-отправителя ООО Рога».
Настройка
Шаг 1. Получить ключи API СДЭК
- Зарегистрируйтесь в личном кабинете СДЭК
- Перейдите в Настройки → Интеграция
- Скопируйте Client ID и Client Secret
Шаг 2. Подключить MCP-сервер
Claude Code (CLI в терминале)
Способ 1: через uvx (не требует установки пакета)
Требуется uv — если не установлен:
curl -LsSf https://astral.sh/uv/install.sh | sh
claude mcp add cdek \
-e CDEK_CLIENT=ваш_client_id \
-e CDEK_SECRET=ваш_client_secret \
-- uvx mcp-server-cdek
Способ 2: через pip
pip install mcp-server-cdek
claude mcp add cdek \
-e CDEK_CLIENT=ваш_client_id \
-e CDEK_SECRET=ваш_client_secret \
-- python -m mcp_server_cdek
Данные отправителя настраиваются через Claude: «установи отправителя: ООО Компания, Иванов И.И., ...» → config_set. Также можно передать через env vars (см. ниже).
Для удаления:
claude mcp remove cdek
Claude Desktop (десктопное приложение)
Добавьте в конфигурационный файл:
| Клиент | ОС | Путь к файлу |
|---|---|---|
| Claude Code | все | ~/.claude/settings.json (секция mcpServers) |
| Claude Desktop | macOS | ~/Library/Application Support/Claude/claude_desktop_config.json |
| Claude Desktop | Windows | %APPDATA%\Claude\claude_desktop_config.json |
| Claude Desktop | Linux | ~/.config/Claude/claude_desktop_config.json |
{
"mcpServers": {
"cdek": {
"command": "uvx",
"args": ["mcp-server-cdek"],
"env": {
"CDEK_CLIENT": "ваш_client_id",
"CDEK_SECRET": "ваш_client_secret"
}
}
}
}
Остальные настройки (отправитель, ПВЗ, дефолты товара) задаются через config_set или env vars (см. таблицу ниже).
Переменные окружения
| Переменная | Обязательная | Описание |
|---|---|---|
CDEK_CLIENT |
да | Client ID из личного кабинета СДЭК |
CDEK_SECRET |
да | Client Secret из личного кабинета СДЭК |
CDEK_SENDER_COMPANY |
нет* | Название компании отправителя |
CDEK_SENDER_NAME |
нет* | Краткое имя отправителя |
CDEK_SENDER_FULL_NAME |
нет* | Полное ФИО отправителя |
CDEK_SENDER_EMAIL |
нет* | Email отправителя |
CDEK_SENDER_PHONE |
нет* | Телефон отправителя |
CDEK_MY_PVZ |
нет* | Код вашего ПВЗ (для приёма посылок "ко мне") |
CDEK_DEFAULT_PRODUCT_NAME |
нет* | Название товара по умолчанию (Товар) |
CDEK_DEFAULT_WEIGHT |
нет* | Вес по умолчанию в кг (0.17) |
CDEK_DEFAULT_HEIGHT |
нет* | Высота по умолчанию в см (8) |
CDEK_DEFAULT_WIDTH |
нет* | Ширина по умолчанию в см (7) |
CDEK_DEFAULT_LENGTH |
нет* | Длина по умолчанию в см (10) |
* Можно задать через config_set вместо переменных окружения. Env vars имеют приоритет над конфиг-файлом.
Шаг 3. Проверить
Попросите Claude: «найди ПВЗ СДЭК в Москве на Тверской» — он вызовет cdek_delivery_points.
Примеры (MCP)
- «отправь посылку Иванову на ПВЗ MSK005, телефон +79001234567» →
cdek_create_order - «отправь посылку до двери: Москва, Тверская 1, Петрову +79007654321» →
cdek_create_order - «создай возвратный заказ от Сидорова, адрес: Самара, Ленина 10» →
cdek_create_order(to_me) - «отследи посылку СДЭК 1234567890» →
cdek_track - «скачай штрихкод для заказа 1234567890» →
cdek_barcode - «скачай этикетку для заказа 1234567890» →
cdek_label - «скачай этикетку A4 для заказа 1234567890» →
cdek_label(format=A4) - «скачай накладную для заказа 1234567890» →
cdek_waybill - «найди ПВЗ в Новосибирске» →
cdek_delivery_points - «какие города СДЭК есть на "Новосиб"?» →
cdek_cities - «добавь товар: Wi-Fi модем, 0.17 кг, 8x7x10 см» →
goods_add - «список товаров» →
goods_list
CLI-режим
Пакет можно использовать как CLI-инструмент в терминале. Без аргументов запускается MCP-сервер, с командой — CLI.
Требования
Переменные окружения CDEK_CLIENT и CDEK_SECRET обязательны. Данные отправителя берутся из ~/.config/mcp-server-cdek/config.json или переменных окружения:
export CDEK_CLIENT=ваш_client_id
export CDEK_SECRET=ваш_client_secret
Команды
# Создать заказ (от меня на ПВЗ)
mcp-server-cdek create-order --direction from_me --name "Петров Пётр" --phone "+79007654321" --pvz MSK005
# Создать заказ (от меня до двери)
mcp-server-cdek create-order --direction from_me --name "Петров Пётр" --phone "+79007654321" --address "Москва, Тверская 1"
# Создать возвратный заказ (ко мне)
mcp-server-cdek create-order --direction to_me --name "Сидоров" --phone "+79009876543" --address "Самара, Ленина 10"
# Отследить заказ
mcp-server-cdek track 1234567890
# Скачать штрихкод
mcp-server-cdek barcode 1234567890 --output /tmp/barcode.pdf
# Скачать этикетку (по умолчанию A6 ~70x120мм)
mcp-server-cdek label 1234567890 --output /tmp/label.pdf
mcp-server-cdek label 1234567890 --output /tmp/label_a4.pdf --format A4
# Скачать накладную
mcp-server-cdek waybill 1234567890 --output /tmp/waybill.pdf
# Поиск ПВЗ
mcp-server-cdek delivery-points Москва --search Тверская
# Поиск городов
mcp-server-cdek cities Новосиб
# Справочник товаров
mcp-server-cdek goods list
mcp-server-cdek goods add --name "Wi-Fi модем" --weight 0.17 --height 8 --width 7 --length 10
mcp-server-cdek goods remove --name "Wi-Fi модем"
Все команды выводят результат в JSON.
Лицензия
MIT
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file mcp_server_cdek-0.4.0.tar.gz.
File metadata
- Download URL: mcp_server_cdek-0.4.0.tar.gz
- Upload date:
- Size: 853.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f461c8244271086f527ecb6e956a5669e1a296fad58fa51a84a3982ac6e26cae
|
|
| MD5 |
9eb263cb4bb091f0b498d4990b8950af
|
|
| BLAKE2b-256 |
4b3ef6e2a0b452140ab288da2b0b68e3f9fc3bad3d717d38fd62add2544f9da3
|
File details
Details for the file mcp_server_cdek-0.4.0-py3-none-any.whl.
File metadata
- Download URL: mcp_server_cdek-0.4.0-py3-none-any.whl
- Upload date:
- Size: 30.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a95d1f8dca8f6331816c5ebc56a980f29d1a54110896aaa17b49b8543ce4bb41
|
|
| MD5 |
fb72bce2234d255ebf1f40046ef1a0e0
|
|
| BLAKE2b-256 |
85b0fed41b755dbd44974b417b5a338f322eeae27b84f4006d340f9cb085a70d
|