Connects Claude to MoySklad, the Russian warehouse and CRM platform. Exposes 21 tools covering the full order lifecycle: product catalog management, real-time stock queries across warehouses, counterparty records, customer order creation and status updates, shipments and incoming supply, profit and sales reports, and webhook registration. Handles price conversion automatically between rubles and kopecks. Includes built-in rate limiting at 45 requests per 3 seconds to match API constraints. Auth via bearer token or basic credentials. Part of a broader Russian e-commerce MCP stack that includes CDEK for delivery, DaData for address validation, and YooKassa for payments. Useful if you're managing inventory and orders for Russian market operations and want Claude to handle the full workflow from stock checks to shipment creation.
MCP server for MoySklad (МойСклад) warehouse / ERP / CRM API. 60 tools covering the full trade and warehouse lifecycle: products & catalog, stock, counterparties, customer & purchase orders, shipments, supplies, stock moves, inventory, write-offs/enters, returns, invoices, payments & cash, reports, audit log, and webhooks.
Part of WWmcp — a set of MCP servers for emerging markets — and the russian-mcp series.
Add to your claude_desktop_config.json:
{
"mcpServers": {
"moysklad": {
"command": "npx",
"args": ["-y", "@theyahia/moysklad-mcp"],
"env": {
"MOYSKLAD_TOKEN": "your-bearer-token"
}
}
}
}
To use login/password instead of a token, replace the env block with:
"env": { "MOYSKLAD_LOGIN": "you@example.com", "MOYSKLAD_PASSWORD": "your-password" }
claude mcp add moysklad --env MOYSKLAD_TOKEN=your-bearer-token -- npx -y @theyahia/moysklad-mcp
Add to MCP settings:
{
"moysklad": {
"command": "npx",
"args": ["-y", "@theyahia/moysklad-mcp"],
"env": { "MOYSKLAD_TOKEN": "your-bearer-token" }
}
}
| Variable | Description |
|---|---|
MOYSKLAD_TOKEN | Bearer token (preferred) |
MOYSKLAD_LOGIN + MOYSKLAD_PASSWORD | HTTP Basic auth |
Get a token in MoySklad: Settings → Users → Access tokens (POST /security/token also works with Basic auth). Generating a new token revokes the previous one.
Required permissions: the user/token needs access to the entities you intend to use. Read tools need view rights; create/update tools need edit rights for that document type. Webhooks and some reports require a paid MoySklad plan.
The MoySklad API stores money in kopecks (1 ruble = 100 kopecks). This server converts automatically:
1500.50)get_dashboard report is passed through verbatim, so its money values are still in kopecks.)When a product carries a sale price, MoySklad requires a price type. The server attaches your account's default price type automatically (from list_price_types); pass price_type_href to choose a specific one.
| Tool | Description |
|---|---|
search_products | Search products by name or article |
get_product | Get a product by UUID (raw for the full object) |
create_product | Create a product (price type attached automatically) |
update_prices | Update sale/buy/min prices |
search_assortment | Unified search across products, variants, services, bundles |
list_price_types | List price types (first is the default) |
search_variants / search_bundles / search_services | Search modifications / kits / services |
create_service | Create a service |
| Tool | Description |
|---|---|
get_stock | Current stock (quantity, reserve, in-transit) |
get_stock_by_store | Stock broken down by warehouse |
get_stock_current | Fast current-stock snapshot |
| Tool | Description |
|---|---|
get_counterparties | Search by name, INN, or phone |
get_counterparty | Get full details (raw for the full object) |
create_counterparty | Create customer/supplier |
| Tool | Description |
|---|---|
create_customer_order / get_orders / get_customer_order / update_customer_order_status | Customer order lifecycle |
create_purchase_order / get_purchase_orders | Purchase orders to suppliers |
create_demand | Shipment (demand) linked to an order and warehouse |
create_supply | Incoming supply (purchase receipt) |
create_sales_return / create_purchase_return | Returns from customers / to suppliers |
| Tool | Description |
|---|---|
create_move / get_moves | Stock transfer between warehouses |
create_enter / get_enters | Stock enter (оприходование) |
create_loss / get_losses | Write-off (списание) |
create_inventory / get_inventories | Inventory count (инвентаризация) |
| Tool | Description |
|---|---|
create_payment_in / create_payment_out | Incoming / outgoing bank payments |
create_cash_in / create_cash_out | Cash receipt / expense orders |
create_invoice_out / create_invoice_in / get_invoices_out | Sales / supplier invoices |
| Tool | Description |
|---|---|
get_profit_report | Profit by product (revenue, cost, margin) |
get_sales_report | Sales by product (quantity, revenue) |
get_dashboard | Day/week/month dashboard metrics |
get_turnover | Product turnover over a period |
get_money_report | Current money balances by account/cash |
| Tool | Description |
|---|---|
list_stores / list_organizations | Warehouses / legal entities |
list_employees / list_currencies / list_product_folders | Reference data |
get_metadata | Entity metadata (states, attributes) — find order-state hrefs here |
get_audit / get_entity_audit | Account event log / single-entity history |
| Tool | Description |
|---|---|
list_webhooks / create_webhook / update_webhook / delete_webhook | Manage webhooks (CREATE/UPDATE/DELETE/PROCESSED) |
get_documents / get_document | Generic list/get for any entity type not covered above |
HTTP_PORT=3000 npx @theyahia/moysklad-mcp
# or
npx @theyahia/moysklad-mcp --http 3000
Endpoints: POST /mcp (JSON-RPC), GET /health (status). CORS is off by default — the HTTP endpoint acts on your MoySklad token, so set MOYSKLAD_HTTP_CORS_ORIGIN only if a trusted browser origin needs it.
| Variable | Default | Description |
|---|---|---|
MOYSKLAD_TOKEN | — | Bearer token |
MOYSKLAD_LOGIN / MOYSKLAD_PASSWORD | — | Basic auth |
MOYSKLAD_RATE_BUCKET | 20 | Requests allowed per 3-second window |
MOYSKLAD_MAX_CONCURRENT | 5 | Max parallel requests (MoySklad allows 5/user) |
MOYSKLAD_HTTP_CORS_ORIGIN | — | Allowed CORS origin for the HTTP transport |
HTTP_PORT | — | Start the Streamable HTTP transport on this port |
MoySklad uses a weight-per-3-seconds model (≈45 units for a solution token, fewer for login/password, and the get_stock/get_stock_by_store reports cost 5 units each). The built-in limiter is a token bucket charged by request weight, kept conservative by default (MOYSKLAD_RATE_BUCKET=20) because the API can temporarily disable access after repeated 429s. It retries 429/5xx with backoff, honoring MoySklad's X-Lognex-Retry-After header. Solution-token users can raise the bucket toward 45.
| Symptom | Cause / fix |
|---|---|
Auth not configured | Set MOYSKLAD_TOKEN (or MOYSKLAD_LOGIN + MOYSKLAD_PASSWORD). |
auth error 401/403 | Token invalid/expired or the user lacks rights for that entity. A new token revokes old ones. |
MoySklad HTTP 412 … | A required field is missing (e.g. an outgoing payment may need an expense item — pass expense_item_href). The error message includes the parameter. |
Many 429 / slow | Lower request volume or rely on the built-in limiter; raise MOYSKLAD_RATE_BUCKET only with a solution token. |
HTTP 415 | The runtime isn't sending gzip — use Node ≥18 (its fetch handles gzip automatically). |
| Webhooks / some reports fail | Require a paid MoySklad plan. |
| Service | MCP Server | What it does |
|---|---|---|
| MoySklad | @theyahia/moysklad-mcp | Warehouse, products, orders |
| CDEK | @theyahia/cdek-mcp | Delivery, tracking |
| DaData | @theyahia/dadata-mcp | Address validation |
| YooKassa | @theyahia/yookassa-mcp | Payments |
"Show me all products with low stock (less than 10 units) and their current prices"
"Create a customer order for counterparty 'OOO Roga i Kopyta' with 50 units of 'Widget Pro' at 1500 rubles each, then create a shipment from the main warehouse"
"Move 20 units of SKU LP15 from the main warehouse to the store, then pull the profit report for this month"
npm install # installs deps + git hooks (husky)
npm run build # tsc -> dist/
npm run lint # eslint
npm run typecheck # tsc --noEmit
npm test # vitest (requires Node >=20)
npm run coverage # vitest with coverage
The published runtime supports Node ≥18; the test tooling requires Node ≥20.
Based on MoySklad JSON API 1.2.
MIT
com.mcparmory/google-sheets
domdomegg/google-sheets-mcp
henilcalagiya/google-sheets-mcp
cct15/war-dashboard-data
moooonad/mcp-google-sheets-full
io.github.br0ski777/csv-to-json