com.twilio.rest.chat.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.chat.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.google.common.base.MoreObjects;
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 org.joda.time.DateTime;
import java.io.IOException;
import java.io.InputStream;
import java.net.URI;
import java.util.List;
import java.util.Map;
import java.util.Objects;
@JsonIgnoreProperties(ignoreUnknown = true)
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 human-readable name of this role.
* @param type What kind of role this is.
* @param permission A permission this role should have.
* @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 A permission this role should have.
* @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 DateTime dateCreated;
private final DateTime 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 A 34 character string that uniquely identifies this resource..
*
* @return A 34 character string that uniquely identifies this resource.
*/
public final String getSid() {
return this.sid;
}
/**
* Returns The The unique id of the Account responsible for this role..
*
* @return The unique id of the Account responsible for this role.
*/
public final String getAccountSid() {
return this.accountSid;
}
/**
* Returns The The unique id of the Service this role belongs to..
*
* @return The unique id of the Service this role belongs to.
*/
public final String getServiceSid() {
return this.serviceSid;
}
/**
* Returns The The human-readable name of this role..
*
* @return The human-readable name of this role.
*/
public final String getFriendlyName() {
return this.friendlyName;
}
/**
* Returns The What kind of role this is..
*
* @return What kind of role this is.
*/
public final Role.RoleType getType() {
return this.type;
}
/**
* Returns The A JSON array of the permissions this role has..
*
* @return A JSON array of the permissions this role has.
*/
public final List getPermissions() {
return this.permissions;
}
/**
* Returns The The date that this resource was created in ISO 8601 format..
*
* @return The date that this resource was created in ISO 8601 format.
*/
public final DateTime getDateCreated() {
return this.dateCreated;
}
/**
* Returns The The date that this resource was last updated in ISO 8601 format..
*
* @return The date that this resource was last updated in ISO 8601 format.
*/
public final DateTime getDateUpdated() {
return this.dateUpdated;
}
/**
* Returns The An absolute URL for this role..
*
* @return An absolute URL for this role.
*/
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);
}
@Override
public String toString() {
return MoreObjects.toStringHelper(this)
.add("sid", sid)
.add("accountSid", accountSid)
.add("serviceSid", serviceSid)
.add("friendlyName", friendlyName)
.add("type", type)
.add("permissions", permissions)
.add("dateCreated", dateCreated)
.add("dateUpdated", dateUpdated)
.add("url", url)
.toString();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy