Field naming
snake_case everywhere — both request body fields and response shapes.
Dates & timestamps
All timestamps are ISO 8601 with the source event’s original UTC offset preserved — never normalized to Z (UTC) or any single fixed zone.
- Korean auction events serialize as
+09:00 (KST).
- Destination-side logistics events (e.g., Lagos customs arrival) serialize in the event’s local offset —
+01:00 for WAT, etc.
- Bare UTC
Z is not acceptable in partner-submitted fields — always include the actual offset of the event location.
Implementation note for Node.js consumers: Date.prototype.toISOString() always returns Z and is therefore not suitable. Use a serializer that preserves the offset (e.g., date-fns-tz, Luxon, or equivalent).
Money
- All amounts are USD integers (whole dollars, not cents).
null for unset amounts (e.g., purchase_price_usd is null until the order reaches secured).
- Partner handles NGN (or other local currency) conversion; LMN does not surface non-USD prices.
IDs
Bare IDs (e.g., 01HXYZ...). No prefixes like ord_ or veh_. Order IDs are ULIDs (26 chars). Vehicle IDs follow the source’s native format.
Cursor-based with composite (sort_field, id) cursors:
{
"data": [ ... ],
"next_cursor": "eyJ0cyI6IjIwMjYtMDQtMTVUMTA6MDAiLCJpZCI6IjAxSFhZWi4uLiJ9"
}
next_cursor is null on the last page.
- Cursors are sort-specific — a cursor obtained with
sort=X is invalid when the next request uses a different sort. Restart from page 1 if changing sort.
- Default page size is 50 (vehicles, orders); max 200.
limit > max returns 400 validation_error.
Nullable fields
Always explicit null, never omitted. Clients should treat missing fields as schema bugs.
HTTP methods & status codes
| Method | Usage |
|---|
GET | Read-only resource fetch or list. Safe, idempotent. |
POST | Create or trigger a state transition. Requires Idempotency-Key. |
DELETE | Cancel an order. Requires Idempotency-Key. |
Operational boundary
┌─────────────────────────────────────────────────────────┐
│ LMN responsibility │
│ • Inventory aggregation (auction + dealer) │
│ • Cost estimation │
│ • Bidding / direct purchase │
│ • Korean export (paperwork, port trucking, vessel load) │
└─────────────────────────────────────────────────────────┘
│ handoff at "vessel loaded"
┌────────────────────────┴────────────────────────────────┐
│ Partner responsibility │
│ • Dealer identity, KYC, account management │
│ • Ocean freight booking │
│ • Destination customs clearance │
│ • Local delivery to dealer │
│ • Pushing post-shipped status back to LMN │
└─────────────────────────────────────────────────────────┘
Versioning
/v1/ is the major-version prefix. Breaking changes increment to /v2/ with a 90-day deprecation window where both versions are served. Non-breaking additions (new optional fields, new endpoints) ship in v1 without notice.
Sandbox
Base URL: https://sandbox-api.lmnauto.com/v1/.
- Synthetic vehicles + canned order flows.
- Lifecycle accelerated (proceed → secured in minutes instead of hours) for end-to-end testing.
- Data resets weekly (Sunday 00:00 KST).
- Best-effort SLAs; no production guarantees.
SDK & OpenAPI
OpenAPI 3.1 spec available at GET /v1/openapi.json. Generate clients via openapi-generator or any compatible tool.