stripe
Version:
Stripe API wrapper
347 lines (346 loc) • 14.6 kB
TypeScript
import { StripeResource } from '../../StripeResource.js';
import { Transaction } from './Transactions.js';
import { Mandate } from './../Mandates.js';
import { MetadataParam, Emptyable, PaginationParams, Metadata, Address } from '../../shared.js';
import { RequestOptions, ApiListPromise, Response } from '../../lib.js';
export declare class OutboundTransferResource extends StripeResource {
/**
* Returns a list of OutboundTransfers sent from the specified FinancialAccount.
*/
list(params: Treasury.OutboundTransferListParams, options?: RequestOptions): ApiListPromise<OutboundTransfer>;
/**
* Creates an OutboundTransfer.
*/
create(params: Treasury.OutboundTransferCreateParams, options?: RequestOptions): Promise<Response<OutboundTransfer>>;
/**
* Retrieves the details of an existing OutboundTransfer by passing the unique OutboundTransfer ID from either the OutboundTransfer creation request or OutboundTransfer list.
*/
retrieve(id: string, params?: Treasury.OutboundTransferRetrieveParams, options?: RequestOptions): Promise<Response<OutboundTransfer>>;
/**
* An OutboundTransfer can be canceled if the funds have not yet been paid out.
*/
cancel(id: string, params?: Treasury.OutboundTransferCancelParams, options?: RequestOptions): Promise<Response<OutboundTransfer>>;
}
export interface OutboundTransfer {
/**
* Unique identifier for the object.
*/
id: string;
/**
* String representing the object's type. Objects of the same type share the same value.
*/
object: 'treasury.outbound_transfer';
/**
* Amount (in cents) transferred.
*/
amount: number;
/**
* Returns `true` if the object can be canceled, and `false` otherwise.
*/
cancelable: boolean;
/**
* Time at which the object was created. Measured in seconds since the Unix epoch.
*/
created: number;
/**
* Three-letter [ISO currency code](https://www.iso.org/iso-4217-currency-codes.html), in lowercase. Must be a [supported currency](https://stripe.com/docs/currencies).
*/
currency: string;
/**
* An arbitrary string attached to the object. Often useful for displaying to users.
*/
description: string | null;
/**
* The PaymentMethod used as the payment instrument for an OutboundTransfer.
*/
destination_payment_method: string | null;
destination_payment_method_details: Treasury.OutboundTransfer.DestinationPaymentMethodDetails;
/**
* The date when funds are expected to arrive in the destination account.
*/
expected_arrival_date: number;
/**
* The FinancialAccount that funds were pulled from.
*/
financial_account: string;
/**
* A [hosted transaction receipt](https://docs.stripe.com/treasury/moving-money/regulatory-receipts) URL that is provided when money movement is considered regulated under Stripe's money transmission licenses.
*/
hosted_regulatory_receipt_url: string | null;
/**
* If the object exists in live mode, the value is `true`. If the object exists in test mode, the value is `false`.
*/
livemode: boolean;
/**
* Set of [key-value pairs](https://docs.stripe.com/api/metadata) that you can attach to an object. This can be useful for storing additional information about the object in a structured format.
*/
metadata: Metadata;
/**
* Details about a returned OutboundTransfer. Only set when the status is `returned`.
*/
returned_details: Treasury.OutboundTransfer.ReturnedDetails | null;
/**
* Information about the OutboundTransfer to be sent to the recipient account.
*/
statement_descriptor: string;
/**
* Current status of the OutboundTransfer: `processing`, `failed`, `canceled`, `posted`, `returned`. An OutboundTransfer is `processing` if it has been created and is pending. The status changes to `posted` once the OutboundTransfer has been "confirmed" and funds have left the account, or to `failed` or `canceled`. If an OutboundTransfer fails to arrive at its destination, its status will change to `returned`.
*/
status: Treasury.OutboundTransfer.Status;
status_transitions: Treasury.OutboundTransfer.StatusTransitions;
/**
* Details about network-specific tracking information if available.
*/
tracking_details: Treasury.OutboundTransfer.TrackingDetails | null;
/**
* The Transaction associated with this object.
*/
transaction: string | Transaction;
}
export declare namespace Treasury {
namespace OutboundTransfer {
interface DestinationPaymentMethodDetails {
billing_details: DestinationPaymentMethodDetails.BillingDetails;
financial_account?: DestinationPaymentMethodDetails.FinancialAccount;
/**
* The type of the payment method used in the OutboundTransfer.
*/
type: DestinationPaymentMethodDetails.Type;
us_bank_account?: DestinationPaymentMethodDetails.UsBankAccount;
}
interface ReturnedDetails {
/**
* Reason for the return.
*/
code: ReturnedDetails.Code;
/**
* The Transaction associated with this object.
*/
transaction: string | Transaction;
}
type Status = 'canceled' | 'failed' | 'posted' | 'processing' | 'returned';
interface StatusTransitions {
/**
* Timestamp describing when an OutboundTransfer changed status to `canceled`
*/
canceled_at: number | null;
/**
* Timestamp describing when an OutboundTransfer changed status to `failed`
*/
failed_at: number | null;
/**
* Timestamp describing when an OutboundTransfer changed status to `posted`
*/
posted_at: number | null;
/**
* Timestamp describing when an OutboundTransfer changed status to `returned`
*/
returned_at: number | null;
}
interface TrackingDetails {
ach?: TrackingDetails.Ach;
/**
* The US bank account network used to send funds.
*/
type: TrackingDetails.Type;
us_domestic_wire?: TrackingDetails.UsDomesticWire;
}
namespace DestinationPaymentMethodDetails {
interface BillingDetails {
address: Address;
/**
* Email address.
*/
email: string | null;
/**
* Full name.
*/
name: string | null;
}
interface FinancialAccount {
/**
* Token of the FinancialAccount.
*/
id: string;
/**
* The rails used to send funds.
*/
network: 'stripe';
}
type Type = 'financial_account' | 'us_bank_account';
interface UsBankAccount {
/**
* Account holder type: individual or company.
*/
account_holder_type: UsBankAccount.AccountHolderType | null;
/**
* Account type: checkings or savings. Defaults to checking if omitted.
*/
account_type: UsBankAccount.AccountType | null;
/**
* Name of the bank associated with the bank account.
*/
bank_name: string | null;
/**
* Uniquely identifies this particular bank account. You can use this attribute to check whether two bank accounts are the same.
*/
fingerprint: string | null;
/**
* Last four digits of the bank account number.
*/
last4: string | null;
/**
* ID of the mandate used to make this payment.
*/
mandate?: string | Mandate;
/**
* The network rails used. See the [docs](https://docs.stripe.com/treasury/money-movement/timelines) to learn more about money movement timelines for each network type.
*/
network: UsBankAccount.Network;
/**
* Routing number of the bank account.
*/
routing_number: string | null;
}
namespace UsBankAccount {
type AccountHolderType = 'company' | 'individual';
type AccountType = 'checking' | 'savings';
type Network = 'ach' | 'us_domestic_wire';
}
}
namespace ReturnedDetails {
type Code = 'account_closed' | 'account_frozen' | 'bank_account_restricted' | 'bank_ownership_changed' | 'declined' | 'incorrect_account_holder_name' | 'invalid_account_number' | 'invalid_currency' | 'no_account' | 'other';
}
namespace TrackingDetails {
interface Ach {
/**
* ACH trace ID of the OutboundTransfer for transfers sent over the `ach` network.
*/
trace_id: string;
}
type Type = 'ach' | 'us_domestic_wire';
interface UsDomesticWire {
/**
* CHIPS System Sequence Number (SSN) of the OutboundTransfer for transfers sent over the `us_domestic_wire` network.
*/
chips: string | null;
/**
* IMAD of the OutboundTransfer for transfers sent over the `us_domestic_wire` network.
*/
imad: string | null;
/**
* OMAD of the OutboundTransfer for transfers sent over the `us_domestic_wire` network.
*/
omad: string | null;
}
}
}
}
export declare namespace Treasury {
interface OutboundTransferCreateParams {
/**
* Amount (in cents) to be transferred.
*/
amount: number;
/**
* Three-letter [ISO currency code](https://www.iso.org/iso-4217-currency-codes.html), in lowercase. Must be a [supported currency](https://stripe.com/docs/currencies).
*/
currency: string;
/**
* The FinancialAccount to pull funds from.
*/
financial_account: string;
/**
* An arbitrary string attached to the object. Often useful for displaying to users.
*/
description?: string;
/**
* The PaymentMethod to use as the payment instrument for the OutboundTransfer.
*/
destination_payment_method?: string;
/**
* Hash used to generate the PaymentMethod to be used for this OutboundTransfer. Exclusive with `destination_payment_method`.
*/
destination_payment_method_data?: OutboundTransferCreateParams.DestinationPaymentMethodData;
/**
* Hash describing payment method configuration details.
*/
destination_payment_method_options?: OutboundTransferCreateParams.DestinationPaymentMethodOptions;
/**
* Specifies which fields in the response should be expanded.
*/
expand?: Array<string>;
/**
* Set of [key-value pairs](https://docs.stripe.com/api/metadata) 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`.
*/
metadata?: MetadataParam;
/**
* Statement descriptor to be shown on the receiving end of an OutboundTransfer. Maximum 10 characters for `ach` transfers or 140 characters for `us_domestic_wire` transfers. The default value is "transfer". Can only include -#.$&*, spaces, and alphanumeric characters.
*/
statement_descriptor?: string;
}
namespace OutboundTransferCreateParams {
interface DestinationPaymentMethodData {
/**
* Required if type is set to `financial_account`. The FinancialAccount ID to send funds to.
*/
financial_account?: string;
/**
* The type of the destination.
*/
type: 'financial_account';
}
interface DestinationPaymentMethodOptions {
/**
* Optional fields for `us_bank_account`.
*/
us_bank_account?: Emptyable<DestinationPaymentMethodOptions.UsBankAccount>;
}
namespace DestinationPaymentMethodOptions {
interface UsBankAccount {
/**
* Specifies the network rails to be used. If not set, will default to the PaymentMethod's preferred network. See the [docs](https://docs.stripe.com/treasury/money-movement/timelines) to learn more about money movement timelines for each network type.
*/
network?: UsBankAccount.Network;
}
namespace UsBankAccount {
type Network = 'ach' | 'us_domestic_wire';
}
}
}
}
export declare namespace Treasury {
interface OutboundTransferRetrieveParams {
/**
* Specifies which fields in the response should be expanded.
*/
expand?: Array<string>;
}
}
export declare namespace Treasury {
interface OutboundTransferListParams extends PaginationParams {
/**
* Returns objects associated with this FinancialAccount.
*/
financial_account: string;
/**
* Specifies which fields in the response should be expanded.
*/
expand?: Array<string>;
/**
* Only return OutboundTransfers that have the given status: `processing`, `canceled`, `failed`, `posted`, or `returned`.
*/
status?: OutboundTransferListParams.Status;
}
namespace OutboundTransferListParams {
type Status = 'canceled' | 'failed' | 'posted' | 'processing' | 'returned';
}
}
export declare namespace Treasury {
interface OutboundTransferCancelParams {
/**
* Specifies which fields in the response should be expanded.
*/
expand?: Array<string>;
}
}