
com.twilio.rest.chat.v2.service.channel.MemberUpdater 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.v2.service.channel;
import com.twilio.base.Updater;
import com.twilio.converter.DateConverter;
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;
public class MemberUpdater extends Updater {
private final String pathServiceSid;
private final String pathChannelSid;
private final String pathSid;
private String roleSid;
private Integer lastConsumedMessageIndex;
private DateTime lastConsumptionTimestamp;
private DateTime dateCreated;
private DateTime dateUpdated;
private String attributes;
/**
* Construct a new MemberUpdater.
*
* @param pathServiceSid The SID of the Service to create the resource under
* @param pathChannelSid The unique ID of the channel the member to update
* belongs to
* @param pathSid The unique string that identifies the resource
*/
public MemberUpdater(final String pathServiceSid,
final String pathChannelSid,
final String pathSid) {
this.pathServiceSid = pathServiceSid;
this.pathChannelSid = pathChannelSid;
this.pathSid = pathSid;
}
/**
* The SID of the [Role](https://www.twilio.com/docs/chat/rest/roles) to assign
* to the member. The default roles are those specified on the
* [Service](https://www.twilio.com/docs/chat/api/services)..
*
* @param roleSid The SID of the Role to assign to the member
* @return this
*/
public MemberUpdater setRoleSid(final String roleSid) {
this.roleSid = roleSid;
return this;
}
/**
* The index of the last
* [Message](https://www.twilio.com/docs/chat/rest/messages) that the Member has
* read within the [Channel](https://www.twilio.com/docs/chat/channels)..
*
* @param lastConsumedMessageIndex The index of the last consumed Message for
* the Channel for the Member
* @return this
*/
public MemberUpdater setLastConsumedMessageIndex(final Integer lastConsumedMessageIndex) {
this.lastConsumedMessageIndex = lastConsumedMessageIndex;
return this;
}
/**
* The ISO 8601 timestamp string that represents the date-time of the last
* [Message](https://www.twilio.com/docs/chat/rest/messages) read event for the
* Member within the [Channel](https://www.twilio.com/docs/chat/channels)..
*
* @param lastConsumptionTimestamp The ISO 8601 based timestamp string
* representing the date-time of the last
* Message read event for the Member within the
* Channel
* @return this
*/
public MemberUpdater setLastConsumptionTimestamp(final DateTime lastConsumptionTimestamp) {
this.lastConsumptionTimestamp = lastConsumptionTimestamp;
return this;
}
/**
* The date, specified in [ISO 8601](https://en.wikipedia.org/wiki/ISO_8601)
* format, to assign to the resource as the date it was created. The default is
* the current time set by the Chat service. Note that this parameter should
* only be used when a Member is being recreated from a backup/separate source..
*
* @param dateCreated The ISO 8601 date and time in GMT when the resource was
* created
* @return this
*/
public MemberUpdater setDateCreated(final DateTime dateCreated) {
this.dateCreated = dateCreated;
return this;
}
/**
* The date, specified in [ISO 8601](https://en.wikipedia.org/wiki/ISO_8601)
* format, to assign to the resource as the date it was last updated. Note that
* this parameter should only be used when a Member is being recreated from a
* backup/separate source and where a Member was previously updated..
*
* @param dateUpdated The ISO 8601 date and time in GMT when the resource was
* updated
* @return this
*/
public MemberUpdater setDateUpdated(final DateTime dateUpdated) {
this.dateUpdated = dateUpdated;
return this;
}
/**
* A valid JSON string that contains application-specific data..
*
* @param attributes A valid JSON string that contains application-specific data
* @return this
*/
public MemberUpdater setAttributes(final String attributes) {
this.attributes = attributes;
return this;
}
/**
* Make the request to the Twilio API to perform the update.
*
* @param client TwilioRestClient with which to make the request
* @return Updated Member
*/
@Override
@SuppressWarnings("checkstyle:linelength")
public Member update(final TwilioRestClient client) {
Request request = new Request(
HttpMethod.POST,
Domains.CHAT.toString(),
"/v2/Services/" + this.pathServiceSid + "/Channels/" + this.pathChannelSid + "/Members/" + this.pathSid + "",
client.getRegion()
);
addPostParams(request);
Response response = client.request(request);
if (response == null) {
throw new ApiConnectionException("Member update failed: Unable to connect to server");
} else if (!TwilioRestClient.SUCCESS.apply(response.getStatusCode())) {
RestException restException = RestException.fromJson(response.getStream(), client.getObjectMapper());
if (restException == null) {
throw new ApiException("Server Error, no content");
}
throw new ApiException(
restException.getMessage(),
restException.getCode(),
restException.getMoreInfo(),
restException.getStatus(),
null
);
}
return Member.fromJson(response.getStream(), client.getObjectMapper());
}
/**
* Add the requested post parameters to the Request.
*
* @param request Request to add post params to
*/
private void addPostParams(final Request request) {
if (roleSid != null) {
request.addPostParam("RoleSid", roleSid);
}
if (lastConsumedMessageIndex != null) {
request.addPostParam("LastConsumedMessageIndex", lastConsumedMessageIndex.toString());
}
if (lastConsumptionTimestamp != null) {
request.addPostParam("LastConsumptionTimestamp", lastConsumptionTimestamp.toString());
}
if (dateCreated != null) {
request.addPostParam("DateCreated", dateCreated.toString());
}
if (dateUpdated != null) {
request.addPostParam("DateUpdated", dateUpdated.toString());
}
if (attributes != null) {
request.addPostParam("Attributes", attributes);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy