io.smooch.v2.client.model.Author Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of api Show documentation
Show all versions of api Show documentation
io.smooch - api - 6.0.0-alpha.7
/*
* Sunshine Conversations API
* # # Introduction Welcome to the Sunshine Conversations API. The API allows you to craft entirely unique messaging experiences for your app and website as well as talk to any backend or external service. The Sunshine Conversations API is designed according to REST principles. The API accepts JSON in request bodies and requires that the content-type: application/json header be specified for all such requests. The API will always respond with an object. Depending on context, resources may be returned as single objects or as arrays of objects, nested within the response object. In some cases, the API will also facilitate cross-origin resource sharing so that it can be called from a web application. ## API pagination and records limits Some APIs can be paginated by providing the `offset` query string parameter. The `offset` is the number of initial records to skip before picking records to return (default 0). The `limit` query string can also be provided to change the number of records to return (maximum 100, default 25). All paginated endpoints will eventually support cursor pagination and `offset` based pagination support will be dropped. ### Cursor Pagination Some APIs are paginated through cursor pagination. Rather than providing an `offset`, a `page[after]` or `page[before]` query string parameter may be provided. `page[after]` and `page[before]` are cursors pointing to a record id. The `page[after]` cursor indicates that only records **subsequent** to it should be returned. The `page[before]` cursor indicates that only records **preceding** it should be returned. **Only one** of `page[after]` or `page[before]` may be provided in a query, not both. In cursor pagination, the equivalent to the `limit` query string is the `page[size]` query string parameter. ## Regions Sunshine Conversations is available in the following regions. Each Sunshine Conversations region has its own API host. | Region | Host | | -------------- | -------------------------- | | United States | https://api.smooch.io | | European Union | https://api.eu-1.smooch.io | For more information on regions, visit [the guide](/guide/regions/).
*
* The version of the OpenAPI document: 6.0.0-alpha.1
* Contact: [email protected]
*
* NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
* https://openapi-generator.tech
* Do not edit the class manually.
*/
package io.smooch.v2.client.model;
import java.util.Objects;
import java.util.Arrays;
import com.fasterxml.jackson.annotation.JsonInclude;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonValue;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import java.net.URI;
import com.fasterxml.jackson.annotation.JsonPropertyOrder;
/**
* Author
*/
@JsonPropertyOrder({
Author.JSON_PROPERTY_ROLE,
Author.JSON_PROPERTY_USER_ID,
Author.JSON_PROPERTY_USER_EXTERNAL_ID,
Author.JSON_PROPERTY_NAME,
Author.JSON_PROPERTY_AVATAR_URL
})
public class Author {
/**
* The role of the message or activity.
*/
public enum RoleEnum {
APPMAKER("appMaker"),
USER("user");
private String value;
RoleEnum(String value) {
this.value = value;
}
@JsonValue
public String getValue() {
return value;
}
@Override
public String toString() {
return String.valueOf(value);
}
@JsonCreator
public static RoleEnum fromValue(String value) {
for (RoleEnum b : RoleEnum.values()) {
if (b.value.equals(value)) {
return b;
}
}
throw new IllegalArgumentException("Unexpected value '" + value + "'");
}
}
public static final String JSON_PROPERTY_ROLE = "role";
private RoleEnum role;
public static final String JSON_PROPERTY_USER_ID = "userId";
private String userId;
public static final String JSON_PROPERTY_USER_EXTERNAL_ID = "userExternalId";
private String userExternalId;
public static final String JSON_PROPERTY_NAME = "name";
private String name;
public static final String JSON_PROPERTY_AVATAR_URL = "avatarUrl";
private URI avatarUrl;
public Author role(RoleEnum role) {
this.role = role;
return this;
}
/**
* The role of the message or activity.
* @return role
**/
@ApiModelProperty(required = true, value = "The role of the message or activity.")
@JsonProperty(JSON_PROPERTY_ROLE)
@JsonInclude(value = JsonInclude.Include.ALWAYS)
public RoleEnum getRole() {
return role;
}
public void setRole(RoleEnum role) {
this.role = role;
}
public Author userId(String userId) {
this.userId = userId;
return this;
}
/**
* The id of the user. Only supported when role is user.
* @return userId
**/
@javax.annotation.Nullable
@ApiModelProperty(value = "The id of the user. Only supported when role is user.")
@JsonProperty(JSON_PROPERTY_USER_ID)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public String getUserId() {
return userId;
}
public void setUserId(String userId) {
this.userId = userId;
}
public Author userExternalId(String userExternalId) {
this.userExternalId = userExternalId;
return this;
}
/**
* The externalId of the user. Only supported when role is user.
* @return userExternalId
**/
@javax.annotation.Nullable
@ApiModelProperty(value = "The externalId of the user. Only supported when role is user.")
@JsonProperty(JSON_PROPERTY_USER_EXTERNAL_ID)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public String getUserExternalId() {
return userExternalId;
}
public void setUserExternalId(String userExternalId) {
this.userExternalId = userExternalId;
}
public Author name(String name) {
this.name = name;
return this;
}
/**
* The display name of the message author.
* @return name
**/
@javax.annotation.Nullable
@ApiModelProperty(value = "The display name of the message author.")
@JsonProperty(JSON_PROPERTY_NAME)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Author avatarUrl(URI avatarUrl) {
this.avatarUrl = avatarUrl;
return this;
}
/**
* The URL of the desired message avatar image.
* @return avatarUrl
**/
@javax.annotation.Nullable
@ApiModelProperty(value = "The URL of the desired message avatar image.")
@JsonProperty(JSON_PROPERTY_AVATAR_URL)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public URI getAvatarUrl() {
return avatarUrl;
}
public void setAvatarUrl(URI avatarUrl) {
this.avatarUrl = avatarUrl;
}
@Override
public boolean equals(java.lang.Object o) {
if (this == o) {
return true;
}
if (o == null || getClass() != o.getClass()) {
return false;
}
Author author = (Author) o;
return Objects.equals(this.role, author.role) &&
Objects.equals(this.userId, author.userId) &&
Objects.equals(this.userExternalId, author.userExternalId) &&
Objects.equals(this.name, author.name) &&
Objects.equals(this.avatarUrl, author.avatarUrl);
}
@Override
public int hashCode() {
return Objects.hash(role, userId, userExternalId, name, avatarUrl);
}
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
sb.append("class Author {\n");
sb.append(" role: ").append(toIndentedString(role)).append("\n");
sb.append(" userId: ").append(toIndentedString(userId)).append("\n");
sb.append(" userExternalId: ").append(toIndentedString(userExternalId)).append("\n");
sb.append(" name: ").append(toIndentedString(name)).append("\n");
sb.append(" avatarUrl: ").append(toIndentedString(avatarUrl)).append("\n");
sb.append("}");
return sb.toString();
}
/**
* Convert the given object to string with each line indented by 4 spaces
* (except the first line).
*/
private String toIndentedString(java.lang.Object o) {
if (o == null) {
return "null";
}
return o.toString().replace("\n", "\n ");
}
}