 
                        
        
                        
        io.prediction.CreateItemRequestBuilder Maven / Gradle / Ivy
package io.prediction;
import com.ning.http.client.Request;
import com.ning.http.client.RequestBuilder;
import org.joda.time.DateTime;
import java.util.Arrays;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;
/**
 * Class to build Item requests
 *
 * @author The PredictionIO Team (http://prediction.io)
 * @version 0.4.2
 * @since 0.2
 */
public class CreateItemRequestBuilder {
    private String apiUrl;
    private String apiFormat;
    private String appkey;
    private String iid;
    private String[] itypes;
    private Double latitude;
    private Double longitude;
    private DateTime startT;
    private DateTime endT;
    private Map attributes;
    private static final String[] SYSTEM_ATTRIBUTES_VALUES = new String[] {"appkey", "iid", "itypes", "latlng", "startT", "endT"};
    private static final Set SYSTEM_ATTRIBUTES = new HashSet(Arrays.asList(SYSTEM_ATTRIBUTES_VALUES));
    /**
     * Instantiate a request builder with mandatory arguments.
     * 
     * Do not use this directly. Please refer to "See Also".
     *
     * @param apiUrl the API URL
     * @param apiFormat the return format of the API
     * @param appkey the new app key to be used
     * @param iid the item ID
     * @param itypes item types
     *
     * @see Client#getCreateItemRequestBuilder
     */
    public CreateItemRequestBuilder(String apiUrl, String apiFormat, String appkey, String iid, String[] itypes) {
        this.apiUrl = apiUrl;
        this.apiFormat = apiFormat;
        this.appkey = appkey;
        this.iid = iid;
        this.itypes = itypes;
        this.attributes = new HashMap();
    }
    /**
     * Add the "latitude" optional argument to the request.
     * 
     * Only certain data backend support geospatial indexing.
     * Please refer to the main documentation for more information.
     *
     * @param latitude latitude
     */
    public CreateItemRequestBuilder latitude(double latitude) {
        this.latitude = new Double(latitude);
        return this;
    }
    /**
     * Add the "longitude" optional argument to the request.
     * 
     * Only certain data backend support geospatial indexing.
     * Please refer to the main documentation for more information.
     *
     * @param longitude longitude
     */
    public CreateItemRequestBuilder longitude(double longitude) {
        this.longitude = new Double(longitude);
        return this;
    }
    /**
     * Add the "startT" optional argument to the request.
     *
     * @param startT the time when this item becomes valid
     */
    public CreateItemRequestBuilder startT(DateTime startT) {
        this.startT = startT;
        return this;
    }
    /**
     * Add the "endT" optional argument to the request.
     *
     * @param endT the time when this item becomes invalid
     */
    public CreateItemRequestBuilder endT(DateTime endT) {
        this.endT = endT;
        return this;
    }
    /**
     * Add optional custom item attributes argument to the request.
     * 
     * Notice that adding custom attributes with following names will be silently ignored as they collide with system attributes at the REST API:
     * 
     * - appkey
     * 
- iid
     * 
- itypes
     * 
- latlng
     * 
- startT
     * 
- endT
     * 
*
     * @param name name of the custom item attribute
     * @param value value of the custom item attribute
     */
    public CreateItemRequestBuilder attribute(String name, String value) {
        if (!SYSTEM_ATTRIBUTES.contains(name)) {
            this.attributes.put(name, value);
        }
        return this;
    }
    /**
     * Build a request.
     *
     * Do not use this directly. Please refer to "See Also".
     *
     * @see Client#createItem(CreateItemRequestBuilder)
     * @see Client#createItemAsFuture(CreateItemRequestBuilder)
     */
    public Request build() {
        RequestBuilder builder = new RequestBuilder("POST");
        builder.setUrl(this.apiUrl + "/items." + this.apiFormat);
        builder.addQueryParameter("appkey", this.appkey);
        builder.addQueryParameter("iid", this.iid);
        builder.addQueryParameter("itypes", Utils.arrayToString(this.itypes));
        if (this.latitude != null && this.longitude != null) {
            builder.addQueryParameter("latlng", this.latitude.toString() + "," + this.longitude.toString());
        }
        if (this.startT != null) {
            builder.addQueryParameter("startT", startT.toString());
        }
        if (this.endT != null) {
            builder.addQueryParameter("endT", endT.toString());
        }
        for (Map.Entry attribute : this.attributes.entrySet()) {
            if (attribute.getValue() != null) {
                builder.addQueryParameter(attribute.getKey(), attribute.getValue());
            }
        }
        return builder.build();
    }
}