POST /company/companies/@id/products/bulk
This endpoint requires authentication.
Header | Value |
---|---|
Authorization | Set the value to Bearer + + access_token |
Replace the @ keywords in the URL with their corresponding value.
A dictionary with fields
Field | Type | Description |
---|---|---|
id | Int | Company ID. Create multiple products in this company |
Pass the following properties via application/json or form encoding in the body of the request.
Minimum 1. Maximum 50. Array of company.Product.detailed: [company.Product.detailed]
Field | Type | Description |
---|---|---|
name | [Language: String] | Name of the product |
description | [Language: String] | Description of the product |
specialty | Bool | Whether this product is a specialty. Specialties are also displayed in a separate category and are highlighted with a star icon. |
active | Bool | Inactive products are not visible in the webshop |
only_order_in_store | Bool | Whether this product can only get ordered in the store with a separate UI for the shop employees, and not in the public webshop. |
price_type | PriceType | A product has a price type that defines the price calculations and the way consumers can order the product. |
price | UInt | Price of the product (cents). Please note that this value is ignored when price_type is MULTIPLE_CHOICE. |
target_price | Bool | Is true when it's not possible to provide an exact price of this product when ordering (e.g. not exact weight possible). This option might deactive online payments for orders with this product (shop settings). |
url_type | String | String enumarion of 'none', 'recipe', 'website' |
url | URL? | Nullable. An URL field starting with http:// or https:// |
min_max | company.MinMaxSummary | The allowed amounts a customer is allowed to order of a product for amount / weight / persons |
option_set_ids | [Int] | ID's of the option sets you want to assign to this product. You can alter the order by switching the position of the ID's |
allergen_ids | [Int]? | Nullable. ID's of the allergens of this product. Set to null if you don't want to specify allergens. Only use an empty array when the product has no allergens. It is a subtle difference but it has legal consequences if you set this to the wrong value. You can find all the available allergen ID's here. |
category_id | Int | The category ID of the product |
seo | company.SeoData | Optional. Product page SEO metatags |
price_look_up_code | String? | Optional. Nullable. A String value |
code | String? | Optional. Nullable. A custom code. You can set this to your own code and use this field to map your products to Bakeronline products |
origin | [Language: String] | Optional. Origin of the product |
ingredients | [Language: String]? | Optional. Nullable. Ingredients that are in the product |
temperature_type | String? | Optional. Nullable. The temperature type when in a latch |
warranty_type | String? | Optional. Nullable. The type of warranty for this product |
warranty_price | UInt? | Optional. Nullable. Price of the warranty (cents). |
stock | company.Stock | Optional. The stock data for a product |
daysavailable | [Int] | Optional. Array of Int |
upfront | company.ProductUpfront | Optional. The upfront settings for a product |
use_pickup_after | Bool | Optional. Can pickup after a certain time be done? |
pickup_after | Time? | Optional. Nullable. Pickup of product after what time? |
use_pickup_before | Bool | Optional. Should a product be picked up before a certain time? |
pickup_before | Time? | Optional. Nullable. Pickup of product before what time? |
related_products | [Int] | Optional. List of related products, with a maximum of 8 |
POST /company/companies/11/products/bulk HTTP/1.1
Host: api.bakeronline.be
X-VERSION: 1.9.0
Accept-Language: en-US,en;q=0.5
Content-Type: application/json
Content-Length: 8105
[
{
"name": {
"nl": "...",
"en": "...",
"fr": "..."
},
"description": {
"nl": "...",
"en": "...",
"fr": "..."
},
"specialty": true,
"active": true,
"only_order_in_store": false,
"price_type": "PER_UNIT",
"price": 16,
"target_price": false,
"url_type": "none",
"url": "https://example.com",
"min_max": {
"amount": {
"minimum": 15,
"maximum": 14,
"maximum_day": 18,
"maximum_week": 18
},
"weight": {
"minimum": 16,
"maximum": 16,
"maximum_day": 12,
"maximum_week": 18,
"suggested": 18
},
"persons": {
"minimum": 16,
"maximum": 18
}
},
"option_set_ids": [
10,
10,
15
],
"allergen_ids": [
16,
13,
19
],
"category_id": 11,
"seo": {
"title": {
"en": "Eos sequi eos est ullam ad saepe."
},
"description": {
"en": "Aut exercitationem molestias veritatis. Cupiditate itaque iste iste ratione natus consequatur. Aut consectetur aut architecto."
},
"url": {
"en": "https://www.reilly.com/nesciunt-maiores-et-aut-dolorum-sequi-vel-assumenda"
}
},
"price_look_up_code": "...",
"code": "...",
"origin": {
"nl": "...",
"en": "...",
"fr": "..."
},
"ingredients": {
"nl": "...",
"en": "...",
"fr": "..."
},
"temperature_type": "any",
"warranty_type": "none",
"warranty_price": 15,
"stock": {
"soldout": false,
"amount": 17,
"soldoutUntil": "2019-01-31 12:00"
},
"daysavailable": [
19,
11,
17
],
"upfront": {
"upfront_use_default": true,
"upfront_type": "days",
"upfront_days": 11,
"upfront_time": "12:00",
"upfront_hours": 15,
"upfront_minutes": 11
},
"use_pickup_after": false,
"pickup_after": "12:00",
"use_pickup_before": false,
"pickup_before": "12:00",
"related_products": [
14,
14,
16
]
},
{
"name": {
"nl": "...",
"en": "...",
"fr": "..."
},
"description": {
"nl": "...",
"en": "...",
"fr": "..."
},
"specialty": false,
"active": false,
"only_order_in_store": false,
"price_type": "PER_UNIT",
"price": 11,
"target_price": true,
"url_type": "none",
"url": "https://example.com",
"min_max": {
"amount": {
"minimum": 16,
"maximum": 13,
"maximum_day": 17,
"maximum_week": 19
},
"weight": {
"minimum": 15,
"maximum": 11,
"maximum_day": 15,
"maximum_week": 17,
"suggested": 12
},
"persons": {
"minimum": 14,
"maximum": 19
}
},
"option_set_ids": [
15,
15,
11
],
"allergen_ids": [
17,
10,
16
],
"category_id": 12,
"seo": {
"title": {
"en": "Nostrum vitae incidunt maxime corrupti nihil error necessitatibus et."
},
"description": {
"en": "Enim voluptas laboriosam enim minus ea officia. Quis autem velit neque cumque consequatur. Consequatur dolor quaerat voluptates voluptatem ut labore tempora expedita."
},
"url": {
"en": "http://medhurst.com/corporis-eaque-aperiam-eos-officiis"
}
},
"price_look_up_code": "...",
"code": "...",
"origin": {
"nl": "...",
"en": "...",
"fr": "..."
},
"ingredients": {
"nl": "...",
"en": "...",
"fr": "..."
},
"temperature_type": "any",
"warranty_type": "none",
"warranty_price": 17,
"stock": {
"soldout": true,
"amount": 19,
"soldoutUntil": "2019-01-31 12:00"
},
"daysavailable": [
18,
13,
11
],
"upfront": {
"upfront_use_default": true,
"upfront_type": "days",
"upfront_days": 15,
"upfront_time": "12:00",
"upfront_hours": 13,
"upfront_minutes": 11
},
"use_pickup_after": true,
"pickup_after": "12:00",
"use_pickup_before": false,
"pickup_before": "12:00",
"related_products": [
14,
14,
16
]
},
{
"name": {
"nl": "...",
"en": "...",
"fr": "..."
},
"description": {
"nl": "...",
"en": "...",
"fr": "..."
},
"specialty": true,
"active": true,
"only_order_in_store": true,
"price_type": "PER_UNIT",
"price": 15,
"target_price": false,
"url_type": "none",
"url": "https://example.com",
"min_max": {
"amount": {
"minimum": 16,
"maximum": 17,
"maximum_day": 18,
"maximum_week": 16
},
"weight": {
"minimum": 12,
"maximum": 12,
"maximum_day": 19,
"maximum_week": 15,
"suggested": 14
},
"persons": {
"minimum": 12,
"maximum": 12
}
},
"option_set_ids": [
16,
17,
19
],
"allergen_ids": [
10,
15,
12
],
"category_id": 19,
"seo": {
"title": {
"en": "Ipsam fugit deserunt natus recusandae sint laboriosam incidunt molestiae quaerat ipsum."
},
"description": {
"en": "Cumque quam id ut fuga culpa. Molestiae quaerat ut fugiat repellendus fugiat. Quaerat voluptas corporis qui dolores id id."
},
"url": {
"en": "http://pollich.com/"
}
},
"price_look_up_code": "...",
"code": "...",
"origin": {
"nl": "...",
"en": "...",
"fr": "..."
},
"ingredients": {
"nl": "...",
"en": "...",
"fr": "..."
},
"temperature_type": "any",
"warranty_type": "none",
"warranty_price": 19,
"stock": {
"soldout": false,
"amount": 11,
"soldoutUntil": "2019-01-31 12:00"
},
"daysavailable": [
18,
15,
11
],
"upfront": {
"upfront_use_default": true,
"upfront_type": "days",
"upfront_days": 13,
"upfront_time": "12:00",
"upfront_hours": 13,
"upfront_minutes": 18
},
"use_pickup_after": true,
"pickup_after": "12:00",
"use_pickup_before": true,
"pickup_before": "12:00",
"related_products": [
12,
14,
17
]
}
]
Array of company.Product.detailed: [company.Product.detailed]
Field | Type | Description |
---|---|---|
name | [Language: String] | Name of the product |
description | [Language: String] | Description of the product |
specialty | Bool | Whether this product is a specialty. Specialties are also displayed in a separate category and are highlighted with a star icon. |
active | Bool | Inactive products are not visible in the webshop |
only_order_in_store | Bool | Whether this product can only get ordered in the store with a separate UI for the shop employees, and not in the public webshop. |
price_type | PriceType | A product has a price type that defines the price calculations and the way consumers can order the product. |
price | UInt | Price of the product (cents). Please note that this value is ignored when price_type is MULTIPLE_CHOICE. |
target_price | Bool | Is true when it's not possible to provide an exact price of this product when ordering (e.g. not exact weight possible). This option might deactive online payments for orders with this product (shop settings). |
url_type | String | String enumarion of 'none', 'recipe', 'website' |
url | URL? | Nullable. An URL field starting with http:// or https:// |
min_max | company.MinMaxSummary | The allowed amounts a customer is allowed to order of a product for amount / weight / persons |
images | [Image] | Array of Image |
product_prices | [company.ProductPrice] | Array of company.ProductPrice |
option_sets | [company.OptionSet.simple] | Array of company.OptionSet.simple |
id | Int | Id of the product |
allergens | [Allergen]? | Nullable. The allergens of this product. An empty array means no allergens. Null means no allergens specified (= can have allergens, ask in shop). |
category_id | Int | The category ID of the product |
price_look_up_code | String? | Nullable. A String value |
code | String? | Nullable. A custom code. You can set this to your own code and use this field to map your products to Bakeronline products |
seo | company.SeoData | Optional. Product page SEO metatags |
origin | [Language: String] | Optional. Origin of the product |
ingredients | [Language: String]? | Optional. Nullable. Ingredients that are in the product |
temperature_type | String? | Optional. Nullable. The temperature type when in a latch |
warranty_type | String? | Optional. Nullable. The type of warranty for this product |
warranty_price | UInt? | Optional. Nullable. Price of the warranty (cents). |
stock | company.Stock | Optional. The stock data for a product |
daysavailable | [Int] | Optional. Array of Int |
upfront | company.ProductUpfront | Optional. The upfront settings for a product |
use_pickup_after | Bool | Optional. Can pickup after a certain time be done? |
pickup_after | Time? | Optional. Nullable. Pickup of product after what time? |
use_pickup_before | Bool | Optional. Should a product be picked up before a certain time? |
pickup_before | Time? | Optional. Nullable. Pickup of product before what time? |
related_products | [Int] | Optional. List of related products, with a maximum of 8 |
HTTP/1.1 200 OK
Content-Type: application/json; charset=utf-8
Content-Length: 22650
[
{
"name": {
"nl": "...",
"en": "...",
"fr": "..."
},
"description": {
"nl": "...",
"en": "...",
"fr": "..."
},
"specialty": true,
"active": true,
"only_order_in_store": true,
"price_type": "PER_UNIT",
"price": 13,
"target_price": true,
"url_type": "none",
"url": "https://example.com",
"min_max": {
"amount": {
"minimum": 18,
"maximum": 13,
"maximum_day": 14,
"maximum_week": 14
},
"weight": {
"minimum": 15,
"maximum": 10,
"maximum_day": 18,
"maximum_week": 10,
"suggested": 11
},
"persons": {
"minimum": 19,
"maximum": 17
}
},
"images": [
{
"resolutions": [
{
"src": "https://example.com",
"width": 600,
"height": 350
},
{
"src": "https://example.com",
"width": 600,
"height": 350
},
{
"src": "https://example.com",
"width": 600,
"height": 350
}
],
"file_id": 14,
"white_background": false
},
{
"resolutions": [
{
"src": "https://example.com",
"width": 600,
"height": 350
},
{
"src": "https://example.com",
"width": 600,
"height": 350
},
{
"src": "https://example.com",
"width": 600,
"height": 350
}
],
"file_id": 19,
"white_background": false
},
{
"resolutions": [
{
"src": "https://example.com",
"width": 600,
"height": 350
},
{
"src": "https://example.com",
"width": 600,
"height": 350
},
{
"src": "https://example.com",
"width": 600,
"height": 350
}
],
"file_id": 10,
"white_background": false
}
],
"product_prices": [
{
"name": {
"nl": "...",
"en": "...",
"fr": "..."
},
"price": 19,
"id": 10,
"order": 14,
"price_look_up_code": "...",
"code": "..."
},
{
"name": {
"nl": "...",
"en": "...",
"fr": "..."
},
"price": 11,
"id": 17,
"order": 14,
"price_look_up_code": "...",
"code": "..."
},
{
"name": {
"nl": "...",
"en": "...",
"fr": "..."
},
"price": 17,
"id": 17,
"order": 13,
"price_look_up_code": "...",
"code": "..."
}
],
"option_sets": [
{
"name": {
"nl": "...",
"en": "...",
"fr": "..."
},
"allow_attachment": true,
"id": 15,
"code": "...",
"multiple_choice": true,
"choose_amount": true,
"min_different_options": 12,
"max_different_options": 19,
"min_amount_options": 16,
"max_amount_options": 16
},
{
"name": {
"nl": "...",
"en": "...",
"fr": "..."
},
"allow_attachment": true,
"id": 14,
"code": "...",
"multiple_choice": false,
"choose_amount": true,
"min_different_options": 10,
"max_different_options": 12,
"min_amount_options": 17,
"max_amount_options": 12
},
{
"name": {
"nl": "...",
"en": "...",
"fr": "..."
},
"allow_attachment": false,
"id": 16,
"code": "...",
"multiple_choice": true,
"choose_amount": true,
"min_different_options": 13,
"max_different_options": 18,
"min_amount_options": 12,
"max_amount_options": 14
}
],
"id": 13,
"allergens": [
{
"id": 10,
"name": "Milk"
},
{
"id": 18,
"name": "Fish"
},
{
"id": 17,
"name": "Nuts"
}
],
"category_id": 11,
"price_look_up_code": "...",
"code": "...",
"seo": {
"title": {
"en": "Optio impedit saepe mollitia dolor esse placeat."
},
"description": {
"en": "Suscipit porro quam minima incidunt qui est recusandae amet. Doloribus laboriosam perspiciatis et quod eveniet voluptates. Aut eos quo ullam temporibus excepturi voluptatem nihil est."
},
"url": {
"en": "http://www.schmidt.org/quis-totam-cum-et-tempore-eveniet-ea-sunt-fugit.html"
}
},
"origin": {
"nl": "...",
"en": "...",
"fr": "..."
},
"ingredients": {
"nl": "...",
"en": "...",
"fr": "..."
},
"temperature_type": "any",
"warranty_type": "none",
"warranty_price": 18,
"stock": {
"soldout": false,
"amount": 10,
"soldoutUntil": "2019-01-31 12:00"
},
"daysavailable": [
12,
15,
15
],
"upfront": {
"upfront_use_default": false,
"upfront_type": "days",
"upfront_days": 10,
"upfront_time": "12:00",
"upfront_hours": 15,
"upfront_minutes": 15
},
"use_pickup_after": true,
"pickup_after": "12:00",
"use_pickup_before": false,
"pickup_before": "12:00",
"related_products": [
12,
13,
17
]
},
{
"name": {
"nl": "...",
"en": "...",
"fr": "..."
},
"description": {
"nl": "...",
"en": "...",
"fr": "..."
},
"specialty": false,
"active": false,
"only_order_in_store": true,
"price_type": "PER_UNIT",
"price": 10,
"target_price": false,
"url_type": "none",
"url": "https://example.com",
"min_max": {
"amount": {
"minimum": 13,
"maximum": 15,
"maximum_day": 18,
"maximum_week": 14
},
"weight": {
"minimum": 14,
"maximum": 17,
"maximum_day": 16,
"maximum_week": 13,
"suggested": 12
},
"persons": {
"minimum": 19,
"maximum": 19
}
},
"images": [
{
"resolutions": [
{
"src": "https://example.com",
"width": 600,
"height": 350
},
{
"src": "https://example.com",
"width": 600,
"height": 350
},
{
"src": "https://example.com",
"width": 600,
"height": 350
}
],
"file_id": 13,
"white_background": true
},
{
"resolutions": [
{
"src": "https://example.com",
"width": 600,
"height": 350
},
{
"src": "https://example.com",
"width": 600,
"height": 350
},
{
"src": "https://example.com",
"width": 600,
"height": 350
}
],
"file_id": 16,
"white_background": true
},
{
"resolutions": [
{
"src": "https://example.com",
"width": 600,
"height": 350
},
{
"src": "https://example.com",
"width": 600,
"height": 350
},
{
"src": "https://example.com",
"width": 600,
"height": 350
}
],
"file_id": 11,
"white_background": false
}
],
"product_prices": [
{
"name": {
"nl": "...",
"en": "...",
"fr": "..."
},
"price": 19,
"id": 19,
"order": 19,
"price_look_up_code": "...",
"code": "..."
},
{
"name": {
"nl": "...",
"en": "...",
"fr": "..."
},
"price": 14,
"id": 18,
"order": 15,
"price_look_up_code": "...",
"code": "..."
},
{
"name": {
"nl": "...",
"en": "...",
"fr": "..."
},
"price": 13,
"id": 12,
"order": 10,
"price_look_up_code": "...",
"code": "..."
}
],
"option_sets": [
{
"name": {
"nl": "...",
"en": "...",
"fr": "..."
},
"allow_attachment": true,
"id": 12,
"code": "...",
"multiple_choice": false,
"choose_amount": false,
"min_different_options": 18,
"max_different_options": 17,
"min_amount_options": 17,
"max_amount_options": 18
},
{
"name": {
"nl": "...",
"en": "...",
"fr": "..."
},
"allow_attachment": false,
"id": 13,
"code": "...",
"multiple_choice": false,
"choose_amount": false,
"min_different_options": 12,
"max_different_options": 11,
"min_amount_options": 16,
"max_amount_options": 12
},
{
"name": {
"nl": "...",
"en": "...",
"fr": "..."
},
"allow_attachment": false,
"id": 15,
"code": "...",
"multiple_choice": true,
"choose_amount": false,
"min_different_options": 15,
"max_different_options": 19,
"min_amount_options": 15,
"max_amount_options": 17
}
],
"id": 12,
"allergens": [
{
"id": 10,
"name": "Mollusc"
},
{
"id": 19,
"name": "Sesame"
},
{
"id": 19,
"name": "Milk"
}
],
"category_id": 12,
"price_look_up_code": "...",
"code": "...",
"seo": {
"title": {
"en": "Et modi quis voluptatem consequatur et."
},
"description": {
"en": "Nam qui corrupti quos sint molestias quo. Sed veniam necessitatibus praesentium animi cumque."
},
"url": {
"en": "http://bogan.biz/"
}
},
"origin": {
"nl": "...",
"en": "...",
"fr": "..."
},
"ingredients": {
"nl": "...",
"en": "...",
"fr": "..."
},
"temperature_type": "any",
"warranty_type": "none",
"warranty_price": 17,
"stock": {
"soldout": true,
"amount": 12,
"soldoutUntil": "2019-01-31 12:00"
},
"daysavailable": [
13,
12,
19
],
"upfront": {
"upfront_use_default": false,
"upfront_type": "days",
"upfront_days": 11,
"upfront_time": "12:00",
"upfront_hours": 16,
"upfront_minutes": 12
},
"use_pickup_after": true,
"pickup_after": "12:00",
"use_pickup_before": true,
"pickup_before": "12:00",
"related_products": [
15,
16,
14
]
},
{
"name": {
"nl": "...",
"en": "...",
"fr": "..."
},
"description": {
"nl": "...",
"en": "...",
"fr": "..."
},
"specialty": false,
"active": false,
"only_order_in_store": false,
"price_type": "PER_UNIT",
"price": 17,
"target_price": true,
"url_type": "none",
"url": "https://example.com",
"min_max": {
"amount": {
"minimum": 10,
"maximum": 14,
"maximum_day": 16,
"maximum_week": 14
},
"weight": {
"minimum": 17,
"maximum": 14,
"maximum_day": 19,
"maximum_week": 15,
"suggested": 16
},
"persons": {
"minimum": 12,
"maximum": 16
}
},
"images": [
{
"resolutions": [
{
"src": "https://example.com",
"width": 600,
"height": 350
},
{
"src": "https://example.com",
"width": 600,
"height": 350
},
{
"src": "https://example.com",
"width": 600,
"height": 350
}
],
"file_id": 13,
"white_background": false
},
{
"resolutions": [
{
"src": "https://example.com",
"width": 600,
"height": 350
},
{
"src": "https://example.com",
"width": 600,
"height": 350
},
{
"src": "https://example.com",
"width": 600,
"height": 350
}
],
"file_id": 10,
"white_background": true
},
{
"resolutions": [
{
"src": "https://example.com",
"width": 600,
"height": 350
},
{
"src": "https://example.com",
"width": 600,
"height": 350
},
{
"src": "https://example.com",
"width": 600,
"height": 350
}
],
"file_id": 12,
"white_background": true
}
],
"product_prices": [
{
"name": {
"nl": "...",
"en": "...",
"fr": "..."
},
"price": 18,
"id": 18,
"order": 13,
"price_look_up_code": "...",
"code": "..."
},
{
"name": {
"nl": "...",
"en": "...",
"fr": "..."
},
"price": 19,
"id": 13,
"order": 12,
"price_look_up_code": "...",
"code": "..."
},
{
"name": {
"nl": "...",
"en": "...",
"fr": "..."
},
"price": 18,
"id": 13,
"order": 10,
"price_look_up_code": "...",
"code": "..."
}
],
"option_sets": [
{
"name": {
"nl": "...",
"en": "...",
"fr": "..."
},
"allow_attachment": false,
"id": 10,
"code": "...",
"multiple_choice": false,
"choose_amount": true,
"min_different_options": 13,
"max_different_options": 12,
"min_amount_options": 17,
"max_amount_options": 19
},
{
"name": {
"nl": "...",
"en": "...",
"fr": "..."
},
"allow_attachment": false,
"id": 17,
"code": "...",
"multiple_choice": false,
"choose_amount": false,
"min_different_options": 14,
"max_different_options": 12,
"min_amount_options": 11,
"max_amount_options": 10
},
{
"name": {
"nl": "...",
"en": "...",
"fr": "..."
},
"allow_attachment": true,
"id": 16,
"code": "...",
"multiple_choice": true,
"choose_amount": true,
"min_different_options": 16,
"max_different_options": 12,
"min_amount_options": 15,
"max_amount_options": 13
}
],
"id": 10,
"allergens": [
{
"id": 16,
"name": "Sulphite"
},
{
"id": 12,
"name": "Milk"
},
{
"id": 18,
"name": "Sesame"
}
],
"category_id": 15,
"price_look_up_code": "...",
"code": "...",
"seo": {
"title": {
"en": "Deserunt explicabo laboriosam libero consequatur aspernatur."
},
"description": {
"en": "Eum ut officiis nostrum nesciunt tempora. Autem vel occaecati ipsum quia ratione esse. Alias in ipsam asperiores perferendis cum facere aut. Doloribus voluptatem laboriosam voluptas."
},
"url": {
"en": "http://altenwerth.com/impedit-quis-ratione-id-fugit.html"
}
},
"origin": {
"nl": "...",
"en": "...",
"fr": "..."
},
"ingredients": {
"nl": "...",
"en": "...",
"fr": "..."
},
"temperature_type": "any",
"warranty_type": "none",
"warranty_price": 18,
"stock": {
"soldout": true,
"amount": 12,
"soldoutUntil": "2019-01-31 12:00"
},
"daysavailable": [
19,
12,
18
],
"upfront": {
"upfront_use_default": true,
"upfront_type": "days",
"upfront_days": 19,
"upfront_time": "12:00",
"upfront_hours": 16,
"upfront_minutes": 16
},
"use_pickup_after": true,
"pickup_after": "12:00",
"use_pickup_before": true,
"pickup_before": "12:00",
"related_products": [
14,
10,
13
]
}
]