com.twilio.rest.ipmessaging.v1.service.Role 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.ipmessaging.v1.service;
import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.core.JsonParseException;
import com.fasterxml.jackson.databind.JsonMappingException;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.twilio.base.Resource;
import com.twilio.converter.DateConverter;
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 lombok.ToString;
import java.io.IOException;
import java.io.InputStream;
import java.net.URI;
import java.time.ZonedDateTime;
import java.util.List;
import java.util.Map;
import java.util.Objects;
@JsonIgnoreProperties(ignoreUnknown = true)
@ToString
public class Role extends Resource {
private static final long serialVersionUID = 78785177979928L;
public enum RoleType {
CHANNEL("channel"),
DEPLOYMENT("deployment");
private final String value;
private RoleType(final String value) {
this.value = value;
}
public String toString() {
return value;
}
/**
* Generate a RoleType from a string.
* @param value string value
* @return generated RoleType
*/
@JsonCreator
public static RoleType forValue(final String value) {
return Promoter.enumFromString(value, RoleType.values());
}
}
/**
* Create a RoleFetcher to execute fetch.
*
* @param pathServiceSid The service_sid
* @param pathSid The sid
* @return RoleFetcher capable of executing the fetch
*/
public static RoleFetcher fetcher(final String pathServiceSid,
final String pathSid) {
return new RoleFetcher(pathServiceSid, pathSid);
}
/**
* Create a RoleDeleter to execute delete.
*
* @param pathServiceSid The service_sid
* @param pathSid The sid
* @return RoleDeleter capable of executing the delete
*/
public static RoleDeleter deleter(final String pathServiceSid,
final String pathSid) {
return new RoleDeleter(pathServiceSid, pathSid);
}
/**
* Create a RoleCreator to execute create.
*
* @param pathServiceSid The service_sid
* @param friendlyName The friendly_name
* @param type The type
* @param permission The permission
* @return RoleCreator capable of executing the create
*/
public static RoleCreator creator(final String pathServiceSid,
final String friendlyName,
final Role.RoleType type,
final List permission) {
return new RoleCreator(pathServiceSid, friendlyName, type, permission);
}
/**
* Create a RoleReader to execute read.
*
* @param pathServiceSid The service_sid
* @return RoleReader capable of executing the read
*/
public static RoleReader reader(final String pathServiceSid) {
return new RoleReader(pathServiceSid);
}
/**
* Create a RoleUpdater to execute update.
*
* @param pathServiceSid The service_sid
* @param pathSid The sid
* @param permission The permission
* @return RoleUpdater capable of executing the update
*/
public static RoleUpdater updater(final String pathServiceSid,
final String pathSid,
final List permission) {
return new RoleUpdater(pathServiceSid, pathSid, permission);
}
/**
* Converts a JSON String into a Role object using the provided ObjectMapper.
*
* @param json Raw JSON String
* @param objectMapper Jackson ObjectMapper
* @return Role object represented by the provided JSON
*/
public static Role fromJson(final String json, final ObjectMapper objectMapper) {
// Convert all checked exceptions to Runtime
try {
return objectMapper.readValue(json, Role.class);
} catch (final JsonMappingException | JsonParseException e) {
throw new ApiException(e.getMessage(), e);
} catch (final IOException e) {
throw new ApiConnectionException(e.getMessage(), e);
}
}
/**
* Converts a JSON InputStream into a Role object using the provided
* ObjectMapper.
*
* @param json Raw JSON InputStream
* @param objectMapper Jackson ObjectMapper
* @return Role object represented by the provided JSON
*/
public static Role fromJson(final InputStream json, final ObjectMapper objectMapper) {
// Convert all checked exceptions to Runtime
try {
return objectMapper.readValue(json, Role.class);
} catch (final JsonMappingException | JsonParseException e) {
throw new ApiException(e.getMessage(), e);
} catch (final IOException e) {
throw new ApiConnectionException(e.getMessage(), e);
}
}
private final String sid;
private final String accountSid;
private final String serviceSid;
private final String friendlyName;
private final Role.RoleType type;
private final List permissions;
private final ZonedDateTime dateCreated;
private final ZonedDateTime dateUpdated;
private final URI url;
@JsonCreator
private Role(@JsonProperty("sid")
final String sid,
@JsonProperty("account_sid")
final String accountSid,
@JsonProperty("service_sid")
final String serviceSid,
@JsonProperty("friendly_name")
final String friendlyName,
@JsonProperty("type")
final Role.RoleType type,
@JsonProperty("permissions")
final List permissions,
@JsonProperty("date_created")
final String dateCreated,
@JsonProperty("date_updated")
final String dateUpdated,
@JsonProperty("url")
final URI url) {
this.sid = sid;
this.accountSid = accountSid;
this.serviceSid = serviceSid;
this.friendlyName = friendlyName;
this.type = type;
this.permissions = permissions;
this.dateCreated = DateConverter.iso8601DateTimeFromString(dateCreated);
this.dateUpdated = DateConverter.iso8601DateTimeFromString(dateUpdated);
this.url = url;
}
/**
* Returns The sid.
*
* @return The sid
*/
public final String getSid() {
return this.sid;
}
/**
* Returns The account_sid.
*
* @return The account_sid
*/
public final String getAccountSid() {
return this.accountSid;
}
/**
* Returns The service_sid.
*
* @return The service_sid
*/
public final String getServiceSid() {
return this.serviceSid;
}
/**
* Returns The friendly_name.
*
* @return The friendly_name
*/
public final String getFriendlyName() {
return this.friendlyName;
}
/**
* Returns The type.
*
* @return The type
*/
public final Role.RoleType getType() {
return this.type;
}
/**
* Returns The permissions.
*
* @return The permissions
*/
public final List getPermissions() {
return this.permissions;
}
/**
* Returns The date_created.
*
* @return The date_created
*/
public final ZonedDateTime getDateCreated() {
return this.dateCreated;
}
/**
* Returns The date_updated.
*
* @return The date_updated
*/
public final ZonedDateTime getDateUpdated() {
return this.dateUpdated;
}
/**
* Returns The url.
*
* @return The url
*/
public final URI getUrl() {
return this.url;
}
@Override
public boolean equals(final Object o) {
if (this == o) {
return true;
}
if (o == null || getClass() != o.getClass()) {
return false;
}
Role other = (Role) o;
return Objects.equals(sid, other.sid) &&
Objects.equals(accountSid, other.accountSid) &&
Objects.equals(serviceSid, other.serviceSid) &&
Objects.equals(friendlyName, other.friendlyName) &&
Objects.equals(type, other.type) &&
Objects.equals(permissions, other.permissions) &&
Objects.equals(dateCreated, other.dateCreated) &&
Objects.equals(dateUpdated, other.dateUpdated) &&
Objects.equals(url, other.url);
}
@Override
public int hashCode() {
return Objects.hash(sid,
accountSid,
serviceSid,
friendlyName,
type,
permissions,
dateCreated,
dateUpdated,
url);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy