com.twilio.rest.serverless.v1.service.asset.AssetVersion 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.serverless.v1.service.asset;
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.Map;
import java.util.Objects;
/**
* PLEASE NOTE that this class contains beta products that are subject to
* change. Use them with caution.
*/
@JsonIgnoreProperties(ignoreUnknown = true)
@ToString
public class AssetVersion extends Resource {
private static final long serialVersionUID = 182506144428248L;
public enum Visibility {
PUBLIC("public"),
PRIVATE("private"),
PROTECTED("protected");
private final String value;
private Visibility(final String value) {
this.value = value;
}
public String toString() {
return value;
}
/**
* Generate a Visibility from a string.
* @param value string value
* @return generated Visibility
*/
@JsonCreator
public static Visibility forValue(final String value) {
return Promoter.enumFromString(value, Visibility.values());
}
}
/**
* Create a AssetVersionReader to execute read.
*
* @param pathServiceSid The SID of the Service to read the Asset Version
* resource from
* @param pathAssetSid The SID of the Asset resource that is the parent of the
* Asset Version resources to read
* @return AssetVersionReader capable of executing the read
*/
public static AssetVersionReader reader(final String pathServiceSid,
final String pathAssetSid) {
return new AssetVersionReader(pathServiceSid, pathAssetSid);
}
/**
* Create a AssetVersionFetcher to execute fetch.
*
* @param pathServiceSid The SID of the Service to fetch the Asset Version
* resource from
* @param pathAssetSid The SID of the Asset resource that is the parent of the
* Asset Version resource to fetch
* @param pathSid The SID that identifies the Asset Version resource to fetch
* @return AssetVersionFetcher capable of executing the fetch
*/
public static AssetVersionFetcher fetcher(final String pathServiceSid,
final String pathAssetSid,
final String pathSid) {
return new AssetVersionFetcher(pathServiceSid, pathAssetSid, pathSid);
}
/**
* Converts a JSON String into a AssetVersion object using the provided
* ObjectMapper.
*
* @param json Raw JSON String
* @param objectMapper Jackson ObjectMapper
* @return AssetVersion object represented by the provided JSON
*/
public static AssetVersion fromJson(final String json, final ObjectMapper objectMapper) {
// Convert all checked exceptions to Runtime
try {
return objectMapper.readValue(json, AssetVersion.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 AssetVersion object using the provided
* ObjectMapper.
*
* @param json Raw JSON InputStream
* @param objectMapper Jackson ObjectMapper
* @return AssetVersion object represented by the provided JSON
*/
public static AssetVersion fromJson(final InputStream json, final ObjectMapper objectMapper) {
// Convert all checked exceptions to Runtime
try {
return objectMapper.readValue(json, AssetVersion.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 assetSid;
private final String path;
private final AssetVersion.Visibility visibility;
private final ZonedDateTime dateCreated;
private final URI url;
@JsonCreator
private AssetVersion(@JsonProperty("sid")
final String sid,
@JsonProperty("account_sid")
final String accountSid,
@JsonProperty("service_sid")
final String serviceSid,
@JsonProperty("asset_sid")
final String assetSid,
@JsonProperty("path")
final String path,
@JsonProperty("visibility")
final AssetVersion.Visibility visibility,
@JsonProperty("date_created")
final String dateCreated,
@JsonProperty("url")
final URI url) {
this.sid = sid;
this.accountSid = accountSid;
this.serviceSid = serviceSid;
this.assetSid = assetSid;
this.path = path;
this.visibility = visibility;
this.dateCreated = DateConverter.iso8601DateTimeFromString(dateCreated);
this.url = url;
}
/**
* Returns The unique string that identifies the Asset Version resource.
*
* @return The unique string that identifies the Asset Version resource
*/
public final String getSid() {
return this.sid;
}
/**
* Returns The SID of the Account that created the Asset Version resource.
*
* @return The SID of the Account that created the Asset Version resource
*/
public final String getAccountSid() {
return this.accountSid;
}
/**
* Returns The SID of the Service that the Asset Version resource is associated
* with.
*
* @return The SID of the Service that the Asset Version resource is associated
* with
*/
public final String getServiceSid() {
return this.serviceSid;
}
/**
* Returns The SID of the Asset resource that is the parent of the Asset
* Version.
*
* @return The SID of the Asset resource that is the parent of the Asset Version
*/
public final String getAssetSid() {
return this.assetSid;
}
/**
* Returns The URL-friendly string by which the Asset Version can be referenced.
*
* @return The URL-friendly string by which the Asset Version can be referenced
*/
public final String getPath() {
return this.path;
}
/**
* Returns The access control that determines how the Asset Version can be
* accessed.
*
* @return The access control that determines how the Asset Version can be
* accessed
*/
public final AssetVersion.Visibility getVisibility() {
return this.visibility;
}
/**
* Returns The ISO 8601 date and time in GMT when the Asset Version resource was
* created.
*
* @return The ISO 8601 date and time in GMT when the Asset Version resource
* was created
*/
public final ZonedDateTime getDateCreated() {
return this.dateCreated;
}
/**
* Returns The absolute URL of the Asset Version resource.
*
* @return The absolute URL of the Asset Version resource
*/
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;
}
AssetVersion other = (AssetVersion) o;
return Objects.equals(sid, other.sid) &&
Objects.equals(accountSid, other.accountSid) &&
Objects.equals(serviceSid, other.serviceSid) &&
Objects.equals(assetSid, other.assetSid) &&
Objects.equals(path, other.path) &&
Objects.equals(visibility, other.visibility) &&
Objects.equals(dateCreated, other.dateCreated) &&
Objects.equals(url, other.url);
}
@Override
public int hashCode() {
return Objects.hash(sid,
accountSid,
serviceSid,
assetSid,
path,
visibility,
dateCreated,
url);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy