All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.urbanairship.api.reports.CustomEventsDetailsListingRequest Maven / Gradle / Ivy

package com.urbanairship.api.reports;

import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.datatype.guava.GuavaModule;
import com.google.common.base.Preconditions;
import com.urbanairship.api.client.Request;
import com.urbanairship.api.client.RequestUtils;
import com.urbanairship.api.client.ResponseParser;
import com.urbanairship.api.common.parse.DateFormats;
import com.urbanairship.api.reports.model.CustomEventsDetailsListingResponse;
import com.urbanairship.api.reports.model.Precision;
import org.apache.http.HttpHeaders;
import org.apache.http.client.utils.URIBuilder;
import org.apache.http.entity.ContentType;
import org.joda.time.DateTime;

import java.io.IOException;
import java.net.URI;
import java.net.URISyntaxException;
import java.util.HashMap;
import java.util.Map;

/**
 * The CustomEventsDetailsListingRequest class builds a request to the custom events details listing api
 * endpoint to be executed in the {@link com.urbanairship.api.client.UrbanAirshipClient}
 */
public class CustomEventsDetailsListingRequest implements Request {
    private final static String API_RESPONSE_REPORT = "/api/reports/events/";
    private final String path;
    private final boolean nextPageRequest;
    private DateTime start;
    private DateTime end;
    private Precision precision;
    private Integer page;
    private Integer pageSize;

    private final static ObjectMapper mapper = new ObjectMapper();
    
    static {
        mapper.registerModule(new GuavaModule());
    }

    private CustomEventsDetailsListingRequest(DateTime start, DateTime end, String path, boolean nextPageRequest) {
        this.path = path;
        this.nextPageRequest = nextPageRequest;
        this.start = start;
        this.end = end;
    }

    /**
     * Create a Response Report request.
     *
     * @param start DateTime
     * @param end DateTime
     * @return CustomEventsDetailsListingRequest
     */
    public static CustomEventsDetailsListingRequest newRequest(DateTime start, DateTime end) {
        return new CustomEventsDetailsListingRequest(start, end, API_RESPONSE_REPORT, false);
    }

    /**
     * Create a new Response Report request using a next page URI.
     *
     * @param start DateTime
     * @param end DateTime
     * @param nextPage URI
     * @return CustomEventsDetailsListingRequest
     */
    public static CustomEventsDetailsListingRequest newRequest(DateTime start, DateTime end, URI nextPage) {
        Preconditions.checkNotNull(nextPage, "Next page URI cannot be null");
        return new CustomEventsDetailsListingRequest(start, end, nextPage.getPath() + "?" + nextPage.getQuery(), true);
    }

    /**
     * Set the precision parameter.
     *
     * @param precision Precision
     * @return CustomEventsDetailsListingRequest
     */
    public CustomEventsDetailsListingRequest setPrecision(Precision precision) {
        this.precision = precision;
        return this;
    }

    /**
     * Set the page parameter.
     *
     * @param page An int
     * @return CustomEventsDetailsListingRequest
     */
    public CustomEventsDetailsListingRequest setPage(Integer page) {
        this.page = page;
        return this;
    }

    /**
     * Set the page_size parameter.
     *
     * @param pageSize An int
     * @return CustomEventsDetailsListingRequest
     */
    public CustomEventsDetailsListingRequest setPageSize(Integer pageSize) {
        this.pageSize = pageSize;
        return this;
    }

    @Override
    public ContentType getContentType() {
        return ContentType.APPLICATION_JSON;
    }

    @Override
    public Request.HttpMethod getHttpMethod() {
        return Request.HttpMethod.GET;
    }

    @Override
    public String getRequestBody() {
        return null;
    }

    @Override
    public Map getRequestHeaders() {
        Map headers = new HashMap();
        headers.put(HttpHeaders.CONTENT_TYPE, CONTENT_TYPE_JSON);
        headers.put(HttpHeaders.ACCEPT, UA_VERSION_JSON);
        return headers;
    }

    @Override
    public URI getUri(URI baseUri) {
        URI uri;
        URIBuilder builder = new URIBuilder(RequestUtils.resolveURI(baseUri, path));

        if (!nextPageRequest) {
            Preconditions.checkNotNull(start, "start cannot be null");
            Preconditions.checkNotNull(end, "end cannot be null");
            Preconditions.checkArgument(end.isAfter(start), "end date must occur after start date");

            builder.addParameter("start", this.start.toString(DateFormats.DATE_FORMATTER));
            builder.addParameter("end", this.end.toString(DateFormats.DATE_FORMATTER));
            if (this.precision != null) {
                builder.addParameter("precision", this.precision.toString());
            }
            if (this.page != null) {
                builder.addParameter("page", this.page.toString());
            }
            if (this.pageSize != null) {
                builder.addParameter("page_size", this.pageSize.toString());
            }
        }

        try {
            uri = builder.build();
        } catch (URISyntaxException e) {
            throw new RuntimeException(e);
        }

        return uri;
    }

    @Override
    public ResponseParser getResponseParser() {
        return response -> mapper.readValue(response, CustomEventsDetailsListingResponse.class);
    }

    @Override
    public boolean bearerTokenAuthRequired() { 
        return false; 
    }

    @Override
    public boolean canUseBearerTokenAuth() {
        return true;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy