Migrate from v2.0 to v2.1
A dedicated guide to migrate your Multimodal Shipment API
Notice
The v2.0 is still maintained, but the v2.1 adheres to the ISO-14083.
What are the benefits of migrating?
- v2.1 is fully ISO-14083 compliant.
- v2.0 won't get any new features.
- It enhances COβe calculations and features for greater precision across all modes.
- Updates in methodology transparency make the new version easier to adopt and integrate into your workflows.
βοΈ How to migrate?
Start by selecting the API version
To use v2.1, you need to include a header to specify the version. Use the Accept-Version
header with the value 2.1
to access the new version as shown below:
curl --request POST \
--url https://api.searoutes.com/shipment/v2/report/co2 \
--header 'Accept-Version: 2.1' \
--header 'Content-Type: application/json' \
--header 'x-api-key: <your-api-key>' \
--data '{
<your_data>
}
1οΈβ£ Passing a request
Our v2.1 input contract contains the following structured objects:
legs
orders
details
We will go through the changes for each of those objects to help you translate your existing requests to the new contract.
To simplify building requests, you can now pass all the enum values as lower case or upper case. This applies for example to order types, container size type codes, fuel types, aircraft types, hub types, modes, inland vessel types, etc.
Legs
Thelegs
field has been replaced with transportChainElements
, introducing two type
s of transportChainElements
:
leg
hub
To translate your old leg
object to the new transportChainElement
, there are two cases:
Case 1:
If leg.mode
value is sea
, air
, road
, rail
or inland-water
:
- add
type=leg
- Also update the mode "
inland-water"
to"inland_water"
{
"from": "FRMRS",
"to": "BEANR",
"mode": "sea"
}
{
"type": "leg",
"from": "FRMRS",
"to": "BEANR",
"mode": "sea"
}
Case 2:
Ifleg.mode
value is hub:
- Add a
"type" : "hub"
field - Hub types such as
TRANSHIPMENT_SITE
andMARITIME_CONTAINER_TERMINAL
are now automatically generated. π« Manual addition of these hub types is no longer supported. - The
details.hubType
field has also moved tohubType
.
{
"mode": "hub",
"details": {
"hubType": "WAREHOUSE"
}
}
{
"type": "hub",
"hubType": "warehouse"
}
Let's summarize the changes by transforming entire legs
object
legs
object"legs": [
{
"from": "CNSHA",
"to": "FRFOS",
"mode": "sea"
},
{
"mode": "hub",
"details": {
"hubType": "MARITIME_CONTAINER_TERMINAL"
}
},
{
"mode": "inland-water",
"from": "FRFOS",
"to": "FRLIO"
},
{
"mode": "hub",
"details": {
"hubType": "WAREHOUSE"
}
}
]
"transportChainElements": [
{
"type": "leg",
"from": "CNSHA",
"to": "FRFOS",
"mode": "sea"
},
{
"type": "leg",
"mode": "inland_water",
"from": "FRFOS",
"to": "FRLIO"
},
{
"type": "hub",
"hubType": "warehouse"
}
]
No other change is needed π₯³
Orders
The type
field no longer supports these values CONTAINER
, UNIT_LOAD
, and PALLET
. These were previously aliases for other types, but aliases are no longer supported.
Apply the following replacement:
v2.0 | v2.1 |
---|---|
CONTAINER | FCL |
UNIT_LOAD | parcel |
PALLET | parcel |
sizeTypeCode | containerSizeTypeCode |
quantity | is now renamed nContainers β οΈ required for requests with order types FCL. For other requests, it will be ignored so you can remove it. |
Examples:
{
"type": "FCL",
"quantity": 3,
"sizeTypeCode": "20GP"
}
{
"type": "FCL",
"nContainers": 3,
"containerSizeTypeCode": "20GP"
}
LCL
order type is not compatible with air mode legs anymoreIf you have this, you must change the order type to
parcel
. This change will help you get more accurate COβe emissions when your requests contain legs of other modes thanair
.
{
"orders": [
{
"weight": 1500,
"type": "LCL"
}
],
"legs": [
{
"from": "CNSHA",
"to": "FRFOS",
"mode": "air"
}
]
}
{
"orders": [
{
"weight": 1500,
"type": "parcel"
}
],
"transportChainElements": [
{
"type": "leg",
"from": "CNSHA",
"to": "FRFOS",
"mode": "air"
}
]
}
Details
The details
field at root level has been removed. This means that:
- The API no longer accepts a
carrier
object indetails.carrier
- You will need to add the carrier to each relevant leg in
leg.details.carrier
.
{
"details": {
"carrier": {
"scac": "MAEU"
}
},
"orders": [
{
"weight": 1500,
"type": "LCL"
}
],
"legs": [
{
"from": "CNSHA",
"to": "FRFOS",
"mode": "sea"
}
]
}
{
"orders": [
{
"weight": 1500,
"type": "LCL"
}
],
"legs": [
{
"from": "CNSHA",
"to": "FRFOS",
"mode": "sea",
"details": {
"carrier": {
"scac": "MAEU"
}
}
}
]
}
All the other fields (referenceNumber
, id
, status
, client
) do not impact the calculation, you can pass them in the metadata
object if you need them to help identifying your shipment.
Query parameters
The generateCertificate
parameter is no longer supported, as certificates are not available in v2.1. They might return later in a new form.
Complete example
{
"details": {
"carrier": {
"scac": "MAEU"
},
"referenceNumber": "myShipment123"
},
"orders": [
{
"type": "PALLET",
"weight": 300
},
{
"type": "CONTAINER",
"quantity": 4,
"sizeTypeCode": "40GP"
}
],
"legs": [
{
"mode": "hub",
"details": {
"hubType": "WAREHOUSE"
}
},
{
"from": "CNSHA",
"to": "BEANR",
"mode": "sea"
},
{
"mode": "hub",
"details": {
"hubType": "MARITIME_CONTAINER_TERMINAL"
}
},
{
"from": "BEANR",
"to": "NOOSL",
"mode": "sea"
},
{
"mode": "hub",
"details": {
"hubType": "TRANSHIPMENT_SITE"
}
},
{
"from": "NOOSL",
"to": "Trondheim",
"mode": "road"
}
]
}
{
"orders": [
{
"type": "parcel",
"weight": 300
},
{
"type": "FCL",
"nContainers": 4,
"containerSizeTypeCode": "40GP"
}
],
"transportChainElements": [
{
"type": "hub",
"hubType": "warehouse"
},
{
"type": "leg",
"from": "CNSHA",
"to": "BEANR",
"mode": "sea",
"details": {
"carrier": {
"scac": "MAEU"
}
}
},
{
"type": "leg",
"from": "BEANR",
"to": "NOOSL",
"mode": "sea",
"details": {
"carrier": {
"scac": "MAEU"
}
}
},
{
"type": "leg",
"from": "NOOSL",
"to": "Trondheim",
"mode": "road"
}
],
"metadata": {
"referenceNumber": "myShipment123"
}
}
πͺMain differences when passing a request
v2.0 | v2.1 | Change type |
---|---|---|
Enum values are case-sensitive | Enum values are insensitive to case | |
hubType values : TRANSHIPMENT_SITE , MARITIME_CONTAINER_TERMINAL , WAREHOUSE , STORAGE_TRANSHIPMENT , LIQUID_BULK_TERMINAL | hubType values : warehouse , storage_transhipment , liquid_bulk_terminal | Removed |
order.type values :CONTAINER , FCL , LCL , UNIT_LOAD , PALLET , PARCEL | order.type values : FCL , LCL , parcel | Removed |
details.carrier | / | Removed |
details | / | Removed |
leg.mode="air" + order.type="LCL"\ returns 200 | http status 400 | Removed |
Query parameter generateCertificate | / | Removed |
/ | transportChainElement.type | Added |
leg.mode="hub" | transportChainElement.type="hub" | Changed |
leg.details.hubType | transportChainElement.hubType | Changed |
legs | transportChainElements | Renamed |
order.sizeTypeCode | order.containerSizeTypeCode | Renamed |
order.quantity | order.nContainers | Renamed |
leg.mode="inland-water" | transportChaineElement.mode="inland_water" | Renamed |
2οΈβ£ Getting a response
The response contract has also been adjusted to match the changes made in the input and now includes additional information about the hubs calculation.
Input alignement
The parameters
field in the response now contains exactly the fields that you passed: if you didn't pass a specific key, you won't see it in the response.
The legs
object becomes transportChainElements
.
In this new field, we match the body input changes:
- The elements of the
transportChainElements
lists contain atype
that can either behub
orleg
- In the
transportChainElements
,properties.orders[*].sizeTypeCode
becomesproperties.orders[*].containerSizeTypeCode
inland-water
legs becomeinland_water
The parameters
objects are updated to match your input.
How to handle the new transportChainElements
transportChainElements
To give you transparency on the details of the calculation of the hubs emissions respecting the new ISO norm, transportChainElements
of type hub
are automatically added.
You can identify easily the hubs that were automatically added by checking that type="hub"
and source="auto_generated"
(as opposed to source="user_input"
for the hubs you entered). Note that the source
field is only added in hub
elements.
Example:
{
"orders": [
{
"type": "FCL",
"nContainers": 4,
"containerSizeTypeCode": "40GP"
}
],
"transportChainElements": [
{
"type": "hub",
"hubType": "warehouse"
},
{
"type": "leg",
"from": "CNSHA",
"to": "BEANR",
"mode": "sea",
"details": {
"carrier": {
"scac": "MAEU"
}
}
},
{
"type": "leg",
"from": "BEANR",
"to": "NOOSL",
"mode": "sea",
"details": {
"carrier": {
"scac": "MAEU"
}
}
}
]
}
{
"parameters": {
"orders": [
{
"type": "fcl",
"containerSizeTypeCode": "40gp",
"nContainers": 4.0
}
]
},
"co2e": {
...
},
"transportChainElements": [
{
"type": "hub",
"location": {
"locode": "CNSHA",
...
},
"properties": {
"source": "user_defined",
"hubType": "warehouse",
...
},
...
},
{
"type": "leg",
"from": {
"locode": "CNSHA",
...
},
"to": {
"locode": "BEANR",
...
},
...
},
{
"type": "hub",
"location": {
"locode": "BEANR",
...
},
"properties": {
"source": "auto_generated",
"hubType": "maritime_container_terminal",
...
}
...
},
{
"type": "leg",
"from": {
"locode": "BEANR",
...
},
"to": {
"locode": "NOOSL",
...
},
...
}
]
}
We pass as input 3 transport chain elements:
- A warehouse hub
- A maritime leg from CNSHA to BEANR
- A maritime leg from BEANR to NOOSL
We get in response 4 transport chain elements:
- The warehouse hub passed as input, easy to spot with the
properties.source="user_input"
- The maritime leg from CNSHA to BEANR
- An auto generated hub in BEANR, with
properties.source="auto_generated"
- The maritime leg from BEANR to NOOSL
π‘A hub with the appropriate type will be automatically added between each pair of consecutive legs.
The case of enum
We now return every enum value in lowercase snake_case. This applies to the fuel types, container size type codes, order types, transport chain elements types, transport modes, data types, distance sources, hub types, hub sources, inland vessel types, aircraft types, etc. This applies to all enum except our model names.
Miscellaneous changes
The distance
field in the legs objects is now a brand new object with more information. It contains the old distance
and secaIntersection
fields along with the shortest feasible distance (sfd) and the details about the distance used for the COβe calculation.
Possible values for distance.used.source
are :
ais
schedules
user_input
daf
(Distance Adjustment Factor), which provides information about the source of the distance used for the COβe calculation.
{
...,
"properties": {
...,
"distance": 4477931,
"secaIntersection": 872150
}
}
{
...,
"properties": {
"distance": {
"sfd": {
"total": 3893853
},
"used": {
"total": 4477931,
"source": "DAF",
"seca": 872150
}
}
}
}
In transportChainElement[*].properties
for a road leg, you will no longer find a carrierScac
field, but a carrier
object with a scac
field if relevant or null
if no carrier was taken into account.
The field transportChainElement.orders[*].nTEU
is now never returned for parcel
orders and always returned for FCL
and LCL
orders and named nTeu
.
v2.0 | v2.1 | Change type |
---|---|---|
leg.properties.containerSizeTypeCode | Removed | |
transportChainElement.type | Added | |
transportChainElement.properties.distance.used.source | Added | |
transportChainElement.properties.source | Added | |
transportChainElement.properties.distance | Added | |
leg.properties.distance | transportChainElement.properties.distance.used.total | Changed Added |
leg.properties.secaIntersection | transportChainElement.properties.distance.used.seca | Changed |
leg.properties.orders[*].nTEU | transportChainElement.orders[*].nTeu | Changed |
leg[*].properties.carrierScac for road legs | transportChainElement[*].properties.carrier.scac | Changed |
legs | transportChainElements | Renamed Changed |
leg.properties.orders[*].sizeTypeCode | transportChainElement.properties.orders[*].containerSizeTypeCode | Renamed |
ENUM_VALUE | enum_value | Renamed |
transportChainElement.orders[*].nTEU | transportChainElement.orders[*].nTeu | Renamed |
transportChainElement.properties.vessel.minTEU | transportChainElement.properties.vessel.minTeu | Renamed |
transportChainElement.properties.vessel.maxTEU | transportChainElement.properties.vessel.maxTeu | Renamed |
transportChainElement.properties.truck.fuel | transportChainElement.properties.truck.fuelType | Renamed |
Need support?
If you have questions about the migration process or need technical support, don't hesitate in reaching us out to [email protected]
Updated 13 days ago