com.twilio.rest.preview.bulkExports.ExportConfigurationUpdater 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.preview.bulkExports;
import com.twilio.base.Updater;
import com.twilio.converter.Promoter;
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.net.URI;
/**
* PLEASE NOTE that this class contains preview products that are subject to
* change. Use them with caution. If you currently do not have developer preview
* access, please contact [email protected].
*/
public class ExportConfigurationUpdater extends Updater {
private final String pathResourceType;
private Boolean enabled;
private URI webhookUrl;
private String webhookMethod;
/**
* Construct a new ExportConfigurationUpdater.
*
* @param pathResourceType The resource_type
*/
public ExportConfigurationUpdater(final String pathResourceType) {
this.pathResourceType = pathResourceType;
}
/**
* The enabled.
*
* @param enabled The enabled
* @return this
*/
public ExportConfigurationUpdater setEnabled(final Boolean enabled) {
this.enabled = enabled;
return this;
}
/**
* The webhook_url.
*
* @param webhookUrl The webhook_url
* @return this
*/
public ExportConfigurationUpdater setWebhookUrl(final URI webhookUrl) {
this.webhookUrl = webhookUrl;
return this;
}
/**
* The webhook_url.
*
* @param webhookUrl The webhook_url
* @return this
*/
public ExportConfigurationUpdater setWebhookUrl(final String webhookUrl) {
return setWebhookUrl(Promoter.uriFromString(webhookUrl));
}
/**
* The webhook_method.
*
* @param webhookMethod The webhook_method
* @return this
*/
public ExportConfigurationUpdater setWebhookMethod(final String webhookMethod) {
this.webhookMethod = webhookMethod;
return this;
}
/**
* Make the request to the Twilio API to perform the update.
*
* @param client TwilioRestClient with which to make the request
* @return Updated ExportConfiguration
*/
@Override
@SuppressWarnings("checkstyle:linelength")
public ExportConfiguration update(final TwilioRestClient client) {
Request request = new Request(
HttpMethod.POST,
Domains.PREVIEW.toString(),
"/BulkExports/Exports/" + this.pathResourceType + "/Configuration",
client.getRegion()
);
addPostParams(request);
Response response = client.request(request);
if (response == null) {
throw new ApiConnectionException("ExportConfiguration update failed: Unable to connect to server");
} else if (!TwilioRestClient.SUCCESS.apply(response.getStatusCode())) {
RestException restException = RestException.fromJson(response.getStream(), client.getObjectMapper());
if (restException == null) {
throw new ApiException("Server Error, no content");
}
throw new ApiException(
restException.getMessage(),
restException.getCode(),
restException.getMoreInfo(),
restException.getStatus(),
null
);
}
return ExportConfiguration.fromJson(response.getStream(), client.getObjectMapper());
}
/**
* Add the requested post parameters to the Request.
*
* @param request Request to add post params to
*/
private void addPostParams(final Request request) {
if (enabled != null) {
request.addPostParam("Enabled", enabled.toString());
}
if (webhookUrl != null) {
request.addPostParam("WebhookUrl", webhookUrl.toString());
}
if (webhookMethod != null) {
request.addPostParam("WebhookMethod", webhookMethod);
}
}
}