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

com.stripe.model.Transfer Maven / Gradle / Ivy

The newest version!
// File generated from our OpenAPI spec
package com.stripe.model;

import com.google.gson.annotations.SerializedName;
import com.stripe.exception.StripeException;
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.TransferCreateParams;
import com.stripe.param.TransferListParams;
import com.stripe.param.TransferRetrieveParams;
import com.stripe.param.TransferUpdateParams;
import java.util.Map;
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.Setter;

/**
 * A {@code Transfer} object is created when you move funds between Stripe accounts as part of
 * Connect.
 *
 * 

Before April 6, 2017, transfers also represented movement of funds from a Stripe account to a * card or bank account. This behavior has since been split out into a Payout object, with corresponding payout * endpoints. For more information, read about the transfer/payout split. * *

Related guide: Creating separate charges * and transfers */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public class Transfer extends ApiResource implements MetadataStore, BalanceTransactionSource { /** Amount in cents (or local equivalent) to be transferred. */ @SerializedName("amount") Long amount; /** * Amount in cents (or local equivalent) reversed (can be less than the amount attribute on the * transfer if a partial reversal was issued). */ @SerializedName("amount_reversed") Long amountReversed; /** Balance transaction that describes the impact of this transfer on your account balance. */ @SerializedName("balance_transaction") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField balanceTransaction; /** Time that this record of the transfer was first created. */ @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; /** ID of the Stripe account the transfer was sent to. */ @SerializedName("destination") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField destination; /** * If the destination is a Stripe account, this will be the ID of the payment that the destination * account received for the transfer. */ @SerializedName("destination_payment") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField destinationPayment; /** Unique identifier for the object. */ @Getter(onMethod_ = {@Override}) @SerializedName("id") String id; /** * 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. */ @Getter(onMethod_ = {@Override}) @SerializedName("metadata") Map metadata; /** * String representing the object's type. Objects of the same type share the same value. * *

Equal to {@code transfer}. */ @SerializedName("object") String object; /** A list of reversals that have been applied to the transfer. */ @SerializedName("reversals") TransferReversalCollection reversals; /** * Whether the transfer has been fully reversed. If the transfer is only partially reversed, this * attribute will still be false. */ @SerializedName("reversed") Boolean reversed; /** * ID of the charge that was used to fund the transfer. If null, the transfer was funded from the * available balance. */ @SerializedName("source_transaction") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField sourceTransaction; /** * The source balance this transfer came from. One of {@code card}, {@code fpx}, or {@code * bank_account}. */ @SerializedName("source_type") String sourceType; /** * A string that identifies this transaction as part of a group. See the Connect * documentation for details. */ @SerializedName("transfer_group") String transferGroup; /** Get ID of expandable {@code balanceTransaction} object. */ public String getBalanceTransaction() { return (this.balanceTransaction != null) ? this.balanceTransaction.getId() : null; } public void setBalanceTransaction(String id) { this.balanceTransaction = ApiResource.setExpandableFieldId(id, this.balanceTransaction); } /** Get expanded {@code balanceTransaction}. */ public BalanceTransaction getBalanceTransactionObject() { return (this.balanceTransaction != null) ? this.balanceTransaction.getExpanded() : null; } public void setBalanceTransactionObject(BalanceTransaction expandableObject) { this.balanceTransaction = new ExpandableField(expandableObject.getId(), expandableObject); } /** Get ID of expandable {@code destination} object. */ public String getDestination() { return (this.destination != null) ? this.destination.getId() : null; } public void setDestination(String id) { this.destination = ApiResource.setExpandableFieldId(id, this.destination); } /** Get expanded {@code destination}. */ public Account getDestinationObject() { return (this.destination != null) ? this.destination.getExpanded() : null; } public void setDestinationObject(Account expandableObject) { this.destination = new ExpandableField(expandableObject.getId(), expandableObject); } /** Get ID of expandable {@code destinationPayment} object. */ public String getDestinationPayment() { return (this.destinationPayment != null) ? this.destinationPayment.getId() : null; } public void setDestinationPayment(String id) { this.destinationPayment = ApiResource.setExpandableFieldId(id, this.destinationPayment); } /** Get expanded {@code destinationPayment}. */ public Charge getDestinationPaymentObject() { return (this.destinationPayment != null) ? this.destinationPayment.getExpanded() : null; } public void setDestinationPaymentObject(Charge expandableObject) { this.destinationPayment = new ExpandableField(expandableObject.getId(), expandableObject); } /** Get ID of expandable {@code sourceTransaction} object. */ public String getSourceTransaction() { return (this.sourceTransaction != null) ? this.sourceTransaction.getId() : null; } public void setSourceTransaction(String id) { this.sourceTransaction = ApiResource.setExpandableFieldId(id, this.sourceTransaction); } /** Get expanded {@code sourceTransaction}. */ public Charge getSourceTransactionObject() { return (this.sourceTransaction != null) ? this.sourceTransaction.getExpanded() : null; } public void setSourceTransactionObject(Charge expandableObject) { this.sourceTransaction = new ExpandableField(expandableObject.getId(), expandableObject); } /** * To send funds from your Stripe account to a connected account, you create a new transfer * object. Your Stripe balance must be able to * cover the transfer amount, or you’ll receive an “Insufficient Funds” error. */ public static Transfer create(Map params) throws StripeException { return create(params, (RequestOptions) null); } /** * To send funds from your Stripe account to a connected account, you create a new transfer * object. Your Stripe balance must be able to * cover the transfer amount, or you’ll receive an “Insufficient Funds” error. */ public static Transfer create(Map params, RequestOptions options) throws StripeException { String path = "/v1/transfers"; ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getGlobalResponseGetter().request(request, Transfer.class); } /** * To send funds from your Stripe account to a connected account, you create a new transfer * object. Your Stripe balance must be able to * cover the transfer amount, or you’ll receive an “Insufficient Funds” error. */ public static Transfer create(TransferCreateParams params) throws StripeException { return create(params, (RequestOptions) null); } /** * To send funds from your Stripe account to a connected account, you create a new transfer * object. Your Stripe balance must be able to * cover the transfer amount, or you’ll receive an “Insufficient Funds” error. */ public static Transfer create(TransferCreateParams params, RequestOptions options) throws StripeException { String path = "/v1/transfers"; ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, ApiRequestParams.paramsToMap(params), options); return getGlobalResponseGetter().request(request, Transfer.class); } /** * Returns a list of existing transfers sent to connected accounts. The transfers are returned in * sorted order, with the most recently created transfers appearing first. */ public static TransferCollection list(Map params) throws StripeException { return list(params, (RequestOptions) null); } /** * Returns a list of existing transfers sent to connected accounts. The transfers are returned in * sorted order, with the most recently created transfers appearing first. */ public static TransferCollection list(Map params, RequestOptions options) throws StripeException { String path = "/v1/transfers"; ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options); return getGlobalResponseGetter().request(request, TransferCollection.class); } /** * Returns a list of existing transfers sent to connected accounts. The transfers are returned in * sorted order, with the most recently created transfers appearing first. */ public static TransferCollection list(TransferListParams params) throws StripeException { return list(params, (RequestOptions) null); } /** * Returns a list of existing transfers sent to connected accounts. The transfers are returned in * sorted order, with the most recently created transfers appearing first. */ public static TransferCollection list(TransferListParams params, RequestOptions options) throws StripeException { String path = "/v1/transfers"; ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.GET, path, ApiRequestParams.paramsToMap(params), options); return getGlobalResponseGetter().request(request, TransferCollection.class); } /** * Retrieves the details of an existing transfer. Supply the unique transfer ID from either a * transfer creation request or the transfer list, and Stripe will return the corresponding * transfer information. */ public static Transfer retrieve(String transfer) throws StripeException { return retrieve(transfer, (Map) null, (RequestOptions) null); } /** * Retrieves the details of an existing transfer. Supply the unique transfer ID from either a * transfer creation request or the transfer list, and Stripe will return the corresponding * transfer information. */ public static Transfer retrieve(String transfer, RequestOptions options) throws StripeException { return retrieve(transfer, (Map) null, options); } /** * Retrieves the details of an existing transfer. Supply the unique transfer ID from either a * transfer creation request or the transfer list, and Stripe will return the corresponding * transfer information. */ public static Transfer retrieve( String transfer, Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/transfers/%s", ApiResource.urlEncodeId(transfer)); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options); return getGlobalResponseGetter().request(request, Transfer.class); } /** * Retrieves the details of an existing transfer. Supply the unique transfer ID from either a * transfer creation request or the transfer list, and Stripe will return the corresponding * transfer information. */ public static Transfer retrieve( String transfer, TransferRetrieveParams params, RequestOptions options) throws StripeException { String path = String.format("/v1/transfers/%s", ApiResource.urlEncodeId(transfer)); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.GET, path, ApiRequestParams.paramsToMap(params), options); return getGlobalResponseGetter().request(request, Transfer.class); } /** * Updates the specified transfer by setting the values of the parameters passed. Any parameters * not provided will be left unchanged. * *

This request accepts only metadata as an argument. */ @Override public Transfer update(Map params) throws StripeException { return update(params, (RequestOptions) null); } /** * Updates the specified transfer by setting the values of the parameters passed. Any parameters * not provided will be left unchanged. * *

This request accepts only metadata as an argument. */ @Override public Transfer update(Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/transfers/%s", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getResponseGetter().request(request, Transfer.class); } /** * Updates the specified transfer by setting the values of the parameters passed. Any parameters * not provided will be left unchanged. * *

This request accepts only metadata as an argument. */ public Transfer update(TransferUpdateParams params) throws StripeException { return update(params, (RequestOptions) null); } /** * Updates the specified transfer by setting the values of the parameters passed. Any parameters * not provided will be left unchanged. * *

This request accepts only metadata as an argument. */ public Transfer update(TransferUpdateParams params, RequestOptions options) throws StripeException { String path = String.format("/v1/transfers/%s", ApiResource.urlEncodeId(this.getId())); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, ApiRequestParams.paramsToMap(params), options); return getResponseGetter().request(request, Transfer.class); } @Override public void setResponseGetter(StripeResponseGetter responseGetter) { super.setResponseGetter(responseGetter); trySetResponseGetter(balanceTransaction, responseGetter); trySetResponseGetter(destination, responseGetter); trySetResponseGetter(destinationPayment, responseGetter); trySetResponseGetter(reversals, responseGetter); trySetResponseGetter(sourceTransaction, responseGetter); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy