CatalogApi v0.0.7 CatalogApi View Source
Contains top-level API functions for making requests to CatalogAPI.
Link to this section Summary
Functions
Adds the specified catalog item id to the user’s shopping cart
Places an order using the address and items in the cart. Deletes the cart if this request is successful. Returns an error if the order could not be placed
Sets the shipping address for the given user’s cart
Unlocks a cart that has been unlocked via the cart_validate method
Validates the address and items in the cart. This is intended to be called just before placing an order to make sure that the order would not be rejected
Returns the contents of the specified user’s shopping cart
Lists the orders placed by the user associated with the external_user_id
Provides tracking information for a specific order number. Provides information on the current status, as well as metadata around fulfillment
Searches for CatalogApi items which meet the specified criteria
Retrieves information about a specific CatalogApi item
Link to this section Functions
Adds the specified catalog item id to the user’s shopping cart.
Optional parameters include:
- option_id (optional): The id of the option for the item that should be added to the cart. If there are multiple options (such as color, size, etc.) for a given item, this allows the correct option to be added. This parameter is optional.
- quantity (default: 1): The quantity of the given item to add to the cart.
Places an order using the address and items in the cart. Deletes the cart if this request is successful. Returns an error if the order could not be placed.
There is one allowed optional parameter:
- cart_version: If this is supplied, this method will only succeed if the passed version matches the version of the current cart. This can be used to ensure that the state of the users cart in your application has not become stale before the order is placed.
cart_set_address(integer(), integer(), map()) :: {:ok, %{description: String.t()}} | {:error, CatalogApi.Address.invalid_address_error()} | {:error, {:bad_status, integer()}} | {:error, {:catalog_api_fault, CatalogApi.Error.extracted_fault()}} | {:error, Poison.ParseError.t()} | {:error, :unparseable_response_description}
Sets the shipping address for the given user’s cart.
Requires a socket_id, an external_user_id, and a map of address parameters.
The list of available address parameters can be found in the module documentation for CatalogApi.Address.
You can use a %CatalogApi.Address{}
struct for the address parameters
argument.
If the address parameters are not valid as per
CatalogApi.Address.validate_params/1
, then this function will return an error
tuple without making a call to the CatalogApi endpoint.
Unlocks a cart that has been unlocked via the cart_validate method.
Validates the address and items in the cart. This is intended to be called just before placing an order to make sure that the order would not be rejected.
If the locked argument is supplied as true, then the cart will be locked. A locked cart cannot be modified and the address cannot be changed. This should be used before processing a credit card transaction so that users cannot change relevant information after the transaction has been finalized.
cart_view(integer(), integer()) :: {:ok, %{items: [CatalogApi.Item.t()], status: map()}} | {:error, atom()}
Returns the contents of the specified user’s shopping cart.
The return contains the list of items in the cart casted as
CatalogApi.CartItem{}
structs.
The return also returns a map under the :status key which contains some information about the status of the cart. The keys contained in this map are as follows:
error
: An error string describing the error. When there is no error, this is “”.has_item_errors
: Boolean indicating whether the cart contains errors specific to items.is_valid
: Boolean indicating whether the cart is valid. If this is false, than this cart cannot be used to place an orderneeds_address
: Boolean indicating whether the cart is missing an address.locked
: Boolean indicating whether the cart is locked or not. If the cart is locked, an order can be placed with it, but it cannot be altered.cart_version
: A String uuid indicating the current version of the cart. This can be used to ensure that the cart which is being used to place an order has not changed since the application’s state has been updated.
Lists the orders placed by the user associated with the external_user_id.
Options that can be supplied:
per_page: Maximum number of results to be displayed per page. Defaults to
- Maximum of 50.
- page: Page of results to return.
Provides tracking information for a specific order number. Provides information on the current status, as well as metadata around fulfillment.
If the item is a gift card, then this method provides additional information around gift card redemption as well as other metadata.
search_catalog(integer(), map()) :: {:ok, %{items: CatalogApi.Item.t(), page_info: map()}} | {:error, {:bad_status, integer()}} | {:error, {:catalog_api_fault, CatalogApi.Error.extracted_fault()}} | {:error, Poison.ParseError.t()}
Searches for CatalogApi items which meet the specified criteria.
Requires a socket_id
and a list of criteria that returned items must match.
All search parameters are optional.
Allowed search parameters:
name
: The name of the item.search
: Matches the name, description or model of items.category_id
: Matches only items within this category_id. (This includes any child categories of the category_id.) The category_id comes from the catalog_breakdown method.min_points
: Matches only items that cost a greater or equal number of points.max_points
: Matches only items that cost a lesser or equal number of points.min_price
: Matches only items that cost a great or equal amount.max_price
: Matches only items that cost a lesser or equal amount.max_rank
: Matches only items with a rank lesser than or equal to the specified value. The rank of an item indicates its popularity between 1 and- A smaller value indicates a more popular item.
tag
: Matches items with custom tags.page
: The page to retrieve.per_page
: The quantity of items to retrieve per page. Must be between 1 and 50. The default is 10 if this parameter is not specifiedsort
: The method to use to sort the results. Allowed values are:"points desc"
- Will return items worth the most points first."points asc"
- Will return items worth the least points first."rank asc"
: Will return items with the most popular ones first."score desc"
(default): Will return items with the the most relevant ones first. Sorting by score only makes sense when you are searching with the “name” or “search” arguments."random asc"
: Will return the items in random order.
catalog_item_ids
: Accepts an array of items. Matches only items that ar in the given list
view_item(integer(), integer() | String.t()) :: {:ok, %{item: CatalogApi.Item.t()}} | {:error, {:bad_status, integer()}} | {:error, {:catalog_api_fault, CatalogApi.Error.extracted_fault()}} | {:error, Poison.ParseError.t()} | {:error, :item_not_found}
Retrieves information about a specific CatalogApi item.
Requires a socket_id and an item_id.
Returns a %CatalogApi.Item{}
struct upon a successful request.
If the item does not exist, this returns an error tuple of the format
{:error, :item_not_found}