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

com.stripe.param.ExternalAccountUpdateParams Maven / Gradle / Ivy

There is a newer version: 28.3.0-beta.1
Show newest version
// Generated by delombok at Tue Jan 14 08:43:16 PST 2020
package com.stripe.param;

import com.google.gson.annotations.SerializedName;
import com.stripe.net.ApiRequestParams;
import com.stripe.net.ApiRequestParams.EnumParam;
import com.stripe.param.common.EmptyParam;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

public class ExternalAccountUpdateParams extends ApiRequestParams {
  /**
   * The name of the person or business that owns the bank account.
   */
  @SerializedName("account_holder_name")
  Object accountHolderName;
  /**
   * The type of entity that holds the account. This can be either `individual` or `company`.
   */
  @SerializedName("account_holder_type")
  EnumParam accountHolderType;
  /**
   * City/District/Suburb/Town/Village.
   */
  @SerializedName("address_city")
  Object addressCity;
  /**
   * Billing address country, if provided when creating card.
   */
  @SerializedName("address_country")
  Object addressCountry;
  /**
   * Address line 1 (Street address/PO Box/Company name).
   */
  @SerializedName("address_line1")
  Object addressLine1;
  /**
   * Address line 2 (Apartment/Suite/Unit/Building).
   */
  @SerializedName("address_line2")
  Object addressLine2;
  /**
   * State/County/Province/Region.
   */
  @SerializedName("address_state")
  Object addressState;
  /**
   * ZIP or postal code.
   */
  @SerializedName("address_zip")
  Object addressZip;
  /**
   * When set to true, this becomes the default external account for its currency.
   */
  @SerializedName("default_for_currency")
  Boolean defaultForCurrency;
  /**
   * Two digit number representing the card’s expiration month.
   */
  @SerializedName("exp_month")
  Object expMonth;
  /**
   * Four digit number representing the card’s expiration year.
   */
  @SerializedName("exp_year")
  Object expYear;
  /**
   * Specifies which fields in the response should be expanded.
   */
  @SerializedName("expand")
  List expand;
  /**
   * Map of extra parameters for custom features not available in this client library. The content
   * in this map is not serialized under this field's {@code @SerializedName} value. Instead, each
   * key/value pair is serialized as if the key is a root-level field (serialized) name in this
   * param object. Effectively, this map is flattened to its parent instance.
   */
  @SerializedName(ApiRequestParams.EXTRA_PARAMS_KEY)
  Map extraParams;
  /**
   * Set of key-value pairs that you can attach to an object. This can be useful for storing
   * additional information about the object in a structured format. Individual keys can be unset by
   * posting an empty value to them. All keys can be unset by posting an empty value to `metadata`.
   */
  @SerializedName("metadata")
  Map metadata;
  /**
   * Cardholder name.
   */
  @SerializedName("name")
  Object name;

  private ExternalAccountUpdateParams(Object accountHolderName, EnumParam accountHolderType, Object addressCity, Object addressCountry, Object addressLine1, Object addressLine2, Object addressState, Object addressZip, Boolean defaultForCurrency, Object expMonth, Object expYear, List expand, Map extraParams, Map metadata, Object name) {
    this.accountHolderName = accountHolderName;
    this.accountHolderType = accountHolderType;
    this.addressCity = addressCity;
    this.addressCountry = addressCountry;
    this.addressLine1 = addressLine1;
    this.addressLine2 = addressLine2;
    this.addressState = addressState;
    this.addressZip = addressZip;
    this.defaultForCurrency = defaultForCurrency;
    this.expMonth = expMonth;
    this.expYear = expYear;
    this.expand = expand;
    this.extraParams = extraParams;
    this.metadata = metadata;
    this.name = name;
  }

  public static Builder builder() {
    return new Builder();
  }


  public static class Builder {
    private Object accountHolderName;
    private EnumParam accountHolderType;
    private Object addressCity;
    private Object addressCountry;
    private Object addressLine1;
    private Object addressLine2;
    private Object addressState;
    private Object addressZip;
    private Boolean defaultForCurrency;
    private Object expMonth;
    private Object expYear;
    private List expand;
    private Map extraParams;
    private Map metadata;
    private Object name;

    /**
     * Finalize and obtain parameter instance from this builder.
     */
    public ExternalAccountUpdateParams build() {
      return new ExternalAccountUpdateParams(this.accountHolderName, this.accountHolderType, this.addressCity, this.addressCountry, this.addressLine1, this.addressLine2, this.addressState, this.addressZip, this.defaultForCurrency, this.expMonth, this.expYear, this.expand, this.extraParams, this.metadata, this.name);
    }

    /**
     * The name of the person or business that owns the bank account.
     */
    public Builder setAccountHolderName(String accountHolderName) {
      this.accountHolderName = accountHolderName;
      return this;
    }

    /**
     * The name of the person or business that owns the bank account.
     */
    public Builder setAccountHolderName(EmptyParam accountHolderName) {
      this.accountHolderName = accountHolderName;
      return this;
    }

    /**
     * The type of entity that holds the account. This can be either `individual` or `company`.
     */
    public Builder setAccountHolderType(AccountHolderType accountHolderType) {
      this.accountHolderType = accountHolderType;
      return this;
    }

    /**
     * The type of entity that holds the account. This can be either `individual` or `company`.
     */
    public Builder setAccountHolderType(EmptyParam accountHolderType) {
      this.accountHolderType = accountHolderType;
      return this;
    }

    /**
     * City/District/Suburb/Town/Village.
     */
    public Builder setAddressCity(String addressCity) {
      this.addressCity = addressCity;
      return this;
    }

    /**
     * City/District/Suburb/Town/Village.
     */
    public Builder setAddressCity(EmptyParam addressCity) {
      this.addressCity = addressCity;
      return this;
    }

    /**
     * Billing address country, if provided when creating card.
     */
    public Builder setAddressCountry(String addressCountry) {
      this.addressCountry = addressCountry;
      return this;
    }

    /**
     * Billing address country, if provided when creating card.
     */
    public Builder setAddressCountry(EmptyParam addressCountry) {
      this.addressCountry = addressCountry;
      return this;
    }

    /**
     * Address line 1 (Street address/PO Box/Company name).
     */
    public Builder setAddressLine1(String addressLine1) {
      this.addressLine1 = addressLine1;
      return this;
    }

    /**
     * Address line 1 (Street address/PO Box/Company name).
     */
    public Builder setAddressLine1(EmptyParam addressLine1) {
      this.addressLine1 = addressLine1;
      return this;
    }

    /**
     * Address line 2 (Apartment/Suite/Unit/Building).
     */
    public Builder setAddressLine2(String addressLine2) {
      this.addressLine2 = addressLine2;
      return this;
    }

    /**
     * Address line 2 (Apartment/Suite/Unit/Building).
     */
    public Builder setAddressLine2(EmptyParam addressLine2) {
      this.addressLine2 = addressLine2;
      return this;
    }

    /**
     * State/County/Province/Region.
     */
    public Builder setAddressState(String addressState) {
      this.addressState = addressState;
      return this;
    }

    /**
     * State/County/Province/Region.
     */
    public Builder setAddressState(EmptyParam addressState) {
      this.addressState = addressState;
      return this;
    }

    /**
     * ZIP or postal code.
     */
    public Builder setAddressZip(String addressZip) {
      this.addressZip = addressZip;
      return this;
    }

    /**
     * ZIP or postal code.
     */
    public Builder setAddressZip(EmptyParam addressZip) {
      this.addressZip = addressZip;
      return this;
    }

    /**
     * When set to true, this becomes the default external account for its currency.
     */
    public Builder setDefaultForCurrency(Boolean defaultForCurrency) {
      this.defaultForCurrency = defaultForCurrency;
      return this;
    }

    /**
     * Two digit number representing the card’s expiration month.
     */
    public Builder setExpMonth(String expMonth) {
      this.expMonth = expMonth;
      return this;
    }

    /**
     * Two digit number representing the card’s expiration month.
     */
    public Builder setExpMonth(EmptyParam expMonth) {
      this.expMonth = expMonth;
      return this;
    }

    /**
     * Four digit number representing the card’s expiration year.
     */
    public Builder setExpYear(String expYear) {
      this.expYear = expYear;
      return this;
    }

    /**
     * Four digit number representing the card’s expiration year.
     */
    public Builder setExpYear(EmptyParam expYear) {
      this.expYear = expYear;
      return this;
    }

    /**
     * Add an element to `expand` list. A list is initialized for the first `add/addAll` call, and
     * subsequent calls adds additional elements to the original list. See {@link
     * ExternalAccountUpdateParams#expand} for the field documentation.
     */
    public Builder addExpand(String element) {
      if (this.expand == null) {
        this.expand = new ArrayList<>();
      }
      this.expand.add(element);
      return this;
    }

    /**
     * Add all elements to `expand` list. A list is initialized for the first `add/addAll` call, and
     * subsequent calls adds additional elements to the original list. See {@link
     * ExternalAccountUpdateParams#expand} for the field documentation.
     */
    public Builder addAllExpand(List elements) {
      if (this.expand == null) {
        this.expand = new ArrayList<>();
      }
      this.expand.addAll(elements);
      return this;
    }

    /**
     * Add a key/value pair to `extraParams` map. A map is initialized for the first `put/putAll`
     * call, and subsequent calls add additional key/value pairs to the original map. See {@link
     * ExternalAccountUpdateParams#extraParams} for the field documentation.
     */
    public Builder putExtraParam(String key, Object value) {
      if (this.extraParams == null) {
        this.extraParams = new HashMap<>();
      }
      this.extraParams.put(key, value);
      return this;
    }

    /**
     * Add all map key/value pairs to `extraParams` map. A map is initialized for the first
     * `put/putAll` call, and subsequent calls add additional key/value pairs to the original map.
     * See {@link ExternalAccountUpdateParams#extraParams} for the field documentation.
     */
    public Builder putAllExtraParam(Map map) {
      if (this.extraParams == null) {
        this.extraParams = new HashMap<>();
      }
      this.extraParams.putAll(map);
      return this;
    }

    /**
     * Add a key/value pair to `metadata` map. A map is initialized for the first `put/putAll` call,
     * and subsequent calls add additional key/value pairs to the original map. See {@link
     * ExternalAccountUpdateParams#metadata} for the field documentation.
     */
    public Builder putMetadata(String key, String value) {
      if (this.metadata == null) {
        this.metadata = new HashMap<>();
      }
      this.metadata.put(key, value);
      return this;
    }

    /**
     * Add all map key/value pairs to `metadata` map. A map is initialized for the first
     * `put/putAll` call, and subsequent calls add additional key/value pairs to the original map.
     * See {@link ExternalAccountUpdateParams#metadata} for the field documentation.
     */
    public Builder putAllMetadata(Map map) {
      if (this.metadata == null) {
        this.metadata = new HashMap<>();
      }
      this.metadata.putAll(map);
      return this;
    }

    /**
     * Cardholder name.
     */
    public Builder setName(String name) {
      this.name = name;
      return this;
    }

    /**
     * Cardholder name.
     */
    public Builder setName(EmptyParam name) {
      this.name = name;
      return this;
    }
  }


  public enum AccountHolderType implements ApiRequestParams.EnumParam {
    @SerializedName("company")
    COMPANY("company"), @SerializedName("individual")
    INDIVIDUAL("individual");
    private final String value;

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

    @Override
    @java.lang.SuppressWarnings("all")
    @lombok.Generated
    public String getValue() {
      return this.value;
    }
  }

  /**
   * The name of the person or business that owns the bank account.
   */
  @java.lang.SuppressWarnings("all")
  @lombok.Generated
  public Object getAccountHolderName() {
    return this.accountHolderName;
  }

  /**
   * The type of entity that holds the account. This can be either `individual` or `company`.
   */
  @java.lang.SuppressWarnings("all")
  @lombok.Generated
  public EnumParam getAccountHolderType() {
    return this.accountHolderType;
  }

  /**
   * City/District/Suburb/Town/Village.
   */
  @java.lang.SuppressWarnings("all")
  @lombok.Generated
  public Object getAddressCity() {
    return this.addressCity;
  }

  /**
   * Billing address country, if provided when creating card.
   */
  @java.lang.SuppressWarnings("all")
  @lombok.Generated
  public Object getAddressCountry() {
    return this.addressCountry;
  }

  /**
   * Address line 1 (Street address/PO Box/Company name).
   */
  @java.lang.SuppressWarnings("all")
  @lombok.Generated
  public Object getAddressLine1() {
    return this.addressLine1;
  }

  /**
   * Address line 2 (Apartment/Suite/Unit/Building).
   */
  @java.lang.SuppressWarnings("all")
  @lombok.Generated
  public Object getAddressLine2() {
    return this.addressLine2;
  }

  /**
   * State/County/Province/Region.
   */
  @java.lang.SuppressWarnings("all")
  @lombok.Generated
  public Object getAddressState() {
    return this.addressState;
  }

  /**
   * ZIP or postal code.
   */
  @java.lang.SuppressWarnings("all")
  @lombok.Generated
  public Object getAddressZip() {
    return this.addressZip;
  }

  /**
   * When set to true, this becomes the default external account for its currency.
   */
  @java.lang.SuppressWarnings("all")
  @lombok.Generated
  public Boolean getDefaultForCurrency() {
    return this.defaultForCurrency;
  }

  /**
   * Two digit number representing the card’s expiration month.
   */
  @java.lang.SuppressWarnings("all")
  @lombok.Generated
  public Object getExpMonth() {
    return this.expMonth;
  }

  /**
   * Four digit number representing the card’s expiration year.
   */
  @java.lang.SuppressWarnings("all")
  @lombok.Generated
  public Object getExpYear() {
    return this.expYear;
  }

  /**
   * Specifies which fields in the response should be expanded.
   */
  @java.lang.SuppressWarnings("all")
  @lombok.Generated
  public List getExpand() {
    return this.expand;
  }

  /**
   * Map of extra parameters for custom features not available in this client library. The content
   * in this map is not serialized under this field's {@code @SerializedName} value. Instead, each
   * key/value pair is serialized as if the key is a root-level field (serialized) name in this
   * param object. Effectively, this map is flattened to its parent instance.
   */
  @java.lang.SuppressWarnings("all")
  @lombok.Generated
  public Map getExtraParams() {
    return this.extraParams;
  }

  /**
   * Set of key-value pairs that you can attach to an object. This can be useful for storing
   * additional information about the object in a structured format. Individual keys can be unset by
   * posting an empty value to them. All keys can be unset by posting an empty value to `metadata`.
   */
  @java.lang.SuppressWarnings("all")
  @lombok.Generated
  public Map getMetadata() {
    return this.metadata;
  }

  /**
   * Cardholder name.
   */
  @java.lang.SuppressWarnings("all")
  @lombok.Generated
  public Object getName() {
    return this.name;
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy