com.twilio.rest.taskrouter.v1.workspace.WorkspaceStatisticsFetcher Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of twilio Show documentation
Show all versions of twilio Show documentation
Twilio Java Helper Library
/**
* This code was generated by
* \ / _ _ _| _ _
* | (_)\/(_)(_|\/| |(/_ v1.0.0
* / /
*/
package com.twilio.rest.taskrouter.v1.workspace;
import com.twilio.base.Fetcher;
import com.twilio.converter.DateConverter;
import com.twilio.exception.ApiConnectionException;
import com.twilio.exception.ApiException;
import com.twilio.exception.RestException;
import com.twilio.http.HttpMethod;
import com.twilio.http.Request;
import com.twilio.http.Response;
import com.twilio.http.TwilioRestClient;
import com.twilio.rest.Domains;
import java.time.ZonedDateTime;
public class WorkspaceStatisticsFetcher extends Fetcher {
private final String pathWorkspaceSid;
private Integer minutes;
private ZonedDateTime startDate;
private ZonedDateTime endDate;
private String taskChannel;
private String splitByWaitTime;
/**
* Construct a new WorkspaceStatisticsFetcher.
*
* @param pathWorkspaceSid The SID of the Workspace to fetch
*/
public WorkspaceStatisticsFetcher(final String pathWorkspaceSid) {
this.pathWorkspaceSid = pathWorkspaceSid;
}
/**
* Only calculate statistics since this many minutes in the past. The default 15
* minutes. This is helpful for displaying statistics for the last 15 minutes,
* 240 minutes (4 hours), and 480 minutes (8 hours) to see trends..
*
* @param minutes Only calculate statistics since this many minutes in the past
* @return this
*/
public WorkspaceStatisticsFetcher setMinutes(final Integer minutes) {
this.minutes = minutes;
return this;
}
/**
* Only calculate statistics from this date and time and later, specified in ISO 8601 format..
*
* @param startDate Only calculate statistics from on or after this date
* @return this
*/
public WorkspaceStatisticsFetcher setStartDate(final ZonedDateTime startDate) {
this.startDate = startDate;
return this;
}
/**
* Only calculate statistics from this date and time and earlier, specified in
* GMT as an ISO 8601
* date-time..
*
* @param endDate Only calculate statistics from this date and time and earlier
* @return this
*/
public WorkspaceStatisticsFetcher setEndDate(final ZonedDateTime endDate) {
this.endDate = endDate;
return this;
}
/**
* Only calculate statistics on this TaskChannel. Can be the TaskChannel's SID
* or its `unique_name`, such as `voice`, `sms`, or `default`..
*
* @param taskChannel Only calculate statistics on this TaskChannel.
* @return this
*/
public WorkspaceStatisticsFetcher setTaskChannel(final String taskChannel) {
this.taskChannel = taskChannel;
return this;
}
/**
* A comma separated list of values that describes the thresholds, in seconds,
* to calculate statistics on. For each threshold specified, the number of Tasks
* canceled and reservations accepted above and below the specified thresholds
* in seconds are computed. For example, `5,30` would show splits of Tasks that
* were canceled or accepted before and after 5 seconds and before and after 30
* seconds. This can be used to show short abandoned Tasks or Tasks that failed
* to meet an SLA..
*
* @param splitByWaitTime A comma separated list of values that describes the
* thresholds to calculate statistics on
* @return this
*/
public WorkspaceStatisticsFetcher setSplitByWaitTime(final String splitByWaitTime) {
this.splitByWaitTime = splitByWaitTime;
return this;
}
/**
* Make the request to the Twilio API to perform the fetch.
*
* @param client TwilioRestClient with which to make the request
* @return Fetched WorkspaceStatistics
*/
@Override
@SuppressWarnings("checkstyle:linelength")
public WorkspaceStatistics fetch(final TwilioRestClient client) {
Request request = new Request(
HttpMethod.GET,
Domains.TASKROUTER.toString(),
"/v1/Workspaces/" + this.pathWorkspaceSid + "/Statistics"
);
addQueryParams(request);
Response response = client.request(request);
if (response == null) {
throw new ApiConnectionException("WorkspaceStatistics fetch failed: Unable to connect to server");
} else if (!TwilioRestClient.SUCCESS.test(response.getStatusCode())) {
RestException restException = RestException.fromJson(response.getStream(), client.getObjectMapper());
if (restException == null) {
throw new ApiException("Server Error, no content");
}
throw new ApiException(restException);
}
return WorkspaceStatistics.fromJson(response.getStream(), client.getObjectMapper());
}
/**
* Add the requested query string arguments to the Request.
*
* @param request Request to add query string arguments to
*/
private void addQueryParams(final Request request) {
if (minutes != null) {
request.addQueryParam("Minutes", minutes.toString());
}
if (startDate != null) {
request.addQueryParam("StartDate", startDate.toString());
}
if (endDate != null) {
request.addQueryParam("EndDate", endDate.toString());
}
if (taskChannel != null) {
request.addQueryParam("TaskChannel", taskChannel);
}
if (splitByWaitTime != null) {
request.addQueryParam("SplitByWaitTime", splitByWaitTime);
}
}
}