Documentation
Feedback
Guides
API Reference

Guides
Logistics
VTEX Shipping Network
VTEX Shipping Network Labels Integration

This feature is in beta, which means that we are working to improve it. If you have any questions, please contact our Support.

VTEX Shipping Network is the solution that uses order tracking data directly from carriers to keep merchants and shoppers up to date with the status of each delivery.

Overview

The VTEX Shipping Network module is responsible for integrating your store with carriers via a defined protocol. The integration is divided into three workflows:

  1. Notification
  2. Tracking
  3. Shipping label creation

A Package created in the VTEX Shipping Network module (SPN) has the following lifecycle, including these workflows:

  1. The cycle begins when an order is invoiced in the OMS module, which results in SPN creating all of its packages. The new packages will have an Invoiced status.
  2. The Carrier App will then receive a notification request for all packages, and their status will move to carrier_notified.
  3. All packages can now have their associated Shipping Label created. Once each label is successfully created, its associated package status moves to label_issued.
  4. Tagged by its Shipping Label, the package can now be delivered, and while it is in transit, the SPN module requests the Carrier App for tracking updates until the package is tagged as Delivered.

The Package lifecycle ends when it is delivered.

{"base64":"  ","img":{"width":3334,"height":1508,"type":"png","mime":"image/png","wUnits":"px","hUnits":"px","length":166432,"url":"https://raw.githubusercontent.com/vtexdocs/dev-portal-content/main/docs/guides/Fulfillment/vtex-shipping-network/vtex_shipping_network_label_diagram.png"}}

Integration

The endpoint described in this document is responsible for creating the Shipping Labels of all the packages associated with an order. Given an orderId, it will provide an URL that when accessed downloads a pdf file containing the Shipping Labels.

The URL returned by the API is valid for 5 days from the moment it was requested, and expires after that period. If the file is required after the link has expired, only a new request with the same orderId will provide a new valid URL.

Be aware that VTEX Shipping Network only keeps track of Fulfillment orders, therefore, the orderId used on the endpoint must have their origin as Fulfillment. All Fulfillment Orders contain a prefix, for example:

  • Order with prefix: 00-1307463503290-01
  • Order without prefix: 1307463503290-01

The order origin can be found using the Orders API documentation. If the order has other origins rather than Fulfillment, the Order.sellerOrderId field should be used, as it references the Fulfillment Order.

Endpoint

Order with Fulfillment origin:

POST - https://api.vtex.com/api/transportation/deliverylabels/{orderId}

Order with another origin:

POST - https://api.vtex.com/api/transportation/deliverylabels/{sellerOrderId}

The authentication headers must be used to call this endpoint:

  • X-VTEX-API-AppKey
  • X-VTEX-API-AppToken

To use the endpoint, the appKey and appToken must have TransportationViewer or TransportationAdmin License Manager resources and roles associated with them.

Example cURL request


_10
curl --location --request POST 'https://api.vtex.com/api/transportation/deliverylabels/{{orderId}}?an={{accountName}}' \
_10
--header 'X-VTEX-API-AppToken: {{token}}' \
_10
--header 'X-VTEX-API-AppKey: {{appKey}}'

Responses

The successful response has the following format:

  • Status code: 200 (OK)
  • Response body:

_10
{
_10
"url" : "www.labelexampledownload.com"
_10
}

This endpoint can return other status codes in the following scenarios:

CodeMessageDescription
400Package {packageId} has an invalid state!One or more packages associated with the orderId have an invalid status. This might happen if the carrier app has not been notified about the package yet. Retry the operation in a few minutes.
401UnauthorizedAuthentication credentials are missing. Make sure to include the headers X-VTEX-API-AppToken and X-VTEX-API-AppKey.
403reason: User does not have access to the resources [TransportationAdmin]Forbidden response status code indicates that the request has not been completed because it lacks valid authentication credentials for the requested resource. In this case, the header values X-VTEX-API-AppToken or X-VTEX-API-AppKey are invalid.
404Not FoundThe orderId provided does not belong to any existing order. This might happen if the orderId does not contain the correct prefix.
500Internal Server ErrorUnexpected error.

Configuring shipping labels printing format

In the VTEX Admin, you can configure the shipping labels printing format as a A4 (297x210mm) or a ZPL (Zebra Programming Language) extension. You will find the instructions in our Help Center article Pronto para envio.

Contributors
2
Photo of the contributor
Photo of the contributor
+ 2 contributors
Was this helpful?
Yes
No
Suggest edits (Github)
Contributors
2
Photo of the contributor
Photo of the contributor
+ 2 contributors
On this page