This sketch cannot currently be displayed in exports
All API access is over HTTPS and accessed from https://api.pickingnpacking.com
. All data is sent and received as JSON.
Blank fields are included as null
instead of being omitted.
All timestamps returned in UTC, ISO 8601 format: YYYY-MM-DDTHH:mm:ss.sssZ
.
All distance measurements are in meters.
To generate the JWT
it is important to have the API KEY
previously generated by the Pick and Pack team.
Create a token of authentication with this endpoint /token Send in the headers of the request Authorization
with the JWT generated in step 1.
{
"Authorization" : "JWT"
}
Endpoints are configurable when creating the carrier configuration
This is the information that VTEX will send to the carrier to create a service
: Carrier configuration
Carrier configuration
Carrier configuration
Carrier configuration
Schema
{
orderId : String !
carrierId : String !
seller : String !
sender : {
name : String
phone : String
email : String
city : String !
state : String !
country : String !
address : String !
neighborhood : String
number : String
reference : String
addressComplement : String
location : {
latitude : Float
longitude : Float
}
pickupDate : AWSDateTime !
deliveryWindow : {
name : String
initialDate : AWSDateTime
finalDate : AWSDateTime
}
zipCode : String !
} !
receiver : {
name : String !
phone : String
email : String
city : String !
state : String !
country : String !
address : String !
neighborhood : String
number : String
reference : String
addressComplement : String
location : {
latitude : Float
longitude : Float
}
identification : String
deliveryDate : AWSDateTime !
deliveryWindow : {
name : String
initialDate : AWSDateTime
finalDate : AWSDateTime
} ,
contactName : String
zipCode : String !
} !
packages : [
{
id : String !
orderId : String !
envelope : String
description : String
categories : [ String ]
dimensions : {
width : String
height : String
length : String
}
weight : String
totalValue : Float
items : [
{
id : String !
name : String !
ean : String !
refId : String
image : String
type : String
price : Float !
weight : String
quantity : Int !
}
]
}
]
type : PICKUP | DELIVERY | PICKUP_DELIVERY | RETURN !
carrierServiceType : NATIONAL | INTERNATIONAL | EXPRESS | SPECIALIZED | OTHERS !
comments : String
paymentMethod : ONLINE | CASH_ON_DELIVERY | PIN_PAD ! ,
settings : [
{
label : String
value : String
"key" : String
}
]
timezone : {
offset : Float !
value : String !
} !
metaData : {
carrier : {
id : String !
name : String !
image : {
content : String !
type : BASE64 | URL !
}
type : {
id : String !
name : String !
terms : String
description : String
international : Boolean
rate : {
shippingPrice : {
currency : String !
value : Float !
} !
insurancePrice : {
currency : String !
value : Float !
}
}
transitTime : Int
shippingEstimatedDate : AWSDateTime
metaData : AWSJSON
} !
metaData : AWSJSON
}
}
}
Example body
{
"orderId" : "SLR-29384924-01" ,
"carrierId" : "servientrega-50461c9f3335" ,
"seller" : "qaolimpica" ,
"sender" : {
"name" : "Tabitha Sears" ,
"phone" : "+57 2305781612" ,
"email" : "tabitha_sears@fortean.brother" ,
"city" : "Jenkinsville" ,
"state" : "Northern Mariana Islands" ,
"country" : "BRA" ,
"address" : "77 Sullivan Place, Jenkinsville, Northern Mariana Islands" ,
"addressComplement" : "Labore sunt laboris reprehenderit nulla cupidatat irure labore sunt dolore est." ,
"number" : "1029" ,
"reference" : "3" ,
"location" : {
"latitude" : -75.269008 ,
"longitude" : 137.499833
} ,
"pickupDate" : "2022-04-25T18:06:41.202Z"
} ,
"receiver" : {
"name" : "Pansy Graves" ,
"phone" : "+57 4240807147" ,
"email" : "pansy_graves@zentime.moda" ,
"city" : "Valle" ,
"state" : "Marshall Islands" ,
"country" : "ICE" ,
"neighborhood" : "Billings" ,
"number" : "9840" ,
"reference" : "65C"
"address" : "63 Billings Place, Valle, Marshall Islands" ,
"addressComplement" : "In excepteur in Lorem id eu et id." ,
"location" : {
"latitude" : -33.249891 ,
"longitude" : -135.052901
} ,
"identification" : "9541933267" ,
"deliveryDate" : "2022-04-16T20:49:36.117Z" ,
"contactName" : "Savannah Porter" ,
"deliveryWindow" : {
"name" : "consectetur" ,
"initialDate" : "2022-04-25T22:50:41.209Z" ,
"finalDate" : "2022-05-05T21:50:41.210Z"
}
} ,
"packages" : [
{
"id" : "6266df719ac55224b793ad36" ,
"orderId" : "SLR-1221800709659-01" ,
"envelope" : "Grande" ,
"description" : "Paquete delicado" ,
"categories" : [ "Cellphone" , "Technology" ]
"dimensions" : {
"width" : "68" ,
"height" : "43" ,
"length" : "13"
} ,
"weight" : "19" ,
"totalValue" : 5616.01 ,
"items" : [
{
"id" : "6266df71a19ebe35637e1f42" ,
"name" : "Celular nokia AD1" ,
"ean" : "473390795673" ,
"refId" : "6266" ,
"image" : "https://static9.depositphotos.com/1628352/1107/i/600/depositphotos_11071361-stock-photo-tomato.jpg" ,
"type" : "Tech" ,
"price" : 774230.01 ,
"weight" : "4 kg" ,
"quantity" : 4
} ,
{
"id" : "6266df71803601c3bc4e2d99" ,
"name" : "Celular nokia AD2" ,
"ean" : "329949764612" ,
"refId" : "6266" ,
"image" : "https://static9.depositphotos.com/1628352/1107/i/600/depositphotos_11071361-stock-photo-tomato.jpg" ,
"type" : "Tech" ,
"price" : 23162 ,
"weight" : "14 kg" ,
"quantity" : 9
}
]
}
] ,
"type" : "PICKUP_DELIVERY" ,
"carrierServiceType" : "OTHERS" ,
"comments" : "Consectetur ex dolor adipisicing proident." ,
"paymentMethod" : "CASH_ON_DELIVERY" ,
"orderValue" : 8000 ,
"settings" : [
{
"label" : "Clave secreta" ,
"value" : "jklsadjfklsjdfkajsdfkjdsfjadksfklsdfjasdjfadklsfjkljklsdf" ,
"key" : "myKey"
}
] ,
"timezone" : {
"offset" : 300 ,
"value" : "America/Bogota"
} ,
"metaData" : {
"carrier" : {
"id" : "fedex" ,
"name" : "FedEx®" ,
"image" : {
"content" : "https://assets.website-files.com/63ee4e652398f23f7f803ab4/63ee4e652398f20d5f803de3_Fedex_logo.png" ,
"type" : "URL"
} ,
"type" : {
"id" : "fedex_2_day" ,
"name" : "FedEx 2Day®" ,
"terms" : "" ,
"description" : "Delivery in 1 to 3 business days" ,
"international" : false ,
"rate" : {
"shippingPrice" : {
"currency" : "USD" ,
"value" : 20.03
} ,
"insurancePrice" : {
"currency" : "USD" ,
"value" : 1.03
}
} ,
"transitTime" : 2880 ,
"shippingEstimatedDate" : "2023-07-17T11:34:40.010Z" ,
"metaData" : { }
} ,
"metaData" : { }
}
}
}
Expected response
{
"status" : "PENDING" ,
"serviceId" : "ASDF23324KDSF2" ,
"shippingPrice" : 20000.09
"metaData" : {
"customKey1" : "customValue1" ,
"custom_key2" : "customValue2"
} ,
"shippingEstimatedDate" : "2022-05-29T22:36:37.589Z" ,
"labels" : [ {
"id" : "6d06dbd7-24c0-4189-9ff5-2c607345c615" ,
"url" : "https://www.shippo.dhl.com/34234234234.pdf" ,
"name" : "Etiqueta de envio" ,
"type" : "PDF"
} ]
}
There are a 5 seconds time space before the service creation is confirmed. After that, is possible to use any of the endpoints below.
This endpoint retrieves all rates from the carriers. This endpoint must be developed and configured in Vtex - Last Mile
: Carrier config
Carrier config
Carrier config
Carrier config
Body schema
{
orderId : String !
carrierId : String !
seller : String !
sender : {
name : String
phone : String
email : String
city : String !
state : String !
country : String !
address : String !
neighborhood : String
number : String
reference : String
addressComplement : String
location : {
latitude : Float
longitude : Float
}
pickupDate : AWSDateTime !
deliveryWindow : {
name : String
initialDate : AWSDateTime
finalDate : AWSDateTime
}
zipCode : String !
} !
receiver : {
name : String !
phone : String
email : String
city : String !
state : String !
country : String !
address : String !
neighborhood : String
number : String
reference : String
addressComplement : String
location : {
latitude : Float
longitude : Float
}
identification : String
deliveryDate : AWSDateTime !
deliveryWindow : {
name : String
initialDate : AWSDateTime
finalDate : AWSDateTime
} ,
contactName : String
zipCode : String !
} !
packages : [
{
id : String !
orderId : String !
envelope : String
description : String
categories : [ String ]
dimensions : {
width : String
height : String
length : String
}
weight : String
totalValue : Float
items : [
{
id : String !
name : String !
ean : String !
refId : String
image : String
type : String
price : Float !
weight : String
quantity : Int !
}
]
}
]
type : PICKUP | DELIVERY | PICKUP_DELIVERY | RETURN !
carrierServiceType : NATIONAL | INTERNATIONAL | EXPRESS | SPECIALIZED | OTHERS !
comments : String
paymentMethod : ONLINE | CASH_ON_DELIVERY | PIN_PAD ! ,
settings : [
{
label : String
value : String
"key" : String
}
]
timezone : {
offset : Float !
value : String !
} !
}
Body example
{
"orderId" : "SLR-29384924-01" ,
"carrierId" : "servientrega-50461c9f3335" ,
"seller" : "qaolimpica" ,
"sender" : {
"name" : "Tabitha Sears" ,
"phone" : "+57 2305781612" ,
"email" : "tabitha_sears@fortean.brother" ,
"city" : "Jenkinsville" ,
"state" : "Northern Mariana Islands" ,
"country" : "Brazil" ,
"address" : "77 Sullivan Place, Jenkinsville, Northern Mariana Islands" ,
"addressComplement" : "Labore sunt laboris reprehenderit nulla cupidatat irure labore sunt dolore est." ,
"number" : "1029" ,
"reference" : "3" ,
"location" : {
"latitude" : -75.269008 ,
"longitude" : 137.499833
} ,
"pickupDate" : "2022-04-25T18:06:41.202Z"
} ,
"receiver" : {
"name" : "Pansy Graves" ,
"phone" : "+57 4240807147" ,
"email" : "pansy_graves@zentime.moda" ,
"city" : "Valle" ,
"state" : "Marshall Islands" ,
"country" : "Iceland" ,
"neighborhood" : "Billings" ,
"number" : "9840" ,
"reference" : "65C"
"address" : "63 Billings Place, Valle, Marshall Islands" ,
"addressComplement" : "In excepteur in Lorem id eu et id." ,
"location" : {
"latitude" : -33.249891 ,
"longitude" : -135.052901
} ,
"identification" : "9541933267" ,
"deliveryDate" : "2022-04-16T20:49:36.117Z" ,
"contactName" : "Savannah Porter" ,
"deliveryWindow" : {
"name" : "consectetur" ,
"initialDate" : "2022-04-25T22:50:41.209Z" ,
"finalDate" : "2022-05-05T21:50:41.210Z"
}
} ,
"packages" : [
{
"id" : "6266df719ac55224b793ad36" ,
"orderId" : "SLR-1221800709659-01" ,
"envelope" : "Grande" ,
"description" : "Paquete delicado" ,
"categories" : [ "Cellphone" , "Technology" ]
"dimensions" : {
"width" : "68" ,
"height" : "43" ,
"length" : "13"
} ,
"weight" : "19" ,
"totalValue" : 5616.01 ,
"items" : [
{
"id" : "6266df71a19ebe35637e1f42" ,
"name" : "Celular nokia AD1" ,
"ean" : "473390795673" ,
"refId" : "6266" ,
"image" : "https://static9.depositphotos.com/1628352/1107/i/600/depositphotos_11071361-stock-photo-tomato.jpg" ,
"type" : "Tech" ,
"price" : 774230.01 ,
"weight" : "4 kg" ,
"quantity" : 4
} ,
{
"id" : "6266df71803601c3bc4e2d99" ,
"name" : "Celular nokia AD2" ,
"ean" : "329949764612" ,
"refId" : "6266" ,
"image" : "https://static9.depositphotos.com/1628352/1107/i/600/depositphotos_11071361-stock-photo-tomato.jpg" ,
"type" : "Tech" ,
"price" : 23162 ,
"weight" : "14 kg" ,
"quantity" : 9
}
]
}
] ,
"type" : "PICKUP_DELIVERY" ,
"carrierServiceType" : "OTHERS" ,
"comments" : "Consectetur ex dolor adipisicing proident." ,
"paymentMethod" : "CASH_ON_DELIVERY" ,
"settings" : [
{
"label" : "Clave secreta" ,
"value" : "keysecret-0122" ,
"key" : "secrekey"
}
] ,
"timezone" : {
"offset" : 300 ,
"value" : "America/Bogota"
}
}
Response example
{
"message" : "Request executed successfully" ,
"data" : [
{
"id" : "fedex" ,
"name" : "FedEx®" ,
"image" : {
"content" : "https://assets.website-files.com/63ee4e652398f23f7f803ab4/63ee4e652398f20d5f803de3_Fedex_logo.png" ,
"type" : "URL"
} ,
"type" : [
{
"id" : "fedex_2_day" ,
"name" : "FedEx 2Day®" ,
"terms" : "" ,
"description" : "Delivery in 1 to 3 business days" ,
"international" : false ,
"rate" : {
"shippingPrice" : {
"currency" : "USD" ,
"value" : 20.03
} ,
"insurancePrice" : {
"currency" : "USD" ,
"value" : 1.03
}
} ,
"transitTime" : 2880 ,
"shippingEstimatedDate" : "2023-07-17T11:34:40.010Z" ,
"metaData" : { }
}
] ,
"metaData" : { }
}
]
}
This endpoint retrieves all carriers from the Broker. This endpoint must be developed and configured in Vtex - Last Mile
This endpoint only applies to multi-carrier integrations such as Shipstation or Shippo.
: Carrier config
Carrier config
Carrier config
Carrier config
Body schema
{
settings : [
{
label : String !
value : String !
"key" : String !
}
] !
}
Request example
{
"settings" : [
{
"label" : "Api key" ,
"key" : "aftership-api-key" ,
"value" : "8f_XXXXXXXXX_db79"
} ,
{
"label" : "Account ID" ,
"key" : "accountId" ,
"value" : "integration-store1-XXXXXXX-dev"
} ,
{
"label" : "Access token" ,
"key" : "token" ,
"value" : "shippo_test_XXXXXXXXXXX_3797"
}
]
}
Response example
{
"message" : "Request executed successfully" ,
"data" : [
{
"id" : "fedex00012" ,
"name" : "FedEx" ,
"image" : {
"content" : "https://www.openpricer.com/wp-content/uploads/2021/10/dhl-round-logo-200x200.png" ,
"type" : "URL"
} ,
"countries" : [ "COL" , "MEX" , "ARG" ] ,
"type" : [
{
"id" : "dpd_uk_1200" ,
"name" : "Door to door 12.00 next day" ,
"international" : null
}
] ,
"metaData" : null
}
]
}
In the case that a user or the application needs to cancel a service, this will be sent to the carrier configurated endpoints
: Carrier config
Carrier config
Carrier config
Carrier config
Schema
{
serviceId : String !
carrierId : String !
reason : String ,
settings : [
{
label : String !
value : String !
"key" : String !
}
] !
metaData : AWSJSON
}
Example
{
"serviceId" : "apknieot924892jaf-1231" ,
"carrierId" : "servientrega9234jaf" ,
"settings" : [ { "label" : "Cliente ID" , "key" : "clientId" , "value" : "HUR123" } ] ,
"reason" : "La dirección de entrega esta mal registrada" ,
"metaData" : { "myFieldCustom" : "custom value" }
}
Response
{
"message" : "Service executed successfully" ,
"data" : {
"serviceId" : "apknieot924892jaf-1231" ,
"carrierId" : "servientrega9234jaf" ,
"reason" : "En el lugar de residencia no hay quien reciba el paquete"
}
}
In the case that a user or the application needs to pause/continue a service, this will be sent to the carrier configurated endpoints
: Carrier config
Carrier config
Carrier config
Carrier config
Schema
{
serviceId : String !
carrierId : String !
pause : Boolean !
reason : String ,
settings : [
{
label : String !
value : String !
"key" : String !
}
] !
metaData : AWSJSON
}
Example
{
"serviceId" : "apknieot924892jaf-1231" ,
"carrierId" : "servientrega9234jaf" ,
"settings" : [ { "label" : "Cliente ID" , "key" : "clientId" , "value" : "HUR123" } ] ,
"pause" : false ,
"reason" : "En el lugar de residencia no hay quien reciba el paquete" ,
"metaData" : { "myFieldCustom" : "custom value" }
}
Response
{
"message" : "Service executed successfully" ,
"data" : {
"serviceId" : "apknieot924892jaf-1231" ,
"carrierId" : "servientrega9234jaf" ,
"pause" : false ,
"reason" : "En el lugar de residencia no hay quien reciba el paquete"
}
}
This endpoint will allow the carriers to update an ongoing shipping service.
REST API endpoints are prefixed with the following URL:
https://api.pickingnpacking.com/dev/v1
https://api.pickingnpacking.com/prod/v1
The following endpoint returns information about a service, which can be queried by providing the carrier ID and the corresponding service ID as query parameters. The response returned by the endpoint will contain the requested information.
GET - /tracking/hook/{carrierId}/{serviceId}
Id generated by the carrier
type ServiceResponseDto {
id : ID !
orderId : String !
carrierId : String !
serviceId : String
carrierLogo : String
carrierName : String !
seller : String !
status : ServiceStatus !
labels : [ ServiceLabel ] !
trackingUrl : String
comments : String
evidences : [ ServiceEvidence ] !
packages : [ PackageService ] !
timeline : [ TrackingTimeline ] !
type : ServiceType !
notes : [ ServiceNotes ] !
paymentMethod : String
carrierServiceType : String
rate : Rate
shippingEstimatedDate : AWSDateTime
shippingFinishedDate : AWSDateTime
metaData : AWSJSON
timezone : CTimezone
tags : [ String ] !
}
enum ServiceStatus {
CREATED
PENDING
ASSIGNED
PICKED
ON_ROUTE
INCIDENT
RETURNED
DELIVERED
CANCELED
ON_HOLD
}
type ServiceLabel {
id : ID !
url : String !
name : String !
type : ServiceLabelType !
}
enum ServiceLabelType {
PDF
BASE64
TEXT
ZPL
}
type ServiceEvidence {
type : ServiceEvidenceType !
content : String
date : AWSDateTime !
author : String
}
enum ServiceEvidenceType {
TEXT
IMAGE
}
type PackageService {
id : ID !
orderId : String !
envelope : String
dimensions : ServiceDimensionsPacking
weight : String
totalValue : Float
items : [ ServiceItemsPackage ] !
categories : [ String ] !
description : String
}
type ServiceDimensionsPacking {
width : String
height : String
length : String
}
type ServiceItemsPackage {
id : ID !
name : String !
ean : String !
refId : String
image : String
type : String
price : Float !
weight : String
quantity : Int !
}
type TrackingTimeline {
id : ID !
type : TrackingTimelineType !
date : AWSDateTime !
description : String
author : String
metaData : AWSJSON
}
enum TrackingTimelineType {
STATUS
EVIDENCE
NOTE
LABEL
OTHER
}
enum ServiceType {
PICKUP
DELIVERY
PICKUP_DELIVERY
RETURN
}
type ServiceNotes {
type : ServiceNotesType !
date : AWSDateTime !
content : String !
author : String
}
enum ServiceNotesType {
COMMENT
ERROR
}
type Rate {
shippingPrice : {
value : Float !
currency : Float !
}
insurancePrice : {
value : Float !
currency : Float !
}
}
type CTimezone {
offset : Float
value : String
label : String
}
{
"message" : "success" ,
"data" : {
"id" : "d9dc0d2c-5f49-4254-ad05-5551be273a2c" ,
"orderId" : "1313160501383-01" ,
"carrierId" : "627eb3b93a19fdc0cf5fe087" ,
"serviceId" : "627eb3b93a19fdc0cf5fe087&470083180050116775042433920287" ,
"carrierName" : "Blue Express" ,
"seller" : "exito96" ,
"status" : "DELIVERED" ,
"type" : "PICKUP_DELIVERY" ,
"labels" : [ ] ,
"evidences" : [
{
"type" : "IMAGE" ,
"date" : "2023-02-27T13:25:08.538Z" ,
"content" : "https://tookan.s3.amazonaws.com/acknowledgement_images/1677504302764669967113822-470083180Signature.jpg" ,
"author" : "Juan C Testing P"
} ,
{
"type" : "IMAGE" ,
"date" : "2023-02-27T13:26:22.799Z" ,
"content" : "https://tookan.s3.amazonaws.com/acknowledgement_images/16775043776540952751646343-470083181Signature.jpg" ,
"author" : "Juan C Testing P"
}
] ,
"packages" : [
{
"id" : "1677504239859" ,
"orderId" : "1313160501383-01" ,
"envelope" : "Box" ,
"dimensions" : {
"height" : "2" ,
"length" : "2" ,
"width" : "2"
} ,
"weight" : "2" ,
"totalValue" : 40000 ,
"items" : [
{
"id" : "60" ,
"name" : "Neutrogena Hydro Boost Water Gel X 50 Gr" ,
"ean" : "EAN159" ,
"quantity" : 2 ,
"price" : 20000 ,
"refId" : "60" ,
"image" : "https://blueExpress.vteximg.com.br/arquivos/ids/155747-55-55/60.jpg?v=637917088184130000" ,
"type" : "PRODUCT" ,
"weight" : "1"
} ,
{
"id" : "59" ,
"name" : "Shampo Sin Sal + Mascarilla French Gold" ,
"ean" : "EAN158" ,
"quantity" : 2 ,
"price" : 20000 ,
"refId" : "59" ,
"image" : "https://blueExpress.vteximg.com.br/arquivos/ids/155746-55-55/59.jpg?v=637917087644630000" ,
"type" : "PRODUCT" ,
"weight" : "1"
}
] ,
"categories" : [ "Personal Care" ] ,
"description" : "-"
}
] ,
"timeline" : [
{
"id" : "d8ecc1d7-52c9-4c1f-81ee-5524a66cc276" ,
"date" : "2023-02-27T13:25:09.749Z" ,
"createdAt" : "2023-02-27T13:25:09.749Z" ,
"updatedAt" : "2023-02-27T13:25:09.749Z" ,
"type" : "STATUS" ,
"description" : "Courier on route" ,
"author" : "System" ,
"metaData" : {
"rating" : 5 ,
"totalDistanceTraveled" : 0 ,
"trackingUrl" : "https://blueExpress.northlatam.com/tracking/index.html?jobID=41903e23c5157de2a3961c05cafc6e5b" ,
"status" : "ON_ROUTE"
}
} ,
{
"id" : "27e6fe70-9a8e-4ca3-8454-d491bb1fe828" ,
"date" : "2023-02-27T13:26:22.809Z" ,
"createdAt" : "2023-02-27T13:26:22.809Z" ,
"updatedAt" : "2023-02-27T13:26:22.809Z" ,
"type" : "EVIDENCE" ,
"description" : "Added evidence" ,
"author" : "Juan C Testing P" ,
"metaData" : {
"0" : {
"type" : "IMAGE" ,
"content" : "https://tookan.s3.amazonaws.com/acknowledgement_images/16775043776540952751646343-470083181Signature.jpg" ,
"author" : "Juan C Testing P"
}
}
} ,
{
"id" : "3395c4b0-40fc-4681-8c13-f26119a1da16" ,
"date" : "2023-02-27T13:25:52.841Z" ,
"createdAt" : "2023-02-27T13:25:52.841Z" ,
"updatedAt" : "2023-02-27T13:25:52.841Z" ,
"type" : "STATUS" ,
"description" : "Courier on route" ,
"author" : "System" ,
"metaData" : {
"rating" : 5 ,
"totalDistanceTraveled" : 0 ,
"trackingUrl" : "https://blueExpress.northlatam.com/tracking/index.html?jobID=41903e23c5157de2a3961c05cafc6e5b" ,
"status" : "ON_ROUTE"
}
} ,
{
"id" : "3d778bfa-dbd3-40de-a23e-03f6e1aa84ea" ,
"date" : "2023-02-27T13:24:45.684Z" ,
"createdAt" : "2023-02-27T13:24:45.684Z" ,
"updatedAt" : "2023-02-27T13:24:45.684Z" ,
"type" : "STATUS" ,
"description" : "Service pending" ,
"author" : "System" ,
"metaData" : {
"rating" : 5 ,
"totalDistanceTraveled" : 0 ,
"trackingUrl" : "https://blueExpress.northlatam.com/tracking/index.html?jobID=98cb758cc7049b956d13c15e67e5fd87" ,
"status" : "PENDING"
}
} ,
{
"id" : "25b9dba7-4e65-4a10-b0b5-27f98997422a" ,
"date" : "2023-02-27T13:26:22.985Z" ,
"createdAt" : "2023-02-27T13:26:22.985Z" ,
"updatedAt" : "2023-02-27T13:26:22.985Z" ,
"type" : "NOTE" ,
"description" : "A new note has been added" ,
"author" : "Juan C Testing P" ,
"metaData" : {
"0" : {
"type" : "COMMENT" ,
"note" : "Entregado" ,
"author" : "Juan C Testing P"
} ,
"1" : {
"type" : "COMMENT" ,
"note" : "Entregado a porteria" ,
"author" : "Juan C Testing P"
}
}
} ,
{
"id" : "a27af5ba-a765-4941-bde8-21f7795473cd" ,
"date" : "2023-02-27T13:24:03.496Z" ,
"createdAt" : "2023-02-27T13:24:03.496Z" ,
"updatedAt" : "2023-02-27T13:24:03.496Z" ,
"type" : "STATUS" ,
"description" : "Service creation" ,
"author" : "System" ,
"metaData" : null
} ,
{
"id" : "4cd358ff-c79b-421d-a0a1-bcdb70622886" ,
"date" : "2023-02-27T13:25:08.691Z" ,
"createdAt" : "2023-02-27T13:25:08.691Z" ,
"updatedAt" : "2023-02-27T13:25:08.691Z" ,
"type" : "NOTE" ,
"description" : "A new note has been added" ,
"author" : "Juan C Testing P" ,
"metaData" : {
"0" : {
"type" : "COMMENT" ,
"note" : "Recogido" ,
"author" : "Juan C Testing P"
}
}
} ,
{
"id" : "5c4137a5-c6db-479c-98ab-b40b9adc22dc" ,
"date" : "2023-02-27T13:25:08.547Z" ,
"createdAt" : "2023-02-27T13:25:08.547Z" ,
"updatedAt" : "2023-02-27T13:25:08.547Z" ,
"type" : "EVIDENCE" ,
"description" : "Added evidence" ,
"author" : "Juan C Testing P" ,
"metaData" : {
"0" : {
"type" : "IMAGE" ,
"content" : "https://tookan.s3.amazonaws.com/acknowledgement_images/1677504302764669967113822-470083180Signature.jpg" ,
"author" : "Juan C Testing P"
}
}
} ,
{
"id" : "912f2d4a-00d6-4ba0-a380-4bf0fa593d6e" ,
"date" : "2023-02-27T13:24:39.847Z" ,
"createdAt" : "2023-02-27T13:24:39.847Z" ,
"updatedAt" : "2023-02-27T13:24:39.847Z" ,
"type" : "STATUS" ,
"description" : "Assigned courier" ,
"author" : "System" ,
"metaData" : {
"rating" : 5 ,
"totalDistanceTraveled" : 0 ,
"trackingUrl" : "https://blueExpress.northlatam.com/tracking/index.html?jobID=98cb758cc7049b956d13c15e67e5fd87" ,
"status" : "ASSIGNED"
}
} ,
{
"id" : "b44f7442-e7b5-4d87-8dc3-9c9ec480a269" ,
"date" : "2023-02-27T13:24:03.471Z" ,
"createdAt" : "2023-02-27T13:24:03.471Z" ,
"updatedAt" : "2023-02-27T13:24:03.471Z" ,
"type" : "STATUS" ,
"description" : "Service pending in PROD" ,
"author" : "System" ,
"metaData" : {
"shippingEstimatedDate" : null ,
"metaData" : null ,
"serviceId" : "470083180050116775042433920287" ,
"shippingPrice" : null ,
"status" : "PENDING"
}
} ,
{
"id" : "b992c08d-3b6c-4e95-9c87-9b41b82abc27" ,
"date" : "2023-02-27T13:25:07.834Z" ,
"createdAt" : "2023-02-27T13:25:07.834Z" ,
"updatedAt" : "2023-02-27T13:25:07.834Z" ,
"type" : "STATUS" ,
"description" : "Courier picked the package" ,
"author" : "System" ,
"metaData" : {
"rating" : 5 ,
"totalDistanceTraveled" : 0 ,
"trackingUrl" : "https://blueExpress.northlatam.com/tracking/index.html?jobID=98cb758cc7049b956d13c15e67e5fd87" ,
"status" : "PICKED"
}
} ,
{
"id" : "23a4bd15-e33d-441c-a699-c0c20dda6a7a" ,
"date" : "2023-02-27T13:26:22.160Z" ,
"createdAt" : "2023-02-27T13:26:22.160Z" ,
"updatedAt" : "2023-02-27T13:26:22.160Z" ,
"type" : "STATUS" ,
"description" : "The package was delivered" ,
"author" : "System" ,
"metaData" : {
"rating" : 5 ,
"totalDistanceTraveled" : 0 ,
"trackingUrl" : "https://blueExpress.northlatam.com/tracking/index.html?jobID=41903e23c5157de2a3961c05cafc6e5b" ,
"status" : "DELIVERED"
}
}
] ,
"notes" : [
{
"type" : "COMMENT" ,
"date" : "2023-02-27T13:25:08.682Z" ,
"content" : "Recogido" ,
"author" : "Juan C Testing P"
} ,
{
"type" : "COMMENT" ,
"date" : "2023-02-27T13:26:22.976Z" ,
"content" : "Entregado" ,
"author" : "Juan C Testing P"
} ,
{
"type" : "COMMENT" ,
"date" : "2023-02-27T13:26:22.976Z" ,
"content" : "Entregado a porteria" ,
"author" : "Juan C Testing P"
}
] ,
"timezone" : {
"offset" : -300 ,
"value" : "America/Bogota" ,
"label" : null
} ,
"carrierLogo" : "iVBORw0KGgoAAAANSUhEUgAAAhQAAAHICAYAAAAWbnMsA" ,
"trackingUrl" : "https://blueExpress.northlatam.com/tracking/index.html?jobID=41903e23c5157de2a3961c05cafc6e5b" ,
"comments" : "-" ,
"paymentMethod" : "ONLINE" ,
"carrierServiceType" : "EXPRESS" ,
"shippingPrice" : null ,
"shippingEstimatedDate" : null ,
"shippingFinishedDate" : null ,
"metaData" : {
"jobCapacityTest" : true ,
"test" : "This is field custom" ,
"name" : "Last Mile Test" ,
"integrationResponse" : {
"customKey1" : "customValue1" ,
"custom_key2" : "customValue2"
}
}
}
}
Service that allows updating the details of the tracking service via webhook
- /tracking/hook/{carrierId}/{serviceId}
Id generated by the service
{
status : PENDING | ASSIGNED | PICKED | ON_ROUTE | INCIDENT | RETURNED | DELIVERED
agent : {
id : String !
name : String !
identification : String
phone : String
email : String
vehicle : SCOOTER | VAN | CAR | TRUCK | BIKE | WALK | DRONE
}
trackingUrl : String
totalDistanceTraveled : Int
rating : Float
shippingPrice : Float
shippingEstimatedDate : String
}
{
"status" : "PENDING" ,
"agent" : {
"id" : "pedro1" ,
"name" : "Pedro!" ,
"identification" : "89082480" ,
"phone" : "242424234" ,
"email" : "pedro@gmailc.om" ,
"vehicle" : "SCOOTER"
} ,
"trackingUrl" : "https://localhost.com" ,
"totalDistanceTraveled" : 2 ,
"rating" : 5 ,
"shippingPrice" : 150000 ,
"shippingEstimatedDate" : "2022-04-27T20:25:45.067Z"
}
{
"message" : "Service updated successfully" ,
"data" : {
"status" : "PENDING" ,
"agent" : {
"id" : "pedro1" ,
"name" : "Pedro!" ,
"identification" : "89082480" ,
"phone" : "242424234" ,
"email" : "pedro@gmailc.om" ,
"vehicle" : "SCOOTER"
} ,
"trackingUrl" : "https://localhost.com" ,
"totalDistanceTraveled" : 2 ,
"rating" : 5 ,
"shippingPrice" : 150000 ,
"shippingEstimatedDate" : "2022-04-27T20:25:45.067Z"
}
}
Service that allows the carriers to add notes/information on services
POST - /tracking/hook/notes/{carrierId}/{serviceId}
Id generated by the service
[
{
type : ERROR | COMMENT !
note : String !
author : String
}
]
[
{
"type" : "ERROR" ,
"note" : "El paquete tarda en ser despachado" ,
"author" : "Oscar Rojas"
} ,
{
"type" : "COMMENT" ,
"note" : "El paquete fue recogido" ,
"author" : "Oscar Rojas"
}
]
{
"message" : "Notes saved successfully" ,
"data" : [
{
"type" : "ERROR"
"note" : "El paquete tarda en ser despachado" ,
"author" : "Oscar Rojas"
} ,
{
"type" : "COMMENT"
"note" : "El paquete ha fue recogido" ,
"author" : "Oscar Rojas"
}
]
}
Service that allows the carrier to add evidence like proof of delivery or pickup to the shipping service, photos, text, others
POST - /tracking/hook/evidences/{carrierId}/{serviceId}
Id generated by the service
[
{
type : IMAGE | TEXT !
content : String !
author : String
}
]
[
{
"type" : "IMAGE" ,
"content" : "https://parkers-images.bauersecure.com/wp-images/18727/courier-van-insurance-01.jpg" ,
"author" : "Felipe Cardenas"
} ,
{
"type" : "TEXT" ,
"content" : "El paquete fue entregado" ,
"author" : "Felipe Cardenas"
}
]
{
"message" : "Evidences saved successfully" ,
"data" : [
{
"type" : "IMAGE" ,
"content" : "https://parkers-images.bauersecure.com/wp-images/18727/courier-van-insurance-01.jpg" ,
"author" : "Felipe Cardenas"
} ,
{
"type" : "TEXT" ,
"content" : "El paquete fue entregado" ,
"author" : "Felipe Cardenas"
}
]
}
Service that allows the carrier to add the shipping labels.
POST - /tracking/hook/labels/{carrierId}/{serviceId}
Id generated by the service
{
id : String !
url : String !
name : String !
type : PDF | BASE64 | TEXT | ZPL !
}
if the label is type or , the max size that we allow is
{
"id" : "AS23424ADASFG" ,
"url" : "http://s3://mybucket-alpha/orc/2013-10-04-custdata/label-pickup.pdf" ,
"name" : "Etiqueta de entrega" ,
"type" : "PDF"
}
{
"message" : "Label saved successfully" ,
"data" : {
"id" : "AS23424ADASFG" ,
"url" : "http://s3://mybucket-alpha/orc/2013-10-04-custdata/label-picup.pdf" ,
"name" : "Etiqueta de entrega" ,
"type" : "PDF"
}
}
Service that will cancel an ongoing shipping service
POST - /tracking/hook/cancel/{carrierId}/{serviceId}
Id generated by the service
{
comment : String
type : ERROR_CREATE_SERVICE | END_CLIENT_CANCELED | NO_THERE_DELIVERY_MAN_ASSIGN | OTHER !
}
{
"comment" : "La direccion de entrega se cambio" ,
"type" : "END_CLIENT_CANCELED"
}
{
"message" : "Service canceled successfully" ,
"data" : {
"comment" : "La direccion de entrega se cambio" ,
"type" : "END_CLIENT_CANCELED"
}
}
Service that allows a carrier to temporarily pause a shipping service
POST - /tracking/hook/on-hold/{carrierId}/{serviceId}
Id generated by the service
{
comment : String
type : ERROR_CREATE_SERVICE | END_CLIENT_PAUSE | NO_THERE_DELIVERY_MAN_ASSIGN | OTHER !
}
{
"comment" : "La direccion de entrega se cambio" ,
"type" : "END_CLIENT_PAUSE"
}
{
"message" : "Service on hold successfully" ,
"data" : {
"comment" : "La direccion de entrega se cambio" ,
"type" : "END_CLIENT_PAUSE"
}
}
Endpoint available to generate authentication JWT
REST API endpoints are prefixed with the following URL:
https://auth.pickingnpacking.com/dev
https://auth.pickingnpacking.com/prod
POST - /token
None
- https://auth.pickingnpacking.com/dev/token
{
"apiKey" : "db5a3cecfef9cb0a9815af7c2eb8f7d6:c400460c165cc9beb146ad4d757e3bb1a24ff15228c424a0bd7c37f0ac356c0f6230568705d93dd6ff68190c0eafe5a74cbb14229748f20d3e53cbcc790ba372"
}
{
"message" : "success" ,
"data" : "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ2.eyJob4N0bmFtZSI6Im5ld2J1c2luZXNzMDEiLCJpYXQiOjE2MzM3MjE1NzksImV4cCI6MTYzMzcyMjQ3OX0.7QRZpElg1HYgyJpE6QTNgE2IN3vXbzIfulBS0Bvyzds"
}