USPS API Docs
Empower Your Dev Team with the USPS Tracking API via AfterShip.
Integrate seamless USPS tracking integration with robust RESTful API and webhooks to automate USPS delivery updates in real-time.
With an AfterShip developer account, you'll experience fast tracking updates and industry-leading 99.9% API uptime. Enhance your logistics now with the USPS Tracking API.
curl --request GET \
--url https://api.aftership.com/tracking/2024-04/trackings/id \
--header 'Content-Type: application/json'
09:56 AM
192 Glenlake CourtSee more info
USPS Tracking API
Create a tracking
Creates a new tracking object.
Parameters
tracking_number
string required
Tracking number of a shipment. Duplicated tracking numbers, tracking numbers with invalid tracking number format will not be accepted.
Only accept tracking numbers with length from 4 to 100slug
string, staticusps
.title
string
By default this field shows thetracking_number
, but you can customize it as you wish with any info (e.g. the order number).order_id
string
A globally-unique identifier for the order.order_promised_delivery_date
string
The promised delivery date of the order. It uses the formatYYYY-MM-DD
. This has no timezone and uses whatever date you provide. Since other EDDs use the shipment recipient’s timezone, we suggest following the same logic here.
Returns
Return a tracking object if the call succeeded.
curl --request POST \
--url https://api.aftership.com/tracking/2024-04/trackings \
--header 'Content-Type: application/json'\
--data '{"tracking":{"slug":"usps","title":"Title Name","smses":["+18555072509","+18555072501"],"emails":["email@yourdomain.com","another_email@yourdomain.com"],"order_id":"ID 1234","language":"en","pickup_note":"Reach out to our staffs when you arrive our stores for shipment pickup","origin_city":"Beijing","order_number":"1234","origin_state":"Beijing","order_id_path":"http://www.aftership.com/order_id=1234","custom_fields":{"product_name":"iPhone Case","product_price":"USD19.99"},"delivery_type":"pickup_at_store","tracking_number":"123456789","pickup_location":"Flagship Store","destination_city":"New York City","destination_state":"New York","origin_postal_code":"065001","origin_country_iso3":"CHN","origin_raw_location":"Lihong Gardon 4A 2301, Chaoyang District, Beijing, BJ, 065001, CHN, China","destination_postal_code":"10001","destination_country_iso3":"USA","destination_raw_location":"13th Street, New York, NY, 10011, USA, United States","order_promised_delivery_date":"2019-05-20"}}'
{
"meta": {
"code": 201
},
"data": {
"tracking": {
"id": "5b766a5cc7c33c0e007de3c9",
"ios": [],
"tag": "Pending",
"slug": "usps",
"note": "test note",
"smses": [],
"title": "1111111111111",
"active": true,
"emails": [],
"source": "api",
"subtag": "Pending_001",
"android": [],
"order_id": "123",
"language": null,
"signed_by": "John Doe",
"created_at": "2018-08-17T06:25:32+00:00",
"updated_at": "2018-08-17T06:25:32+00:00",
"order_date": "2021-07-26T11:23:51-05:00",
"order_tags": [],
"checkpoints": [],
"pickup_note": "Contact shop keepers when you arrive our stores for shipment pickup",
"unique_token": "deprecated",
"tracking_key": null,
"custom_fields": null,
"customer_name": "John doe",
"delivery_time": 0,
"order_id_path": "/123",
"shipment_type": "{shipment_type}",
"tracked_count": 0,
"delivery_type": "pickup_at_store",
"subtag_message": "Pending",
"tracking_state": null,
"on_time_status": "trending-on-time",
"last_updated_at": "2018-08-17T06:25:32+00:00",
"tracking_number": "1111111111111",
"shipment_weight": 1,
"pickup_location": "Flagship Store",
"subscribed_smses": [],
"return_to_sender": false,
"expected_delivery": "2018-08-16",
"subscribed_emails": [],
"tracking_ship_date": null,
"first_attempted_at": "2018-08-16",
"on_time_difference": 0,
"origin_country_iso3": "USD",
"shipment_pickup_date": "2018-08-16",
"shipment_weight_unit": "kg",
"tracking_postal_code": null,
"courier_tracking_link": "{courier_tracking_link}",
"courier_redirect_link": "{courier_redirect_link}",
"shipment_package_count": 0,
"shipment_delivery_date": "2018-08-16",
"tracking_account_number": null,
"tracking_origin_country": null,
"destination_country_iso3": "USA",
"last_mile_tracking_supported": false,
"tracking_destination_country": null,
"order_promised_delivery_date": "2019-05-20",
"courier_destination_country_iso3": "USA",
"aftership_estimated_delivery_date": null
}
}
}
Retrieve a tracking
Retrieves the details of an existing tracking. Supply the unique tracking ID from either a tracking creation request or the tracking list, and AfterShip will return the corresponding tracking information.
Parameters
fields
string
List of fields to include in the response. Use comma for multiple values. Fields to include:tracking_postal_code
,tracking_ship_date
,tracking_account_number
,tracking_key
,tracking_origin_country
,tracking_destination_country
,tracking_state
,title
,order_id
,tag
,checkpoints
lang
string
Translate checkpoint messages from the carrier’s provided language to the target language.
Returns
Returns a tracking object if a valid identifier was provided.
curl --request GET \
--url https://api.aftership.com/tracking/2024-04/trackings/id \
--header 'Content-Type: application/json'
{
"meta": {
"code": 200
},
"data": {
"tracking": {
"id": "5b7658cec7c33c0e007de3c5",
"ios": [],
"tag": "Delivered",
"slug": "usps",
"note": null,
"smses": [],
"title": "Title Name",
"active": false,
"emails": [],
"source": "api",
"subtag": "Delivered_001",
"android": [],
"order_id": null,
"language": null,
"signed_by": "..KOSUTOKO",
"created_at": "2018-08-17T05:10:38+00:00",
"updated_at": "2018-08-17T05:10:46+00:00",
"order_tags": [],
"checkpoints": [
{
"slug": "usps",
"city": null,
"created_at": "2018-08-17T05:10:41+00:00",
"location": null,
"country_name": null,
"message": "Shipment information sent to USPS",
"country_iso3": null,
"tag": "InfoReceived",
"subtag": "InfoReceived_001",
"subtag_message": "Info Received",
"checkpoint_time": "2018-07-23T01:21:39-05:00",
"coordinates": [],
"state": null,
"zip": null,
"raw_tag": "FPX_L_RPIF"
}
],
"pickup_note": null,
"order_number": "1234",
"unique_token": "deprecated",
"tracking_key": null,
"custom_fields": null,
"customer_name": null,
"delivery_time": 2,
"order_id_path": null,
"shipment_type": "{shipment_type}",
"tracked_count": 1,
"delivery_type": "pickup_at_store",
"subtag_message": "Delivered",
"tracking_state": null,
"on_time_status": "trending-on-time",
"last_updated_at": "2018-08-17T05:10:46+00:00",
"tracking_number": "111111111111",
"shipment_weight": 4,
"pickup_location": "Flagship Store",
"subscribed_smses": [],
"return_to_sender": false,
"expected_delivery": null,
"subscribed_emails": [],
"tracking_ship_date": null,
"first_attempted_at": "2018-07-25T10:10:00+09:00",
"on_time_difference": 0,
"origin_country_iso3": "CHN",
"shipment_pickup_date": "2018-07-23T08:58:00",
"shipment_weight_unit": "kg",
"tracking_postal_code": null,
"courier_tracking_link": "{courier_tracking_link}",
"courier_redirect_link": "{courier_redirect_linkGet tracking results of a single tracking.}",
"shipment_package_count": 1,
"shipment_delivery_date": "2018-07-25T01:10:00",
"tracking_account_number": null,
"tracking_origin_country": null,
"destination_country_iso3": "JPN",
"last_mile_tracking_supported": null,
"tracking_destination_country": null,
"order_promised_delivery_date": "2019-05-02",
"courier_destination_country_iso3": "JPN",
"aftership_estimated_delivery_date": {
"confidence_score": null,
"estimated_delivery_date": "2022-01-03",
"estimated_delivery_date_min": "2022-01-01",
"estimated_delivery_date_max": "2022-01-06"
}
}
}
}
Update a tracking
Updates the specific tracking by setting the values of the parameters passed. Any parameters not provided will be left unchanged.
Parameters
smses
array[string]
The phone number(s) to receive sms notifications. Input [] to clear the value of this field. Supports up to 3 phone numbers.emails
array[string]
Email address(es) to receive email notifications. Input [] to clear the value of this field. Supports up to 3 email addresses.title
string
By default this field shows the tracking_number, but you can customize it as you wish with any info (e.g. the order number).customer_name
string
Customer name of the tracking.order_id
string
A globally-unique identifier for the order.order_id_path
string
The URL for the order in your system or store.note
string
Text field for the note. Input""
to clear the value of this field.language
string
The recipient’s language. If you set up AfterShip notifications in different languages, we use this to send the recipient tracking updates in their preferred language. Use an ISO 639-1 Language Code to specify the language.order_promised_delivery_date
string
The promised delivery date of the order. It uses the format YYYY-MM-DD. This has no timezone and uses whatever date you provide. Since other EDDs use the shipment recipient’s timezone, we suggest following the same logic here.
Returns
Returns the tracking object if the update succeeded.
curl --request PUT \
--url https://api.aftership.com/tracking/2024-04/trackings/id \
--header 'Content-Type: application/json'\
--data '{"value":{"tracking":{"note":"some notes","title":"New Title"}}}'
{
"value": {
"meta": {
"code": 200
},
"data": {
"tracking": {
"id": "5b7658cec7c33c0e007de3c5",
"ios": [],
"tag": "Delivered",
"slug": "usps",
"note": null,
"smses": [],
"title": "Title Name",
"active": false,
"emails": [],
"source": "api",
"subtag": "Delivered_001",
"android": [],
"order_id": null,
"language": null,
"signed_by": "..KOSUTOKO",
"created_at": "2018-08-17T05:10:38+00:00",
"updated_at": "2018-08-17T05:10:46+00:00",
"order_tags": [],
"checkpoints": [
{
"slug": "usps",
"city": null,
"created_at": "2018-08-17T05:10:41+00:00",
"location": null,
"country_name": null,
"message": "Shipment information sent to USPS",
"country_iso3": null,
"tag": "InfoReceived",
"subtag": "InfoReceived_001",
"subtag_message": "Info Received",
"checkpoint_time": "2018-07-23T01:21:39-05:00",
"coordinates": [],
"state": null,
"zip": null,
"raw_tag": "FPX_L_RPIF"
}
],
"pickup_note": null,
"unique_token": "deprecated",
"tracking_key": null,
"custom_fields": null,
"customer_name": null,
"delivery_time": 2,
"order_id_path": null,
"shipment_type": "{shipment_type}",
"tracked_count": 1,
"delivery_type": "pickup_at_store",
"subtag_message": "Delivered",
"tracking_state": null,
"on_time_status": "trending-on-time",
"last_updated_at": "2018-08-17T05:10:46+00:00",
"tracking_number": "111111111111",
"shipment_weight": 4,
"pickup_location": "Flagship Store",
"subscribed_smses": [],
"return_to_sender": false,
"expected_delivery": null,
"subscribed_emails": [],
"tracking_ship_date": null,
"first_attempted_at": "2018-07-25T10:10:00+09:00",
"on_time_difference": 0,
"origin_country_iso3": "CHN",
"shipment_pickup_date": "2018-07-23T08:58:00",
"shipment_weight_unit": "kg",
"tracking_postal_code": null,
"courier_tracking_link": "{courier_tracking_link}",
"courier_redirect_link": "{courier_redirect_link}",
"shipment_package_count": 1,
"shipment_delivery_date": "2018-07-25T01:10:00",
"tracking_account_number": null,
"tracking_origin_country": null,
"destination_country_iso3": "JPN",
"last_mile_tracking_supported": null,
"tracking_destination_country": null,
"order_promised_delivery_date": "2019-05-02",
"courier_destination_country_iso3": "JPN",
"aftership_estimated_delivery_date": {
"confidence_score": null,
"estimated_delivery_date": "2022-01-03",
"estimated_delivery_date_min": "2022-01-01",
"estimated_delivery_date_max": "2022-01-06"
}
}
}
}
}
Delete a tracking
Delete a tracking.
Parameters
id
string required
Tracking ID
Returns
Returns a deleted object on success. Otherwise, this call raises an error.
curl --request DELETE \
--url https://api.aftership.com/tracking/2024-04/trackings/id \
--header 'Content-Type: application/json'
{
"value": {
"meta": {
"code": 200
},
"data": {
"tracking": {
"id": "5b7658cec7c33c0e007de3c5",
"slug": "usps",
"tracking_key": null,
"tracking_state": null,
"tracking_number": "772857780801111",
"tracking_ship_date": null,
"tracking_postal_code": null,
"tracking_account_number": null,
"tracking_origin_country": null,
"tracking_destination_country": null
}
}
}
}
Retrack an expired tracking
Retrack an expired tracking. Max 3 times per tracking.
Parameters
id
string, required
Tracking ID
Returns
Returns the tracking object if the retrack succeeded.
curl --request POST \
--url https://api.aftership.com/tracking/2024-04/trackings/id/retrack \
--header 'Content-Type: application/json'
{
"meta": {
"code": 200,
"type": "BadRequest",
"message": "string"
},
"data": {
"tracking": {
"id": "string",
"slug": "string",
"active": true,
"tracking_key": "string",
"tracking_state": "string",
"tracking_number": "string",
"tracking_ship_date": "string",
"tracking_postal_code": "string",
"tracking_account_number": "string",
"tracking_origin_country": "string",
"tracking_destination_country": "string"
}
}
}
Mark tracking as completed
Mark a tracking as completed. The tracking won't auto update until retrack it.
Parameters
reason
string required
required
One of DELIVERED
, LOST
or RETURNED_TO_SENDER
.
- Mark the tracking as completed with
DELIVERED
. The tag of the tracking will be updated to Delivered and the subtag will be updated toDelivered_001
. - Mark the tracking as completed with
LOST
. The tag of the tracking will be updated toException
and the subtag will be updated toException_013
. - Mark the tracking as completed with
RETURNED_TO_SENDER
. The tag of the tracking will be updated to Exception and the subtag will be updated toException_011
.
Allowed values: DELIVERED
LOST
RETURNED_TO_SENDER
Returns
meta
meta required
Meta data
code
integer required
meta code
Example:200
message
string
error message, only exist if the response status is not 2xxtype
string
error type, only exist if the response status is not 2xx
Allowed values:BadRequest
Unauthorized
Forbidden
NotFound
TooManyRequests
InternalError
data
object requiredtracking
Tracking
Object describes the tracking information.
curl --request POST \
--url https://api.aftership.com/tracking/2024-04/trackings/id/mark-as-completed \
--header 'Content-Type: application/json'\
--data '{"reason":{"type":"string","enum":["DELIVERED","LOST","RETURNED_TO_SENDER"],"description":"One of `DELIVERED`, `LOST` or `RETURNED_TO_SENDER`.\n\n- Mark the tracking as completed with `DELIVERED`. The tag of the tracking will be updated to `Delivered` and the subtag will be updated to `Delivered_001`.\n- Mark the tracking as completed with `LOST`. The tag of the tracking will be updated to `Exception` and the subtag will be updated to `Exception_013`.\n- Mark the tracking as completed with `RETURNED_TO_SENDER`. The tag of the tracking will be updated to `Exception` and the subtag will be updated to `Exception_011`."}}'
{
"meta": {
"code": 200,
"type": "BadRequest",
"message": "string"
},
"data": {
"tracking": {
"id": "my2uktymyz72xld1f7l3h01z",
"tag": "Delivered",
"slug": "usps",
"note": "note",
"smses": [
"+8613800138000"
],
"title": "61293150000079650811",
"active": false,
"emails": [
"example@aftership.com"
],
"source": "api",
"subtag": "Delivered_002",
"order_id": "6845a095a27a4caeb27487806f058add",
"language": "en",
"signed_by": "Steve Young",
"created_at": "2023-01-18T08:47:10+00:00",
"updated_at": "2023-01-18T17:47:10+00:00",
"order_date": "2022-01-20T15:56:12+08:00",
"order_tags": [
"Exception"
],
"origin_city": "Beijing",
"checkpoints": [
{
"created_at": "2023-01-18T08:47:10+00:00",
"slug": "usps",
"checkpoint_time": "2022-01-01T18:47:10-05:00",
"location": "13th Street, New York, NY 10011, USA, United States",
"city": "New York",
"state": "NY",
"zip": "10011",
"coordinate": null,
"country_iso3": "USA",
"country_name": "United States",
"message": "Package delivered",
"tag": "Delivered",
"subtag": "Delivered_002",
"subtag_message": "Picked up by customer",
"raw_tag": "RO",
"events": {
"code": "unable_to_deliver",
"reason": {
"code": "incorrect_missing_address"
}
}
}
],
"pickup_note": "No notes",
"location_id": "bda843ed811541fc852a8447371cf6f2",
"transit_time": 9,
"origin_state": "Beijing",
"unique_token": "Deprecated",
"tracking_key": null,
"order_number": "162654659775",
"custom_fields": {
"store_name": "my-store"
},
"customer_name": "Steve Young",
"order_id_path": "https://www.aftership.com/my-orders/6845a095a27a4caeb27487806f058add",
"shipment_type": "{shipment_type}",
"tracked_count": 13,
"delivery_type": "pickup_at_store",
"shipment_tags": [
"Returned"
],
"next_couriers": [
{
"slug": "usps",
"tracking_number": "61293150000079650811",
"source": "system"
}
],
"subtag_message": "Picked up by customer",
"on_time_status": "on-time",
"tracking_state": "CA",
"last_updated_at": "2023-01-18T17:47:10+00:00",
"tracking_number": "61293150000079650811",
"shipment_weight": 0.7,
"pickup_location": "13th Street, New York, NY 10011, USA, United States",
"shipping_method": "Local Delivery",
"destination_city": "New York City",
"subscribed_smses": [
"string"
],
"return_to_sender": false,
"carbon_emissions": {
"unit": "kg",
"value": 0.7
},
"destination_state": "New York",
"expected_delivery": "2022-01-05T12:11:11+01:00",
"subscribed_emails": [
"string"
],
"origin_postal_code": "065001",
"first_attempted_at": "2022-01-01T17:00:00-05:00",
"tracking_ship_date": "20220101",
"on_time_difference": 0,
"origin_country_iso3": "CHN",
"origin_raw_location": "Lihong Gardon 4A 2301, Chaoyang District, Beijing, BJ, 065001, CHN, China",
"shipment_pickup_date": "2022-01-21T15:00:00",
"shipment_weight_unit": "kg",
"tracking_postal_code": "90213",
"courier_tracking_link": "{courier_tracking_link}",
"courier_redirect_link": "{courier_redirect_link}",
"courier_connection_id": "8e1261bde336436abbc7cb3eee8cd707",
"signature_requirement": "signature_required",
"shipment_package_count": 1,
"shipment_delivery_date": "2022-01-29T11:23:00",
"destination_postal_code": "10001",
"tracking_account_number": null,
"tracking_origin_country": "CHN",
"destination_country_iso3": "USA",
"destination_raw_location": "13th Street, New York, NY, 10011, USA, United States",
"first_estimated_delivery": {
"type": "specific",
"source": "Carrier EDD",
"datetime": "2022-01-05T12:11:11+01:00",
"datetime_min": null,
"datetime_max": null
},
"failed_delivery_attempts": 2,
"latest_estimated_delivery": {
"type": "specific",
"source": "AfterShip EDD",
"datetime": "2022-01-05T12:11:11+01:00",
"datetime_min": null,
"datetime_max": null
},
"last_mile_tracking_supported": true,
"order_promised_delivery_date": "2022-01-01",
"tracking_destination_country": "USA",
"custom_estimated_delivery_date": {
"type": "specific",
"datetime": "2022-01-05",
"datetime_min": null,
"datetime_max": null
},
"courier_destination_country_iso3": "USA",
"aftership_estimated_delivery_date": {
"confidence_code": 10001,
"estimated_delivery_date": "2022-01-03",
"estimated_delivery_date_min": "2022-01-02",
"estimated_delivery_date_max": "2022-01-04"
}
}
}
}
USPS Last Checkpoint API
Get last checkpoint
Return the tracking information of the last checkpoint of a single tracking.
Parameters
fields
string
List of fields to include in the response. Use comma for multiple values. Fields to include:slug
,created_at
,checkpoint_time
,city
,coordinates
,country_iso3
,country_name
,message
,state
,tag
,zip
Example:city,tag
lang
string
Support Chinese to English translation forchina-ems
andchina-post
only
Example:en
Returns
meta
metacode
integer required
meta code
Example: 200message
string
error message, only exist if the response status is not 2xxtype
string
error type, only exist if the response status is not 2xx
Allowed values:BadRequest
Unauthorized
Forbidden
NotFound
TooManyRequests
InternalError
data
objectid
string
Tracking idtracking_number
string
Tracking number.slug
string usps
Unique code of courier.tag
string
Current status of tracking. (See tag definition)
Allowed values:Pending
InfoReceived
InTransit
OutForDelivery
AttemptFail
Delivered
AvailableForPickup
Exception
Expired
Example:Delivered
subtag
string
Current subtag of tracking. ([See subtag definition]subtag_message
string
Normalized tracking message. (See subtag message definition)checkpoint
Checkpoint
Object describes checkpoint information.
curl --request GET \
--url https://api.aftership.com/tracking/2024-04/last_checkpoint/tracking_id \
--header 'Content-Type: application/json'
{
"value": {
"meta": {
"code": 200
},
"data": {
"id": "5b74f4958776db0e00b6f5ed",
"tag": "Delivered",
"slug": "usps",
"subtag": "Delivered_001",
"checkpoint": {
"tag": "Delivered",
"zip": null,
"slug": "usps",
"city": "Deal",
"state": "NJ",
"subtag": "Delivered_001",
"message": "Delivered - Left at front door. Signature Service not requested.",
"raw_tag": "FPX_L_RPIF",
"created_at": "2018-08-16T03:50:47+00:00",
"coordinates": [],
"country_iso3": null,
"country_name": null,
"subtag_message": "Delivered",
"checkpoint_time": "2018-08-01T13:19:47-04:00"
},
"subtag_message": "Delivered",
"tracking_number": "111111111111"
}
}
}
USPS Estimated delivery date API
Batch predict the estimated delivery date
The estimated delivery date is provided by AfterShip, based on its AI-predictive model. You can display the EDD on the product page, cart, and order checkout page. It indicates when a customer will receive the order.
You can use AfterShip’s AI-powered predictive estimated delivery date API to provide expected delivery dates to shoppers for online orders without tracking numbers. You can get the earliest date, the latest date, and the most-likely-arrival date through our AI-predictive EDD API.
Display accurate estimated delivery dates on the product page, store cart, and order checkout page to encourage customers to check out faster and give them a better customer experience.
Contact sales to activate this feature.
Supported functionalities require:
- One
EstimatedDeliveryDate
object for one prediction result. - Maximum 5
EstimatedDeliveryDate
objects are allowed. - API call will fail if any of the requests
EstimatedDeliveryDate
objects do not meet the specification requirement.
Parameters
estimated_delivery_dates
array[EstimatedDeliveryDate] required
>= 1 items
<= 5 items
slug
stringusps
required
AfterShip's unique code of courier. Please refer to https://track.aftership.com/couriers/download.service_type_name
string or null
AfterShip’s unique code represents carrier’s shipping and delivery options. Refer to Download Link.origin_address
objectrequired
The location from where the package is picked up by the carrier to be delivered to the final destination.destination_address
objectrequired
The final destination of the customer where the delivery will be made.weight
object or null
AfterShip uses this object to calculate the total weight of the order.package_count
integer or null
The number of packages.pickup_time
string or null
The local pickup time in the origin address time zone of the package.estimated_pickup
object or null
The local pickup time of the package. Eitherpickup_time
orestimated_pickup
is required.
Returns
meta
meta requiredcode
integer required
meta codemessage
string
error message, only exist if the response status is not 2xxtype
string
error type, only exist if the response status is not 2xx
Allowed values:BadRequest
Unauthorized
Forbidden
NotFound
TooManyRequests
InternalError
- data object required
estimated_delivery_dates
array[EstimatedDeliveryDate] required
curl --request POST \
--url https://api.aftership.com/tracking/2024-04/estimated-delivery-date/predict-batch \
--header 'Content-Type: application/json'\
--data '{"estimated_delivery_dates":[{"slug":"usps","service_type_name":"{service_type_name}","origin_address":{"country":"USA","state":"WA","city":"Seattle","postal_code":"98108","raw_location":"Seattle, Washington, 98108, USA, United States"},"destination_address":{"country":"USA","state":"CA","postal_code":"92019","raw_location":"El Cajon, California, 92019, USA, United States"},"weight":{"unit":"kg","value":1},"package_count":1,"pickup_time":"2021-07-01 15:00:00"},{"slug":"usps","service_type_name":"{service_type_name}","origin_address":{"country":"USA","state":"WA","postal_code":"98108","raw_location":"Seattle, Washington, 98108, USA, United States"},"destination_address":{"country":"USA","state":"California","postal_code":"92019","raw_location":"El Cajon, California, 92019, USA, United States"},"weight":null,"package_count":null,"estimated_pickup":{"order_time":"2021-07-01 15:04:05","order_cutoff_time":"20:00:00","business_days":[1,2,3,4,5,6,7],"order_processing_time":{"unit":"day","value":0}}}]}'
{
"meta": {
"code": 200
},
"data": {
"estimated_delivery_dates": [
{
"slug": "usps",
"service_type_name": "{service_type_name}",
"origin_address": {
"country": "USA",
"state": "WA",
"postal_code": "98108",
"raw_location": "Seattle, Washington, 98108, USA, United States",
"city": null
},
"destination_address": {
"country": "USA",
"state": "CA",
"postal_code": "92019",
"raw_location": "El Cajon, California, 92019, USA, United States",
"city": null
},
"weight": {
"unit": "kg",
"value": 1
},
"package_count": 1,
"pickup_time": "2021-07-01 15:00:00",
"estimated_pickup": null,
"estimated_delivery_date": "2021-07-04",
"estimated_delivery_date_min": "2021-07-03",
"estimated_delivery_date_max": "2021-07-04"
},
{
"slug": "usps",
"service_type_name": "{service_type_name}",
"origin_address": {
"country": "USA",
"state": "WA",
"postal_code": "98108",
"raw_location": "Seattle, Washington, 98108, USA, United States",
"city": null
},
"destination_address": {
"country": "USA",
"state": "CA",
"postal_code": "92019",
"raw_location": "El Cajon, California, 92019, USA, United States",
"city": null
},
"weight": null,
"package_count": null,
"pickup_time": null,
"estimated_pickup": {
"order_time": "2021-07-01 15:04:05",
"order_cutoff_time": "20:00:00",
"business_days": [
1,
2,
3,
4,
5,
6,
7
],
"order_processing_time": {
"unit": "day",
"value": 0
},
"pickup_time": "2021-07-01 20:00:00"
},
"estimated_delivery_date": "2021-07-03",
"estimated_delivery_date_min": "2021-07-02",
"estimated_delivery_date_max": "2021-07-04"
}
]
}
}
USPS Rate API
USPS Label API
Create a label
Create a label.
Parameters
billing
Billing
Billing object: the description of billing informationpaid_by
string required
Allowed values:shipper
third_party
recipient
method
PaymentMethodAccount
PaymentMethodAccount object: the description of account information
customs
Customs
Customs object: the description of customs informationpurpose
string required
Allowed values:gift
merchandise
personal
sample
return
repair
non-merchandise
terms_of_trade
string
Allowed values:dat
ddu
ddp
dap
exw
fca
fob
cip
cif
cpt
cfr
dpu
eei
one of: AES
AES object: the description of EEI Type - aesbilling
Billing
Billing object: the description of billing informationimporter_address
Address
Address object: the description of address informationpassport
object
Passport Objectadditional_charges
array[object]
This array contains additional_charges object. Additional charge to be added to the commercial invoice of this shipment. Only applies to FedEx, DHL, UPS currently.
shipment
Shipment
Shipment object: the description of shipment informationship_from
Address required
Address object: the description of address informationship_to Address
required
Address object: the description of address informationparcels
array[Parcel] required
Parcels of shipmentreturn_to
Address
Address object: the description of address informationdelivery_instructions
string
Instructions to aid in prompt delivery of the shipment.
Return
meta
Meta
Meta data object.code
integer required
Code of Metamessage
string required
Message of Metadetails
array[Error]
Details of Metaretryable
boolean
Whether this request will be retryable or not
data
Label
Label object: the description of label objectid
string
Label IDstatus
string
Allowed values:creating
created
cancelling
cancelled
manifesting
manifested
failed
ship_date
string
tracking_numbers
array[string]
curl --request POST \
--url https://api.aftership.com/postmen/v3/labels \
--header 'Content-Type: application/json'\
--data '{"shipment":{"ship_to":{"city":"Salt Lake City","state":"UT","phone":"123456789","email":"test@test.com","street1":"230 W 200 S LBBY","country":"USA","postal_code":"84101","contact_name":"AfterShip Shipping","company_name":"AfterShip Shipping"},"parcels":[{"box_type":"custom","dimension":{"width":10,"height":10,"depth":10,"unit":"cm"},"items":[{"description":"Food Bar","quantity":1,"price":{"currency":"USD","amount":100},"item_id":"1234567","origin_country":"CHN","weight":{"unit":"kg","value":1},"sku":"imac2014","hs_code":"100630","return_reason":"too big"}],"description":"Food XS","weight":{"unit":"kg","value":1}}],"ship_from":{"city":"Salt Lake City","state":"UT","phone":"123456789","email":"test@test.com","street1":"230 W 200 S LBBY","country":"USA","postal_code":"84101","contact_name":"AfterShip Shipping","company_name":"AfterShip Shipping"}},"paper_size":"4x6","references":["refernce1"],"is_document":false,"service_type":"usps-discounted_express_mail","custom_fields":{"ship_code":"01"},"return_shipment":false,"shipper_account":{"id":"3ba41ff5-59a7-4ff0-8333-64a4375c7f21"}}'
{
"meta": {
"code": 200,
"message": "OK",
"details": []
},
"data": {
"id": "3318b97b-150f-4205-840d-a6d966b9e0ea",
"rate": {
"total_charge": {
"amount": 0,
"currency": "USD"
},
"service_type": "{service_type}",
"service_name": "{service_name}",
"transit_time": null,
"info_message": null,
"charge_weight": {
"unit": "lb",
"value": 3.307
},
"delivery_date": null,
"error_message": null,
"shipper_account": {
"id": "00000000-0000-0000-0000-000000000000",
"slug": "usps",
"description": "USPS Sandbox"
},
"pickup_deadline": null,
"booking_cut_off": null,
"detailed_charges": []
},
"files": {
"label": {
"url": "https://sandbox-download.postmen.com/label/2015-11-27/00000000-0000-0000-0000-000000000000-1441785264309885.pdf",
"file_type": "pdf",
"paper_size": "4x8"
},
"invoice": null,
"manifest": null,
"customs_declaration": null
},
"status": "created",
"ship_date": "2022-09-09",
"created_at": "2022-05-09T07:54:13.024Z",
"updated_at": "2022-09-09T07:54:24.569Z",
"tracking_numbers": [
"3884930103"
]
},
"custom_fields": {
"ship_code": "01"
}
}
Get a label
Get a label.
Parameters
id
string required
label id
Returns
meta
Meta
Meta data object.code
integer required
Code of Metamessage
string required
Message of Metadetails
array[Error]
Details of Metaretryable
boolean
Whether this request will be retryable or not
data
Label
Label object: the description of label objectid
string
Label IDstatus
string
Allowed values:creating
created
cancelling
cancelled
manifesting
manifested
failed
curl --request GET \
--url https://api.aftership.com/postmen/v3/labels/id \
--header 'Content-Type: application/json'
{
"meta": {
"code": 200,
"type": "OK",
"message": "Everything worked as expected."
},
"data": {
"id": "3318b97b-150f-4205-840d-a6d966b9e0ea",
"rate": {
"total_charge": {
"amount": 0,
"currency": "USD"
},
"service_type": "{service_type}",
"service_name": "{service_name}",
"transit_time": null,
"info_message": null,
"charge_weight": {
"unit": "lb",
"value": 3.307
},
"delivery_date": null,
"error_message": null,
"shipper_account": {
"id": "00000000-0000-0000-0000-000000000000",
"slug": "usps",
"description": "USPS Sandbox"
},
"pickup_deadline": null,
"booking_cut_off": null,
"detailed_charges": []
},
"files": {
"label": {
"url": "https://sandbox-download.postmen.com/label/2015-11-27/00000000-0000-0000-0000-000000000000-1441785264309885.pdf",
"file_type": "pdf",
"paper_size": "4x8"
},
"invoice": null,
"manifest": null,
"customs_declaration": null
},
"status": "created",
"ship_date": "2015-09-09",
"created_at": "2015-09-09T07:54:13.024Z",
"updated_at": "2015-09-09T07:54:24.569Z",
"tracking_numbers": [
"3884930103"
]
}
}
USPS Manifest API
USPS Cancel Label API
USPS Pickup API
USPS Cancel Pickup API
USPS Shipper Account API
USPS Address Validation (Beta) API
Frequently Asked Questions
How to generate USPS API key?
To ensure secure access, AfterShip requires an as-api-key in the header of each request. You can request a free API key by submitting the form. Get a free API Key
Do I need a USPS developer account to use this API?
No, you don't need a USPS account. AfterShip has partnered with USPS, allowing you direct access to USPS tracking data through the AfterShip API.
Enhance the entire post-purchase experience with AfterShip
Integrate USPS and Multi-Carrier Tracking APIs
Easily integrate shipment tracking into your system or website for a seamless tracking experience. AfterShip's tracking API allows you to offer shipment visibility across multiple touchpoints without stretching your development resources.- Global coverage: 1,100+ carrier integrations and 52+ languages
- Accuracy: Normalized data and standardized 7 main-statuses and 33 sub-statuses
- Data integrity: AI helps recognize new tracking number patterns
- Uptime & Reliability: 99.99%+ uptime, ISO 27001, SOC2, and GDPR compliance