catalog_api = client.catalog
CatalogApi
- Batch Delete Catalog Objects
- Batch Retrieve Catalog Objects
- Batch Upsert Catalog Objects
- Create Catalog Image
- Catalog Info
- List Catalog
- Upsert Catalog Object
- Delete Catalog Object
- Retrieve Catalog Object
- Search Catalog Objects
- Search Catalog Items
- Update Item Modifier Lists
- Update Item Taxes
Deletes a set of CatalogItems based on the provided list of target IDs and returns a set of successfully deleted IDs in the response. Deletion is a cascading event such that all children of the targeted object are also deleted. For example, deleting a CatalogItem will also delete all of its CatalogItemVariation children.
BatchDeleteCatalogObjects
succeeds even if only a portion of the targeted
IDs can be deleted. The response will only include IDs that were
actually deleted.
def batch_delete_catalog_objects(body:)
Parameter | Type | Tags | Description |
---|---|---|---|
body |
Batch Delete Catalog Objects Request Hash |
Body, Required | An object containing the fields to POST for the request. See the corresponding object definition for field details. |
Batch Delete Catalog Objects Response Hash
body = {}
body[:object_ids] = ['W62UWFY35CWMYGVWK6TWJDNI', 'AA27W3M2GGTF3H6AVPNB77CK']
result = catalog_api.batch_delete_catalog_objects(body: body)
if result.success?
puts result.data
elsif result.error?
warn result.errors
end
Returns a set of objects based on the provided ID. Each CatalogItem returned in the set includes all of its child information including: all of its CatalogItemVariation objects, references to its CatalogModifierList objects, and the ids of any CatalogTax objects that apply to it.
def batch_retrieve_catalog_objects(body:)
Parameter | Type | Tags | Description |
---|---|---|---|
body |
Batch Retrieve Catalog Objects Request Hash |
Body, Required | An object containing the fields to POST for the request. See the corresponding object definition for field details. |
Batch Retrieve Catalog Objects Response Hash
body = {}
body[:object_ids] = ['W62UWFY35CWMYGVWK6TWJDNI', 'AA27W3M2GGTF3H6AVPNB77CK']
body[:include_related_objects] = true
body[:catalog_version] = 118
result = catalog_api.batch_retrieve_catalog_objects(body: body)
if result.success?
puts result.data
elsif result.error?
warn result.errors
end
Creates or updates up to 10,000 target objects based on the provided list of objects. The target objects are grouped into batches and each batch is inserted/updated in an all-or-nothing manner. If an object within a batch is malformed in some way, or violates a database constraint, the entire batch containing that item will be disregarded. However, other batches in the same request may still succeed. Each batch may contain up to 1,000 objects, and batches will be processed in order as long as the total object count for the request (items, variations, modifier lists, discounts, and taxes) is no more than 10,000.
def batch_upsert_catalog_objects(body:)
Parameter | Type | Tags | Description |
---|---|---|---|
body |
Batch Upsert Catalog Objects Request Hash |
Body, Required | An object containing the fields to POST for the request. See the corresponding object definition for field details. |
Batch Upsert Catalog Objects Response Hash
body = {}
body[:idempotency_key] = '789ff020-f723-43a9-b4b5-43b5dc1fa3dc'
body[:batches] = []
body[:batches][0] = {}
body[:batches][0][:objects] = []
body[:batches][0][:objects][0] = {}
body[:batches][0][:objects][0][:type] = 'ITEM'
body[:batches][0][:objects][0][:id] = '#Tea'
body[:batches][0][:objects][0][:updated_at] = 'updated_at6'
body[:batches][0][:objects][0][:version] = 252
body[:batches][0][:objects][0][:is_deleted] = false
body[:batches][0][:objects][0][:custom_attribute_values] = {}
body[:batches][0][:objects][0][:catalog_v1_ids] = []
body[:batches][0][:objects][0][:catalog_v1_ids][0] = {}
body[:batches][0][:objects][0][:catalog_v1_ids][0][:catalog_v1_id] = 'catalog_v1_id4'
body[:batches][0][:objects][0][:catalog_v1_ids][0][:location_id] = 'location_id4'
body[:batches][0][:objects][0][:present_at_all_locations] = true
body[:batches][0][:objects][0][:item_data] = {}
body[:batches][0][:objects][0][:item_data][:name] = 'Tea'
body[:batches][0][:objects][0][:item_data][:description] = 'Hot Leaf Juice'
body[:batches][0][:objects][0][:item_data][:abbreviation] = 'abbreviation0'
body[:batches][0][:objects][0][:item_data][:label_color] = 'label_color0'
body[:batches][0][:objects][0][:item_data][:available_online] = false
body[:batches][0][:objects][0][:item_data][:category_id] = '#Beverages'
body[:batches][0][:objects][0][:item_data][:tax_ids] = ['#SalesTax']
body[:batches][0][:objects][0][:item_data][:variations] = []
body[:batches][0][:objects][0][:item_data][:variations][0] = {}
body[:batches][0][:objects][0][:item_data][:variations][0][:type] = 'ITEM_VARIATION'
body[:batches][0][:objects][0][:item_data][:variations][0][:id] = '#Tea_Mug'
body[:batches][0][:objects][0][:item_data][:variations][0][:updated_at] = 'updated_at5'
body[:batches][0][:objects][0][:item_data][:variations][0][:version] = 99
body[:batches][0][:objects][0][:item_data][:variations][0][:is_deleted] = true
body[:batches][0][:objects][0][:item_data][:variations][0][:custom_attribute_values] = {}
body[:batches][0][:objects][0][:item_data][:variations][0][:catalog_v1_ids] = []
body[:batches][0][:objects][0][:item_data][:variations][0][:catalog_v1_ids][0] = {}
body[:batches][0][:objects][0][:item_data][:variations][0][:catalog_v1_ids][0][:catalog_v1_id] = 'catalog_v1_id3'
body[:batches][0][:objects][0][:item_data][:variations][0][:catalog_v1_ids][0][:location_id] = 'location_id3'
body[:batches][0][:objects][0][:item_data][:variations][0][:present_at_all_locations] = true
body[:batches][0][:objects][0][:item_data][:variations][0][:item_variation_data] = {}
body[:batches][0][:objects][0][:item_data][:variations][0][:item_variation_data][:item_id] = '#Tea'
body[:batches][0][:objects][0][:item_data][:variations][0][:item_variation_data][:name] = 'Mug'
body[:batches][0][:objects][0][:item_data][:variations][0][:item_variation_data][:sku] = 'sku9'
body[:batches][0][:objects][0][:item_data][:variations][0][:item_variation_data][:upc] = 'upc7'
body[:batches][0][:objects][0][:item_data][:variations][0][:item_variation_data][:ordinal] = 149
body[:batches][0][:objects][0][:item_data][:variations][0][:item_variation_data][:pricing_type] = 'FIXED_PRICING'
body[:batches][0][:objects][1] = {}
body[:batches][0][:objects][1][:type] = 'ITEM'
body[:batches][0][:objects][1][:id] = '#Coffee'
body[:batches][0][:objects][1][:updated_at] = 'updated_at7'
body[:batches][0][:objects][1][:version] = 253
body[:batches][0][:objects][1][:is_deleted] = true
body[:batches][0][:objects][1][:custom_attribute_values] = {}
body[:batches][0][:objects][1][:catalog_v1_ids] = []
body[:batches][0][:objects][1][:catalog_v1_ids][0] = {}
body[:batches][0][:objects][1][:catalog_v1_ids][0][:catalog_v1_id] = 'catalog_v1_id5'
body[:batches][0][:objects][1][:catalog_v1_ids][0][:location_id] = 'location_id5'
body[:batches][0][:objects][1][:catalog_v1_ids][1] = {}
body[:batches][0][:objects][1][:catalog_v1_ids][1][:catalog_v1_id] = 'catalog_v1_id6'
body[:batches][0][:objects][1][:catalog_v1_ids][1][:location_id] = 'location_id6'
body[:batches][0][:objects][1][:present_at_all_locations] = true
body[:batches][0][:objects][1][:item_data] = {}
body[:batches][0][:objects][1][:item_data][:name] = 'Coffee'
body[:batches][0][:objects][1][:item_data][:description] = 'Hot Bean Juice'
body[:batches][0][:objects][1][:item_data][:abbreviation] = 'abbreviation9'
body[:batches][0][:objects][1][:item_data][:label_color] = 'label_color9'
body[:batches][0][:objects][1][:item_data][:available_online] = true
body[:batches][0][:objects][1][:item_data][:category_id] = '#Beverages'
body[:batches][0][:objects][1][:item_data][:tax_ids] = ['#SalesTax']
body[:batches][0][:objects][1][:item_data][:variations] = []
body[:batches][0][:objects][1][:item_data][:variations][0] = {}
body[:batches][0][:objects][1][:item_data][:variations][0][:type] = 'ITEM_VARIATION'
body[:batches][0][:objects][1][:item_data][:variations][0][:id] = '#Coffee_Regular'
body[:batches][0][:objects][1][:item_data][:variations][0][:updated_at] = 'updated_at4'
body[:batches][0][:objects][1][:item_data][:variations][0][:version] = 100
body[:batches][0][:objects][1][:item_data][:variations][0][:is_deleted] = false
body[:batches][0][:objects][1][:item_data][:variations][0][:custom_attribute_values] = {}
body[:batches][0][:objects][1][:item_data][:variations][0][:catalog_v1_ids] = []
body[:batches][0][:objects][1][:item_data][:variations][0][:catalog_v1_ids][0] = {}
body[:batches][0][:objects][1][:item_data][:variations][0][:catalog_v1_ids][0][:catalog_v1_id] = 'catalog_v1_id4'
body[:batches][0][:objects][1][:item_data][:variations][0][:catalog_v1_ids][0][:location_id] = 'location_id4'
body[:batches][0][:objects][1][:item_data][:variations][0][:catalog_v1_ids][1] = {}
body[:batches][0][:objects][1][:item_data][:variations][0][:catalog_v1_ids][1][:catalog_v1_id] = 'catalog_v1_id5'
body[:batches][0][:objects][1][:item_data][:variations][0][:catalog_v1_ids][1][:location_id] = 'location_id5'
body[:batches][0][:objects][1][:item_data][:variations][0][:present_at_all_locations] = true
body[:batches][0][:objects][1][:item_data][:variations][0][:item_variation_data] = {}
body[:batches][0][:objects][1][:item_data][:variations][0][:item_variation_data][:item_id] = '#Coffee'
body[:batches][0][:objects][1][:item_data][:variations][0][:item_variation_data][:name] = 'Regular'
body[:batches][0][:objects][1][:item_data][:variations][0][:item_variation_data][:sku] = 'sku8'
body[:batches][0][:objects][1][:item_data][:variations][0][:item_variation_data][:upc] = 'upc6'
body[:batches][0][:objects][1][:item_data][:variations][0][:item_variation_data][:ordinal] = 150
body[:batches][0][:objects][1][:item_data][:variations][0][:item_variation_data][:pricing_type] = 'FIXED_PRICING'
body[:batches][0][:objects][1][:item_data][:variations][1] = {}
body[:batches][0][:objects][1][:item_data][:variations][1][:type] = 'ITEM_VARIATION'
body[:batches][0][:objects][1][:item_data][:variations][1][:id] = '#Coffee_Large'
body[:batches][0][:objects][1][:item_data][:variations][1][:updated_at] = 'updated_at3'
body[:batches][0][:objects][1][:item_data][:variations][1][:version] = 101
body[:batches][0][:objects][1][:item_data][:variations][1][:is_deleted] = true
body[:batches][0][:objects][1][:item_data][:variations][1][:custom_attribute_values] = {}
body[:batches][0][:objects][1][:item_data][:variations][1][:catalog_v1_ids] = []
body[:batches][0][:objects][1][:item_data][:variations][1][:catalog_v1_ids][0] = {}
body[:batches][0][:objects][1][:item_data][:variations][1][:catalog_v1_ids][0][:catalog_v1_id] = 'catalog_v1_id5'
body[:batches][0][:objects][1][:item_data][:variations][1][:catalog_v1_ids][0][:location_id] = 'location_id5'
body[:batches][0][:objects][1][:item_data][:variations][1][:catalog_v1_ids][1] = {}
body[:batches][0][:objects][1][:item_data][:variations][1][:catalog_v1_ids][1][:catalog_v1_id] = 'catalog_v1_id6'
body[:batches][0][:objects][1][:item_data][:variations][1][:catalog_v1_ids][1][:location_id] = 'location_id6'
body[:batches][0][:objects][1][:item_data][:variations][1][:catalog_v1_ids][2] = {}
body[:batches][0][:objects][1][:item_data][:variations][1][:catalog_v1_ids][2][:catalog_v1_id] = 'catalog_v1_id7'
body[:batches][0][:objects][1][:item_data][:variations][1][:catalog_v1_ids][2][:location_id] = 'location_id7'
body[:batches][0][:objects][1][:item_data][:variations][1][:present_at_all_locations] = true
body[:batches][0][:objects][1][:item_data][:variations][1][:item_variation_data] = {}
body[:batches][0][:objects][1][:item_data][:variations][1][:item_variation_data][:item_id] = '#Coffee'
body[:batches][0][:objects][1][:item_data][:variations][1][:item_variation_data][:name] = 'Large'
body[:batches][0][:objects][1][:item_data][:variations][1][:item_variation_data][:sku] = 'sku7'
body[:batches][0][:objects][1][:item_data][:variations][1][:item_variation_data][:upc] = 'upc5'
body[:batches][0][:objects][1][:item_data][:variations][1][:item_variation_data][:ordinal] = 151
body[:batches][0][:objects][1][:item_data][:variations][1][:item_variation_data][:pricing_type] = 'FIXED_PRICING'
body[:batches][0][:objects][2] = {}
body[:batches][0][:objects][2][:type] = 'CATEGORY'
body[:batches][0][:objects][2][:id] = '#Beverages'
body[:batches][0][:objects][2][:updated_at] = 'updated_at8'
body[:batches][0][:objects][2][:version] = 254
body[:batches][0][:objects][2][:is_deleted] = false
body[:batches][0][:objects][2][:custom_attribute_values] = {}
body[:batches][0][:objects][2][:catalog_v1_ids] = []
body[:batches][0][:objects][2][:catalog_v1_ids][0] = {}
body[:batches][0][:objects][2][:catalog_v1_ids][0][:catalog_v1_id] = 'catalog_v1_id6'
body[:batches][0][:objects][2][:catalog_v1_ids][0][:location_id] = 'location_id6'
body[:batches][0][:objects][2][:catalog_v1_ids][1] = {}
body[:batches][0][:objects][2][:catalog_v1_ids][1][:catalog_v1_id] = 'catalog_v1_id7'
body[:batches][0][:objects][2][:catalog_v1_ids][1][:location_id] = 'location_id7'
body[:batches][0][:objects][2][:catalog_v1_ids][2] = {}
body[:batches][0][:objects][2][:catalog_v1_ids][2][:catalog_v1_id] = 'catalog_v1_id8'
body[:batches][0][:objects][2][:catalog_v1_ids][2][:location_id] = 'location_id8'
body[:batches][0][:objects][2][:present_at_all_locations] = true
body[:batches][0][:objects][2][:category_data] = {}
body[:batches][0][:objects][2][:category_data][:name] = 'Beverages'
body[:batches][0][:objects][3] = {}
body[:batches][0][:objects][3][:type] = 'TAX'
body[:batches][0][:objects][3][:id] = '#SalesTax'
body[:batches][0][:objects][3][:updated_at] = 'updated_at9'
body[:batches][0][:objects][3][:version] = 255
body[:batches][0][:objects][3][:is_deleted] = true
body[:batches][0][:objects][3][:custom_attribute_values] = {}
body[:batches][0][:objects][3][:catalog_v1_ids] = []
body[:batches][0][:objects][3][:catalog_v1_ids][0] = {}
body[:batches][0][:objects][3][:catalog_v1_ids][0][:catalog_v1_id] = 'catalog_v1_id7'
body[:batches][0][:objects][3][:catalog_v1_ids][0][:location_id] = 'location_id7'
body[:batches][0][:objects][3][:present_at_all_locations] = true
body[:batches][0][:objects][3][:tax_data] = {}
body[:batches][0][:objects][3][:tax_data][:name] = 'Sales Tax'
body[:batches][0][:objects][3][:tax_data][:calculation_phase] = 'TAX_SUBTOTAL_PHASE'
body[:batches][0][:objects][3][:tax_data][:inclusion_type] = 'ADDITIVE'
body[:batches][0][:objects][3][:tax_data][:percentage] = '5.0'
body[:batches][0][:objects][3][:tax_data][:applies_to_custom_amounts] = true
body[:batches][0][:objects][3][:tax_data][:enabled] = true
result = catalog_api.batch_upsert_catalog_objects(body: body)
if result.success?
puts result.data
elsif result.error?
warn result.errors
end
Uploads an image file to be represented by a CatalogImage object linked to an existing CatalogObject instance. A call to this endpoint can upload an image, link an image to a catalog object, or do both.
This CreateCatalogImage
endpoint accepts HTTP multipart/form-data requests with a JSON part and an image file part in
JPEG, PJPEG, PNG, or GIF format. The maximum file size is 15MB.
def create_catalog_image(request: nil,
image_file: nil)
Parameter | Type | Tags | Description |
---|---|---|---|
request |
Create Catalog Image Request Hash |
Form, Optional | - |
image_file |
File | UploadIO |
Form, Optional | - |
Create Catalog Image Response Hash
request = {}
request[:idempotency_key] = '528dea59-7bfb-43c1-bd48-4a6bba7dd61f86'
request[:object_id] = 'ND6EA5AAJEO5WL3JNNIAQA32'
request[:image] = {}
request[:image][:type] = 'IMAGE'
request[:image][:id] = '#TEMP_ID'
request[:image][:updated_at] = 'updated_at4'
request[:image][:version] = 68
request[:image][:is_deleted] = false
request[:image][:custom_attribute_values] = {}
request[:image][:catalog_v1_ids] = []
request[:image][:catalog_v1_ids][0] = {}
request[:image][:catalog_v1_ids][0][:catalog_v1_id] = 'catalog_v1_id4'
request[:image][:catalog_v1_ids][0][:location_id] = 'location_id4'
request[:image][:image_data] = {}
request[:image][:image_data][:name] = 'name0'
request[:image][:image_data][:url] = 'url4'
request[:image][:image_data][:caption] = 'A picture of a cup of coffee'
image_file = FileWrapper.new(File::open('dummy_file', 'rb'), content_type: 'optional-content-type')
result = catalog_api.create_catalog_image(request: request, image_file: image_file)
if result.success?
puts result.data
elsif result.error?
warn result.errors
end
Retrieves information about the Square Catalog API, such as batch size
limits that can be used by the BatchUpsertCatalogObjects
endpoint.
def catalog_info
result = catalog_api.catalog_info()
if result.success?
puts result.data
elsif result.error?
warn result.errors
end
Returns a list of CatalogObjects that includes
all objects of a set of desired types (for example, all CatalogItem
and CatalogTax objects) in the catalog. The types
parameter
is specified as a comma-separated list of valid CatalogObject types:
ITEM
, ITEM_VARIATION
, MODIFIER
, MODIFIER_LIST
, CATEGORY
, DISCOUNT
, TAX
, IMAGE
.
Important: ListCatalog does not return deleted catalog items. To retrieve
deleted catalog items, use SearchCatalogObjects
and set the include_deleted_objects
attribute value to true
.
def list_catalog(cursor: nil,
types: nil,
catalog_version: nil)
Parameter | Type | Tags | Description |
---|---|---|---|
cursor |
String |
Query, Optional | The pagination cursor returned in the previous response. Leave unset for an initial request. The page size is currently set to be 100. See Pagination for more information. |
types |
String |
Query, Optional | An optional case-insensitive, comma-separated list of object types to retrieve, for exampleITEM,ITEM_VARIATION,CATEGORY,IMAGE .The legal values are taken from the CatalogObjectType enum: ITEM , ITEM_VARIATION , CATEGORY , DISCOUNT , TAX ,MODIFIER , MODIFIER_LIST , or IMAGE . |
catalog_version |
Long |
Query, Optional | The specific version of the catalog objects to be included in the response. This allows you to retrieve historical versions of objects. The specified version value is matched against the CatalogObjects' version attribute. |
cursor = 'cursor6'
types = 'types6'
catalog_version = 126
result = catalog_api.list_catalog(cursor: cursor, types: types, catalog_version: catalog_version)
if result.success?
puts result.data
elsif result.error?
warn result.errors
end
Creates or updates the target CatalogObject.
def upsert_catalog_object(body:)
Parameter | Type | Tags | Description |
---|---|---|---|
body |
Upsert Catalog Object Request Hash |
Body, Required | An object containing the fields to POST for the request. See the corresponding object definition for field details. |
Upsert Catalog Object Response Hash
body = {}
body[:idempotency_key] = 'af3d1afc-7212-4300-b463-0bfc5314a5ae'
body[:object] = {}
body[:object][:type] = 'ITEM'
body[:object][:id] = '#Cocoa'
body[:object][:updated_at] = 'updated_at8'
body[:object][:version] = 252
body[:object][:is_deleted] = false
body[:object][:custom_attribute_values] = {}
body[:object][:catalog_v1_ids] = []
body[:object][:catalog_v1_ids][0] = {}
body[:object][:catalog_v1_ids][0][:catalog_v1_id] = 'catalog_v1_id0'
body[:object][:catalog_v1_ids][0][:location_id] = 'location_id0'
body[:object][:catalog_v1_ids][1] = {}
body[:object][:catalog_v1_ids][1][:catalog_v1_id] = 'catalog_v1_id1'
body[:object][:catalog_v1_ids][1][:location_id] = 'location_id1'
body[:object][:catalog_v1_ids][2] = {}
body[:object][:catalog_v1_ids][2][:catalog_v1_id] = 'catalog_v1_id2'
body[:object][:catalog_v1_ids][2][:location_id] = 'location_id2'
body[:object][:item_data] = {}
body[:object][:item_data][:name] = 'Cocoa'
body[:object][:item_data][:description] = 'Hot chocolate'
body[:object][:item_data][:abbreviation] = 'Ch'
body[:object][:item_data][:label_color] = 'label_color4'
body[:object][:item_data][:available_online] = false
result = catalog_api.upsert_catalog_object(body: body)
if result.success?
puts result.data
elsif result.error?
warn result.errors
end
Deletes a single CatalogObject based on the provided ID and returns the set of successfully deleted IDs in the response. Deletion is a cascading event such that all children of the targeted object are also deleted. For example, deleting a CatalogItem will also delete all of its CatalogItemVariation children.
def delete_catalog_object(object_id:)
Parameter | Type | Tags | Description |
---|---|---|---|
object_id |
String |
Template, Required | The ID of the catalog object to be deleted. When an object is deleted, other objects in the graph that depend on that object will be deleted as well (for example, deleting a catalog item will delete its catalog item variations). |
Delete Catalog Object Response Hash
object_id = 'object_id8'
result = catalog_api.delete_catalog_object(object_id: object_id)
if result.success?
puts result.data
elsif result.error?
warn result.errors
end
Returns a single CatalogItem as a CatalogObject based on the provided ID. The returned object includes all of the relevant CatalogItem information including: CatalogItemVariation children, references to its CatalogModifierList objects, and the ids of any CatalogTax objects that apply to it.
def retrieve_catalog_object(object_id:,
include_related_objects: false,
catalog_version: nil)
Parameter | Type | Tags | Description |
---|---|---|---|
object_id |
String |
Template, Required | The object ID of any type of catalog objects to be retrieved. |
include_related_objects |
Boolean |
Query, Optional | If true , the response will include additional objects that are related to therequested object, as follows: If the object field of the response contains a CatalogItem , its associatedCatalogCategory , CatalogTax , CatalogImage and CatalogModifierList objects willbe returned in the related_objects field of the response. If the object field ofthe response contains a CatalogItemVariation , its parent CatalogItem will be returnedin the related_objects field of the response.Default value: false Default: false |
catalog_version |
Long |
Query, Optional | Requests objects as of a specific version of the catalog. This allows you to retrieve historical versions of objects. The value to retrieve a specific version of an object can be found in the version field of CatalogObjects. |
Retrieve Catalog Object Response Hash
object_id = 'object_id8'
include_related_objects = false
catalog_version = 126
result = catalog_api.retrieve_catalog_object(object_id: object_id, include_related_objects: include_related_objects, catalog_version: catalog_version)
if result.success?
puts result.data
elsif result.error?
warn result.errors
end
Searches for CatalogObject of any type by matching supported search attribute values, excluding custom attribute values on items or item variations, against one or more of the specified query expressions.
This (SearchCatalogObjects
) endpoint differs from the SearchCatalogItems
endpoint in the following aspects:
SearchCatalogItems
can only search for items or item variations, whereasSearchCatalogObjects
can search for any type of catalog objects.SearchCatalogItems
supports the custom attribute query filters to return items or item variations that contain custom attribute values, whereSearchCatalogObjects
does not.SearchCatalogItems
does not support theinclude_deleted_objects
filter to search for deleted items or item variations, whereasSearchCatalogObjects
does.- The both endpoints have different call conventions, including the query filter formats.
def search_catalog_objects(body:)
Parameter | Type | Tags | Description |
---|---|---|---|
body |
Search Catalog Objects Request Hash |
Body, Required | An object containing the fields to POST for the request. See the corresponding object definition for field details. |
Search Catalog Objects Response Hash
body = {}
body[:cursor] = 'cursor0'
body[:object_types] = ['ITEM']
body[:include_deleted_objects] = false
body[:include_related_objects] = false
body[:begin_time] = 'begin_time4'
body[:query] = {}
body[:query][:sorted_attribute_query] = {}
body[:query][:sorted_attribute_query][:attribute_name] = 'attribute_name6'
body[:query][:sorted_attribute_query][:initial_attribute_value] = 'initial_attribute_value4'
body[:query][:sorted_attribute_query][:sort_order] = 'DESC'
body[:query][:exact_query] = {}
body[:query][:exact_query][:attribute_name] = 'attribute_name2'
body[:query][:exact_query][:attribute_value] = 'attribute_value2'
body[:query][:set_query] = {}
body[:query][:set_query][:attribute_name] = 'attribute_name8'
body[:query][:set_query][:attribute_values] = ['attribute_values0']
body[:query][:prefix_query] = {}
body[:query][:prefix_query][:attribute_name] = 'name'
body[:query][:prefix_query][:attribute_prefix] = 'tea'
body[:query][:range_query] = {}
body[:query][:range_query][:attribute_name] = 'attribute_name6'
body[:query][:range_query][:attribute_min_value] = 14
body[:query][:range_query][:attribute_max_value] = 180
body[:limit] = 100
result = catalog_api.search_catalog_objects(body: body)
if result.success?
puts result.data
elsif result.error?
warn result.errors
end
Searches for catalog items or item variations by matching supported search attribute values, including custom attribute values, against one or more of the specified query expressions.
This (SearchCatalogItems
) endpoint differs from the SearchCatalogObjects
endpoint in the following aspects:
SearchCatalogItems
can only search for items or item variations, whereasSearchCatalogObjects
can search for any type of catalog objects.SearchCatalogItems
supports the custom attribute query filters to return items or item variations that contain custom attribute values, whereSearchCatalogObjects
does not.SearchCatalogItems
does not support theinclude_deleted_objects
filter to search for deleted items or item variations, whereasSearchCatalogObjects
does.- The both endpoints use different call conventions, including the query filter formats.
def search_catalog_items(body:)
Parameter | Type | Tags | Description |
---|---|---|---|
body |
Search Catalog Items Request Hash |
Body, Required | An object containing the fields to POST for the request. See the corresponding object definition for field details. |
Search Catalog Items Response Hash
body = {}
body[:text_filter] = 'red'
body[:category_ids] = ['WINE_CATEGORY_ID']
body[:stock_levels] = ['OUT', 'LOW']
body[:enabled_location_ids] = ['ATL_LOCATION_ID']
body[:cursor] = 'cursor0'
body[:limit] = 100
body[:sort_order] = 'ASC'
body[:product_types] = ['REGULAR']
body[:custom_attribute_filters] = []
body[:custom_attribute_filters][0] = {}
body[:custom_attribute_filters][0][:custom_attribute_definition_id] = 'VEGAN_DEFINITION_ID'
body[:custom_attribute_filters][0][:key] = 'key2'
body[:custom_attribute_filters][0][:string_filter] = 'string_filter4'
body[:custom_attribute_filters][0][:number_filter] = {}
body[:custom_attribute_filters][0][:number_filter][:min] = 'min0'
body[:custom_attribute_filters][0][:number_filter][:max] = 'max2'
body[:custom_attribute_filters][0][:selection_uids_filter] = ['selection_uids_filter2', 'selection_uids_filter3']
body[:custom_attribute_filters][0][:bool_filter] = true
body[:custom_attribute_filters][1] = {}
body[:custom_attribute_filters][1][:custom_attribute_definition_id] = 'BRAND_DEFINITION_ID'
body[:custom_attribute_filters][1][:key] = 'key3'
body[:custom_attribute_filters][1][:string_filter] = 'Dark Horse'
body[:custom_attribute_filters][1][:number_filter] = {}
body[:custom_attribute_filters][1][:number_filter][:min] = 'min1'
body[:custom_attribute_filters][1][:number_filter][:max] = 'max1'
body[:custom_attribute_filters][1][:selection_uids_filter] = ['selection_uids_filter1']
body[:custom_attribute_filters][2] = {}
body[:custom_attribute_filters][2][:custom_attribute_definition_id] = 'custom_attribute_definition_id8'
body[:custom_attribute_filters][2][:key] = 'VINTAGE'
body[:custom_attribute_filters][2][:string_filter] = 'string_filter6'
body[:custom_attribute_filters][2][:number_filter] = {}
body[:custom_attribute_filters][2][:number_filter][:min] = '2017'
body[:custom_attribute_filters][2][:number_filter][:max] = '2018'
body[:custom_attribute_filters][2][:selection_uids_filter] = ['selection_uids_filter0', 'selection_uids_filter1', 'selection_uids_filter2']
body[:custom_attribute_filters][3] = {}
body[:custom_attribute_filters][3][:custom_attribute_definition_id] = 'VARIETAL_DEFINITION_ID'
body[:custom_attribute_filters][3][:key] = 'key5'
body[:custom_attribute_filters][3][:string_filter] = 'string_filter7'
body[:custom_attribute_filters][3][:number_filter] = {}
body[:custom_attribute_filters][3][:number_filter][:min] = 'min3'
body[:custom_attribute_filters][3][:number_filter][:max] = 'max9'
body[:custom_attribute_filters][3][:selection_uids_filter] = ['selection_uids_filter9', 'selection_uids_filter0']
result = catalog_api.search_catalog_items(body: body)
if result.success?
puts result.data
elsif result.error?
warn result.errors
end
Updates the CatalogModifierList objects that apply to the targeted CatalogItem without having to perform an upsert on the entire item.
def update_item_modifier_lists(body:)
Parameter | Type | Tags | Description |
---|---|---|---|
body |
Update Item Modifier Lists Request Hash |
Body, Required | An object containing the fields to POST for the request. See the corresponding object definition for field details. |
Update Item Modifier Lists Response Hash
body = {}
body[:item_ids] = ['H42BRLUJ5KTZTTMPVSLFAACQ', '2JXOBJIHCWBQ4NZ3RIXQGJA6']
body[:modifier_lists_to_enable] = ['H42BRLUJ5KTZTTMPVSLFAACQ', '2JXOBJIHCWBQ4NZ3RIXQGJA6']
body[:modifier_lists_to_disable] = ['7WRC16CJZDVLSNDQ35PP6YAD']
result = catalog_api.update_item_modifier_lists(body: body)
if result.success?
puts result.data
elsif result.error?
warn result.errors
end
Updates the CatalogTax objects that apply to the targeted CatalogItem without having to perform an upsert on the entire item.
def update_item_taxes(body:)
Parameter | Type | Tags | Description |
---|---|---|---|
body |
Update Item Taxes Request Hash |
Body, Required | An object containing the fields to POST for the request. See the corresponding object definition for field details. |
Update Item Taxes Response Hash
body = {}
body[:item_ids] = ['H42BRLUJ5KTZTTMPVSLFAACQ', '2JXOBJIHCWBQ4NZ3RIXQGJA6']
body[:taxes_to_enable] = ['4WRCNHCJZDVLSNDQ35PP6YAD']
body[:taxes_to_disable] = ['AQCEGCEBBQONINDOHRGZISEX']
result = catalog_api.update_item_taxes(body: body)
if result.success?
puts result.data
elsif result.error?
warn result.errors
end