com.stripe.param.treasury.FinancialAccountUpdateParams Maven / Gradle / Ivy
// File generated from our OpenAPI spec
package com.stripe.param.treasury;
import com.google.gson.annotations.SerializedName;
import com.stripe.net.ApiRequestParams;
import com.stripe.param.common.EmptyParam;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import lombok.Getter;
@Getter
public class FinancialAccountUpdateParams extends ApiRequestParams {
/**
* The display name for the FinancialAccount. Use this field to customize the names of the
* FinancialAccounts for your connected accounts. Unlike the {@code nickname} field, {@code
* display_name} is not internal metadata and will be exposed to connected accounts.
*/
@SerializedName("display_name")
Object displayName;
/** 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;
/**
* Encodes whether a FinancialAccount has access to a particular feature, with a status enum and
* associated {@code status_details}. Stripe or the platform may control features via the
* requested field.
*/
@SerializedName("features")
Features features;
/**
* 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 {@code metadata}.
*/
@SerializedName("metadata")
Map metadata;
/** The set of functionalities that the platform can restrict on the FinancialAccount. */
@SerializedName("platform_restrictions")
PlatformRestrictions platformRestrictions;
private FinancialAccountUpdateParams(
Object displayName,
List expand,
Map extraParams,
Features features,
Map metadata,
PlatformRestrictions platformRestrictions) {
this.displayName = displayName;
this.expand = expand;
this.extraParams = extraParams;
this.features = features;
this.metadata = metadata;
this.platformRestrictions = platformRestrictions;
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private Object displayName;
private List expand;
private Map extraParams;
private Features features;
private Map metadata;
private PlatformRestrictions platformRestrictions;
/** Finalize and obtain parameter instance from this builder. */
public FinancialAccountUpdateParams build() {
return new FinancialAccountUpdateParams(
this.displayName,
this.expand,
this.extraParams,
this.features,
this.metadata,
this.platformRestrictions);
}
/**
* The display name for the FinancialAccount. Use this field to customize the names of the
* FinancialAccounts for your connected accounts. Unlike the {@code nickname} field, {@code
* display_name} is not internal metadata and will be exposed to connected accounts.
*/
public Builder setDisplayName(String displayName) {
this.displayName = displayName;
return this;
}
/**
* The display name for the FinancialAccount. Use this field to customize the names of the
* FinancialAccounts for your connected accounts. Unlike the {@code nickname} field, {@code
* display_name} is not internal metadata and will be exposed to connected accounts.
*/
public Builder setDisplayName(EmptyParam displayName) {
this.displayName = displayName;
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
* FinancialAccountUpdateParams#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
* FinancialAccountUpdateParams#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
* FinancialAccountUpdateParams#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 FinancialAccountUpdateParams#extraParams} for the field documentation.
*/
public Builder putAllExtraParam(Map map) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.putAll(map);
return this;
}
/**
* Encodes whether a FinancialAccount has access to a particular feature, with a status enum and
* associated {@code status_details}. Stripe or the platform may control features via the
* requested field.
*/
public Builder setFeatures(FinancialAccountUpdateParams.Features features) {
this.features = features;
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
* FinancialAccountUpdateParams#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 FinancialAccountUpdateParams#metadata} for the field documentation.
*/
public Builder putAllMetadata(Map map) {
if (this.metadata == null) {
this.metadata = new HashMap<>();
}
this.metadata.putAll(map);
return this;
}
/** The set of functionalities that the platform can restrict on the FinancialAccount. */
public Builder setPlatformRestrictions(
FinancialAccountUpdateParams.PlatformRestrictions platformRestrictions) {
this.platformRestrictions = platformRestrictions;
return this;
}
}
@Getter
public static class Features {
/**
* Encodes the FinancialAccount's ability to be used with the Issuing product, including
* attaching cards to and drawing funds from the FinancialAccount.
*/
@SerializedName("card_issuing")
CardIssuing cardIssuing;
/**
* Represents whether this FinancialAccount is eligible for deposit insurance. Various factors
* determine the insurance amount.
*/
@SerializedName("deposit_insurance")
DepositInsurance depositInsurance;
/**
* 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;
/** Contains Features that add FinancialAddresses to the FinancialAccount. */
@SerializedName("financial_addresses")
FinancialAddresses financialAddresses;
/**
* Contains settings related to adding funds to a FinancialAccount from another Account with the
* same owner.
*/
@SerializedName("inbound_transfers")
InboundTransfers inboundTransfers;
/**
* Represents the ability for the FinancialAccount to send money to, or receive money from other
* FinancialAccounts (for example, via OutboundPayment).
*/
@SerializedName("intra_stripe_flows")
IntraStripeFlows intraStripeFlows;
/**
* Includes Features related to initiating money movement out of the FinancialAccount to someone
* else's bucket of money.
*/
@SerializedName("outbound_payments")
OutboundPayments outboundPayments;
/**
* Contains a Feature and settings related to moving money out of the FinancialAccount into
* another Account with the same owner.
*/
@SerializedName("outbound_transfers")
OutboundTransfers outboundTransfers;
private Features(
CardIssuing cardIssuing,
DepositInsurance depositInsurance,
Map extraParams,
FinancialAddresses financialAddresses,
InboundTransfers inboundTransfers,
IntraStripeFlows intraStripeFlows,
OutboundPayments outboundPayments,
OutboundTransfers outboundTransfers) {
this.cardIssuing = cardIssuing;
this.depositInsurance = depositInsurance;
this.extraParams = extraParams;
this.financialAddresses = financialAddresses;
this.inboundTransfers = inboundTransfers;
this.intraStripeFlows = intraStripeFlows;
this.outboundPayments = outboundPayments;
this.outboundTransfers = outboundTransfers;
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private CardIssuing cardIssuing;
private DepositInsurance depositInsurance;
private Map extraParams;
private FinancialAddresses financialAddresses;
private InboundTransfers inboundTransfers;
private IntraStripeFlows intraStripeFlows;
private OutboundPayments outboundPayments;
private OutboundTransfers outboundTransfers;
/** Finalize and obtain parameter instance from this builder. */
public FinancialAccountUpdateParams.Features build() {
return new FinancialAccountUpdateParams.Features(
this.cardIssuing,
this.depositInsurance,
this.extraParams,
this.financialAddresses,
this.inboundTransfers,
this.intraStripeFlows,
this.outboundPayments,
this.outboundTransfers);
}
/**
* Encodes the FinancialAccount's ability to be used with the Issuing product, including
* attaching cards to and drawing funds from the FinancialAccount.
*/
public Builder setCardIssuing(FinancialAccountUpdateParams.Features.CardIssuing cardIssuing) {
this.cardIssuing = cardIssuing;
return this;
}
/**
* Represents whether this FinancialAccount is eligible for deposit insurance. Various factors
* determine the insurance amount.
*/
public Builder setDepositInsurance(
FinancialAccountUpdateParams.Features.DepositInsurance depositInsurance) {
this.depositInsurance = depositInsurance;
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
* FinancialAccountUpdateParams.Features#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 FinancialAccountUpdateParams.Features#extraParams} for the field documentation.
*/
public Builder putAllExtraParam(Map map) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.putAll(map);
return this;
}
/** Contains Features that add FinancialAddresses to the FinancialAccount. */
public Builder setFinancialAddresses(
FinancialAccountUpdateParams.Features.FinancialAddresses financialAddresses) {
this.financialAddresses = financialAddresses;
return this;
}
/**
* Contains settings related to adding funds to a FinancialAccount from another Account with
* the same owner.
*/
public Builder setInboundTransfers(
FinancialAccountUpdateParams.Features.InboundTransfers inboundTransfers) {
this.inboundTransfers = inboundTransfers;
return this;
}
/**
* Represents the ability for the FinancialAccount to send money to, or receive money from
* other FinancialAccounts (for example, via OutboundPayment).
*/
public Builder setIntraStripeFlows(
FinancialAccountUpdateParams.Features.IntraStripeFlows intraStripeFlows) {
this.intraStripeFlows = intraStripeFlows;
return this;
}
/**
* Includes Features related to initiating money movement out of the FinancialAccount to
* someone else's bucket of money.
*/
public Builder setOutboundPayments(
FinancialAccountUpdateParams.Features.OutboundPayments outboundPayments) {
this.outboundPayments = outboundPayments;
return this;
}
/**
* Contains a Feature and settings related to moving money out of the FinancialAccount into
* another Account with the same owner.
*/
public Builder setOutboundTransfers(
FinancialAccountUpdateParams.Features.OutboundTransfers outboundTransfers) {
this.outboundTransfers = outboundTransfers;
return this;
}
}
@Getter
public static class CardIssuing {
/**
* 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;
/** Required. Whether the FinancialAccount should have the Feature. */
@SerializedName("requested")
Boolean requested;
private CardIssuing(Map extraParams, Boolean requested) {
this.extraParams = extraParams;
this.requested = requested;
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private Map extraParams;
private Boolean requested;
/** Finalize and obtain parameter instance from this builder. */
public FinancialAccountUpdateParams.Features.CardIssuing build() {
return new FinancialAccountUpdateParams.Features.CardIssuing(
this.extraParams, this.requested);
}
/**
* 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 FinancialAccountUpdateParams.Features.CardIssuing#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 FinancialAccountUpdateParams.Features.CardIssuing#extraParams} for the
* field documentation.
*/
public Builder putAllExtraParam(Map map) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.putAll(map);
return this;
}
/** Required. Whether the FinancialAccount should have the Feature. */
public Builder setRequested(Boolean requested) {
this.requested = requested;
return this;
}
}
}
@Getter
public static class DepositInsurance {
/**
* 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;
/** Required. Whether the FinancialAccount should have the Feature. */
@SerializedName("requested")
Boolean requested;
private DepositInsurance(Map extraParams, Boolean requested) {
this.extraParams = extraParams;
this.requested = requested;
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private Map extraParams;
private Boolean requested;
/** Finalize and obtain parameter instance from this builder. */
public FinancialAccountUpdateParams.Features.DepositInsurance build() {
return new FinancialAccountUpdateParams.Features.DepositInsurance(
this.extraParams, this.requested);
}
/**
* 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 FinancialAccountUpdateParams.Features.DepositInsurance#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 FinancialAccountUpdateParams.Features.DepositInsurance#extraParams} for
* the field documentation.
*/
public Builder putAllExtraParam(Map map) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.putAll(map);
return this;
}
/** Required. Whether the FinancialAccount should have the Feature. */
public Builder setRequested(Boolean requested) {
this.requested = requested;
return this;
}
}
}
@Getter
public static class FinancialAddresses {
/** Adds an ABA FinancialAddress to the FinancialAccount. */
@SerializedName("aba")
Aba aba;
/**
* 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;
private FinancialAddresses(Aba aba, Map extraParams) {
this.aba = aba;
this.extraParams = extraParams;
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private Aba aba;
private Map extraParams;
/** Finalize and obtain parameter instance from this builder. */
public FinancialAccountUpdateParams.Features.FinancialAddresses build() {
return new FinancialAccountUpdateParams.Features.FinancialAddresses(
this.aba, this.extraParams);
}
/** Adds an ABA FinancialAddress to the FinancialAccount. */
public Builder setAba(FinancialAccountUpdateParams.Features.FinancialAddresses.Aba aba) {
this.aba = aba;
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 FinancialAccountUpdateParams.Features.FinancialAddresses#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 FinancialAccountUpdateParams.Features.FinancialAddresses#extraParams} for
* the field documentation.
*/
public Builder putAllExtraParam(Map map) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.putAll(map);
return this;
}
}
@Getter
public static class Aba {
/** Requested bank partner. */
@SerializedName("bank")
Bank bank;
/**
* 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;
/** Required. Whether the FinancialAccount should have the Feature. */
@SerializedName("requested")
Boolean requested;
private Aba(Bank bank, Map extraParams, Boolean requested) {
this.bank = bank;
this.extraParams = extraParams;
this.requested = requested;
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private Bank bank;
private Map extraParams;
private Boolean requested;
/** Finalize and obtain parameter instance from this builder. */
public FinancialAccountUpdateParams.Features.FinancialAddresses.Aba build() {
return new FinancialAccountUpdateParams.Features.FinancialAddresses.Aba(
this.bank, this.extraParams, this.requested);
}
/** Requested bank partner. */
public Builder setBank(
FinancialAccountUpdateParams.Features.FinancialAddresses.Aba.Bank bank) {
this.bank = bank;
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
* FinancialAccountUpdateParams.Features.FinancialAddresses.Aba#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
* FinancialAccountUpdateParams.Features.FinancialAddresses.Aba#extraParams} for the field
* documentation.
*/
public Builder putAllExtraParam(Map map) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.putAll(map);
return this;
}
/** Required. Whether the FinancialAccount should have the Feature. */
public Builder setRequested(Boolean requested) {
this.requested = requested;
return this;
}
}
public enum Bank implements ApiRequestParams.EnumParam {
@SerializedName("evolve")
EVOLVE("evolve"),
@SerializedName("fifth_third")
FIFTH_THIRD("fifth_third"),
@SerializedName("goldman_sachs")
GOLDMAN_SACHS("goldman_sachs");
@Getter(onMethod_ = {@Override})
private final String value;
Bank(String value) {
this.value = value;
}
}
}
}
@Getter
public static class InboundTransfers {
/** Enables ACH Debits via the InboundTransfers API. */
@SerializedName("ach")
Ach ach;
/**
* 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;
private InboundTransfers(Ach ach, Map extraParams) {
this.ach = ach;
this.extraParams = extraParams;
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private Ach ach;
private Map extraParams;
/** Finalize and obtain parameter instance from this builder. */
public FinancialAccountUpdateParams.Features.InboundTransfers build() {
return new FinancialAccountUpdateParams.Features.InboundTransfers(
this.ach, this.extraParams);
}
/** Enables ACH Debits via the InboundTransfers API. */
public Builder setAch(FinancialAccountUpdateParams.Features.InboundTransfers.Ach ach) {
this.ach = ach;
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 FinancialAccountUpdateParams.Features.InboundTransfers#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 FinancialAccountUpdateParams.Features.InboundTransfers#extraParams} for
* the field documentation.
*/
public Builder putAllExtraParam(Map map) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.putAll(map);
return this;
}
}
@Getter
public static class Ach {
/**
* 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;
/** Required. Whether the FinancialAccount should have the Feature. */
@SerializedName("requested")
Boolean requested;
private Ach(Map extraParams, Boolean requested) {
this.extraParams = extraParams;
this.requested = requested;
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private Map extraParams;
private Boolean requested;
/** Finalize and obtain parameter instance from this builder. */
public FinancialAccountUpdateParams.Features.InboundTransfers.Ach build() {
return new FinancialAccountUpdateParams.Features.InboundTransfers.Ach(
this.extraParams, this.requested);
}
/**
* 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 FinancialAccountUpdateParams.Features.InboundTransfers.Ach#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 FinancialAccountUpdateParams.Features.InboundTransfers.Ach#extraParams}
* for the field documentation.
*/
public Builder putAllExtraParam(Map map) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.putAll(map);
return this;
}
/** Required. Whether the FinancialAccount should have the Feature. */
public Builder setRequested(Boolean requested) {
this.requested = requested;
return this;
}
}
}
}
@Getter
public static class IntraStripeFlows {
/**
* 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;
/** Required. Whether the FinancialAccount should have the Feature. */
@SerializedName("requested")
Boolean requested;
private IntraStripeFlows(Map extraParams, Boolean requested) {
this.extraParams = extraParams;
this.requested = requested;
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private Map extraParams;
private Boolean requested;
/** Finalize and obtain parameter instance from this builder. */
public FinancialAccountUpdateParams.Features.IntraStripeFlows build() {
return new FinancialAccountUpdateParams.Features.IntraStripeFlows(
this.extraParams, this.requested);
}
/**
* 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 FinancialAccountUpdateParams.Features.IntraStripeFlows#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 FinancialAccountUpdateParams.Features.IntraStripeFlows#extraParams} for
* the field documentation.
*/
public Builder putAllExtraParam(Map map) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.putAll(map);
return this;
}
/** Required. Whether the FinancialAccount should have the Feature. */
public Builder setRequested(Boolean requested) {
this.requested = requested;
return this;
}
}
}
@Getter
public static class OutboundPayments {
/** Enables ACH transfers via the OutboundPayments API. */
@SerializedName("ach")
Ach ach;
/**
* 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;
/** Enables US domestic wire transfers via the OutboundPayments API. */
@SerializedName("us_domestic_wire")
UsDomesticWire usDomesticWire;
private OutboundPayments(
Ach ach, Map extraParams, UsDomesticWire usDomesticWire) {
this.ach = ach;
this.extraParams = extraParams;
this.usDomesticWire = usDomesticWire;
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private Ach ach;
private Map extraParams;
private UsDomesticWire usDomesticWire;
/** Finalize and obtain parameter instance from this builder. */
public FinancialAccountUpdateParams.Features.OutboundPayments build() {
return new FinancialAccountUpdateParams.Features.OutboundPayments(
this.ach, this.extraParams, this.usDomesticWire);
}
/** Enables ACH transfers via the OutboundPayments API. */
public Builder setAch(FinancialAccountUpdateParams.Features.OutboundPayments.Ach ach) {
this.ach = ach;
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 FinancialAccountUpdateParams.Features.OutboundPayments#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 FinancialAccountUpdateParams.Features.OutboundPayments#extraParams} for
* the field documentation.
*/
public Builder putAllExtraParam(Map map) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.putAll(map);
return this;
}
/** Enables US domestic wire transfers via the OutboundPayments API. */
public Builder setUsDomesticWire(
FinancialAccountUpdateParams.Features.OutboundPayments.UsDomesticWire usDomesticWire) {
this.usDomesticWire = usDomesticWire;
return this;
}
}
@Getter
public static class Ach {
/**
* 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;
/** Required. Whether the FinancialAccount should have the Feature. */
@SerializedName("requested")
Boolean requested;
private Ach(Map extraParams, Boolean requested) {
this.extraParams = extraParams;
this.requested = requested;
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private Map extraParams;
private Boolean requested;
/** Finalize and obtain parameter instance from this builder. */
public FinancialAccountUpdateParams.Features.OutboundPayments.Ach build() {
return new FinancialAccountUpdateParams.Features.OutboundPayments.Ach(
this.extraParams, this.requested);
}
/**
* 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 FinancialAccountUpdateParams.Features.OutboundPayments.Ach#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 FinancialAccountUpdateParams.Features.OutboundPayments.Ach#extraParams}
* for the field documentation.
*/
public Builder putAllExtraParam(Map map) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.putAll(map);
return this;
}
/** Required. Whether the FinancialAccount should have the Feature. */
public Builder setRequested(Boolean requested) {
this.requested = requested;
return this;
}
}
}
@Getter
public static class UsDomesticWire {
/**
* 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;
/** Required. Whether the FinancialAccount should have the Feature. */
@SerializedName("requested")
Boolean requested;
private UsDomesticWire(Map extraParams, Boolean requested) {
this.extraParams = extraParams;
this.requested = requested;
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private Map extraParams;
private Boolean requested;
/** Finalize and obtain parameter instance from this builder. */
public FinancialAccountUpdateParams.Features.OutboundPayments.UsDomesticWire build() {
return new FinancialAccountUpdateParams.Features.OutboundPayments.UsDomesticWire(
this.extraParams, this.requested);
}
/**
* 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
* FinancialAccountUpdateParams.Features.OutboundPayments.UsDomesticWire#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
* FinancialAccountUpdateParams.Features.OutboundPayments.UsDomesticWire#extraParams} for
* the field documentation.
*/
public Builder putAllExtraParam(Map map) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.putAll(map);
return this;
}
/** Required. Whether the FinancialAccount should have the Feature. */
public Builder setRequested(Boolean requested) {
this.requested = requested;
return this;
}
}
}
}
@Getter
public static class OutboundTransfers {
/** Enables ACH transfers via the OutboundTransfers API. */
@SerializedName("ach")
Ach ach;
/**
* 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;
/** Enables US domestic wire transfers via the OutboundTransfers API. */
@SerializedName("us_domestic_wire")
UsDomesticWire usDomesticWire;
private OutboundTransfers(
Ach ach, Map extraParams, UsDomesticWire usDomesticWire) {
this.ach = ach;
this.extraParams = extraParams;
this.usDomesticWire = usDomesticWire;
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private Ach ach;
private Map extraParams;
private UsDomesticWire usDomesticWire;
/** Finalize and obtain parameter instance from this builder. */
public FinancialAccountUpdateParams.Features.OutboundTransfers build() {
return new FinancialAccountUpdateParams.Features.OutboundTransfers(
this.ach, this.extraParams, this.usDomesticWire);
}
/** Enables ACH transfers via the OutboundTransfers API. */
public Builder setAch(FinancialAccountUpdateParams.Features.OutboundTransfers.Ach ach) {
this.ach = ach;
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 FinancialAccountUpdateParams.Features.OutboundTransfers#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 FinancialAccountUpdateParams.Features.OutboundTransfers#extraParams} for
* the field documentation.
*/
public Builder putAllExtraParam(Map map) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.putAll(map);
return this;
}
/** Enables US domestic wire transfers via the OutboundTransfers API. */
public Builder setUsDomesticWire(
FinancialAccountUpdateParams.Features.OutboundTransfers.UsDomesticWire usDomesticWire) {
this.usDomesticWire = usDomesticWire;
return this;
}
}
@Getter
public static class Ach {
/**
* 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;
/** Required. Whether the FinancialAccount should have the Feature. */
@SerializedName("requested")
Boolean requested;
private Ach(Map extraParams, Boolean requested) {
this.extraParams = extraParams;
this.requested = requested;
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private Map extraParams;
private Boolean requested;
/** Finalize and obtain parameter instance from this builder. */
public FinancialAccountUpdateParams.Features.OutboundTransfers.Ach build() {
return new FinancialAccountUpdateParams.Features.OutboundTransfers.Ach(
this.extraParams, this.requested);
}
/**
* 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
* FinancialAccountUpdateParams.Features.OutboundTransfers.Ach#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
* FinancialAccountUpdateParams.Features.OutboundTransfers.Ach#extraParams} for the field
* documentation.
*/
public Builder putAllExtraParam(Map map) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.putAll(map);
return this;
}
/** Required. Whether the FinancialAccount should have the Feature. */
public Builder setRequested(Boolean requested) {
this.requested = requested;
return this;
}
}
}
@Getter
public static class UsDomesticWire {
/**
* 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;
/** Required. Whether the FinancialAccount should have the Feature. */
@SerializedName("requested")
Boolean requested;
private UsDomesticWire(Map extraParams, Boolean requested) {
this.extraParams = extraParams;
this.requested = requested;
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private Map extraParams;
private Boolean requested;
/** Finalize and obtain parameter instance from this builder. */
public FinancialAccountUpdateParams.Features.OutboundTransfers.UsDomesticWire build() {
return new FinancialAccountUpdateParams.Features.OutboundTransfers.UsDomesticWire(
this.extraParams, this.requested);
}
/**
* 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
* FinancialAccountUpdateParams.Features.OutboundTransfers.UsDomesticWire#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
* FinancialAccountUpdateParams.Features.OutboundTransfers.UsDomesticWire#extraParams} for
* the field documentation.
*/
public Builder putAllExtraParam(Map map) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.putAll(map);
return this;
}
/** Required. Whether the FinancialAccount should have the Feature. */
public Builder setRequested(Boolean requested) {
this.requested = requested;
return this;
}
}
}
}
}
@Getter
public static class PlatformRestrictions {
/**
* 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;
/** Restricts all inbound money movement. */
@SerializedName("inbound_flows")
InboundFlows inboundFlows;
/** Restricts all outbound money movement. */
@SerializedName("outbound_flows")
OutboundFlows outboundFlows;
private PlatformRestrictions(
Map extraParams, InboundFlows inboundFlows, OutboundFlows outboundFlows) {
this.extraParams = extraParams;
this.inboundFlows = inboundFlows;
this.outboundFlows = outboundFlows;
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private Map extraParams;
private InboundFlows inboundFlows;
private OutboundFlows outboundFlows;
/** Finalize and obtain parameter instance from this builder. */
public FinancialAccountUpdateParams.PlatformRestrictions build() {
return new FinancialAccountUpdateParams.PlatformRestrictions(
this.extraParams, this.inboundFlows, this.outboundFlows);
}
/**
* 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
* FinancialAccountUpdateParams.PlatformRestrictions#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 FinancialAccountUpdateParams.PlatformRestrictions#extraParams} for the field
* documentation.
*/
public Builder putAllExtraParam(Map map) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.putAll(map);
return this;
}
/** Restricts all inbound money movement. */
public Builder setInboundFlows(
FinancialAccountUpdateParams.PlatformRestrictions.InboundFlows inboundFlows) {
this.inboundFlows = inboundFlows;
return this;
}
/** Restricts all outbound money movement. */
public Builder setOutboundFlows(
FinancialAccountUpdateParams.PlatformRestrictions.OutboundFlows outboundFlows) {
this.outboundFlows = outboundFlows;
return this;
}
}
public enum InboundFlows implements ApiRequestParams.EnumParam {
@SerializedName("restricted")
RESTRICTED("restricted"),
@SerializedName("unrestricted")
UNRESTRICTED("unrestricted");
@Getter(onMethod_ = {@Override})
private final String value;
InboundFlows(String value) {
this.value = value;
}
}
public enum OutboundFlows implements ApiRequestParams.EnumParam {
@SerializedName("restricted")
RESTRICTED("restricted"),
@SerializedName("unrestricted")
UNRESTRICTED("unrestricted");
@Getter(onMethod_ = {@Override})
private final String value;
OutboundFlows(String value) {
this.value = value;
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy