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

com.stripe.model.treasury.InboundTransfer Maven / Gradle / Ivy

There is a newer version: 28.2.0
Show newest version
// File generated from our OpenAPI spec
package com.stripe.model.treasury;

import com.google.gson.annotations.SerializedName;
import com.stripe.exception.StripeException;
import com.stripe.model.Address;
import com.stripe.model.ExpandableField;
import com.stripe.model.HasId;
import com.stripe.model.Mandate;
import com.stripe.model.StripeObject;
import com.stripe.net.ApiMode;
import com.stripe.net.ApiRequest;
import com.stripe.net.ApiRequestParams;
import com.stripe.net.ApiResource;
import com.stripe.net.BaseAddress;
import com.stripe.net.RequestOptions;
import com.stripe.net.StripeResponseGetter;
import com.stripe.param.treasury.InboundTransferCancelParams;
import com.stripe.param.treasury.InboundTransferCreateParams;
import com.stripe.param.treasury.InboundTransferFailParams;
import com.stripe.param.treasury.InboundTransferListParams;
import com.stripe.param.treasury.InboundTransferRetrieveParams;
import com.stripe.param.treasury.InboundTransferReturnInboundTransferParams;
import com.stripe.param.treasury.InboundTransferSucceedParams;
import java.util.Map;
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.Setter;

/**
 * Use InboundTransfers
 * to add funds to your FinancialAccount via a PaymentMethod
 * that is owned by you. The funds will be transferred via an ACH debit.
 */
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public class InboundTransfer extends ApiResource implements HasId {
  /** Amount (in cents) transferred. */
  @SerializedName("amount")
  Long amount;

  /** Returns {@code true} if the InboundTransfer is able to be canceled. */
  @SerializedName("cancelable")
  Boolean cancelable;

  /** Time at which the object was created. Measured in seconds since the Unix epoch. */
  @SerializedName("created")
  Long created;

  /**
   * Three-letter ISO currency code,
   * in lowercase. Must be a supported currency.
   */
  @SerializedName("currency")
  String currency;

  /** An arbitrary string attached to the object. Often useful for displaying to users. */
  @SerializedName("description")
  String description;

  /** Details about this InboundTransfer's failure. Only set when status is {@code failed}. */
  @SerializedName("failure_details")
  FailureDetails failureDetails;

  /** The FinancialAccount that received the funds. */
  @SerializedName("financial_account")
  String financialAccount;

  /**
   * A hosted
   * transaction receipt URL that is provided when money movement is considered regulated under
   * Stripe's money transmission licenses.
   */
  @SerializedName("hosted_regulatory_receipt_url")
  String hostedRegulatoryReceiptUrl;

  /** Unique identifier for the object. */
  @Getter(onMethod_ = {@Override})
  @SerializedName("id")
  String id;

  @SerializedName("linked_flows")
  LinkedFlows linkedFlows;

  /**
   * Has the value {@code true} if the object exists in live mode or the value {@code false} if the
   * object exists in test mode.
   */
  @SerializedName("livemode")
  Boolean livemode;

  /**
   * 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.
   */
  @SerializedName("metadata")
  Map metadata;

  /**
   * String representing the object's type. Objects of the same type share the same value.
   *
   * 

Equal to {@code treasury.inbound_transfer}. */ @SerializedName("object") String object; /** The origin payment method to be debited for an InboundTransfer. */ @SerializedName("origin_payment_method") String originPaymentMethod; /** Details about the PaymentMethod for an InboundTransfer. */ @SerializedName("origin_payment_method_details") OriginPaymentMethodDetails originPaymentMethodDetails; /** * Returns {@code true} if the funds for an InboundTransfer were returned after the * InboundTransfer went to the {@code succeeded} state. */ @SerializedName("returned") Boolean returned; /** * Statement descriptor shown when funds are debited from the source. Not all payment networks * support {@code statement_descriptor}. */ @SerializedName("statement_descriptor") String statementDescriptor; /** * Status of the InboundTransfer: {@code processing}, {@code succeeded}, {@code failed}, and * {@code canceled}. An InboundTransfer is {@code processing} if it is created and pending. The * status changes to {@code succeeded} once the funds have been "confirmed" and a {@code * transaction} is created and posted. The status changes to {@code failed} if the transfer fails. * *

One of {@code canceled}, {@code failed}, {@code processing}, or {@code succeeded}. */ @SerializedName("status") String status; @SerializedName("status_transitions") StatusTransitions statusTransitions; /** The Transaction associated with this object. */ @SerializedName("transaction") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField transaction; /** Get ID of expandable {@code transaction} object. */ public String getTransaction() { return (this.transaction != null) ? this.transaction.getId() : null; } public void setTransaction(String id) { this.transaction = ApiResource.setExpandableFieldId(id, this.transaction); } /** Get expanded {@code transaction}. */ public Transaction getTransactionObject() { return (this.transaction != null) ? this.transaction.getExpanded() : null; } public void setTransactionObject(Transaction expandableObject) { this.transaction = new ExpandableField(expandableObject.getId(), expandableObject); } /** Cancels an InboundTransfer. */ public InboundTransfer cancel() throws StripeException { return cancel((Map) null, (RequestOptions) null); } /** Cancels an InboundTransfer. */ public InboundTransfer cancel(RequestOptions options) throws StripeException { return cancel((Map) null, options); } /** Cancels an InboundTransfer. */ public InboundTransfer cancel(Map params) throws StripeException { return cancel(params, (RequestOptions) null); } /** Cancels an InboundTransfer. */ public InboundTransfer cancel(Map params, RequestOptions options) throws StripeException { String path = String.format( "/v1/treasury/inbound_transfers/%s/cancel", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options, ApiMode.V1); return getResponseGetter().request(request, InboundTransfer.class); } /** Cancels an InboundTransfer. */ public InboundTransfer cancel(InboundTransferCancelParams params) throws StripeException { return cancel(params, (RequestOptions) null); } /** Cancels an InboundTransfer. */ public InboundTransfer cancel(InboundTransferCancelParams params, RequestOptions options) throws StripeException { String path = String.format( "/v1/treasury/inbound_transfers/%s/cancel", ApiResource.urlEncodeId(this.getId())); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, ApiRequestParams.paramsToMap(params), options, ApiMode.V1); return getResponseGetter().request(request, InboundTransfer.class); } /** Creates an InboundTransfer. */ public static InboundTransfer create(Map params) throws StripeException { return create(params, (RequestOptions) null); } /** Creates an InboundTransfer. */ public static InboundTransfer create(Map params, RequestOptions options) throws StripeException { String path = "/v1/treasury/inbound_transfers"; ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options, ApiMode.V1); return getGlobalResponseGetter().request(request, InboundTransfer.class); } /** Creates an InboundTransfer. */ public static InboundTransfer create(InboundTransferCreateParams params) throws StripeException { return create(params, (RequestOptions) null); } /** Creates an InboundTransfer. */ public static InboundTransfer create(InboundTransferCreateParams params, RequestOptions options) throws StripeException { String path = "/v1/treasury/inbound_transfers"; ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, ApiRequestParams.paramsToMap(params), options, ApiMode.V1); return getGlobalResponseGetter().request(request, InboundTransfer.class); } /** Returns a list of InboundTransfers sent from the specified FinancialAccount. */ public static InboundTransferCollection list(Map params) throws StripeException { return list(params, (RequestOptions) null); } /** Returns a list of InboundTransfers sent from the specified FinancialAccount. */ public static InboundTransferCollection list(Map params, RequestOptions options) throws StripeException { String path = "/v1/treasury/inbound_transfers"; ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options, ApiMode.V1); return getGlobalResponseGetter().request(request, InboundTransferCollection.class); } /** Returns a list of InboundTransfers sent from the specified FinancialAccount. */ public static InboundTransferCollection list(InboundTransferListParams params) throws StripeException { return list(params, (RequestOptions) null); } /** Returns a list of InboundTransfers sent from the specified FinancialAccount. */ public static InboundTransferCollection list( InboundTransferListParams params, RequestOptions options) throws StripeException { String path = "/v1/treasury/inbound_transfers"; ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.GET, path, ApiRequestParams.paramsToMap(params), options, ApiMode.V1); return getGlobalResponseGetter().request(request, InboundTransferCollection.class); } /** Retrieves the details of an existing InboundTransfer. */ public static InboundTransfer retrieve(String id) throws StripeException { return retrieve(id, (Map) null, (RequestOptions) null); } /** Retrieves the details of an existing InboundTransfer. */ public static InboundTransfer retrieve(String id, RequestOptions options) throws StripeException { return retrieve(id, (Map) null, options); } /** Retrieves the details of an existing InboundTransfer. */ public static InboundTransfer retrieve( String id, Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/treasury/inbound_transfers/%s", ApiResource.urlEncodeId(id)); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options, ApiMode.V1); return getGlobalResponseGetter().request(request, InboundTransfer.class); } /** Retrieves the details of an existing InboundTransfer. */ public static InboundTransfer retrieve( String id, InboundTransferRetrieveParams params, RequestOptions options) throws StripeException { String path = String.format("/v1/treasury/inbound_transfers/%s", ApiResource.urlEncodeId(id)); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.GET, path, ApiRequestParams.paramsToMap(params), options, ApiMode.V1); return getGlobalResponseGetter().request(request, InboundTransfer.class); } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class FailureDetails extends StripeObject { /** * Reason for the failure. * *

One of {@code account_closed}, {@code account_frozen}, {@code bank_account_restricted}, * {@code bank_ownership_changed}, {@code debit_not_authorized}, {@code * incorrect_account_holder_address}, {@code incorrect_account_holder_name}, {@code * incorrect_account_holder_tax_id}, {@code insufficient_funds}, {@code invalid_account_number}, * {@code invalid_currency}, {@code no_account}, or {@code other}. */ @SerializedName("code") String code; } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class LinkedFlows extends StripeObject { /** * If funds for this flow were returned after the flow went to the {@code succeeded} state, this * field contains a reference to the ReceivedDebit return. */ @SerializedName("received_debit") String receivedDebit; } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class OriginPaymentMethodDetails extends StripeObject { @SerializedName("billing_details") BillingDetails billingDetails; /** * The type of the payment method used in the InboundTransfer. * *

Equal to {@code us_bank_account}. */ @SerializedName("type") String type; @SerializedName("us_bank_account") UsBankAccount usBankAccount; @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class BillingDetails extends StripeObject { @SerializedName("address") Address address; /** Email address. */ @SerializedName("email") String email; /** Full name. */ @SerializedName("name") String name; } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class UsBankAccount extends StripeObject { /** * Account holder type: individual or company. * *

One of {@code company}, or {@code individual}. */ @SerializedName("account_holder_type") String accountHolderType; /** * Account type: checkings or savings. Defaults to checking if omitted. * *

One of {@code checking}, or {@code savings}. */ @SerializedName("account_type") String accountType; /** Name of the bank associated with the bank account. */ @SerializedName("bank_name") String bankName; /** * Uniquely identifies this particular bank account. You can use this attribute to check * whether two bank accounts are the same. */ @SerializedName("fingerprint") String fingerprint; /** Last four digits of the bank account number. */ @SerializedName("last4") String last4; /** ID of the mandate used to make this payment. */ @SerializedName("mandate") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField mandate; /** * The network rails used. See the docs to learn more * about money movement timelines for each network type. * *

Equal to {@code ach}. */ @SerializedName("network") String network; /** Routing number of the bank account. */ @SerializedName("routing_number") String routingNumber; /** Get ID of expandable {@code mandate} object. */ public String getMandate() { return (this.mandate != null) ? this.mandate.getId() : null; } public void setMandate(String id) { this.mandate = ApiResource.setExpandableFieldId(id, this.mandate); } /** Get expanded {@code mandate}. */ public Mandate getMandateObject() { return (this.mandate != null) ? this.mandate.getExpanded() : null; } public void setMandateObject(Mandate expandableObject) { this.mandate = new ExpandableField(expandableObject.getId(), expandableObject); } } } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class StatusTransitions extends StripeObject { /** Timestamp describing when an InboundTransfer changed status to {@code canceled}. */ @SerializedName("canceled_at") Long canceledAt; /** Timestamp describing when an InboundTransfer changed status to {@code failed}. */ @SerializedName("failed_at") Long failedAt; /** Timestamp describing when an InboundTransfer changed status to {@code succeeded}. */ @SerializedName("succeeded_at") Long succeededAt; } public TestHelpers getTestHelpers() { return new TestHelpers(this); } public static class TestHelpers { private final InboundTransfer resource; private TestHelpers(InboundTransfer resource) { this.resource = resource; } /** * Transitions a test mode created InboundTransfer to the {@code failed} status. The * InboundTransfer must already be in the {@code processing} state. */ public InboundTransfer fail() throws StripeException { return fail((Map) null, (RequestOptions) null); } /** * Transitions a test mode created InboundTransfer to the {@code failed} status. The * InboundTransfer must already be in the {@code processing} state. */ public InboundTransfer fail(RequestOptions options) throws StripeException { return fail((Map) null, options); } /** * Transitions a test mode created InboundTransfer to the {@code failed} status. The * InboundTransfer must already be in the {@code processing} state. */ public InboundTransfer fail(Map params) throws StripeException { return fail(params, (RequestOptions) null); } /** * Transitions a test mode created InboundTransfer to the {@code failed} status. The * InboundTransfer must already be in the {@code processing} state. */ public InboundTransfer fail(Map params, RequestOptions options) throws StripeException { String path = String.format( "/v1/test_helpers/treasury/inbound_transfers/%s/fail", ApiResource.urlEncodeId(this.resource.getId())); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options, ApiMode.V1); return resource.getResponseGetter().request(request, InboundTransfer.class); } /** * Transitions a test mode created InboundTransfer to the {@code failed} status. The * InboundTransfer must already be in the {@code processing} state. */ public InboundTransfer fail(InboundTransferFailParams params) throws StripeException { return fail(params, (RequestOptions) null); } /** * Transitions a test mode created InboundTransfer to the {@code failed} status. The * InboundTransfer must already be in the {@code processing} state. */ public InboundTransfer fail(InboundTransferFailParams params, RequestOptions options) throws StripeException { String path = String.format( "/v1/test_helpers/treasury/inbound_transfers/%s/fail", ApiResource.urlEncodeId(this.resource.getId())); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, ApiRequestParams.paramsToMap(params), options, ApiMode.V1); return resource.getResponseGetter().request(request, InboundTransfer.class); } /** * Marks the test mode InboundTransfer object as returned and links the InboundTransfer to a * ReceivedDebit. The InboundTransfer must already be in the {@code succeeded} state. */ public InboundTransfer returnInboundTransfer() throws StripeException { return returnInboundTransfer((Map) null, (RequestOptions) null); } /** * Marks the test mode InboundTransfer object as returned and links the InboundTransfer to a * ReceivedDebit. The InboundTransfer must already be in the {@code succeeded} state. */ public InboundTransfer returnInboundTransfer(RequestOptions options) throws StripeException { return returnInboundTransfer((Map) null, options); } /** * Marks the test mode InboundTransfer object as returned and links the InboundTransfer to a * ReceivedDebit. The InboundTransfer must already be in the {@code succeeded} state. */ public InboundTransfer returnInboundTransfer(Map params) throws StripeException { return returnInboundTransfer(params, (RequestOptions) null); } /** * Marks the test mode InboundTransfer object as returned and links the InboundTransfer to a * ReceivedDebit. The InboundTransfer must already be in the {@code succeeded} state. */ public InboundTransfer returnInboundTransfer(Map params, RequestOptions options) throws StripeException { String path = String.format( "/v1/test_helpers/treasury/inbound_transfers/%s/return", ApiResource.urlEncodeId(this.resource.getId())); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options, ApiMode.V1); return resource.getResponseGetter().request(request, InboundTransfer.class); } /** * Marks the test mode InboundTransfer object as returned and links the InboundTransfer to a * ReceivedDebit. The InboundTransfer must already be in the {@code succeeded} state. */ public InboundTransfer returnInboundTransfer(InboundTransferReturnInboundTransferParams params) throws StripeException { return returnInboundTransfer(params, (RequestOptions) null); } /** * Marks the test mode InboundTransfer object as returned and links the InboundTransfer to a * ReceivedDebit. The InboundTransfer must already be in the {@code succeeded} state. */ public InboundTransfer returnInboundTransfer( InboundTransferReturnInboundTransferParams params, RequestOptions options) throws StripeException { String path = String.format( "/v1/test_helpers/treasury/inbound_transfers/%s/return", ApiResource.urlEncodeId(this.resource.getId())); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, ApiRequestParams.paramsToMap(params), options, ApiMode.V1); return resource.getResponseGetter().request(request, InboundTransfer.class); } /** * Transitions a test mode created InboundTransfer to the {@code succeeded} status. The * InboundTransfer must already be in the {@code processing} state. */ public InboundTransfer succeed() throws StripeException { return succeed((Map) null, (RequestOptions) null); } /** * Transitions a test mode created InboundTransfer to the {@code succeeded} status. The * InboundTransfer must already be in the {@code processing} state. */ public InboundTransfer succeed(RequestOptions options) throws StripeException { return succeed((Map) null, options); } /** * Transitions a test mode created InboundTransfer to the {@code succeeded} status. The * InboundTransfer must already be in the {@code processing} state. */ public InboundTransfer succeed(Map params) throws StripeException { return succeed(params, (RequestOptions) null); } /** * Transitions a test mode created InboundTransfer to the {@code succeeded} status. The * InboundTransfer must already be in the {@code processing} state. */ public InboundTransfer succeed(Map params, RequestOptions options) throws StripeException { String path = String.format( "/v1/test_helpers/treasury/inbound_transfers/%s/succeed", ApiResource.urlEncodeId(this.resource.getId())); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options, ApiMode.V1); return resource.getResponseGetter().request(request, InboundTransfer.class); } /** * Transitions a test mode created InboundTransfer to the {@code succeeded} status. The * InboundTransfer must already be in the {@code processing} state. */ public InboundTransfer succeed(InboundTransferSucceedParams params) throws StripeException { return succeed(params, (RequestOptions) null); } /** * Transitions a test mode created InboundTransfer to the {@code succeeded} status. The * InboundTransfer must already be in the {@code processing} state. */ public InboundTransfer succeed(InboundTransferSucceedParams params, RequestOptions options) throws StripeException { String path = String.format( "/v1/test_helpers/treasury/inbound_transfers/%s/succeed", ApiResource.urlEncodeId(this.resource.getId())); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, ApiRequestParams.paramsToMap(params), options, ApiMode.V1); return resource.getResponseGetter().request(request, InboundTransfer.class); } } @Override public void setResponseGetter(StripeResponseGetter responseGetter) { super.setResponseGetter(responseGetter); trySetResponseGetter(failureDetails, responseGetter); trySetResponseGetter(linkedFlows, responseGetter); trySetResponseGetter(originPaymentMethodDetails, responseGetter); trySetResponseGetter(statusTransitions, responseGetter); trySetResponseGetter(transaction, responseGetter); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy