ReDoc documentation
Locations can be managed separately in Order Book, which allows the user to capture their related business rules in a reusable manner. This is especially valuable in business cases where a select set of Locations is reused across many orders.
Typical use cases include capturing regular opening hours or requirements tied to a specific Location.
This is an endpoint that allows you to retrieve a list of Locations in bulk. The locations are identified by their business id, provided in the query.
When one or more locations could not be found, this will be indicated in the errors-section of the response.
a list of locations
{- "data": [
- {
- "business_id": "locationA",
- "location_category": "locationCategoryA",
- "name": "locationName",
- "description": "locationDescription",
- "comment": "locationComment",
- "address": {
- "address_line": "Voordries 41",
- "city": "Oosterzele",
- "zip_code": "9860",
- "country_code": "BE",
- "geo_point": {
- "latitude": 50.9514048,
- "longitude": 3.8067878
}, - "resolved_address": {
- "geo_point": {
- "latitude": 50.9514048,
- "longitude": 3.8067878
}, - "address_line": "Voordries 41",
- "city": "Oosterzele",
- "zip_code": "9860",
- "country_code": "BE",
- "score": 9
}
}, - "planning_address": {
- "address_line": "Voordries 41",
- "city": "Oosterzele",
- "zip_code": "9860",
- "country_code": "BE",
- "geo_point": {
- "latitude": 50.9514048,
- "longitude": 3.8067878
}, - "resolved_address": {
- "geo_point": {
- "latitude": 50.9514048,
- "longitude": 3.8067878
}, - "address_line": "Voordries 41",
- "city": "Oosterzele",
- "zip_code": "9860",
- "country_code": "BE",
- "score": 9
}
}, - "stop_time": "PT5M",
- "requirements": {
- "tags": [ ],
- "forbidden_tags": [ ]
}, - "time_window": {
- "description": "a description",
- "windows": [
- {
- "open_time": "14:45",
- "open_day": "MONDAY",
- "close_time": "14:45",
- "close_day": "MONDAY",
- "cost": 0
}
]
}, - "planning_time_window": {
- "description": "a description",
- "windows": [
- {
- "open_time": "14:45",
- "open_day": "MONDAY",
- "close_time": "14:45",
- "close_day": "MONDAY",
- "cost": 0
}
]
}, - "custom_data": {
- "shop_manager": "John Smith"
}, - "etag": "W/\"1\""
}
], - "errors": [
- {
- "title": "Invalid ...",
- "status": 400,
- "detail": "string",
- "instance": "an URI",
- "violations": [
- {
- "field": "class.field",
- "message": "a violation message"
}
]
}
]
}
Retrieve a list of Locations in bulk, identified by the query parameters defined in the request. The query requires at least a page and page size, in which case all Locations will be returned in a paged format. Providing any additional filter will return the matching subset of Locations. When providing multiple filter parameters, all filters must match for a Location to be included in the response.
The returned list can be empty, but the request will not fail if no results are found.
a list of locations
General error payload
{- "data": [
- {
- "business_id": "locationA",
- "location_category": "locationCategoryA",
- "name": "locationName",
- "description": "locationDescription",
- "comment": "locationComment",
- "address": {
- "address_line": "Voordries 41",
- "city": "Oosterzele",
- "zip_code": "9860",
- "country_code": "BE",
- "geo_point": {
- "latitude": 50.9514048,
- "longitude": 3.8067878
}, - "resolved_address": {
- "geo_point": {
- "latitude": 50.9514048,
- "longitude": 3.8067878
}, - "address_line": "Voordries 41",
- "city": "Oosterzele",
- "zip_code": "9860",
- "country_code": "BE",
- "score": 9
}
}, - "planning_address": {
- "address_line": "Voordries 41",
- "city": "Oosterzele",
- "zip_code": "9860",
- "country_code": "BE",
- "geo_point": {
- "latitude": 50.9514048,
- "longitude": 3.8067878
}, - "resolved_address": {
- "geo_point": {
- "latitude": 50.9514048,
- "longitude": 3.8067878
}, - "address_line": "Voordries 41",
- "city": "Oosterzele",
- "zip_code": "9860",
- "country_code": "BE",
- "score": 9
}
}, - "stop_time": "PT5M",
- "requirements": {
- "tags": [ ],
- "forbidden_tags": [ ]
}, - "time_window": {
- "description": "a description",
- "windows": [
- {
- "open_time": "14:45",
- "open_day": "MONDAY",
- "close_time": "14:45",
- "close_day": "MONDAY",
- "cost": 0
}
]
}, - "planning_time_window": {
- "description": "a description",
- "windows": [
- {
- "open_time": "14:45",
- "open_day": "MONDAY",
- "close_time": "14:45",
- "close_day": "MONDAY",
- "cost": 0
}
]
}, - "custom_data": {
- "shop_manager": "John Smith"
}, - "etag": "W/\"1\""
}
], - "page": {
- "total_items": 100,
- "total_pages": 10,
- "page_size": 10,
- "current_page": 1
}
}
Retrieve a single location by its business id.
OK
The entity is not found
General error payload
{- "data": {
- "business_id": "locationA",
- "location_category": "locationCategoryA",
- "name": "locationName",
- "description": "locationDescription",
- "comment": "locationComment",
- "address": {
- "address_line": "Voordries 41",
- "city": "Oosterzele",
- "zip_code": "9860",
- "country_code": "BE",
- "geo_point": {
- "latitude": 50.9514048,
- "longitude": 3.8067878
}, - "resolved_address": {
- "geo_point": {
- "latitude": 50.9514048,
- "longitude": 3.8067878
}, - "address_line": "Voordries 41",
- "city": "Oosterzele",
- "zip_code": "9860",
- "country_code": "BE",
- "score": 9
}
}, - "planning_address": {
- "address_line": "Voordries 41",
- "city": "Oosterzele",
- "zip_code": "9860",
- "country_code": "BE",
- "geo_point": {
- "latitude": 50.9514048,
- "longitude": 3.8067878
}, - "resolved_address": {
- "geo_point": {
- "latitude": 50.9514048,
- "longitude": 3.8067878
}, - "address_line": "Voordries 41",
- "city": "Oosterzele",
- "zip_code": "9860",
- "country_code": "BE",
- "score": 9
}
}, - "stop_time": "PT5M",
- "requirements": {
- "tags": [ ],
- "forbidden_tags": [ ]
}, - "time_window": {
- "description": "a description",
- "windows": [
- {
- "open_time": "14:45",
- "open_day": "MONDAY",
- "close_time": "14:45",
- "close_day": "MONDAY",
- "cost": 0
}
]
}, - "planning_time_window": {
- "description": "a description",
- "windows": [
- {
- "open_time": "14:45",
- "open_day": "MONDAY",
- "close_time": "14:45",
- "close_day": "MONDAY",
- "cost": 0
}
]
}, - "custom_data": {
- "shop_manager": "John Smith"
}, - "etag": "W/\"1\""
}
}
Create of update a location.
The caller is responsible for providing a unique business id for each Location to retain consistency. If a call is made using an unknown business id, a new Location will be created, otherwise an update will be applied to the existing Location. Locations are versioned and the ETag-header will represent the type of operation that was executed. Conversely, adding an If-Match header to requests can protect the caller against unintended operations by acting as an optimistic lock.
If-Match | string weak Etag as optimistic locking check |
Prefer | Array of strings The RFC7240 Prefer header indicates that a particular server behavior is preferred by the client but is not required for successful completion of the request (see RFC 7240). The following behavior is supported by this API:
|
business_id required | string Unique reference id |
location_category | string An optional category for the Locations, represented by its code. Defining a category for your Location can help in easy retrieval of the information through the search-endpoints or in the user interface. A category will also allow you to target Conditionals to Orders which are tied to a Location with specific categories. |
name | string An optional name that helps in identifying the Location. |
description | string A freeform text description of the Location, providing additional details that might be of use for a planner. |
comment | string A freeform text field for adding comments to a Location. |
required | object (GeoAddress) The main, physical address for this Location. This address as mandatory for creating/updating a Location. |
object (GeoAddress) The planning address allows you to override the address on a Location. A typical use case for this would be to provide the official address of a retail location in the address field, but specifying a loading dock in a back alley using the planning address. | |
stop_time | string (IsoDuration) The stop time to be applied when visiting this Location. Must be specified as a valid ISO Duration (see wikipedia ISO-8601 and RFC-3339). |
object (Requirements) Requirements that have to be fulfilled by the executor of an order at this location. | |
object (TimeWindows) A collection of TimeWindows, defining when this location can be visited. This can be used to restrict an Order's windowed timeframes. If this property is not provided, we consider the location open 24/7. | |
object (TimeWindows) Planning time windows allow you to specify a different set of time windows for use in the planning, and follow the same format as the If no planning time windows are specified, the regular time windows will be used for planning. | |
object (CustomData) Custom data allows you te enrich a Custom Data on a Location will be inherited by | |
etag | string (Etag) Must match header if provided on request. |
Indicates the locations is created or updated.
The response body contains the location, since Prefer is set to return=representation.
Indicates the locations is created or updated.
The response body will be empty, this is the default behaviour or the case when the Prefer-header is set to return=minimal.
Indicates the entity could not be found. This will occur when trying to update a Location, using an If-Match header, that has not been created before.
Client error response code indicates that access to the target resource has been denied. This happens with conditional requests on methods other than GET or HEAD when the condition defined by the If-Unmodified-Since, If-Match or If-None-Match headers is not fulfilled. This is typically the case when the entity was updated by someone else before you commit your request. In that case, the request, usually a modification of a resource, cannot be executed and this error response is sent back.
General error payload
{- "business_id": "locationA",
- "location_category": "locationCategoryA",
- "name": "locationName",
- "description": "locationDescription",
- "comment": "locationComment",
- "address": {
- "address_line": "Voordries 41",
- "city": "Oosterzele",
- "zip_code": "9860",
- "country_code": "BE",
- "geo_point": {
- "latitude": 50.9514048,
- "longitude": 3.8067878
}
}, - "planning_address": {
- "address_line": "Voordries 41",
- "city": "Oosterzele",
- "zip_code": "9860",
- "country_code": "BE",
- "geo_point": {
- "latitude": 50.9514048,
- "longitude": 3.8067878
}
}, - "stop_time": "PT5M",
- "requirements": {
- "tags": [ ],
- "forbidden_tags": [ ]
}, - "time_window": {
- "description": "a description",
- "windows": [
- {
- "open_time": "14:45",
- "open_day": "MONDAY",
- "close_time": "14:45",
- "close_day": "MONDAY",
- "cost": 0
}
]
}, - "planning_time_window": {
- "description": "a description",
- "windows": [
- {
- "open_time": "14:45",
- "open_day": "MONDAY",
- "close_time": "14:45",
- "close_day": "MONDAY",
- "cost": 0
}
]
}, - "custom_data": {
- "shop_manager": "John Smith"
}, - "etag": "W/\"1\""
}
{- "data": {
- "business_id": "locationA",
- "location_category": "locationCategoryA",
- "name": "locationName",
- "description": "locationDescription",
- "comment": "locationComment",
- "address": {
- "address_line": "Voordries 41",
- "city": "Oosterzele",
- "zip_code": "9860",
- "country_code": "BE",
- "geo_point": {
- "latitude": 50.9514048,
- "longitude": 3.8067878
}, - "resolved_address": {
- "geo_point": {
- "latitude": 50.9514048,
- "longitude": 3.8067878
}, - "address_line": "Voordries 41",
- "city": "Oosterzele",
- "zip_code": "9860",
- "country_code": "BE",
- "score": 9
}
}, - "planning_address": {
- "address_line": "Voordries 41",
- "city": "Oosterzele",
- "zip_code": "9860",
- "country_code": "BE",
- "geo_point": {
- "latitude": 50.9514048,
- "longitude": 3.8067878
}, - "resolved_address": {
- "geo_point": {
- "latitude": 50.9514048,
- "longitude": 3.8067878
}, - "address_line": "Voordries 41",
- "city": "Oosterzele",
- "zip_code": "9860",
- "country_code": "BE",
- "score": 9
}
}, - "stop_time": "PT5M",
- "requirements": {
- "tags": [ ],
- "forbidden_tags": [ ]
}, - "time_window": {
- "description": "a description",
- "windows": [
- {
- "open_time": "14:45",
- "open_day": "MONDAY",
- "close_time": "14:45",
- "close_day": "MONDAY",
- "cost": 0
}
]
}, - "planning_time_window": {
- "description": "a description",
- "windows": [
- {
- "open_time": "14:45",
- "open_day": "MONDAY",
- "close_time": "14:45",
- "close_day": "MONDAY",
- "cost": 0
}
]
}, - "custom_data": {
- "shop_manager": "John Smith"
}, - "etag": "W/\"1\""
}
}
This endpoint allows you to delete a location.
Deletion has succeeded, but body is empty
The entity is not found
Typically indicates that this Location is still in use by an Order that is executable in the future.
General error payload
{- "title": "Invalid ...",
- "status": 400,
- "detail": "string",
- "instance": "an URI",
- "violations": [
- {
- "field": "class.field",
- "message": "a violation message"
}
]
}