
com.twilio.rest.api.v2010.account.availablephonenumbercountry.VoipReader Maven / Gradle / Ivy
/**
* This code was generated by
* \ / _ _ _| _ _
* | (_)\/(_)(_|\/| |(/_ v1.0.0
* / /
*/
package com.twilio.rest.api.v2010.account.availablephonenumbercountry;
import com.twilio.base.Page;
import com.twilio.base.Reader;
import com.twilio.base.ResourceSet;
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;
public class VoipReader extends Reader {
private String pathAccountSid;
private final String pathCountryCode;
private Integer areaCode;
private String contains;
private Boolean smsEnabled;
private Boolean mmsEnabled;
private Boolean voiceEnabled;
private Boolean excludeAllAddressRequired;
private Boolean excludeLocalAddressRequired;
private Boolean excludeForeignAddressRequired;
private Boolean beta;
private com.twilio.type.PhoneNumber nearNumber;
private String nearLatLong;
private Integer distance;
private String inPostalCode;
private String inRegion;
private String inRateCenter;
private String inLata;
private String inLocality;
private Boolean faxEnabled;
/**
* Construct a new VoipReader.
*
* @param pathCountryCode The ISO Country code of the country from which to
* read phone numbers
*/
public VoipReader(final String pathCountryCode) {
this.pathCountryCode = pathCountryCode;
}
/**
* Construct a new VoipReader.
*
* @param pathAccountSid The SID of the Account requesting the
* AvailablePhoneNumber resources
* @param pathCountryCode The ISO Country code of the country from which to
* read phone numbers
*/
public VoipReader(final String pathAccountSid,
final String pathCountryCode) {
this.pathAccountSid = pathAccountSid;
this.pathCountryCode = pathCountryCode;
}
/**
* The area code of the phone numbers to read. Applies to only phone numbers in
* the US and Canada..
*
* @param areaCode The area code of the phone numbers to read
* @return this
*/
public VoipReader setAreaCode(final Integer areaCode) {
this.areaCode = areaCode;
return this;
}
/**
* The pattern on which to match phone numbers. Valid characters are `*`, `0-9`,
* `a-z`, and `A-Z`. The `*` character matches any single digit. For examples,
* see Example
* 2 and Example
* 3. If specified, this value must have at least two characters..
*
* @param contains The pattern on which to match phone numbers
* @return this
*/
public VoipReader setContains(final String contains) {
this.contains = contains;
return this;
}
/**
* Whether the phone numbers can receive text messages. Can be: `true` or
* `false`..
*
* @param smsEnabled Whether the phone numbers can receive text messages
* @return this
*/
public VoipReader setSmsEnabled(final Boolean smsEnabled) {
this.smsEnabled = smsEnabled;
return this;
}
/**
* Whether the phone numbers can receive MMS messages. Can be: `true` or
* `false`..
*
* @param mmsEnabled Whether the phone numbers can receive MMS messages
* @return this
*/
public VoipReader setMmsEnabled(final Boolean mmsEnabled) {
this.mmsEnabled = mmsEnabled;
return this;
}
/**
* Whether the phone numbers can receive calls. Can be: `true` or `false`..
*
* @param voiceEnabled Whether the phone numbers can receive calls.
* @return this
*/
public VoipReader setVoiceEnabled(final Boolean voiceEnabled) {
this.voiceEnabled = voiceEnabled;
return this;
}
/**
* Whether to exclude phone numbers that require an Address. Can be:
* `true` or `false` and the default is `false`..
*
* @param excludeAllAddressRequired Whether to exclude phone numbers that
* require an Address
* @return this
*/
public VoipReader setExcludeAllAddressRequired(final Boolean excludeAllAddressRequired) {
this.excludeAllAddressRequired = excludeAllAddressRequired;
return this;
}
/**
* Whether to exclude phone numbers that require a local Address. Can be:
* `true` or `false` and the default is `false`..
*
* @param excludeLocalAddressRequired Whether to exclude phone numbers that
* require a local address
* @return this
*/
public VoipReader setExcludeLocalAddressRequired(final Boolean excludeLocalAddressRequired) {
this.excludeLocalAddressRequired = excludeLocalAddressRequired;
return this;
}
/**
* Whether to exclude phone numbers that require a foreign Address. Can be:
* `true` or `false` and the default is `false`..
*
* @param excludeForeignAddressRequired Whether to exclude phone numbers that
* require a foreign address
* @return this
*/
public VoipReader setExcludeForeignAddressRequired(final Boolean excludeForeignAddressRequired) {
this.excludeForeignAddressRequired = excludeForeignAddressRequired;
return this;
}
/**
* Whether to read phone numbers that are new to the Twilio platform. Can be:
* `true` or `false` and the default is `true`..
*
* @param beta Whether to read phone numbers new to the Twilio platform
* @return this
*/
public VoipReader setBeta(final Boolean beta) {
this.beta = beta;
return this;
}
/**
* Given a phone number, find a geographically close number within `distance`
* miles. Distance defaults to 25 miles. Applies to only phone numbers in the US
* and Canada..
*
* @param nearNumber Given a phone number, find a geographically close number
* within distance miles. (US/Canada only)
* @return this
*/
public VoipReader setNearNumber(final com.twilio.type.PhoneNumber nearNumber) {
this.nearNumber = nearNumber;
return this;
}
/**
* Given a phone number, find a geographically close number within `distance`
* miles. Distance defaults to 25 miles. Applies to only phone numbers in the US
* and Canada..
*
* @param nearNumber Given a phone number, find a geographically close number
* within distance miles. (US/Canada only)
* @return this
*/
public VoipReader setNearNumber(final String nearNumber) {
return setNearNumber(Promoter.phoneNumberFromString(nearNumber));
}
/**
* Given a latitude/longitude pair `lat,long` find geographically close numbers
* within `distance` miles. Applies to only phone numbers in the US and Canada..
*
* @param nearLatLong Given a latitude/longitude pair lat,long find
* geographically close numbers within distance miles.
* (US/Canada only)
* @return this
*/
public VoipReader setNearLatLong(final String nearLatLong) {
this.nearLatLong = nearLatLong;
return this;
}
/**
* The search radius, in miles, for a `near_` query. Can be up to `500` and the
* default is `25`. Applies to only phone numbers in the US and Canada..
*
* @param distance The search radius, in miles, for a near_ query. (US/Canada
* only)
* @return this
*/
public VoipReader setDistance(final Integer distance) {
this.distance = distance;
return this;
}
/**
* Limit results to a particular postal code. Given a phone number, search
* within the same postal code as that number. Applies to only phone numbers in
* the US and Canada..
*
* @param inPostalCode Limit results to a particular postal code. (US/Canada
* only)
* @return this
*/
public VoipReader setInPostalCode(final String inPostalCode) {
this.inPostalCode = inPostalCode;
return this;
}
/**
* Limit results to a particular region, state, or province. Given a phone
* number, search within the same region as that number. Applies to only phone
* numbers in the US and Canada..
*
* @param inRegion Limit results to a particular region. (US/Canada only)
* @return this
*/
public VoipReader setInRegion(final String inRegion) {
this.inRegion = inRegion;
return this;
}
/**
* Limit results to a specific rate center, or given a phone number search
* within the same rate center as that number. Requires `in_lata` to be set as
* well. Applies to only phone numbers in the US and Canada..
*
* @param inRateCenter Limit results to a specific rate center, or given a
* phone number search within the same rate center as that
* number. (US/Canada only)
* @return this
*/
public VoipReader setInRateCenter(final String inRateCenter) {
this.inRateCenter = inRateCenter;
return this;
}
/**
* Limit results to a specific local access and transport area (LATA).
* Given a phone number, search within the same LATA
* as that number. Applies to only phone numbers in the US and Canada..
*
* @param inLata Limit results to a specific local access and transport area.
* (US/Canada only)
* @return this
*/
public VoipReader setInLata(final String inLata) {
this.inLata = inLata;
return this;
}
/**
* Limit results to a particular locality or city. Given a phone number, search
* within the same Locality as that number..
*
* @param inLocality Limit results to a particular locality
* @return this
*/
public VoipReader setInLocality(final String inLocality) {
this.inLocality = inLocality;
return this;
}
/**
* Whether the phone numbers can receive faxes. Can be: `true` or `false`..
*
* @param faxEnabled Whether the phone numbers can receive faxes
* @return this
*/
public VoipReader setFaxEnabled(final Boolean faxEnabled) {
this.faxEnabled = faxEnabled;
return this;
}
/**
* Make the request to the Twilio API to perform the read.
*
* @param client TwilioRestClient with which to make the request
* @return Voip ResourceSet
*/
@Override
public ResourceSet read(final TwilioRestClient client) {
return new ResourceSet<>(this, client, firstPage(client));
}
/**
* Make the request to the Twilio API to perform the read.
*
* @param client TwilioRestClient with which to make the request
* @return Voip ResourceSet
*/
@Override
@SuppressWarnings("checkstyle:linelength")
public Page firstPage(final TwilioRestClient client) {
this.pathAccountSid = this.pathAccountSid == null ? client.getAccountSid() : this.pathAccountSid;
Request request = new Request(
HttpMethod.GET,
Domains.API.toString(),
"/2010-04-01/Accounts/" + this.pathAccountSid + "/AvailablePhoneNumbers/" + this.pathCountryCode + "/Voip.json"
);
addQueryParams(request);
return pageForRequest(client, request);
}
/**
* Retrieve the target page from the Twilio API.
*
* @param targetUrl API-generated URL for the requested results page
* @param client TwilioRestClient with which to make the request
* @return Voip ResourceSet
*/
@Override
@SuppressWarnings("checkstyle:linelength")
public Page getPage(final String targetUrl, final TwilioRestClient client) {
this.pathAccountSid = this.pathAccountSid == null ? client.getAccountSid() : this.pathAccountSid;
Request request = new Request(
HttpMethod.GET,
targetUrl
);
return pageForRequest(client, request);
}
/**
* Retrieve the next page from the Twilio API.
*
* @param page current page
* @param client TwilioRestClient with which to make the request
* @return Next Page
*/
@Override
public Page nextPage(final Page page,
final TwilioRestClient client) {
Request request = new Request(
HttpMethod.GET,
page.getNextPageUrl(Domains.API.toString())
);
return pageForRequest(client, request);
}
/**
* Retrieve the previous page from the Twilio API.
*
* @param page current page
* @param client TwilioRestClient with which to make the request
* @return Previous Page
*/
@Override
public Page previousPage(final Page page,
final TwilioRestClient client) {
Request request = new Request(
HttpMethod.GET,
page.getPreviousPageUrl(Domains.API.toString())
);
return pageForRequest(client, request);
}
/**
* Generate a Page of Voip Resources for a given request.
*
* @param client TwilioRestClient with which to make the request
* @param request Request to generate a page for
* @return Page for the Request
*/
private Page pageForRequest(final TwilioRestClient client, final Request request) {
Response response = client.request(request);
if (response == null) {
throw new ApiConnectionException("Voip read 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 Page.fromJson(
"available_phone_numbers",
response.getContent(),
Voip.class,
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 (areaCode != null) {
request.addQueryParam("AreaCode", areaCode.toString());
}
if (contains != null) {
request.addQueryParam("Contains", contains);
}
if (smsEnabled != null) {
request.addQueryParam("SmsEnabled", smsEnabled.toString());
}
if (mmsEnabled != null) {
request.addQueryParam("MmsEnabled", mmsEnabled.toString());
}
if (voiceEnabled != null) {
request.addQueryParam("VoiceEnabled", voiceEnabled.toString());
}
if (excludeAllAddressRequired != null) {
request.addQueryParam("ExcludeAllAddressRequired", excludeAllAddressRequired.toString());
}
if (excludeLocalAddressRequired != null) {
request.addQueryParam("ExcludeLocalAddressRequired", excludeLocalAddressRequired.toString());
}
if (excludeForeignAddressRequired != null) {
request.addQueryParam("ExcludeForeignAddressRequired", excludeForeignAddressRequired.toString());
}
if (beta != null) {
request.addQueryParam("Beta", beta.toString());
}
if (nearNumber != null) {
request.addQueryParam("NearNumber", nearNumber.toString());
}
if (nearLatLong != null) {
request.addQueryParam("NearLatLong", nearLatLong);
}
if (distance != null) {
request.addQueryParam("Distance", distance.toString());
}
if (inPostalCode != null) {
request.addQueryParam("InPostalCode", inPostalCode);
}
if (inRegion != null) {
request.addQueryParam("InRegion", inRegion);
}
if (inRateCenter != null) {
request.addQueryParam("InRateCenter", inRateCenter);
}
if (inLata != null) {
request.addQueryParam("InLata", inLata);
}
if (inLocality != null) {
request.addQueryParam("InLocality", inLocality);
}
if (faxEnabled != null) {
request.addQueryParam("FaxEnabled", faxEnabled.toString());
}
if (getPageSize() != null) {
request.addQueryParam("PageSize", Integer.toString(getPageSize()));
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy