com.twilio.rest.api.v2010.account.queue.MemberUpdater 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.api.v2010.account.queue;
import com.twilio.base.Updater;
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;
public class MemberUpdater extends Updater {
private String pathAccountSid;
private final String pathQueueSid;
private final String pathCallSid;
private final URI url;
private HttpMethod method;
/**
* Construct a new MemberUpdater.
*
* @param pathQueueSid The SID of the Queue in which to find the members
* @param pathCallSid The Call SID of the resource(s) to update
* @param url The absolute URL of the Queue resource
*/
public MemberUpdater(final String pathQueueSid,
final String pathCallSid,
final URI url) {
this.pathQueueSid = pathQueueSid;
this.pathCallSid = pathCallSid;
this.url = url;
}
/**
* Construct a new MemberUpdater.
*
* @param pathAccountSid The SID of the Account that created the resource(s) to
* update
* @param pathQueueSid The SID of the Queue in which to find the members
* @param pathCallSid The Call SID of the resource(s) to update
* @param url The absolute URL of the Queue resource
*/
public MemberUpdater(final String pathAccountSid,
final String pathQueueSid,
final String pathCallSid,
final URI url) {
this.pathAccountSid = pathAccountSid;
this.pathQueueSid = pathQueueSid;
this.pathCallSid = pathCallSid;
this.url = url;
}
/**
* How to pass the update request data. Can be `GET` or `POST` and the default
* is `POST`. `POST` sends the data as encoded form data and `GET` sends the
* data as query parameters..
*
* @param method How to pass the update request data
* @return this
*/
public MemberUpdater setMethod(final HttpMethod method) {
this.method = method;
return this;
}
/**
* Make the request to the Twilio API to perform the update.
*
* @param client TwilioRestClient with which to make the request
* @return Updated Member
*/
@Override
@SuppressWarnings("checkstyle:linelength")
public Member update(final TwilioRestClient client) {
this.pathAccountSid = this.pathAccountSid == null ? client.getAccountSid() : this.pathAccountSid;
Request request = new Request(
HttpMethod.POST,
Domains.API.toString(),
"/2010-04-01/Accounts/" + this.pathAccountSid + "/Queues/" + this.pathQueueSid + "/Members/" + this.pathCallSid + ".json"
);
addPostParams(request);
Response response = client.request(request);
if (response == null) {
throw new ApiConnectionException("Member update 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 Member.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 (url != null) {
request.addPostParam("Url", url.toString());
}
if (method != null) {
request.addPostParam("Method", method.toString());
}
}
}