com.twilio.rest.conversations.v1.service.conversation.Webhook 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.conversations.v1.service.conversation;
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.Converter;
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;
@JsonIgnoreProperties(ignoreUnknown = true)
@ToString
public class Webhook extends Resource {
private static final long serialVersionUID = 134707839484307L;
public enum Target {
WEBHOOK("webhook"),
TRIGGER("trigger"),
STUDIO("studio");
private final String value;
private Target(final String value) {
this.value = value;
}
public String toString() {
return value;
}
/**
* Generate a Target from a string.
* @param value string value
* @return generated Target
*/
@JsonCreator
public static Target forValue(final String value) {
return Promoter.enumFromString(value, Target.values());
}
}
public enum Method {
GET("GET"),
POST("POST");
private final String value;
private Method(final String value) {
this.value = value;
}
public String toString() {
return value;
}
/**
* Generate a Method from a string.
* @param value string value
* @return generated Method
*/
@JsonCreator
public static Method forValue(final String value) {
return Promoter.enumFromString(value, Method.values());
}
}
/**
* Create a WebhookCreator to execute create.
*
* @param pathChatServiceSid The SID of the Conversation Service that the
* resource is associated with.
* @param pathConversationSid The unique ID of the Conversation for this
* webhook.
* @param target The target of this webhook.
* @return WebhookCreator capable of executing the create
*/
public static WebhookCreator creator(final String pathChatServiceSid,
final String pathConversationSid,
final Webhook.Target target) {
return new WebhookCreator(pathChatServiceSid, pathConversationSid, target);
}
/**
* Create a WebhookUpdater to execute update.
*
* @param pathChatServiceSid The SID of the Conversation Service that the
* resource is associated with.
* @param pathConversationSid The unique ID of the Conversation for this
* webhook.
* @param pathSid A 34 character string that uniquely identifies this resource.
* @return WebhookUpdater capable of executing the update
*/
public static WebhookUpdater updater(final String pathChatServiceSid,
final String pathConversationSid,
final String pathSid) {
return new WebhookUpdater(pathChatServiceSid, pathConversationSid, pathSid);
}
/**
* Create a WebhookDeleter to execute delete.
*
* @param pathChatServiceSid The SID of the Conversation Service that the
* resource is associated with.
* @param pathConversationSid The unique ID of the Conversation for this
* webhook.
* @param pathSid A 34 character string that uniquely identifies this resource.
* @return WebhookDeleter capable of executing the delete
*/
public static WebhookDeleter deleter(final String pathChatServiceSid,
final String pathConversationSid,
final String pathSid) {
return new WebhookDeleter(pathChatServiceSid, pathConversationSid, pathSid);
}
/**
* Create a WebhookFetcher to execute fetch.
*
* @param pathChatServiceSid The SID of the Conversation Service that the
* resource is associated with.
* @param pathConversationSid The unique ID of the Conversation for this
* webhook.
* @param pathSid A 34 character string that uniquely identifies this resource.
* @return WebhookFetcher capable of executing the fetch
*/
public static WebhookFetcher fetcher(final String pathChatServiceSid,
final String pathConversationSid,
final String pathSid) {
return new WebhookFetcher(pathChatServiceSid, pathConversationSid, pathSid);
}
/**
* Create a WebhookReader to execute read.
*
* @param pathChatServiceSid The SID of the Conversation Service that the
* resource is associated with.
* @param pathConversationSid The unique ID of the Conversation for this
* webhook.
* @return WebhookReader capable of executing the read
*/
public static WebhookReader reader(final String pathChatServiceSid,
final String pathConversationSid) {
return new WebhookReader(pathChatServiceSid, pathConversationSid);
}
/**
* Converts a JSON String into a Webhook object using the provided ObjectMapper.
*
* @param json Raw JSON String
* @param objectMapper Jackson ObjectMapper
* @return Webhook object represented by the provided JSON
*/
public static Webhook fromJson(final String json, final ObjectMapper objectMapper) {
// Convert all checked exceptions to Runtime
try {
return objectMapper.readValue(json, Webhook.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 Webhook object using the provided
* ObjectMapper.
*
* @param json Raw JSON InputStream
* @param objectMapper Jackson ObjectMapper
* @return Webhook object represented by the provided JSON
*/
public static Webhook fromJson(final InputStream json, final ObjectMapper objectMapper) {
// Convert all checked exceptions to Runtime
try {
return objectMapper.readValue(json, Webhook.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 chatServiceSid;
private final String conversationSid;
private final String target;
private final URI url;
private final Map configuration;
private final ZonedDateTime dateCreated;
private final ZonedDateTime dateUpdated;
@JsonCreator
private Webhook(@JsonProperty("sid")
final String sid,
@JsonProperty("account_sid")
final String accountSid,
@JsonProperty("chat_service_sid")
final String chatServiceSid,
@JsonProperty("conversation_sid")
final String conversationSid,
@JsonProperty("target")
final String target,
@JsonProperty("url")
final URI url,
@JsonProperty("configuration")
final Map configuration,
@JsonProperty("date_created")
final String dateCreated,
@JsonProperty("date_updated")
final String dateUpdated) {
this.sid = sid;
this.accountSid = accountSid;
this.chatServiceSid = chatServiceSid;
this.conversationSid = conversationSid;
this.target = target;
this.url = url;
this.configuration = configuration;
this.dateCreated = DateConverter.iso8601DateTimeFromString(dateCreated);
this.dateUpdated = DateConverter.iso8601DateTimeFromString(dateUpdated);
}
/**
* Returns 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 unique ID of the Account responsible for this conversation..
*
* @return The unique ID of the Account responsible for this conversation.
*/
public final String getAccountSid() {
return this.accountSid;
}
/**
* Returns The SID of the Conversation Service that the resource is associated
* with..
*
* @return The SID of the Conversation Service that the resource is associated
* with.
*/
public final String getChatServiceSid() {
return this.chatServiceSid;
}
/**
* Returns The unique ID of the Conversation for this webhook..
*
* @return The unique ID of the Conversation for this webhook.
*/
public final String getConversationSid() {
return this.conversationSid;
}
/**
* Returns The target of this webhook..
*
* @return The target of this webhook.
*/
public final String getTarget() {
return this.target;
}
/**
* Returns An absolute URL for this webhook..
*
* @return An absolute URL for this webhook.
*/
public final URI getUrl() {
return this.url;
}
/**
* Returns The configuration of this webhook..
*
* @return The configuration of this webhook.
*/
public final Map getConfiguration() {
return this.configuration;
}
/**
* Returns The date that this resource was created..
*
* @return The date that this resource was created.
*/
public final ZonedDateTime getDateCreated() {
return this.dateCreated;
}
/**
* Returns The date that this resource was last updated..
*
* @return The date that this resource was last updated.
*/
public final ZonedDateTime getDateUpdated() {
return this.dateUpdated;
}
@Override
public boolean equals(final Object o) {
if (this == o) {
return true;
}
if (o == null || getClass() != o.getClass()) {
return false;
}
Webhook other = (Webhook) o;
return Objects.equals(sid, other.sid) &&
Objects.equals(accountSid, other.accountSid) &&
Objects.equals(chatServiceSid, other.chatServiceSid) &&
Objects.equals(conversationSid, other.conversationSid) &&
Objects.equals(target, other.target) &&
Objects.equals(url, other.url) &&
Objects.equals(configuration, other.configuration) &&
Objects.equals(dateCreated, other.dateCreated) &&
Objects.equals(dateUpdated, other.dateUpdated);
}
@Override
public int hashCode() {
return Objects.hash(sid,
accountSid,
chatServiceSid,
conversationSid,
target,
url,
configuration,
dateCreated,
dateUpdated);
}
}