MCP server for Ozon Seller API — products, FBS/FBO, finance, analytics, returns
Project description
mcp-server-ozon-seller
MCP-сервер, CLI-утилита и библиотека Pydantic-моделей для Ozon Seller API.
- MCP-сервер — интеграция с Claude Code, Claude Desktop и другими MCP-клиентами
- CLI-утилита — работа с API из терминала, скрипты и автоматизация
- Pydantic-модели — типизированные модели API для использования в своих Python-программах
Все данные остаются на вашем компьютере — ключи API никуда не передаются.
Оглавление
- Архитектура
- Доступные действия
- MCP-сервер
- CLI-утилита
- Pydantic-модели
- Переменные окружения
- Разработка
- Лицензия
Архитектура
Сервер использует паттерн search + execute — вместо 111 отдельных инструментов предоставляет 3:
| Инструмент | Описание |
|---|---|
ozon_search |
Поиск действий по описанию на естественном языке |
ozon_execute |
Выполнение действия по ID |
ozon_execute_file |
Выполнение действия со скачиванием файла |
Как это работает
LLM: ozon_search("отменить отправление fbs")
→ [{"id": "fbs-posting-cancel", "params_schema": {"posting_number": "str", ...}, ...}]
LLM: ozon_execute("fbs-posting-cancel", '{"posting_number": "12345678-0001-1", "cancel_reason_id": 352}')
→ {"result": true}
Доступные действия (111)
| Домен | Кол-во | Описание |
|---|---|---|
products |
21 | Товары: создание, обновление, цены, остатки, атрибуты |
fbs |
17 | FBS-отправления: списки, отмены, этикетки, акты |
fbo |
9 | FBO: отправления, поставки, склады |
categories |
4 | Категории и атрибуты товаров |
finance |
4 | Финансы: транзакции, итоги, движение средств |
analytics |
3 | Аналитика: данные, остатки, оборачиваемость |
warehouses |
2 | Склады и способы доставки |
returns |
8 | Возвраты FBO/FBS/rFBS |
chats |
6 | Чаты с покупателями |
promos |
6 | Акции и промо |
strategies |
4 | Ценовые стратегии |
rating |
3 | Рейтинг и качество продавца |
reports |
4 | Отчёты |
reviews |
4 | Отзывы покупателей |
questions |
3 | Вопросы покупателей |
cancellations |
4 | Заявки на отмену |
certificates |
6 | Сертификаты |
barcodes |
2 | Штрихкоды |
brands |
1 | Бренды |
MCP-сервер
Установка
Шаг 1. Получить API-ключи
- Войдите в Ozon Seller
- Перейдите в Настройки → API-ключи
- Создайте ключ (Admin)
- Скопируйте
Client-IdиApi-Key
Шаг 2. Подключить MCP-сервер
Подключение к Claude Code
Способ 1: через uvx (не требует установки пакета)
Требуется uv — если не установлен:
curl -LsSf https://astral.sh/uv/install.sh | sh
claude mcp add ozon-seller \
-e OZON_CLIENT_ID=ваш_client_id \
-e OZON_API_KEY=ваш_api_key \
-- uvx mcp-server-ozon-seller
Способ 2: через pip
pip install mcp-server-ozon-seller
claude mcp add ozon-seller \
-e OZON_CLIENT_ID=ваш_client_id \
-e OZON_API_KEY=ваш_api_key \
-- mcp-server-ozon-seller
Для удаления:
claude mcp remove ozon-seller
Подключение к 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 |
Через uvx:
{
"mcpServers": {
"ozon-seller": {
"command": "uvx",
"args": ["mcp-server-ozon-seller"],
"env": {
"OZON_CLIENT_ID": "ваш_client_id",
"OZON_API_KEY": "ваш_api_key"
}
}
}
}
Через pip (после pip install mcp-server-ozon-seller):
{
"mcpServers": {
"ozon-seller": {
"command": "mcp-server-ozon-seller",
"env": {
"OZON_CLIENT_ID": "ваш_client_id",
"OZON_API_KEY": "ваш_api_key"
}
}
}
}
Подключение через --mcp-config
Подключает сервер только на время одной сессии Claude, не сохраняя в настройки. Токен хранится в отдельном .env.mcp файле, а не в конфиге Claude.
Из JSON-строки:
claude --mcp-config '{"ozon-seller":{"command":"bash","args":["-c","source ~/.env.mcp && exec uvx mcp-server-ozon-seller"]}}'
Из файла:
claude --mcp-config ~/mcp-servers.json
Пример ~/mcp-servers.json:
{
"ozon-seller": {
"command": "bash",
"args": ["-c", "source ~/.env.mcp && exec uvx mcp-server-ozon-seller"]
}
}
Пример ~/.env.mcp:
OZON_CLIENT_ID=ваш_client_id
OZON_API_KEY=ваш_api_key
Шаг 3. Проверить
Попросите Claude: «покажи мои товары на Ozon» — он вызовет ozon_search, затем ozon_execute.
Примеры (MCP)
- «покажи мои товары на Ozon» →
ozon_search("products list")→ozon_execute("product-list") - «отмени FBS отправление 12345678-0001-1» →
ozon_execute("fbs-posting-cancel", ...) - «скачай акт приёмки №42» →
ozon_execute_file("fbs-act-pdf", ...) - «какие FBS заказы ещё не собраны?» →
ozon_execute("fbs-postings-list", ...) - «покажи финансовые транзакции за апрель» →
ozon_execute("finance-transactions", ...)
CLI-утилита
Установка (CLI)
pip install mcp-server-ozon-seller
Переменные окружения OZON_CLIENT_ID и OZON_API_KEY должны быть установлены:
export OZON_CLIENT_ID=ваш_client_id
export OZON_API_KEY=ваш_api_key
Или через файл:
ozon-seller-cli --env /path/to/.env <command>
Формат файла — KEY=VALUE, по одной переменной на строку, #-комментарии.
Использование (CLI)
Без аргументов запускается MCP-сервер, с командой — CLI. Все команды выводят JSON.
# Версия
ozon-seller-cli --version
# Справка
ozon-seller-cli --help
ozon-seller-cli <command> --help
Примеры команд
# Товары
ozon-seller-cli product-list --limit 10
ozon-seller-cli product-info --offer-id SKU-001
ozon-seller-cli product-stocks-info
# FBS-отправления
ozon-seller-cli fbs-list
ozon-seller-cli fbs-cancel-reasons
ozon-seller-cli fbs-label 12345678-0001-1
# FBO
ozon-seller-cli fbo-list
ozon-seller-cli fbo-supply-list
# Финансы и аналитика
ozon-seller-cli finance-transactions '{"date": {"from": "2026-04-01", "to": "2026-04-25"}}'
ozon-seller-cli analytics-stock
# Возвраты
ozon-seller-cli returns-fbs
ozon-seller-cli returns-fbo
# Другое
ozon-seller-cli warehouses
ozon-seller-cli categories
ozon-seller-cli rating
ozon-seller-cli reviews
ozon-seller-cli brands
Pydantic-модели
Пакет содержит типизированные Pydantic-модели всех объектов API. Модели можно использовать в своих Python-программах для валидации данных и автодополнения в IDE.
Установка (библиотеки)
pip install mcp-server-ozon-seller
Использование в своих программах
from mcp_server_ozon_seller.models import FbsPostingsListParams
# Валидация данных
params = FbsPostingsListParams.model_validate({
"filter_dict": {"status": "awaiting_packaging"},
"limit": 50,
})
print(params.model_dump_json())
# Создание объекта
params = FbsPostingsListParams(limit=10)
print(params.limit) # type-safe доступ к полям
Все модели используют extra="allow" для forward compatibility — неизвестные поля API не вызывают ошибок.
Полный список моделей: models.py
Переменные окружения
| Переменная | Обязательная | По умолчанию | Описание |
|---|---|---|---|
OZON_CLIENT_ID |
да | — | Client-Id из личного кабинета Ozon Seller |
OZON_API_KEY |
да | — | Api-Key из личного кабинета Ozon Seller |
OZON_TIMEOUT |
нет | 30 |
Таймаут HTTP-запросов к API (секунды) |
OZON_FILE_TIMEOUT |
нет | 60 |
Таймаут скачивания файлов (секунды) |
Получить ключи: Ozon Seller → Настройки → API-ключи.
Разработка
pip install -e ".[test]"
ruff check src/ tests/
pytest tests/ -v
Лицензия
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_ozon_seller-0.3.1.tar.gz.
File metadata
- Download URL: mcp_server_ozon_seller-0.3.1.tar.gz
- Upload date:
- Size: 47.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d8d960e496444072e9a98febe6e3ec0b9bd4e699e818c7751e6276b4d602db05
|
|
| MD5 |
d03d8734b1ecdcd0401eae7dd5ce0509
|
|
| BLAKE2b-256 |
f8ae1f794512cc95fb014e5be7696d8e94958ba80c134ca52e304be9dc3ea7f7
|
File details
Details for the file mcp_server_ozon_seller-0.3.1-py3-none-any.whl.
File metadata
- Download URL: mcp_server_ozon_seller-0.3.1-py3-none-any.whl
- Upload date:
- Size: 35.2 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 |
b397abde3675fca7dbb7c1d9396f2fad66fde4ba36d2ddc641d34ae891d94676
|
|
| MD5 |
599204d02eb9f53de28b62b2e5e1665d
|
|
| BLAKE2b-256 |
aeaa857726a4385cd77b124daab2b3377eb65b5178911da38ccfd98abe4f7788
|