com.recombee.api_client.api_requests.ListItems Maven / Gradle / Ivy
package com.recombee.api_client.api_requests;
/*
This file is auto-generated, do not edit
*/
import java.util.Date;
import java.util.Map;
import java.util.HashMap;
import com.recombee.api_client.bindings.Logic;
import com.recombee.api_client.util.HTTPMethod;
/**
* Gets a list of IDs of items currently present in the catalog.
*/
public class ListItems extends Request {
/**
* Boolean-returning [ReQL](https://docs.recombee.com/reql.html) expression, which allows you to filter items to be listed. Only the items for which the expression is *true* will be returned.
*/
protected String filter;
/**
* The number of items to be listed.
*/
protected Long count;
/**
* Specifies the number of items to skip (ordered by `itemId`).
*/
protected Long offset;
/**
* With `returnProperties=true`, property values of the listed items are returned along with their IDs in a JSON dictionary.
* Example response:
* ```
* [
* {
* "itemId": "tv-178",
* "description": "4K TV with 3D feature",
* "categories": ["Electronics", "Televisions"],
* "price": 342,
* "url": "myshop.com/tv-178"
* },
* {
* "itemId": "mixer-42",
* "description": "Stainless Steel Mixer",
* "categories": ["Home & Kitchen"],
* "price": 39,
* "url": "myshop.com/mixer-42"
* }
* ]
* ```
*/
protected Boolean returnProperties;
/**
* Allows to specify, which properties should be returned when `returnProperties=true` is set. The properties are given as a comma-separated list.
* Example response for `includedProperties=description,price`:
* ```
* [
* {
* "itemId": "tv-178",
* "description": "4K TV with 3D feature",
* "price": 342
* },
* {
* "itemId": "mixer-42",
* "description": "Stainless Steel Mixer",
* "price": 39
* }
* ]
* ```
*/
protected String[] includedProperties;
/**
* Construct the request
*/
public ListItems () {
this.timeout = 100000;
}
/**
* @param filter Boolean-returning [ReQL](https://docs.recombee.com/reql.html) expression, which allows you to filter items to be listed. Only the items for which the expression is *true* will be returned.
*/
public ListItems setFilter(String filter) {
this.filter = filter;
return this;
}
/**
* @param count The number of items to be listed.
*/
public ListItems setCount(long count) {
this.count = count;
return this;
}
/**
* @param offset Specifies the number of items to skip (ordered by `itemId`).
*/
public ListItems setOffset(long offset) {
this.offset = offset;
return this;
}
/**
* @param returnProperties With `returnProperties=true`, property values of the listed items are returned along with their IDs in a JSON dictionary.
* Example response:
* ```
* [
* {
* "itemId": "tv-178",
* "description": "4K TV with 3D feature",
* "categories": ["Electronics", "Televisions"],
* "price": 342,
* "url": "myshop.com/tv-178"
* },
* {
* "itemId": "mixer-42",
* "description": "Stainless Steel Mixer",
* "categories": ["Home & Kitchen"],
* "price": 39,
* "url": "myshop.com/mixer-42"
* }
* ]
* ```
*/
public ListItems setReturnProperties(boolean returnProperties) {
this.returnProperties = returnProperties;
return this;
}
/**
* @param includedProperties Allows to specify, which properties should be returned when `returnProperties=true` is set. The properties are given as a comma-separated list.
* Example response for `includedProperties=description,price`:
* ```
* [
* {
* "itemId": "tv-178",
* "description": "4K TV with 3D feature",
* "price": 342
* },
* {
* "itemId": "mixer-42",
* "description": "Stainless Steel Mixer",
* "price": 39
* }
* ]
* ```
*/
public ListItems setIncludedProperties(String[] includedProperties) {
this.includedProperties = includedProperties;
return this;
}
public String getFilter() {
return this.filter;
}
public long getCount() {
return this.count;
}
public long getOffset() {
return this.offset;
}
public boolean getReturnProperties() {
if (this.returnProperties==null) return false;
return this.returnProperties;
}
public String[] getIncludedProperties() {
return this.includedProperties;
}
/**
* @return Used HTTP method
*/
@Override
public HTTPMethod getHTTPMethod() {
return HTTPMethod.GET;
}
/**
* @return URI to the endpoint including path parameters
*/
@Override
public String getPath() {
return "/items/list/";
}
/**
* Get query parameters
* @return Values of query parameters (name of parameter: value of the parameter)
*/
@Override
public Map getQueryParameters() {
HashMap params = new HashMap();
if (this.filter!=null) {
params.put("filter", this.filter.toString());
}
if (this.count!=null) {
params.put("count", this.count.toString());
}
if (this.offset!=null) {
params.put("offset", this.offset.toString());
}
if (this.returnProperties!=null) {
params.put("returnProperties", this.returnProperties.toString());
}
if (this.includedProperties!=null) {
String includedPropertiesStr = "";
for(String el: this.includedProperties) includedPropertiesStr += ((includedPropertiesStr.equals(""))?"":",") + el;
params.put("includedProperties", includedPropertiesStr);
}
return params;
}
/**
* Get body parameters
* @return Values of body parameters (name of parameter: value of the parameter)
*/
@Override
public Map getBodyParameters() {
HashMap params = new HashMap();
return params;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy