Selecting a shipping method
How to select a shipping method for each of the order shipments
Problem
You have a pending order and you want to give your customer the possibility to select a shipping method for each of the order shipments, based on its cost and delivery lead time.

Solution
Within Commerce Layer, an order can have many shipments and each shipment must have a valid shipping method before the order can be placed. To let the customer select a shipping method, first you need to get the list of available shipping methods for the order shipments and display them to the customer along with their delivery lead times. Then you can associate the selected shipping method with the shipment and eventually display its delivery lead time. To do that:
- Send a - GETrequest to the- /api/orders/:id/shipmentsendpoint, including the associated- available_shipping_methodsand- stock_location.
- Send a - GETrequest to the- /api/orders/delivery_lead_times, including the associated- shipping_methodand- stock_location, and add some front-end logic to determine which of the returned delivery lead times is associated with a stock location that matches the one associated with the shipment.
- Send a - PATCHrequest to the- /api/shipments/:idendpoint, setting its- shipping_methodrelationship.
- Send a - GETrequest to the- /api/shipments/:id endpoint, including the associated- shipping_methodand- delivery_lead_time.
Example
1. Get the available shipping methods
The following request retrieves the list of available shipping methods associated with the shipments of the order identified by the "NgojhKoyYN" ID:
curl -g -X GET \
  'https://yourdomain.commercelayer.io/api/orders/NgojhKoyYN/shipments?include=available_shipping_methods,stock_location' \
  -H 'Authorization: Bearer your-access-token' \
  -H 'Accept: application/vnd.api+json'2. Displaying the available shipping methods delivery lead times
The following request retrieves the list of the delivery lead times for the market in scope:
curl -g -X GET \
  'https://yourdomain.commercelayer.io/api/delivery_lead_times?include=shipping_method,stock_location' \
  -H 'Authorization: Bearer your-access-token' \
  -H 'Accept: application/vnd.api+json'For performance reasons and to minimize the number of calls to the API, at this point you need to add the necessary logic to determine which of the returned delivery lead times has to be displayed for each shipping method on the front-end. Basically, it's all about — for each one of the available shipping methods associated with each shipment — filtering the returned delivery lead times to find which one is associated with a stock location that matches the stock location associated with the shipment.
The image below shows which specific attribute of the shipping method and delivery lead time object has to be displayed.

For performance reasons, in the response of both the above calls (1. and 2.) the price of the shipping methods whose cost is supposed to be provided by an external service (if any) is not updated with the value calculated externally which is fetched only when the shipping method is selected.
3. Select a shipping method
The following request associates the selected shipping method (identified by the "DEqjzFMykO" ID) with the shipment identified by the "kPzgnCjdQy" ID:
curl -g -X PATCH \
  'https://yourdomain.commercelayer.io/api/shipments/kPzgnCjdQy' \
  -H 'Authorization: Bearer your-access-token' \
  -H 'Accept: application/vnd.api+json' \
  -H 'Content-Type: application/vnd.api+json' \
  -d '{
    "data": {
      "type": "shipments",
      "id": "kPzgnCjdQy",
      "relationships": {
        "shipping_method": {
          "data": {
            "type": "shipping_methods",
            "id": "DEqjzFMykO"
          }
        }
      }
    }
  }'4. Displaying the selected shipping method delivery lead time
The following request retrieves the delivery lead time associated with the shipment identified by the "kPzgnCjdQy" ID:
curl -g -X GET \ 
  'https://yourdomain.commercelayer.io/api/shipments/kPzgnCjdQy?include=shipping_method,delivery_lead_time' \
  -H 'Authorization: Bearer your-access-token' \
  -H 'Accept: application/vnd.api+json'The image below shows how the displayed information about the selected shipping method is mapped to specific relationships of the shipment object.

Additional notes
Purchasing gift cards
When purchasing digital products — i.e. gift cards — no shipments are created for the order, therefore the order can be placed without any shipping method.
Default shipping method
If you set a default shipping method for a market, all the shipments that belong to the market's orders and that are not already associated with a shipping method will be automatically associated with the default one. In particular, any new shipment will be automatically associated with the default shipping method at creation time and the default shipping method will be listed among the shipment's available shipping methods. Of course, you can always change the shipping method by patching the shipment and updating the relationship.
More to read
See our documentation if you need more information about the shipping method, delivery lead time, and gift card objects or on how to update and retrieve a shipment or include associations.
Last updated

