Fulfillment Engine API
Optimally fulfill orders with Shipium's Fulfillment Engine API.
Get started
To use the Fulfillment Engine API, you must first configure your account. Guidance can be found in the Fulfillment Engine documentation. This document provides instructions for using the API.
You'll need to provide information for the following four top-level entities for this API:
- Fulfillment centers. Data at the fulfillment center, or origin, level includes addresses and other standard details; processing times at each fulfillment center; carriers, service methods, and related costs for each fulfillment center; and Fulfillment Engine-specific configuration information, such as whether split shipments should be allowed and what types of splits will be considered (e.g., hazmat, no inventory available for all order items).
- Orders. This entity is a list of orders to plan. Data for orders includes the date and time of the order, the destination address, and item quantities for the order.
- Packaging types. Data at the packaging type level is used as a default across fulfillment centers when no packaging information is available when calling Fulfillment Engine for a plan. If provided, this data will override all preconfigured packaging types for the planning activity.
- Product details. Inventory data includes product availability and cost, dimensions and weight, and special attributes or designations (e.g., hazardous material).
Create a fulfillment plan with the Fulfillment Engine API
The Fulfillment Engine API is designed to be flexible to fit your organization’s business strategy and technical capabilities. All API calls assume you're using one of the authentication mechanisms detailed in our authentication documentation. The endpoint for all Fulfillment Engine API calls is included in the table below.
API type | API endpoint |
|---|---|
POST | https://api.shipium.com /api/v1/fe/plans |
Authentication for API CallsIn the cURL example on this page, the environment variable
AUTHSTRINGis used to handle authorization. The recipe below shows how to set it correctly for both API Key and OAuth users.
The following table provides all required and optional fields for calling the Fulfillment Engine API. You can find additional support in the Fulfillment Engine API Reference.
Request field | Required/Optional | Field properties | Description |
|---|---|---|---|
| Optional | String | An optional ID that allows you to set your own ID for looking up the plan after creation |
| Required | String | A unique identifier for the fulfillment context. This ID must correspond to a Shipium-registered fulfillment context for your organization. |
| Optional | String | The currency code of the fulfillment costs |
| Optional | Number ($float) | Additional processing cost added per item in a shipment |
| Optional | Number ($float) | Additional processing cost added per package in a shipment |
| Data for packaging types at the fulfillment center level allows for overriding packaging types for a specific fulfillment center. This is more specific than packagingTypes at the primary entity level and will override those values when processing for a specific fulfillment center. | ||
| Required | Decimal | Length of the shortest side of the box to be packed |
| Required | Decimal | Length of the longest side of the box to be packed |
| Required | String enumeration
| The unit of measurement the linear dimensions of the box are specified in |
| Required | Decimal | Length of the second longest side of the box to be packed |
| Conditional (optional, but required if including packaging type values configured in the Shipium platform) | String | Packing type identifier; you also can include your own unique |
| Conditional (optional, but required if no | String enumeration
| The shipment packaging material |
| Optional | String | A name your organization wishes to provide for the packaging size |
| Conditional (optional, but required if no | Decimal | The weight of the empty packaging |
| Conditional (optional, but required if no | String enumeration
| The unit of measurement in which the empty packaging is specified |
| Optional | Decimal | This is the default product weight that will be used when no specific weight information is provided for a product in a Fulfillment Engine plan. |
| Optional | String enumeration
| The unit of measurement in which the maximum content weight is specified |
| Optional | An array of processing time values | The amount of time it takes for the fulfillment center to process a shipment; the expected format is based on the ISO-8601 duration format: |
| Optional | Boolean | When set to |
| Conditional (optional, but required when | Integer | The maximum number of items allowed per package when planning runs generate shipments from order items; this value is used when |
| Conditional (optional, but required when | Integer | The maximum number of packages allowed per order for planning runs; this value is used when the |
| Optional | String enumeration
| A list of split types supported by the fulfillment center. When the value is |
| Optional | String | Currency code of the orders (e.g., USD = U.S. dollars) |
| Required | String enumeration
| The type of location for this address |
| Optional | String | The name of the city for the address |
| Optional | String | The company name for the address |
| Required | String | The country code for the address |
| Optional | String | The name associated with the address |
| Required | String | The postal code for the address |
| Optional | String | The name of the state or region for the address (e.g., NM) |
| Optional | String | The first line of the address |
| Optional | String | The second line of the address |
| Required | String | A unique product identifier (e.g., RN03947-Z43121) |
| Required | Integer | The number of units of this product |
| Optional | Boolean |
|
| Optional | String | The timestamp for when the customer ordered the product |
| Required | String | The identification your organization provided for this order |
| Optional | String | The string representation of either an ISO-8601 date or a local date for desired delivery: yyyy-mm-dd. The date or date-time the package is intended to arrive to the customer. This is used to determine the most appropriate service method when generating a label. |
| Optional | Boolean | If |
| Optional | Boolean | If |
| Optional | String | If set, this is the maximum amount of additional spend that your organization is willing to pay to upgrade a shipment to the desired delivery date (DDD) if the lowest cost carrier service method is unable to safely meet the DDD. |
| Optional | String | The ISO-4217 currency code of the |
| Optional | Integer ($int32) | Indicates the number of business days from the ship time by when the shipment needs to be delivered |
| Optional | String | A high-level shipping option shown to or selected by a customer |
| Optional | String ($date-time) | The timestamp for when you (or your fulfillment partner) shipped the product from your (or their) warehouse; the timestamp must be a valid ISO 8601 timestamp. If not provided, this value defaults to |
| Data for packaging at the orders level allows for defining the packaging type to use for a specific order. | ||
| Conditional (optional, but required if including packaging type values configured in the Shipium platform) | String | Packing type identifier |
| Conditional (optional, but required if no | String enumeration
| The shipment packaging material |
| Required | String enumeration
| The unit of measurement the linear dimensions of the box are specified in |
| Required | Decimal | Length of the longest side of the box to be packed |
| Required | Decimal | Length of the second longest side of the box to be packed |
| Required | Decimal | Length of the shortest side of the box to be packed |
| Conditional (optional, but required if no | String
| The unit of measurement in which the empty packaging is specified |
| Conditional (optional, but required if no | Decimal | The weight of the empty packaging |
| Conditional (optional, but required if Packaging Planner values are included but no | String
| The unit of measurement of the maximum weight of the contents that the packaging type can support |
| Conditional (optional, but required if Packaging Planner values are included but no | Decimal | The maximum weight of contents that the packaging type can support |
| Optional | String | The uniform resource name for identifying the packaging type |
| Optional | String | A name your organization wishes to provide for the packaging size |
| Data for packaging types at this primary level allows for specifying the packaging types to use for the request across fulfillment centers. | ||
| Conditional (optional, but required if no | Decimal | The numerical value of the shortest side of the package |
| Conditional (optional, but required if no | Decimal | The numerical value of the longest side of the package |
| Conditional (optional, but required if no | String enumeration
| The unit of measurement in which the linear dimensions of the package are specified |
| Conditional (optional, but required if no | Decimal | The numerical value of the second longest side of the package |
| Required | String | Packing type identifier |
| Required | String enumeration
| The shipment packaging material |
| Required | Decimal | The weight of the packaging |
| Required | String enumeration
| The unit of measurement in which the packaging is specified |
| Conditional (optional, but required if Packaging Planner values are included but no | String enumeration
| The unit of measurement of the maximum weight of the contents that the packaging type can support |
| Conditional (optional, but required if Packaging Planner values are included but no | Decimal | The maximum weight of contents that the packaging type can support |
| Optional | String | A name your organization wishes to provide for the packaging size |
| Optional | String | A future date to use as the starting date of the plan. A value of |
| Required | String | A list of attributes that may affect the shipping of the product |
| Optional | Boolean | If |
| Conditional (optional, but required if the | String enumeration
| Hazmat category for this order item. Use 'defined' to specify detailed information. |
| Conditional (optional, but required if the | String enumeration
| The material in which the hazardous material is packed |
| Conditional (optional, but required if the | String enumeration
| Hazard class of the hazardous material |
| Conditional (optional, but required if the | String | The International Air Transport Association (IATA) or U.S. Department of Transportation (DOT) regulatory identifier for the commodity as appropriate |
| Optional | String enumeration
| The degree of danger the material presents |
| Optional | String | The packing instruction code used for air transport |
| Conditional (optional, but required if the | String | The proper shipping name that is associated with the specified |
| Required | Number | The amount of quantity type material in quantity units |
| Required | String enumeration
| Determines whether the quantity includes the raw material (net) or also includes the material housing (gross) |
| Required | String enumeration
| The units of measure for the quantity of hazardous materials specified |
| Optional | String | The appropriate IATA or DOT subsidiary classes associated with the material and the hazard class |
| Conditional (optional, but required if the | String enumeration
| The packing instruction code used for air transport |
| Optional | String | The unique identifier for the fulfillment center that corresponds to a fulfillment center configured in the Shipium platform |
| Required | String | A unique identifier for the fulfillment context. This ID must correspond to a Shipium-registered fulfillment context for your organization. |
| Optional | String | Currency code of the fulfillment cost (e.g., USD = U.S. dollars) |
| Optional | Number | The price of fulfilling one item from the fulfillment center |
| Required | Integer | The quantity of the item available at the fulfillment center; this value should be zero (0) for a fulfillment center that has no inventory to fill the request. |
| Required | Decimal | The numerical value of the shortest side of the product |
| Required | Decimal | The numerical value of the longest side of the product |
| Required | String enumeration
| The unit of measurement in which the linear dimensions of the product are specified |
| Required | Decimal | The numerical value of the second longest side of the product |
| Required | String
| A list of product details that may affect shipping of the product |
| Required | String | The product stock-keeping unit (SKU) |
| Conditional (optional, but required if including | Decimal | The weight of the product |
| Conditional (optional, but required if including | String enumeration
| The unit of measurement in which the weight is specified |
| Optional | String | An optional human-readable name your organization has assigned to the plan |
| Optional | String | An optional description you can use to provide additional information for the plan |
The Fulfillment Engine response attributes are defined in the following table.
There are three major sections of the response:
- proposedShipments contains the list of shipments recommended, including FC, packaging and cost details, items and links for each element in the
shipmentItemsarray back to the originating order. - unfulfillableItems contains order items that could not be fulfilled, usually due to insufficient inventory available across all FCs.
- resultingInventory contains the ending inventory state. If a given SKU in a given warehouse started out with a quantity of 10 and 4 were used as part of producing shipments then this array will contain a
quantityAvailableof 6 for that FC and SKU, reflecting the end state of the inventory after assignments are complete.
Response attribute | Description |
|---|---|
| Indicates whether this asset is active (a value of |
| Indicates whether this asset is archived (a value of |
| The username of the last person (or system) who created the entity |
| ISO-8601 formatted date in UTC when the entity was initially created |
| The username of the last person (or system) to update the entity |
| ISO-8601 formatted date in UTC when the entity was last updated |
| A number corresponding to each version change |
| The unique identification (ID) for your organization |
| The unique ID assigned to the tenant by Shipium, if applicable |
| The unique ID for the Fulfillment Engine plan generated by Shipium |
| An optional ID that is returned if you set your own ID for looking up plans in the call request |
| The proposed carrier to ship the package out of the fulfillment center |
| The proposed carrier service method to ship the package out of the fulfillment center |
| The estimated cost to ship the package out of the fulfillment center |
| Calculation for the effective ship date time that a shipment will ship out |
| The date and time by when the package is estimated to be delivered to the customer |
| The local date-time of the destination of the shipment |
| The zone ID used for the destination of the shipment |
| The type of location for this address (i.e., |
| The name of the city for the address |
| The company name for the address |
| The ISO-3166 country code for the address |
| The name associated with the address |
| The postal code for the address |
| The name of the state or region for the address |
| The first line of the address |
| The second line of the address |
| The unique ID of the fulfillment context |
| The numerical value of the longest side of the packaging |
| The numerical value of the shortest side of the packaging |
| The unit of measurement in which the linear dimensions of the packaging are specified ( |
| The numerical value of the second longest side of the packaging |
| Packaging type identifier |
| The shipment packaging material (box, envelope, flat pack, mailing tube, parcel pallet, or unknown) |
| The name your organization provided for the packaging size |
| The weight of the packaging |
| The unit of measurement the packaging is specified in |
| A unique ID of the shipment |
| The numerical value of the longest side of the |
| The numerical value of the shortest side of the items to be shipped |
| The unit of measurement |
| The |
| The ID your organization provided for this order |
| A unique product identifier (e.g., |
| The weight of the items to be shipped |
| The unit of measurement the items to be shipped are specified in |
| The total weight of the proposed shipment |
| The unit of measurement the total proposed shipment is specified in |
| The number of unfulfillable items for the order |
| A unique product identifier (e.g., |
| The number of units of the product |
| A unique order identifier for the unfulfillable items provided by your organization |
| The reason the item could not be fulfilled |
| The uniform resource name for identifying this asset |
Shipium assumptions for the Fulfillment Engine API
- Orders
Order items that can be fulfilled from the same order will be grouped for maximum consolidation opportunity.
Order items will be split into shipment groups based on the information passed in the API call (e.g., hazmat).
Orders will be processed into proposed shipments based on the order in which they are listed in the API call. - Inventory
Order items will be consolidated into proposed shipments based on the inventory levels provided by your organization.
Example cURL call
curl --request POST
--url https://api.shipium.com/api/v1/fe/plans
--header 'accept: application/json'
--header $AUTHSTRING
--header 'content-type: application/json'
--data 'INSERT REQUEST BODY FROM BELOW'Example request body
{
"partnerPlanId": "myPartnerPlanId123",
"fulfillmentCenters": [
{
"fulfillmentContextId": "76172e5c-e2c1-4652-b5f0-bd43e2d41ee0",
"fulfillmentCost": {
"currencyCode": "usd",
"perItem": 0,
"perPackage": 0
},
"packagingTypes": [
{
"linearDimensions": {
"height": 10,
"length": 13,
"linearUnit": "in",
"width": 12
},
"packagingTypeId": "a7c89cab-e9b8-42d9-8b27-3021133912d7",
"packagingMaterial": "box",
"packagingSizeName": "large box",
"weight": {
"weight": 50,
"weightUnit": "lb"
},
"maxContentWeight": {
"weightUnit": "lb",
"weight": 50
}
}
],
"processingTime": "PnDTnHnMn.nS",
"rules": {
"splitSettings": {
"allowSplits": true,
"maxItemsPerPackage": 0,
"maxPackagesPerOrder": 0,
"splitTypes": [
"hazmat"
]
}
}
}
],
"orders": [
{
"currencyCode": "usd",
"desiredDeliveryDate": "2024-01-16T18:22:12.454Z",
"destinationAddress": {
"addressType": "commercial",
"city": "Albuquerque",
"company": "ACME",
"countryCode": "US",
"name": "Wile E. Coyote",
"postalCode": "87121",
"region": "NM",
"street1": "123 Main St.",
"street2": "Suite 42"
},
"orderItemQuantities": [
{
"productId": "RN03947--Z43121",
"quantity": 0
}
],
"orderParams": {
"mustShipComplete": true
},
"orderedDateTime": "2019-10-28T14:34:55.123456Z",
"partnerOrderId": "myCustomPartnerOrderId123",
"packagingType": {
"linearDimensions": {
"height": 10,
"length": 13,
"linearUnit": "in",
"width": 12
},
"packagingTypeId": "a7c89cab-e9b8-42d9-8b27-3021133912d7",
"packagingMaterial": "box",
"packagingSizeName": "large box",
"weight": {
"weight": 50,
"weightUnit": "lb"
},
"maxContentWeight": {
"weight": 100,
"weightUnit": "lb"
}
}
}
],
"packagingTypes": [
{
"linearDimensions": {
"height": 10,
"length": 13,
"linearUnit": "in",
"width": 12
},
"packagingTypeId": "a7c89cab-e9b8-42d9-8b27-3021133912d7",
"packagingMaterial": "box",
"packagingSizeName": "large box",
"weight": {
"weight": 50,
"weightUnit": "lb"
},
"maxContentWeight": {
"weight": 100,
"weightUnit": "lb"
}
}
],
"planDateTime": "2024-01-16T18:22:12.454Z",
"productDetails": [
{
"fulfillmentAttributes": [
"Extra_Padding_Required"
],
"hazmat": true,
"hazmatInfo": {
"category": "defined",
"containerType": "aluminum_jerrican",
"hazardClass": "class_8_corrosive_material",
"hazmatId": "UN1755",
"packingGroup": "ii",
"packingInstructionCode": "967",
"properShippingName": "chromic acid solution",
"quantity": 2.1,
"quantityType": "gross",
"quantityUnits": "l",
"subsidiaryClasses": [
8.1
],
"transportMode": "passenger_and_cargo_aircraft"
},
"inventoryStatuses": [
{
"fulfillmentContextId": "76172e5c-e2c1-4652-b5f0-bd43e2d41ee0",
"fulfillmentCostCurrencyCode": "usd",
"fulfillmentCostPerItem": 0,
"quantityAvailable": 0
}
],
"linearDimensions": {
"height": 10,
"length": 13,
"linearUnit": "in",
"width": 12
},
"productDetails": [
"special_handling"
],
"productId": "RN03947--Z43121",
"weight": {
"weight": 50,
"weightUnit": "lb"
}
}
]
}Example response
{
"active": true,
"archived": true,
"auditInfo": {
"createdBy": "user_name",
"creationTimeStamp": "2023-09-07T15:36:55.503Z",
"lastUpdatedBy": "user_name",
"lastUpdatedTimeStamp": "2023-09-07T15:36:55.503Z",
"version": 1
},
"description": "fulfillment",
"name": "my_fe_plan",
"partnerId": "096b869c-769b-40dd-b337-eb5120e08f99",
"tenantId": "04a23f17-8773-459c-a26a-1d5a539bcf04",
"planId": "3fadf9cd-0c57-47b6-95dd-94629c6f7312",
"partnerPlanId": "myPartnerPlanId123",
"proposedShipments": [
{
"cost": {
"carrier": "ups",
"cost": 0,
"serviceMethod": "ups-ground-service-method"
},
"destinationAddress": {
"addressType": "commercial",
"city": "Albuquerque",
"company": "ACME",
"countryCode": "US",
"name": "Wile E. Coyote",
"postalCode": "87121",
"region": "NM",
"street1": "123 Main St.",
"street2": "Suite 42"
},
"fulfillmentContextId": "76172e5c-e2c1-4652-b5f0-bd43e2d41ee0",
"packagingType": {
"linearDimensions": {
"height": 10,
"length": 13,
"linearUnit": "in",
"width": 12
},
"packagingTypeId": "a7c89cab-e9b8-42d9-8b27-3021133912d7",
"packagingMaterial": "box",
"packagingSizeName": "large box",
"weight": {
"weight": 50,
"weightUnit": "lb"
},
"maxContentWeight": {
"weight": 100,
"weightUnit": "lb"
}
},
"proposedShipmentId": "db862e2f-d38f-4dc8-9e07-3500e1b11337",
"shipmentItems": [
{
"linearDimensions": {
"height": 10,
"length": 13,
"linearUnit": "in",
"width": 12
},
"partnerOrderId": "myCustomPartnerOrderId123",
"productId": "RN03947--Z43121",
"weight": {
"weight": 50,
"weightUnit": "lb"
}
}
],
"totalWeight": {
"weight": 50,
"weightUnit": "lb"
}
}
],
"resultingInventory": {
"additionalProp1": [
{
"fulfillmentContextId": "76172e5c-e2c1-4652-b5f0-bd43e2d41ee0",
"fulfillmentCostCurrencyCode": "usd",
"fulfillmentCostPerItem": 0,
"quantityAvailable": 0
}
],
"additionalProp2": [
{
"fulfillmentContextId": "76172e5c-e2c1-4652-b5f0-bd43e2d41ee0",
"fulfillmentCostCurrencyCode": "usd",
"fulfillmentCostPerItem": 0,
"quantityAvailable": 0
}
],
"additionalProp3": [
{
"fulfillmentContextId": "76172e5c-e2c1-4652-b5f0-bd43e2d41ee0",
"fulfillmentCostCurrencyCode": "usd",
"fulfillmentCostPerItem": 0,
"quantityAvailable": 0
}
]
},
"unfulfillableItems": [
{
"countUnfulfilled": 0,
"orderItem": {
"productId": "RN03947--Z43121",
"quantity": 0
},
"partnerOrderId": "myCustomPartnerOrderId123",
"reason": "Product requires special handling not available at any fulfillment center"
}
],
"urn": "urn:fe:global-config:FE91F3A8-6838-469A-B9F8-2D82127573DC:1"
}Example request body with inclusion of desired delivery date
{
"orders": [
{
"currencyCode": "usd",
"desiredDeliveryDate": "2025-02-25",
"desiredDeliveryDateOptions": {
"exactDeliveryDate": true
},
"destinationAddress": {
"addressType": "commercial",
"city": "Albuquerque",
"company": "ACME",
"countryCode": "US",
"name": "Wile E. Coyote",
"postalCode": "87121",
"region": "NM",
"street1": "123 Main St.",
"street2": "Suite 42"
},
"orderItemQuantities": [
{
"productId": "PRD-12345",
"quantity": 1
}
],
"orderedDateTime": "2024-10-28T14:34:55.123456Z",
"partnerOrderId": "ORD-12345"
}
],
"productDetails": [
{
"inventoryStatuses": [
{
"fulfillmentContextId": "45f9a048-771c-4d85-8421-80d94abc1194",
"fulfillmentCostCurrencyCode": "usd",
"fulfillmentCostPerItem": 0,
"quantityAvailable": 2
}
],
"linearDimensions": {
"height": 10,
"length": 13,
"linearUnit": "in",
"width": 12
},
"productId": "PRD-12345",
"weight": {
"weight": 1,
"weightUnit": "lb"
}
}
]
}Example response with desired delivery date
{
"active": true,
"archived": false,
"auditInfo": {
"createdBy": "fulfillment-engine-integration-tests-internal",
"creationTimeStamp": "2025-02-20T18:42:35.347Z",
"lastUpdatedBy": "fulfillment-engine-integration-tests-internal",
"lastUpdatedTimeStamp": "2025-02-20T18:42:35.347Z",
"version": 1
},
"description": null,
"name": null,
"partnerId": "8e75cc7f-05bb-4520-9233-9768201f033b",
"partnerPlanId": null,
"planId": "1b185e91-1fb9-44eb-b483-93c1832a07b5",
"proposedShipments": [
{
"cost": {
"carrier": "ups",
"cost": 51.7,
"performance": {
"destinationTimezoneId": "America/Denver",
"effectiveShipDateTime": "2025-02-20T18:42:35.425Z",
"estimatedDeliveryDate": "2025-02-26T03:00:00Z",
"estimatedDeliveryDateLocal": "2025-02-25T20:00:00"
},
"serviceMethod": "ups-ground-service-method"
},
"destinationAddress": {
"addressType": "commercial",
"city": "Albuquerque",
"company": "ACME",
"countryCode": "US",
"name": "Wile E. Coyote",
"postalCode": "87121",
"region": "NM",
"street1": "123 Main St.",
"street2": "Suite 42"
},
"fulfillmentContextId": "45f9a048-771c-4d85-8421-80d94abc1194",
"packagingType": {
"linearDimensions": {
"height": 23,
"length": 23,
"linearUnit": "in",
"width": 23
},
"maxContentWeight": {
"weight": 50,
"weightUnit": "lb"
},
"packagingMaterial": "box",
"packagingSizeName": "FC default box",
"packagingTypeId": null,
"weight": {
"weight": 1,
"weightUnit": "lb"
}
},
"proposedShipmentId": "a5da5b41-2b88-4d8f-a58c-7c3780728540",
"shipmentItems": [
{
"linearDimensions": null,
"partnerOrderId": "ORD-12345",
"productId": "PRD-12345",
"weight": null
}
],
"totalWeight": {
"weight": 2,
"weightUnit": "lb"
}
}
],
"resultingInventory": {
"PRD-12345": [
{
"fulfillmentContextId": "45f9a048-771c-4d85-8421-80d94abc1194",
"fulfillmentCostCurrencyCode": "usd",
"fulfillmentCostPerItem": 0,
"quantityAvailable": 1
}
]
},
"tenantId": null,
"unfulfillableItems": [],
"urn": "urn:fe:plan:1b185e91-1fb9-44eb-b483-93c1832a07b5:1"
}Example request for package and product handling cost overrides
{
"orders": [
{
"currencyCode": "usd",
"desiredDeliveryDate": "2023-08-20T15:51:30.982Z",
"destinationAddress": {
"addressType": "residential",
"city": "Albuquerque",
"company": "ACME",
"countryCode": "US",
"name": "Wile E. Coyote",
"postalCode": "87121",
"region": "NM",
"street1": "123 Main St.",
"street2": "Suite 42"
},
"orderItemQuantities": [
{
"productId": "SKU1",
"quantity": 1
}
],
"orderedDateTime": "2019-10-28T14:34:55.123456Z",
"partnerOrderId": "MyOrder1"
}
],
"productDetails": [
{
"inventoryStatuses": [
{
"fulfillmentContextId": "4b2ac183-a657-4477-bfe6-d2b6c74bc7b5",
"fulfillmentCenterName": "NY",
"fulfillmentCostCurrencyCode": "usd",
"fulfillmentCostPerItem": null,
"quantityAvailable": 10
}
],
"linearDimensions": {
"height": 10,
"length": 13,
"linearUnit": "in",
"width": 12
},
"productId": "SKU1",
"weight": {
"weight": 1,
"weightUnit": "lb"
}
}
],
"fulfillmentCenters": [
{
"fulfillmentContextId": "4b2ac183-a657-4477-bfe6-d2b6c74bc7b5",
"fulfillmentCost": {
"currencyCode": "usd",
"perItem": 1.0,
"perPackage": 4.0 // <<-- This is where the fulfillment center package handling cost is set
}
}
]
}Example response with package and product handling cost overrides
{
"partnerId": "76abb3d4-8990-4f80-aa13-4c2007cb852a",
"tenantId": "this-needs-to-come-from-the-tenant-header...",
"urn": "urn:fe:plan:a477a6fb-e078-4e1a-8054-7025a5e80a57:1",
"name": "set-name-with-something...",
"description": "set-description-with-something...",
"active": true,
"archived": false,
"auditInfo": {
"createdBy": "fulfillment-engine-integration-tests-internal",
"creationTimeStamp": "2024-01-17T18:47:51.794Z",
"lastUpdatedBy": "fulfillment-engine-integration-tests-internal",
"lastUpdatedTimeStamp": "2024-01-17T18:47:51.794Z",
"version": 1
},
"planId": "a477a6fb-e078-4e1a-8054-7025a5e80a57",
"proposedShipments": [
{
"proposedShipmentId": "192b51f1-2a1d-4bd5-80c2-49f857cfdf98",
"fulfillmentContextId": "4b2ac183-a657-4477-bfe6-d2b6c74bc7b5",
"cost": {
"carrier": "ups",
"serviceMethod": "ups-ground-service-method",
"cost": 9.0
},
"destinationAddress": {
"name": "Wile E. Coyote",
"company": "ACME",
"street1": "123 Main St.",
"street2": "Suite 42",
"city": "Albuquerque",
"region": "NM",
"countryCode": "US",
"postalCode": "87121",
"addressType": "residential"
},
"packagingType": {
"packagingTypeId": null,
"packagingMaterial": "box",
"linearDimensions": {
"linearUnit": "in",
"length": 12.0,
"width": 11.0,
"height": 10.0
},
"weight": {
"weightUnit": "lb",
"weight": 1.0
}
},
"shipmentItems": [
{
"productId": "SKU1",
"partnerOrderId": "MyOrder1",
"linearDimensions": null,
"weight": null
}
],
"totalWeight": {
"weightUnit": "lb",
"weight": 1.0
}
}
],
"resultingInventory": {
"SKU1": [
{
"fulfillmentContextId": "4b2ac183-a657-4477-bfe6-d2b6c74bc7b5",
"quantityAvailable": 9,
"fulfillmentCostCurrencyCode": "usd",
"fulfillmentCostPerItem": null
}
]
},
"unfulfillableItems": []
}Examples for order splits
Fulfillment Engine splits order items into shipment groups based on information passed in the API. Splits can be based on the following:
- setting at a fulfillment center level (
fc_split) - item is hazmat (
hazmat). The value forproductDetails.hazmatin the API call must betrue. - no inventory available to fulfill in single origin (
inventory) - maximum packages per order (
max_shipments). An integer value should be included forfulfillmentCenters.rules.maxPackagesPerOrderin the API call. - use of the Packaging Planner (
package_planner) - item ships in its own container (
sioc). The value forproductDetails.productDetailsin the API call must besioc. - maximum number of items per package (
unit_count)
For any type of split, the two fields in the following table must be included in your API call.
Request field | Required/Optional | Field properties | Description |
|---|---|---|---|
| Required | Boolean | When set to |
| Required | String enumeration
| The types of splits supported by this fulfillment center; the types are described in more detail in the bulleted list above this table. |
Example request body for fulfillment center split
In order to be a candidate for splitting across fulfillment centers, the fulfillment center must be marked as supporting fulfillment center splits. The value passed in the API call for fulfillmentCenters.rules.splitSettings.splitTypes must be fc_split.
{
"description": "partner provided plan description",
"fulfillmentCenters": [
{
"fulfillmentContextId": "4b2ac183-a657-4477-bfe6-d2b6c74bc7b5",
"rules": {
"splitSettings": {
"allowSplits": true,
"splitTypes": [
"fc_split"
]
}
}
},
{
"fulfillmentContextId": "d20cdd21-ec3b-4902-b64f-4877c6113c83",
"rules": {
"splitSettings": {
"allowSplits": true,
"splitTypes": [
"fc_split"
]
}
}
}
],
"name": "partner provided plan name",
"orders": [
{
"currencyCode": "USD",
"desiredDeliveryDate": "2023-08-20T15:51:30.982Z",
"destinationAddress": {
"addressType": "residential",
"city": "Albuquerque",
"company": "ACME",
"countryCode": "US",
"name": "Wile E. Coyote",
"postalCode": "87121",
"region": "NM",
"street1": "123 Main St.",
"street2": "Suite 42"
},
"orderItemQuantities": [
{
"productId": "product1",
"quantity": 1
},
{
"productId": "product2",
"quantity": 2
}
],
"orderedDateTime": "2019-10-28T14:34:55.123456Z",
"packagingType": {
"linearDimensions": {
"height": 20,
"length": 20,
"linearUnit": "in",
"width": 20
},
"maxContentWeight": {
"weight": 50,
"weightUnit": "lb"
},
"packagingMaterial": "box",
"packagingSizeName": "Partner selected 9x8x7 box",
"weight": {
"weight": 1,
"weightUnit": "lb"
}
},
"partnerOrderId": "MyOrder1"
}
],
"partnerPlanId": "partner provided plan id",
"productDetails": [
{
"inventoryStatuses": [
{
"fulfillmentContextId": "4b2ac183-a657-4477-bfe6-d2b6c74bc7b5",
"quantityAvailable": 1
},
{
"fulfillmentContextId": "d20cdd21-ec3b-4902-b64f-4877c6113c83",
"quantityAvailable": 1
}
],
"linearDimensions": {
"height": 6,
"length": 7,
"linearUnit": "in",
"width": 8
},
"productId": "product1",
"weight": {
"weight": 1.2,
"weightUnit": "lb"
}
},
{
"inventoryStatuses": [
{
"fulfillmentContextId": "4b2ac183-a657-4477-bfe6-d2b6c74bc7b5",
"quantityAvailable": 1
},
{
"fulfillmentContextId": "d20cdd21-ec3b-4902-b64f-4877c6113c83",
"quantityAvailable": 1
}
],
"linearDimensions": {
"height": 5,
"length": 7,
"linearUnit": "in",
"width": 6
},
"productId": "product2",
"weight": {
"weight": 1.3,
"weightUnit": "lb"
}
}
]
}Example response for fulfillment center split
{
"active": true,
"archived": false,
"description": "partner provided plan description",
"name": "partner provided plan name",
"partnerId": "76abb3d4-8990-4f80-aa13-4c2007cb852a",
"partnerPlanId": "partner provided plan id",
"planId": "a8e1e825-4ad3-4b95-971d-520e6c6b9fbb",
"proposedShipments": [
{
"cost": {
"carrier": "ups",
"cost": 5.05,
"serviceMethod": "ups-ground-service-method"
},
"destinationAddress": {
"addressType": "residential",
"city": "Albuquerque",
"company": "ACME",
"countryCode": "US",
"name": "Wile E. Coyote",
"postalCode": "87121",
"region": "NM",
"street1": "123 Main St.",
"street2": "Suite 42"
},
"fulfillmentContextId": "4b2ac183-a657-4477-bfe6-d2b6c74bc7b5",
"packagingType": {
"linearDimensions": {
"height": 20,
"length": 20,
"linearUnit": "in",
"width": 20
},
"maxContentWeight": {
"weight": 50,
"weightUnit": "lb"
},
"packagingMaterial": "box",
"packagingSizeName": "Partner selected 9x8x7 box",
"packagingTypeId": null,
"weight": {
"weight": 1,
"weightUnit": "lb"
}
},
"proposedShipmentId": "41bda27c-a5b8-42cc-a739-795624703f83",
"shipmentItems": [
{
"linearDimensions": null,
"partnerOrderId": "MyOrder1",
"productId": "product2",
"weight": null
},
{
"linearDimensions": null,
"partnerOrderId": "MyOrder1",
"productId": "product1",
"weight": null
}
],
"totalWeight": {
"weight": 3.5,
"weightUnit": "lb"
}
},
{
"cost": {
"carrier": "ups",
"cost": 5.05,
"serviceMethod": "ups-ground-service-method"
},
"destinationAddress": {
"addressType": "residential",
"city": "Albuquerque",
"company": "ACME",
"countryCode": "US",
"name": "Wile E. Coyote",
"postalCode": "87121",
"region": "NM",
"street1": "123 Main St.",
"street2": "Suite 42"
},
"fulfillmentContextId": "d20cdd21-ec3b-4902-b64f-4877c6113c83",
"packagingType": {
"linearDimensions": {
"height": 20,
"length": 20,
"linearUnit": "in",
"width": 20
},
"maxContentWeight": {
"weight": 50,
"weightUnit": "lb"
},
"packagingMaterial": "box",
"packagingSizeName": "Partner selected 9x8x7 box",
"packagingTypeId": null,
"weight": {
"weight": 1,
"weightUnit": "lb"
}
},
"proposedShipmentId": "9947ac72-5f3a-477a-95ce-2e59466d8025",
"shipmentItems": [
{
"linearDimensions": null,
"partnerOrderId": "MyOrder1",
"productId": "product2",
"weight": null
}
],
"totalWeight": {
"weight": 2.3,
"weightUnit": "lb"
}
}
],
"resultingInventory": {
"product1": [
{
"fulfillmentContextId": "4b2ac183-a657-4477-bfe6-d2b6c74bc7b5",
"fulfillmentCostCurrencyCode": null,
"fulfillmentCostPerItem": null,
"quantityAvailable": 0
},
{
"fulfillmentContextId": "d20cdd21-ec3b-4902-b64f-4877c6113c83",
"fulfillmentCostCurrencyCode": null,
"fulfillmentCostPerItem": null,
"quantityAvailable": 1
}
],
"product2": [
{
"fulfillmentContextId": "4b2ac183-a657-4477-bfe6-d2b6c74bc7b5",
"fulfillmentCostCurrencyCode": null,
"fulfillmentCostPerItem": null,
"quantityAvailable": 0
},
{
"fulfillmentContextId": "d20cdd21-ec3b-4902-b64f-4877c6113c83",
"fulfillmentCostCurrencyCode": null,
"fulfillmentCostPerItem": null,
"quantityAvailable": 0
}
]
},
"tenantId": null,
"unfulfillableItems": [],
"urn": "urn:fe:plan:a8e1e825-4ad3-4b95-971d-520e6c6b9fbb:1"
}
Example request body for Packaging Planner split
This use case is if you are also using Shipium’s Packaging Planner service. The value passed in the API call for fulfillmentCenters.rules.splitSettings.splitTypes must be package_planner.
{
"description": "partner provided plan description",
"fulfillmentCenters": [
{
"fulfillmentContextId": "4b2ac183-a657-4477-bfe6-d2b6c74bc7b5",
"rules": {
"splitSettings": {
"allowSplits": true,
"splitTypes": [
"package_planner"
]
}
}
}
],
"name": "partner provided plan name",
"orders": [
{
"currencyCode": "USD",
"desiredDeliveryDate": "2023-08-20T15:51:30.982Z",
"destinationAddress": {
"addressType": "residential",
"city": "Albuquerque",
"company": "ACME",
"countryCode": "US",
"name": "Wile E. Coyote",
"postalCode": "87121",
"region": "NM",
"street1": "123 Main St.",
"street2": "Suite 42"
},
"orderItemQuantities": [
{
"productId": "product1",
"quantity": 1
},
{
"productId": "product2",
"quantity": 1
}
],
"orderedDateTime": "2019-10-28T14:34:55.123456Z",
"partnerOrderId": "MyOrder1"
}
],
"packagingTypes": [
{
"linearDimensions": {
"height": 10,
"length": 13,
"linearUnit": "in",
"width": 12
},
"maxContentWeight": {
"weight": 50,
"weightUnit": "lb"
},
"packagingMaterial": "box",
"packagingSizeName": "13x12x10 box",
"weight": {
"weight": 1,
"weightUnit": "lb"
}
}
],
"partnerPlanId": "partner provided plan id",
"productDetails": [
{
"inventoryStatuses": [
{
"fulfillmentContextId": "4b2ac183-a657-4477-bfe6-d2b6c74bc7b5",
"quantityAvailable": 10
}
],
"linearDimensions": {
"height": 10,
"length": 12,
"linearUnit": "in",
"width": 11
},
"productId": "product1",
"weight": {
"weight": 1.2,
"weightUnit": "lb"
}
},
{
"inventoryStatuses": [
{
"fulfillmentContextId": "4b2ac183-a657-4477-bfe6-d2b6c74bc7b5",
"quantityAvailable": 10
}
],
"linearDimensions": {
"height": 50,
"length": 50,
"linearUnit": "in",
"width": 50
},
"productId": "product2",
"weight": {
"weight": 1.3,
"weightUnit": "lb"
}
}
]
}Example response for Packaging Planner split
{
"active": true,
"archived": false,
"description": "partner provided plan description",
"name": "partner provided plan name",
"partnerId": "76abb3d4-8990-4f80-aa13-4c2007cb852a",
"partnerPlanId": "partner provided plan id",
"proposedShipments": [
{
"cost": {
"carrier": "ups",
"cost": 4,
"serviceMethod": "ups-ground-service-method"
},
"destinationAddress": {
"addressType": "residential",
"city": "Albuquerque",
"company": "ACME",
"countryCode": "US",
"name": "Wile E. Coyote",
"postalCode": "87121",
"region": "NM",
"street1": "123 Main St.",
"street2": "Suite 42"
},
"fulfillmentContextId": "4b2ac183-a657-4477-bfe6-d2b6c74bc7b5",
"packagingType": {
"linearDimensions": {
"height": 10,
"length": 13,
"linearUnit": "in",
"width": 12
},
"maxContentWeight": {
"weight": 50,
"weightUnit": "lb"
},
"packagingMaterial": "box",
"packagingSizeName": "13x12x10 box",
"packagingTypeId": null,
"weight": {
"weight": 1,
"weightUnit": "lb"
}
},
"shipmentItems": [
{
"linearDimensions": null,
"partnerOrderId": "MyOrder1",
"productId": "product1",
"weight": null
}
],
"totalWeight": {
"weight": 2.2,
"weightUnit": "lb"
}
}
],
"resultingInventory": {
"product1": [
{
"fulfillmentContextId": "4b2ac183-a657-4477-bfe6-d2b6c74bc7b5",
"fulfillmentCostCurrencyCode": null,
"fulfillmentCostPerItem": null,
"quantityAvailable": 9
}
],
"product2": [
{
"fulfillmentContextId": "4b2ac183-a657-4477-bfe6-d2b6c74bc7b5",
"fulfillmentCostCurrencyCode": null,
"fulfillmentCostPerItem": null,
"quantityAvailable": 10
}
]
},
"tenantId": null,
"unfulfillableItems": [
{
"countUnfulfilled": 1,
"orderItem": {
"productId": "product2",
"quantity": 1
},
"partnerOrderId": "MyOrder1",
"reason": "UNPACKABLE ITEM"
}
]
}
Example request body for maximum items per package split
The value passed in the API call for fulfillmentCenters.rules.splitSettings.splitTypes must be unit_count. An integer value should be included for fulfillmentCenters.rules.maxItemsPerPackage.
{
"fulfillmentCenters": [
{
"fulfillmentContextId": "4b2ac183-a657-4477-bfe6-d2b6c74bc7b5",
"rules": {
"splitSettings": {
"allowSplits": true,
"maxItemsPerPackage": 4,
"splitTypes": [
"unit_count"
]
}
}
}
],
"orders": [
{
"currencyCode": "USD",
"desiredDeliveryDate": "2023-08-20T15:51:30.982Z",
"destinationAddress": {
"addressType": "commercial",
"city": "Albuquerque",
"company": "ACME",
"countryCode": "US",
"name": "Wile E. Coyote",
"postalCode": "87121",
"region": "NM",
"street1": "123 Main St.",
"street2": "Suite 42"
},
"orderItemQuantities": [
{
"productId": "product1",
"quantity": 5
}
],
"orderedDateTime": "2019-10-28T14:34:55.123456Z",
"partnerOrderId": "partnerOrderId"
}
],
"productDetails": [
{
"inventoryStatuses": [
{
"fulfillmentContextId": "4b2ac183-a657-4477-bfe6-d2b6c74bc7b5",
"fulfillmentCostCurrencyCode": "usd",
"fulfillmentCostPerItem": 0,
"quantityAvailable": 5
}
],
"linearDimensions": {
"height": 10,
"length": 13,
"linearUnit": "in",
"width": 12
},
"productId": "product1",
"weight": {
"weight": 1,
"weightUnit": "lb"
}
}
]
}Example response for maximum items per package split
{
"active": true,
"archived": false,
"auditInfo": {
"createdBy": "fulfillment-engine-integration-tests-internal",
"creationTimeStamp": "2024-01-22T23:46:50.619Z",
"lastUpdatedBy": "fulfillment-engine-integration-tests-internal",
"lastUpdatedTimeStamp": "2024-01-22T23:46:50.619Z",
"version": 1
},
"description": "set-description-with-something...",
"name": "set-name-with-something...",
"partnerId": "76abb3d4-8990-4f80-aa13-4c2007cb852a",
"planId": "dd17b1fb-a472-4df7-8ac2-1513b950ac40",
"proposedShipments": [
{
"cost": {
"carrier": "ups",
"cost": 4,
"serviceMethod": "ups-ground-service-method"
},
"destinationAddress": {
"addressType": "commercial",
"city": "Albuquerque",
"company": "ACME",
"countryCode": "US",
"name": "Wile E. Coyote",
"postalCode": "87121",
"region": "NM",
"street1": "123 Main St.",
"street2": "Suite 42"
},
"fulfillmentContextId": "4b2ac183-a657-4477-bfe6-d2b6c74bc7b5",
"packagingType": {
"linearDimensions": {
"height": 10,
"length": 12,
"linearUnit": "in",
"width": 11
},
"packagingTypeId": null,
"packagingMaterial": "box",
"weight": {
"weight": 1,
"weightUnit": "lb"
}
},
"proposedShipmentId": "03f36117-13b5-4de8-81ba-0ed78c99eb91",
"shipmentItems": [
{
"linearDimensions": null,
"partnerOrderId": "partnerOrderId",
"productId": "product1",
"weight": null
},
{
"linearDimensions": null,
"partnerOrderId": "partnerOrderId",
"productId": "product1",
"weight": null
},
{
"linearDimensions": null,
"partnerOrderId": "partnerOrderId",
"productId": "product1",
"weight": null
},
{
"linearDimensions": null,
"partnerOrderId": "partnerOrderId",
"productId": "product1",
"weight": null
}
],
"totalWeight": {
"weight": 1,
"weightUnit": "lb"
}
},
{
"cost": {
"carrier": "ups",
"cost": 4,
"serviceMethod": "ups-ground-service-method"
},
"destinationAddress": {
"addressType": "commercial",
"city": "Albuquerque",
"company": "ACME",
"countryCode": "US",
"name": "Wile E. Coyote",
"postalCode": "87121",
"region": "NM",
"street1": "123 Main St.",
"street2": "Suite 42"
},
"fulfillmentContextId": "4b2ac183-a657-4477-bfe6-d2b6c74bc7b5",
"packagingType": {
"linearDimensions": {
"height": 10,
"length": 12,
"linearUnit": "in",
"width": 11
},
"packagingTypeId": null,
"packagingMaterial": "box",
"weight": {
"weight": 1,
"weightUnit": "lb"
}
},
"proposedShipmentId": "03edeacb-92c9-4efb-abb8-c61ed15d46a4",
"shipmentItems": [
{
"linearDimensions": null,
"partnerOrderId": "partnerOrderId",
"productId": "product1",
"weight": null
}
],
"totalWeight": {
"weight": 1,
"weightUnit": "lb"
}
}
],
"resultingInventory": {
"product1": [
{
"fulfillmentContextId": "4b2ac183-a657-4477-bfe6-d2b6c74bc7b5",
"fulfillmentCostCurrencyCode": "usd",
"fulfillmentCostPerItem": 0,
"quantityAvailable": 0
}
]
},
"tenantId": "this-needs-to-come-from-the-tenant-header...",
"unfulfillableItems": [],
"urn": "urn:fe:plan:dd17b1fb-a472-4df7-8ac2-1513b950ac40:1"
}
Resources
Your Shipium team member is available to help along the way. However, you might find these resources helpful:
Updated 4 days ago
