com.twilio.rest.conversations.v1.service.conversation.Message 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.List;
import java.util.Map;
import java.util.Objects;
@JsonIgnoreProperties(ignoreUnknown = true)
@ToString
public class Message extends Resource {
private static final long serialVersionUID = 166901888663263L;
public enum WebhookEnabledType {
TRUE("true"),
FALSE("false");
private final String value;
private WebhookEnabledType(final String value) {
this.value = value;
}
public String toString() {
return value;
}
/**
* Generate a WebhookEnabledType from a string.
* @param value string value
* @return generated WebhookEnabledType
*/
@JsonCreator
public static WebhookEnabledType forValue(final String value) {
return Promoter.enumFromString(value, WebhookEnabledType.values());
}
}
/**
* Create a MessageCreator 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
* message.
* @return MessageCreator capable of executing the create
*/
public static MessageCreator creator(final String pathChatServiceSid,
final String pathConversationSid) {
return new MessageCreator(pathChatServiceSid, pathConversationSid);
}
/**
* Create a MessageUpdater 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
* message.
* @param pathSid A 34 character string that uniquely identifies this resource.
* @return MessageUpdater capable of executing the update
*/
public static MessageUpdater updater(final String pathChatServiceSid,
final String pathConversationSid,
final String pathSid) {
return new MessageUpdater(pathChatServiceSid, pathConversationSid, pathSid);
}
/**
* Create a MessageDeleter 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
* message.
* @param pathSid A 34 character string that uniquely identifies this resource.
* @return MessageDeleter capable of executing the delete
*/
public static MessageDeleter deleter(final String pathChatServiceSid,
final String pathConversationSid,
final String pathSid) {
return new MessageDeleter(pathChatServiceSid, pathConversationSid, pathSid);
}
/**
* Create a MessageFetcher 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
* message.
* @param pathSid A 34 character string that uniquely identifies this resource.
* @return MessageFetcher capable of executing the fetch
*/
public static MessageFetcher fetcher(final String pathChatServiceSid,
final String pathConversationSid,
final String pathSid) {
return new MessageFetcher(pathChatServiceSid, pathConversationSid, pathSid);
}
/**
* Create a MessageReader 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 messages.
* @return MessageReader capable of executing the read
*/
public static MessageReader reader(final String pathChatServiceSid,
final String pathConversationSid) {
return new MessageReader(pathChatServiceSid, pathConversationSid);
}
/**
* Converts a JSON String into a Message object using the provided ObjectMapper.
*
* @param json Raw JSON String
* @param objectMapper Jackson ObjectMapper
* @return Message object represented by the provided JSON
*/
public static Message fromJson(final String json, final ObjectMapper objectMapper) {
// Convert all checked exceptions to Runtime
try {
return objectMapper.readValue(json, Message.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 Message object using the provided
* ObjectMapper.
*
* @param json Raw JSON InputStream
* @param objectMapper Jackson ObjectMapper
* @return Message object represented by the provided JSON
*/
public static Message fromJson(final InputStream json, final ObjectMapper objectMapper) {
// Convert all checked exceptions to Runtime
try {
return objectMapper.readValue(json, Message.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 accountSid;
private final String chatServiceSid;
private final String conversationSid;
private final String sid;
private final Integer index;
private final String author;
private final String body;
private final List