Skip to main content
Glama

Delivery: push tracking event [sandbox]

delivery_tracking

Report one parcel movement event to Avito, such as status transition from RECEIVED_AT_TRANSIT_TERMINAL to IN_TRANSIT. Intended for delivery service partners to log tracking updates.

Instructions

[SANDBOX] Appends one parcel tracking event to Avito on behalf of the delivery service; does not modify existing history — a single status transition (e.g. RECEIVED_AT_TRANSIT_TERMINAL → IN_TRANSIT). Use this to report movement as it happens; one call records one event, and events accumulate into the parcel history (not idempotent — re-sending logs a duplicate). Returns an empty 200 on success; a 4xx means the order/status pair was rejected. Comply with Avito's retry policy on 5xx. For delivery-service PARTNERS only (not regular sellers). Sibling tools: delivery_set_order_properties sets cost/parameters, delivery_change_parcels reschedules a parcel — this one only appends a status event.

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault
orderIdYesOrder identifier.
avitoEventTypeYesEvent code on the Avito side. Example: RECEIVED_AT_TRANSIT_TERMINAL.
avitoStatusYesParcel status. Enum: CONFIRMED | IN_TRANSIT | ON_DELIVERY | DELIVERED | IN_TRANSIT_RETURN | ON_DELIVERY_RETURN | RETURNED | LOST | DESTROYED.
dateYesEvent date and time in RFC 3339 format, UTC.
locationYesEvent locality in the nominative case. Example: Kazan.
providerEventCodeYesEvent code as defined by the delivery service.
commentNoComment on the status (optional).
optionsNoAdditional status options: parcel barcode, return numbers (optional).
dryRunNov0.7.0: if true — returns a preview of the HTTP request without calling the Avito API. Safe for inspecting exactly what would be done. Default: the value of AVITO_MCP_DRY_RUN_DEFAULT (usually false).
idempotencyKeyNov0.7.0: optional key for duplicate protection. A repeat call with the same key within AVITO_MCP_IDEMPOTENCY_TTL_SEC returns the cached result. The same key with different args returns a conflict error — this is safe by design.
Behavior5/5

Does the description disclose side effects, auth requirements, rate limits, or destructive behavior?

Annotations already indicate readOnlyHint=false, destructiveHint=false, and idempotentHint=false. The description adds critical context: events accumulate non-idempotently ('re-sending logs a duplicate'), it returns empty 200 on success, 4xx for rejection, and advises compliance with Avito's retry policy on 5xx. No contradiction.

Agents need to know what a tool does to the world before calling it. Descriptions should go beyond structured annotations to explain consequences.

Conciseness5/5

Is the description appropriately sized, front-loaded, and free of redundancy?

The description is four sentences, front-loaded with the core action, and every sentence adds distinct value: purpose, usage scope, behavioral note, error handling, and sibling differentiation. No wasted words.

Shorter descriptions cost fewer tokens and are easier for agents to parse. Every sentence should earn its place.

Completeness5/5

Given the tool's complexity, does the description cover enough for an agent to succeed on first attempt?

Despite no output schema, the description covers purpose, usage, behavior (non-idempotence, error responses), retry policy, authorization (partners only), and relationship to siblings. This is complete for a tool with 10 parameters and detailed schema descriptions.

Complex tools with many parameters or behaviors need more documentation. Simple tools need less. This dimension scales expectations accordingly.

Parameters3/5

Does the description clarify parameter syntax, constraints, interactions, or defaults beyond what the schema provides?

Schema coverage is 100%, with detailed descriptions for each parameter (e.g., dryRun and idempotencyKey include version info and behavior). The tool description does not add further parameter-level meaning beyond what the schema provides, so baseline 3 is appropriate.

Input schemas describe structure but not intent. Descriptions should explain non-obvious parameter relationships and valid value ranges.

Purpose5/5

Does the description clearly state what the tool does and how it differs from similar tools?

The description states 'Appends one parcel tracking event to Avito on behalf of the delivery service; does not modify existing history — a single status transition.' This is a specific verb+resource, and it distinguishes from siblings by noting that it 'only appends a status event' while other tools set parameters or reschedule parcels.

Agents choose between tools based on descriptions. A clear purpose with a specific verb and resource helps agents select the right tool.

Usage Guidelines5/5

Does the description explain when to use this tool, when not to, or what alternatives exist?

The description explicitly says 'Use this to report movement as it happens; one call records one event' and notes that it is 'For delivery-service PARTNERS only (not regular sellers).' It also names sibling tools and contrasts their functions, providing clear when-to-use and when-not-to-use guidance.

Agents often have multiple tools that could apply. Explicit usage guidance like "use X instead of Y when Z" prevents misuse.

Install Server

Other Tools

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/elchin92/avito-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server