Documentation Index
Fetch the complete documentation index at: https://terminal49.com/docs/llms.txt
Use this file to discover all available pages before exploring further.
This page contains updates to Terminal49 API and DataSync only (not
general product updates).
May 4, 2026
APIDashboard
Global vessel map, custom field search, sensitive custom fields, expanded terminal coverage, and bug fixes
Global vessel map
The Terminal49 dashboard now includes a global vessel map showing live positions for vessels carrying your shipments. Click any vessel to see its current voyage, route, and the shipments on board. The map streams updates over a websocket connection so positions stay current without manual refresh.Search by custom field values
Shipments and containers can now be searched by custom field values alongside built-in identifiers. Use the same search you already use for container numbers or PO numbers to find records by any custom field you’ve defined.Custom Field Definitions
Custom Fields API reference
Sensitive custom fields
Custom field definitions now support asensitive flag. Mark a field as sensitive to restrict its visibility to authorized users — useful for fields containing internal references, financial data, or PII.Configurable duplicate document handling
Accounts can now configure how duplicate documents are handled at upload time. Choose whether to reject duplicates, replace the existing document, or accept both, so document intake matches your team’s workflow.Document processing guide
How document linking works
xlsm spreadsheet support
Macro-enabled Excel files (.xlsm) are now accepted by the document upload pipeline and converted to CSV for reference extraction. Previously only .xls and .xlsx were processed; mixed Excel uploads now flow through end-to-end without manual conversion.Destination ETA for non-US/CA containers without rail data
Containers routed to inland destinations outside the US and Canada now return a destination ETA even when no rail tracking data is available, expanding ETA coverage for international inland moves.Container API reference
View the container resource
New terminal scrapers
- Felixstowe — added a mobile-site-based scraper as an alternative data source, improving reliability for containers moving through Felixstowe
- DP World Vancouver (3380) — added a public-API scraper for terminal data at DP World Vancouver
Promo codes and coupon links for Pay-As-You-Go checkout
Pay-As-You-Go customers can now enter a promo code at Stripe Checkout, or follow a coupon link that pre-applies the discount during signup.Bug fixes
- YMLU transshipment events — Fixed spurious full-out events generated at transshipment ports and corrected port-of-discharge mismatches for YMLU shipments
- MSC inland voyage numbers — Stabilized voyage number assignment for MSC inland feeder and barge legs so the same leg no longer appears under different voyage numbers across updates
- ONE event timestamps — Rail unloaded and other ONE events now use port-local time consistently, fixing display and ordering issues for ONE-tracked containers
- Bulk email CSV uploads — Fixed an issue where rows using alternative SCACs were silently dropped from CSVs submitted by email
- Rail carrier lookup — Rail carrier resolution now considers neighboring ports, improving carrier assignment for containers transferring between adjacent rail-served facilities
- Tideworks terminal sessions — A 403 on the CSV endpoint now clears the cached session immediately, preventing a cascade of failed terminal lookups across containers
- Steamship tracker reliability — Proxy and firewall blocks at carrier websites are now classified as
TrackerBlockederrors, surfacing a clearer failure reason and enabling targeted retries - POMTOC (L239) — Routed POMTOC Tideworks requests through a residential proxy and added required Referer/Origin headers to restore data collection
- Free plan container limits — Free plan accounts now meter against active container concurrency rather than monthly cumulative counts, so picked-up and delivered containers no longer count toward the limit
- Duplicate tags — Eliminated a race condition that could cause duplicate tag creation to fail with a unique constraint error
- Postmark email intake — Recipient email lookups are now case-insensitive, fixing missed matches on inbound document emails
- Pay-As-You-Go cancellation — Fixed handling of Stripe subscription period dates so the cancel response returns accurate end-of-period timing for newer subscription structures
- Daily digest jobs — Database errors during daily digest delivery now release the cache lock cleanly so the next run can proceed
April 27, 2026
APIDashboard
Booking number type inference, delivered date filter, document fuzzy search, hold descriptions, and bug fixes
Booking number support in Infer Tracking Number
The Infer Tracking Number endpoint now predicts the carrier and number type for booking numbers, in addition to container numbers and bills of lading. Send a booking number you aren’t sure how to route, and Terminal49 returns a confidence-scored decision so you can create the tracking request with the correct VOCC SCAC andrequest_type.Infer Tracking Number guide
How to use Infer Tracking Number in your workflow
Delivered date filter and column on the container dashboard
The container dashboard now includes a Delivered at column and date-range filter, plus delivered-date sorting. Quickly find recently delivered containers, sort by delivery date, or filter to a specific window for reporting and reconciliation.Fuzzy search for documents
Document search is now fuzzy across shipment, container, and tracking request reference numbers. Minor typos, format differences, or partial reference numbers still return the right document, reducing time spent hunting for paperwork.Hold descriptions on container holds
Each hold returned on a container now includes a plain-language description explaining what the hold means and what’s typically required to clear it. The descriptions are surfaced wherever holds appear so your team — and your customers — can act without looking up terminology.Holds and fees guide
How to work with holds and fees data
Reference number flag on custom field definitions
Custom field definitions now support areference_number flag. Mark a custom field as a reference number and Terminal49 will treat its value as a searchable identifier alongside built-in references like PO numbers and BOLs.Custom Field Definitions
Custom Fields API reference
PO number normalization for document linking
Document-to-shipment linking via PO numbers now normalizes common format variants (separators, prefixes, and casing differences), so documents match shipments even when the PO is written slightly differently across systems.Bug fixes
- Containers requiring attention — Picked-up, on-rail, empty-returned, and delivered containers no longer appear under the “needs attention” LFD view. Only containers still active at a terminal show up
- Tideworks fees — Containers reported as on a vessel or on rail no longer return stale terminal fees from a previous move
- MSC Port of Discharge events — Improved criteria for selecting the correct POD arrival event on MSC shipments
- LBCT inland transfers — Fixed handling of on-dock-to-inland transfer events at LBCT, so rail moves out of the terminal are tracked correctly
- COSCO vessel departure — Improved logic for determining when a COSCO vessel has departed the port of loading
- Vessel event deduplication — Fixed duplicate vessel events on the shipment timeline coming from carriers and from the CSE invalidation pipeline
- Document linking race condition — Eliminated a race condition that could leave a document briefly unlinked when references arrived from multiple sources at once
- Webhook notifications page — Fixed an exception that could occur when listing webhook notifications containing document processing events
- Carrier integrations — Fixes to MAEU auth handling (now treats 403 correctly), APM Empty In OAuth requests, BNSF rail scraping, NSRR equipment requests, Hapag-Lloyd booking sweeps for shipments with no containers, and Voyager terminal request headers
- Terminal data — Updated headers for SSAMX and Holt agent terminals, and added external location mapping for PCIU
- Document email intake — Tightened sender-email rules so unrelated inbox messages are filtered out, and fixed an edge case where a single email recipient was not handled as an array
April 20, 2026
APIDashboard
Improved document linking, mark-as-delivered fix, LFD accuracy improvements, and terminal data fixes
Smarter document-to-shipment linking
Documents are now matched to shipments using indirect references such as purchase order (PO) numbers. Previously, a document had to contain a direct identifier like a bill of lading or container number. Now, if a document references a PO number that appears on another already-linked document, Terminal49 can connect the two — reducing unlinked documents and manual work.Document processing guide
How document linking works
Improved document extraction accuracy
Document data extraction now uses the original filename as additional context, improving field-level accuracy when the filename contains shipment identifiers or document type hints.Bug fixes
- Mark as delivered — Fixed an issue where marking a container as delivered from the dashboard event viewer could fail. User-submitted delivery events are now accepted correctly
- Stale terminal LFD dates — Fixed a bug where outdated Last Free Day dates from a previous cycle could appear on containers still in transit. Terminal LFD events are now rejected until the container arrives at the port
- MSC departure events — Corrected incorrect departure-from-POD events being reported for certain MSC containers
- Hapag-Lloyd tracking — Fixed an error that could occur when Hapag-Lloyd returns an empty shipment overview, preventing container data from loading
- Norfolk Southern rail LFD timezone — Fixed incorrect timezone parsing for Norfolk Southern rail Last Free Day dates, which could shift the date by a day
- Dashboard event viewer — Fixed display issues in the unified event viewer for user-submitted events
- Terminal data collection — Resolved connectivity and data retrieval issues at Goport, Maher, and Packer Avenue terminals, restoring terminal-sourced hold, fee, and availability data for containers at those facilities
April 14, 2026
APIDashboard
Dashboard deep linking, calculated LFD, Smart LFD dashboard columns, and bug fixes
Dashboard deep linking
You can now link directly to any shipment or container in the Terminal49 dashboard using a container number, bill of lading, booking number, or reference number — no internal IDs needed.Use the URL pattern:Deep linking guide
How to build direct links to shipments and containers
Calculated Last Free Day
The Smart LFD system now includes a calculated Last Free Day derived from carrier demurrage tariff rules. When a shipping line or terminal hasn’t reported an LFD, Terminal49 computes one using the applicable tariff — including free days, start events, holidays, and business-day rules.Calculated values appear as a fallback in theimport_deadlines field on the container API. If a reported LFD is available from the carrier or terminal, it takes priority.Container API reference
View the container resource
Smart LFD dashboard columns
The container dashboard now includes two new columns for accounts with Smart LFD enabled:- Calc. Line LFD — the calculated Last Free Day derived from carrier tariff rules
- Smart LFD — the best available LFD with its source displayed, so you can see at a glance whether the date comes from the shipping line, terminal, or a tariff calculation
Bug fixes
- Hapag-Lloyd booking tracking — Fixed an issue where certain Hapag-Lloyd bookings could return an invalid number error, preventing container data from loading
April 2026
APIDashboard
Smart Last Free Day, inland destination ETA source transparency, and bug fixes
Smart Last Free Day
The container API now returns a detailed breakdown of Last Free Day (LFD) data within theimport_deadlines field. Instead of a single date, you get separate LFD values from the shipping line and the terminal facility — at both the port of discharge and the inland destination.Each source includes:- Original — the first LFD reported
- Current — the latest LFD reported
- Calculated — a derived value when the raw date needs adjustment
Container API reference
View the container resource
Inland destination ETA source transparency
Containers now include aninland_destination_eta_source_summary field that tells you exactly where the displayed inland destination ETA comes from. Possible sources are:- Shipping line — ETA provided by the carrier
- Rail — ETA from the rail carrier
- T49 operations team — manually verified ETA
- T49 prediction engine — machine-learning-based estimate
Expanded shipping line LFD coverage
Shipping line Last Free Day data is now collected from additional SSA terminals, improving LFD accuracy for containers moving through those facilities.Container table properties
DataSync containers reference
Bug fixes
- Hapag-Lloyd booking tracking — Fixed an error that could prevent booking equipment data from being returned for Hapag-Lloyd shipments
- Dashboard copy/paste — Copy and paste keyboard shortcuts in the container dashboard no longer interfere with text input fields
- Webhook notification links — The dashboard webhook notifications page now correctly displays reference links for events with multiple related resources
March 2026
APISDKMCPDataSync
TypeScript SDK, MCP server, Custom Fields API, webhook trigger endpoint, and DataSync improvements
TypeScript SDK
Released the Terminal49 TypeScript SDK (@terminal49/sdk), a typed client for Node.js 18+ with built-in retry logic, error handling, and JSON:API deserialization.- Track containers, retrieve shipments, and manage tracking requests with type-safe methods
- Automatic retry with exponential backoff for rate limits and server errors
- Flexible response formats: raw JSON:API, mapped objects, or both
SDK docs
Get started with the TypeScript SDK
MCP server
Launched the Terminal49 MCP server, letting you query live container and shipment data from Claude Desktop, Cursor, or any MCP-compatible AI client.- 10 tools — search, track, get container details, shipment routing, transport events, and more
- 3 prompts — pre-built workflows for tracking, demurrage analysis, and delay root cause analysis
- Connect with a single config block — no custom code required
MCP setup guide
Connect your AI client to Terminal49
Custom Fields API
You can now create and manage custom fields on shipments and containers via the API. Define your own field schemas (text, number, date, single-select, multi-select), create option lists, and attach values to individual shipments or containers.- Custom Field Definitions — create, update, list, and delete field schemas scoped to shipments or containers
- Custom Field Options — manage allowed values for select-type fields
- Custom Fields — assign values to specific shipments or containers
Custom Field Definitions
View the Custom Fields API reference
Webhook trigger endpoint
AddedPOST /webhooks/trigger to send a one-time test webhook delivery to any HTTPS URL — without creating a webhook endpoint first. Use it to validate your webhook handler before going live.Trigger a webhook
API reference for the trigger endpoint
DataSync improvements
- Shipping line Last Free Day — new
ssl_last_free_day_onandssl_last_free_day_on_localcolumns on both thecontainersandcontainers_railtables, so you can distinguish the shipping line’s LFD from the terminal’s LFD - Pending hold status — individual hold columns (
freight_hold,customs_hold,usda_hold,tmf_hold,other_hold) now support a"Pending"value in addition to"Hold"and blank, giving you earlier visibility into holds before they become active
Container table properties
DataSync containers reference
Holds and fees guide
How to work with holds and fees data
Container Holds, Fees, and Release Readiness
Published a comprehensive guide for working with holds and fees data in the Terminal49 API. The guide covers:- Pickup readiness logic — a decision flowchart and code example showing how to combine
available_for_pickupwithholds_at_pod_terminalto determine if a container can be picked up - Hold and fee enum references — quick-reference tables for all hold names and fee types, with expandable details for each value
- Webhook changeset examples — how to subscribe to
container.updatedand react to hold/fee changes in real time - Rail and inland destinations — clarification that the same fields apply at inland rail terminals, not just the port of discharge
- FAQ — answers to common integration questions like double-counting fees, sync lag between holds and availability, and case-sensitive hold names
Read the guide
Container Holds, Fees, and Release Readiness
Infer Tracking Number (Beta)
Added the Infer Tracking Number endpoint to help you predict:- The VOCC SCAC to use for tracking
- The number type (container, bill of lading, booking)
- A confidence-driven decision (
auto_select,needs_confirmation,no_prediction)
API Reference
Infer Tracking Number endpoint details
Guide
How to use Infer Tracking Number in your workflow