All Downloads are FREE. Search and download functionalities are using the official Maven repository.

Model.PaymentsProductsECheckSubscriptionInformation Maven / Gradle / Ivy

/*
 * CyberSource Merged Spec
 * All CyberSource API specs merged together. These are available at https://developer.cybersource.com/api/reference/api-reference.html
 *
 * OpenAPI spec version: 0.0.1
 * 
 *
 * NOTE: This class is auto generated by the swagger code generator program.
 * https://github.com/swagger-api/swagger-codegen.git
 * Do not edit the class manually.
 */


package 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 java.util.ArrayList;
import java.util.List;

/**
 * PaymentsProductsECheckSubscriptionInformation
 */

public class PaymentsProductsECheckSubscriptionInformation {
  @SerializedName("enabled")
  private Boolean enabled = null;

  /**
   * Indicates if the organization can enable this product using self service.
   */
  @JsonAdapter(SelfServiceabilityEnum.Adapter.class)
  public enum SelfServiceabilityEnum {
    SELF_SERVICEABLE("SELF_SERVICEABLE"),
    
    NOT_SELF_SERVICEABLE("NOT_SELF_SERVICEABLE"),
    
    SELF_SERVICE_ONLY("SELF_SERVICE_ONLY");

    private String value;

    SelfServiceabilityEnum(String value) {
      this.value = value;
    }

    public String getValue() {
      return value;
    }

    @Override
    public String toString() {
      return String.valueOf(value);
    }

    public static SelfServiceabilityEnum fromValue(String text) {
      for (SelfServiceabilityEnum b : SelfServiceabilityEnum.values()) {
        if (String.valueOf(b.value).equals(text)) {
          return b;
        }
      }
      return null;
    }

    public static class Adapter extends TypeAdapter {
      @Override
      public void write(final JsonWriter jsonWriter, final SelfServiceabilityEnum enumeration) throws IOException {
        jsonWriter.value(enumeration.getValue());
      }

      @Override
      public SelfServiceabilityEnum read(final JsonReader jsonReader) throws IOException {
        String value = jsonReader.nextString();
        return SelfServiceabilityEnum.fromValue(String.valueOf(value));
      }
    }
  }
  @SerializedName("selfServiceability")
  private SelfServiceabilityEnum selfServiceability = SelfServiceabilityEnum.NOT_SELF_SERVICEABLE;

  @SerializedName("mode")
  private List mode = null;

  public PaymentsProductsECheckSubscriptionInformation enabled(Boolean enabled) {
    this.enabled = enabled;
    return this;
  }

   /**
   * Get enabled
   * @return enabled
  **/
  @ApiModelProperty(value = "")
  public Boolean isEnabled() {
    return enabled;
  }

  public void setEnabled(Boolean enabled) {
    this.enabled = enabled;
  }

  public PaymentsProductsECheckSubscriptionInformation selfServiceability(SelfServiceabilityEnum selfServiceability) {
    this.selfServiceability = selfServiceability;
    return this;
  }

   /**
   * Indicates if the organization can enable this product using self service.
   * @return selfServiceability
  **/
  @ApiModelProperty(value = "Indicates if the organization can enable this product using self service.")
  public SelfServiceabilityEnum getSelfServiceability() {
    return selfServiceability;
  }

  public void setSelfServiceability(SelfServiceabilityEnum selfServiceability) {
    this.selfServiceability = selfServiceability;
  }

  public PaymentsProductsECheckSubscriptionInformation mode(List mode) {
    this.mode = mode;
    return this;
  }

  public PaymentsProductsECheckSubscriptionInformation addModeItem(String modeItem) {
    if (this.mode == null) {
      this.mode = new ArrayList();
    }
    this.mode.add(modeItem);
    return this;
  }

   /**
   * Indicates what mode the product is expected to behave at boarding and transaction flows. Ex, Acquirer/Gateway/Other.
   * @return mode
  **/
  @ApiModelProperty(value = "Indicates what mode the product is expected to behave at boarding and transaction flows. Ex, Acquirer/Gateway/Other.")
  public List getMode() {
    return mode;
  }

  public void setMode(List mode) {
    this.mode = mode;
  }


  @Override
  public boolean equals(java.lang.Object o) {
    if (this == o) {
      return true;
    }
    if (o == null || getClass() != o.getClass()) {
      return false;
    }
    PaymentsProductsECheckSubscriptionInformation paymentsProductsECheckSubscriptionInformation = (PaymentsProductsECheckSubscriptionInformation) o;
    return Objects.equals(this.enabled, paymentsProductsECheckSubscriptionInformation.enabled) &&
        Objects.equals(this.selfServiceability, paymentsProductsECheckSubscriptionInformation.selfServiceability) &&
        Objects.equals(this.mode, paymentsProductsECheckSubscriptionInformation.mode);
  }

  @Override
  public int hashCode() {
    return Objects.hash(enabled, selfServiceability, mode);
  }


  @Override
  public String toString() {
    StringBuilder sb = new StringBuilder();
    sb.append("class PaymentsProductsECheckSubscriptionInformation {\n");
    
    sb.append("    enabled: ").append(toIndentedString(enabled)).append("\n");
    sb.append("    selfServiceability: ").append(toIndentedString(selfServiceability)).append("\n");
    sb.append("    mode: ").append(toIndentedString(mode)).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    ");
  }

}





© 2015 - 2025 Weber Informatics LLC | Privacy Policy