Track international packages by tracking number. Supports 3100+ carriers (China Post, DHL, FedEx, UPS, USPS, Yanwen, Cainiao, etc.) via 17track. Optional: set TRACK17_API_KEY for best results. Without a key, uses Playwright (headless browser) as fallback. Use when the user asks about package tracking, shipment status, delivery time, or logistics queries.
Track international packages by tracking number only. Supports 3100+ carriers worldwide.
| Mode | API Key Required? | Description |
|---|---|---|
| With TRACK17_API_KEY | Yes (1 key) | Uses the official api.17track.net — most reliable, 3100+ carriers. |
| Without key | No | Uses Playwright (headless Chromium) to query t.17track.net. Requires playwright npm package. |
Recommendation: Set TRACK17_API_KEY for the best reliability. Get a free key at https://api.17track.net
You deploy the MCP HTTP server with TRACK17_API_KEY on your server. End users connect via URL — they don't need any API key.
export TRACK17_API_KEY=your-17track-api-key
npx -y @shopmeagent/logistics-tracking-mcp serve
# Default: http://0.0.0.0:3000/mcp
# Override with PORT and HOST env vars
{
"mcpServers": {
"logistics-tracking": {
"type": "streamable-http",
"url": "https://your-domain.com/mcp"
}
}
}
Users only need a tracking number — no API key required on their end.
Zero-config (no key, uses Playwright fallback — requires playwright installed):
{
"mcpServers": {
"logistics-tracking": {
"command": "npx",
"args": ["-y", "@shopmeagent/logistics-tracking-mcp"]
}
}
}
Recommended — with API key for broader carrier coverage and better reliability:
{
"mcpServers": {
"logistics-tracking": {
"command": "npx",
"args": ["-y", "@shopmeagent/logistics-tracking-mcp"],
"env": {
"TRACK17_API_KEY": "your-17track-api-key"
}
}
}
}
Get a free 17track API key: https://api.17track.net
Add this skill to OpenClaw:
npx skills add shopmeskills/mcp
Then in OpenClaw's MCP configuration, add either the HTTP or stdio config shown above.
Example prompts:
Query tracking info for a single package.
trackingNumber (required), carrier (optional, auto-detected)Identify the carrier from a tracking number's format.
trackingNumberTrack up to 40 packages at once.
trackingNumbers arrayGet a human-readable explanation of a tracking status code.
statusCode (e.g. InTransit, CustomsClearance, Delivered)| Pattern | Carrier | Example |
|---|---|---|
XX123456789CN | China Post | LX123456789CN |
EX123456789CN | China EMS | EA123456789CN |
YT + 16 digits | Yanwen | YT1234567890123456 |
LP + 14+ digits | Cainiao | LP12345678901234 |
SF + 12+ digits | SF Express | SF1234567890123 |
1Z + 16 chars | UPS | 1ZABCDEF1234567890 |
94/93/92 + 20 digits | USPS | 9400111899223100012345 |
10-11 digits | DHL | 1234567890 |
12-15 digits | FedEx | 123456789012 |
| Route | Standard | Express |
|---|---|---|
| China to US | 15-30 days | 5-10 days |
| China to EU | 15-30 days | 5-10 days |
| China to SE Asia | 7-15 days | 3-7 days |
| China to Japan/Korea | 5-10 days | 3-5 days |
npm install playwright for this to work.batch_track for multiple packages — more efficient than individual queries.