Unified shipment tracking data from FedEx, UPS, and USPS APIs.
FedEx: Track API 1.0.0 (https://apis.fedex.com/track/v1)
UPS: Track API v1 (https://onlinetools.ups.com/api/track/v1)
USPS: Package Tracking and Notification 3.2.1 (https://api.usps.com/tracking/v3/tracking)
$ npm install ts-shipment-tracking
Courier API credentials are stored using dotenv. If you do not have dotenv installed:
$ npm install dotenv
Copy the contents of .env.template into your .env
file and fill it out.
Example input:
import "dotenv/config";
import { track, TrackingInfo } from "ts-shipment-tracking";
(async () => {
// With automatic courier detection
try {
const tragnostic: TrackingInfo = await track("<any_tracking_number>");
console.log(tragnostic);
} catch (err) {
console.log((err as Error).message);
}
// With explicitly specified courier
try {
const tracking: TrackingInfo = await track(
"<ups_tracking_number>",
// Supports autocomplete!
{ courierCode: "ups" }
);
console.log(tracking);
} catch (err) {
console.log((err as Error).message);
}
})();
Example output:
{
events: [
{
status: 'IN_TRANSIT',
label: 'Arrived at FedEx location',
location: 'LEBANON TN US 37090',
time: 1616823540000
},
// ...
],
estimatedDeliveryTime: 1616996340000
}
All statuses:
export enum TrackingStatus {
LABEL_CREATED = "LABEL_CREATED",
IN_TRANSIT = "IN_TRANSIT",
OUT_FOR_DELIVERY = "OUT_FOR_DELIVERY",
DELIVERY_ATTEMPTED = "DELIVERY_ATTEMPTED",
RETURNED_TO_SENDER = "RETURNED_TO_SENDER",
EXCEPTION = "EXCEPTION",
DELIVERED = "DELIVERED",
}
API environment is determined by process.env.NODE_ENV
("development" or "production"). It can be overridden like so:
await track("<tracking_number>", { env: myProductionFlag ? "production" : "development" });
Thanks to @rjbrooksjr's TS Tracking Number module being used for tracking number validation and courier detection.
Thanks to @hautelook's Shipment Tracking repo used as a reference for some gaps in courier status codes as well as inspiration for architecture.