org.openapitools.client.model.Term Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of zuora-sdk-java Show documentation
Show all versions of zuora-sdk-java Show documentation
The SDK of JAVA language for Zuora pricing system
/*
* Quickstart API Reference
* Zuora Quickstart API is the API that helps you achieve fundamental use cases.
* It provides a much simplified object model and improved performance, enabling developers to easily learn and use.
*/
package org.openapitools.client.model;
import java.util.Objects;
import java.util.Arrays;
import com.google.gson.TypeAdapter;
import com.google.gson.annotations.JsonAdapter;
import com.google.gson.annotations.SerializedName;
import com.google.gson.stream.JsonReader;
import com.google.gson.stream.JsonWriter;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import java.io.IOException;
import org.threeten.bp.LocalDate;
import org.openapitools.client.JSON.CustomFieldAdapter;
import org.openapitools.client.JSON.NullableFieldAdapter;
/**
* Term information of the subscription.
*/
@ApiModel(description = "Term information of the subscription.")
@javax.annotation.Generated(value = "org.openapitools.codegen.languages.JavaClientCodegen")
public class Term {
public static final String SERIALIZED_NAME_INTERVAL_COUNT = "interval_count";
@SerializedName(SERIALIZED_NAME_INTERVAL_COUNT)
private Integer intervalCount;
/**
* Unit in which term duration is defined. One of day, week, month or year.
*/
@JsonAdapter(IntervalEnum.Adapter.class)
public enum IntervalEnum {
DAY("day"),
WEEK("week"),
MONTH("month"),
YEAR("year"),
UNKNOWN_DEFAULT_OPEN_API("unknown_default_open_api");
private String value;
IntervalEnum(String value) {
this.value = value;
}
public String getValue() {
return value;
}
@Override
public String toString() {
return String.valueOf(value);
}
public static IntervalEnum fromValue(String value) {
for (IntervalEnum b : IntervalEnum.values()) {
if (b.value.equals(value)) {
return b;
}
}
throw new IllegalArgumentException("Unexpected value '" + value + "'");
}
public static class Adapter extends TypeAdapter {
@Override
public void write(final JsonWriter jsonWriter, final IntervalEnum enumeration) throws IOException {
jsonWriter.value(enumeration.getValue());
}
@Override
public IntervalEnum read(final JsonReader jsonReader) throws IOException {
String value = jsonReader.nextString();
return IntervalEnum.fromValue(value);
}
}
}
public static final String SERIALIZED_NAME_INTERVAL = "interval";
@SerializedName(SERIALIZED_NAME_INTERVAL)
private IntervalEnum interval;
public static final String SERIALIZED_NAME_START_DATE = "start_date";
@SerializedName(SERIALIZED_NAME_START_DATE)
private LocalDate startDate;
/**
* Type of the subscription. Can be either `termed` or `evergreen`.
*/
@JsonAdapter(TypeEnum.Adapter.class)
public enum TypeEnum {
EVERGREEN("evergreen"),
TERMED("termed"),
UNKNOWN_DEFAULT_OPEN_API("unknown_default_open_api");
private String value;
TypeEnum(String value) {
this.value = value;
}
public String getValue() {
return value;
}
@Override
public String toString() {
return String.valueOf(value);
}
public static TypeEnum fromValue(String value) {
for (TypeEnum b : TypeEnum.values()) {
if (b.value.equals(value)) {
return b;
}
}
throw new IllegalArgumentException("Unexpected value '" + value + "'");
}
public static class Adapter extends TypeAdapter {
@Override
public void write(final JsonWriter jsonWriter, final TypeEnum enumeration) throws IOException {
jsonWriter.value(enumeration.getValue());
}
@Override
public TypeEnum read(final JsonReader jsonReader) throws IOException {
String value = jsonReader.nextString();
return TypeEnum.fromValue(value);
}
}
}
public static final String SERIALIZED_NAME_TYPE = "type";
@SerializedName(SERIALIZED_NAME_TYPE)
private TypeEnum type;
public static final String SERIALIZED_NAME_END_DATE = "end_date";
@SerializedName(SERIALIZED_NAME_END_DATE)
private LocalDate endDate;
public Term() {
}
public Term intervalCount(Integer intervalCount) {
this.intervalCount = intervalCount;
return this;
}
/**
* The number of intervals in a term. For example, interval=year and interval_count=1 represents a 1 year term.
* minimum: 1
* @return intervalCount
**/
@javax.annotation.Nullable
@ApiModelProperty(value = "The number of intervals in a term. For example, interval=year and interval_count=1 represents a 1 year term.")
public Integer getIntervalCount() {
return intervalCount;
}
public void setIntervalCount(Integer intervalCount) {
this.intervalCount = intervalCount;
}
public Term interval(IntervalEnum interval) {
this.interval = interval;
return this;
}
/**
* Unit in which term duration is defined. One of day, week, month or year.
* @return interval
**/
@javax.annotation.Nullable
@ApiModelProperty(value = "Unit in which term duration is defined. One of day, week, month or year.")
public IntervalEnum getInterval() {
return interval;
}
public void setInterval(IntervalEnum interval) {
this.interval = interval;
}
public Term startDate(LocalDate startDate) {
this.startDate = startDate;
return this;
}
/**
* Date when the subscription term starts.
* @return startDate
**/
@javax.annotation.Nullable
@ApiModelProperty(example = "Wed Jan 01 00:00:00 GMT 2020", value = "Date when the subscription term starts.")
public LocalDate getStartDate() {
return startDate;
}
public void setStartDate(LocalDate startDate) {
this.startDate = startDate;
}
public Term type(TypeEnum type) {
this.type = type;
return this;
}
/**
* Type of the subscription. Can be either `termed` or `evergreen`.
* @return type
**/
@javax.annotation.Nullable
@ApiModelProperty(value = "Type of the subscription. Can be either `termed` or `evergreen`.")
public TypeEnum getType() {
return type;
}
public void setType(TypeEnum type) {
this.type = type;
}
public Term endDate(LocalDate endDate) {
this.endDate = endDate;
return this;
}
/**
* Date when the subscription term ends.
* @return endDate
**/
@javax.annotation.Nullable
@ApiModelProperty(example = "Sun Jan 01 00:00:00 GMT 2023", value = "Date when the subscription term ends.")
public LocalDate getEndDate() {
return endDate;
}
public void setEndDate(LocalDate endDate) {
this.endDate = endDate;
}
@Override
public boolean equals(Object o) {
if (this == o) {
return true;
}
if (o == null || getClass() != o.getClass()) {
return false;
}
Term term = (Term) o;
return Objects.equals(this.intervalCount, term.intervalCount) &&
Objects.equals(this.interval, term.interval) &&
Objects.equals(this.startDate, term.startDate) &&
Objects.equals(this.type, term.type) &&
Objects.equals(this.endDate, term.endDate);
}
@Override
public int hashCode() {
return Objects.hash(intervalCount, interval, startDate, type, endDate);
}
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
sb.append("class Term {\n");
sb.append(" intervalCount: ").append(toIndentedString(intervalCount)).append("\n");
sb.append(" interval: ").append(toIndentedString(interval)).append("\n");
sb.append(" startDate: ").append(toIndentedString(startDate)).append("\n");
sb.append(" type: ").append(toIndentedString(type)).append("\n");
sb.append(" endDate: ").append(toIndentedString(endDate)).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(Object o) {
if (o == null) {
return "null";
}
return o.toString().replace("\n", "\n ");
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy