Account capabilities
Learn about capabilities you can enable for accounts and the requirements you must satisfy to use them.
The capabilities you request for a connected account determine the information you need to collect for that account. To reduce onboarding effort, only request the capabilities you need. The more capabilities you request, the more information you must collect.
You can start by completing the platform profile to understand which capabilities might be appropriate for your platform.
Note
For some capabilities, requesting them enables them permanently. Attempting to remove or unrequest a permanent capability returns an error.
After creating an account, you can request additional capabilities and remove existing non-permanent capabilities. For connected accounts that other platforms control, you can’t unrequest capabilities.
Supported capabilities data:image/s3,"s3://crabby-images/79a47/79a47ee7ebdfd290b13435ea3c570c0802cbc09a" alt=""
Following is a list of available capabilities. Click an item to expand or collapse it.
Transfersdata:image/s3,"s3://crabby-images/79a47/79a47ee7ebdfd290b13435ea3c570c0802cbc09a" alt=""
Card paymentsdata:image/s3,"s3://crabby-images/79a47/79a47ee7ebdfd290b13435ea3c570c0802cbc09a" alt=""
US tax reportingdata:image/s3,"s3://crabby-images/79a47/79a47ee7ebdfd290b13435ea3c570c0802cbc09a" alt=""
Payment methodsdata:image/s3,"s3://crabby-images/79a47/79a47ee7ebdfd290b13435ea3c570c0802cbc09a" alt=""
India international paymentsdata:image/s3,"s3://crabby-images/79a47/79a47ee7ebdfd290b13435ea3c570c0802cbc09a" alt=""
Multiple capabilities data:image/s3,"s3://crabby-images/79a47/79a47ee7ebdfd290b13435ea3c570c0802cbc09a" alt=""
Requesting multiple capabilities for a connected account is common, but involves the following considerations:
- Capabilities operate independently of each other.
- If a connected account has both
card_
andpayments transfers
, and thestatus
of either one isinactive
, then both capabilities are disabled. - You can request or unrequest a capability for a connected account at any time during the account’s lifecycle.
Capabilities also allow you to collect information for multiple purposes at the same time. For example, you can collect both required tax information and the information required for a requested capability. If you’re onboarding a connected account with the transfers
capability and they’re required to file an IRS form 1099-MISC (a US federal tax reporting form), you can collect information for both at the same time.
Create an account with capabilities data:image/s3,"s3://crabby-images/79a47/79a47ee7ebdfd290b13435ea3c570c0802cbc09a" alt=""
Capabilities are set on the Account object. To get the list of available capabilities for an Account, use the list_capabilities endpoint.
Account creation and requesting capabilities differ for connected accounts in different configurations.
- For connected accounts with access to the full Stripe Dashboard, including Standard accounts, some capabilities are requested automatically, based on their country. You can also request other capabilities for them.
- For connected accounts with access to the Express Dashboard, including Express accounts, you can either request their capabilities or use the onboarding configuration settings to automate capability requests.
- For connected accounts without access to a Stripe-hosted dashboard, including Custom accounts, you must request their capabilities.
Information requirements vary depending on the capability, but they often relate to identity verification or other information specific to a payment type.
When your connected account is successfully created, you can retrieve a list of its requirements:
In the response, the requirements
hash specifies the required information. The values for payouts_
and charges_
indicate whether payouts and charges are enabled for the account.
Capabilities for existing connected accounts data:image/s3,"s3://crabby-images/79a47/79a47ee7ebdfd290b13435ea3c570c0802cbc09a" alt=""
The following sections describe how to preview information requirements or manage capabilities for existing connected accounts using the Capabilities API.
Preview information requirements data:image/s3,"s3://crabby-images/79a47/79a47ee7ebdfd290b13435ea3c570c0802cbc09a" alt=""
You can preview what information is needed from your connected account for a particular capability either before or after that capability has been requested.
When you request capabilities, account.
webhooks fire and the account’s requirements can change. To enable a requirement faster and avoid disabling the account, preview the requirements and collect any required information before requesting the capability.
The following example lists the requirements for the card_
capability for a specific account.
In the response, check the requirements
hash to see what information is needed:
{ "id": "card_payments", "object": "capability", "account":
, "requested": false, "requested_at": null, "requirements": { "past_due": [], "currently_due": ["company.tax_id", ...], "eventually_due": [...], "disabled_reason": ..., "current_deadline": ..., }, "status": "unrequested" }"{{CONNECTED_ACCOUNT_ID}}"
The value for status
identifies whether the capability has been requested. When the value is requested, the account’s requirements are active.
In addition to previewing a capability’s requirements before requesting it, you can use the same endpoint to view a capability’s current requirements. That can help you stay informed when requirements change.
Request and unrequest capabilities data:image/s3,"s3://crabby-images/79a47/79a47ee7ebdfd290b13435ea3c570c0802cbc09a" alt=""
To request a capability for an account, set the capability’s requested
value to true
by updating the account. If the request succeeds, the API returns requested: true
in the response.
To unrequest a capability for an account, set the capability’s requested
value to false
by updating the account. If the capability can’t be removed, the call returns an error. If the call succeeds, the API returns requested: false
in the response.
You can also request and remove an account’s capabilities from the Dashboard. If a capability can’t be removed, its Remove button is disabled.
The example below requests the transfers
capability for a specific connected account:
The example below requests multiple capabilities for a specific connected account:
Deprecated capabilitiesdata:image/s3,"s3://crabby-images/79a47/79a47ee7ebdfd290b13435ea3c570c0802cbc09a" alt=""
Capabilities described in the following sections are deprecated. If possible, don’t request them for new accounts. If you have existing accounts that use deprecated capabilities, we recommend that you update them to use other capabilities instead.
legacy_paymentsdata:image/s3,"s3://crabby-images/79a47/79a47ee7ebdfd290b13435ea3c570c0802cbc09a" alt=""
The legacy_
capability enables charges, payouts, and transfers. Newer accounts enable those actions using the card_
and transfers
capabilities, which support more flexible configurations.
We recommend that you take the following steps:
Update your connected account onboarding process to request the appropriate combination of
card_
andpayments transfers
instead oflegacy_
.payments Update your existing connected accounts to request the appropriate combination of
card_
andpayments transfers
.Update any code that checks the status of
legacy_
to check the status of eitherpayments legacy_
or the appropriate new capability. For example, update code that relies on an account’s ability to make card payments to run when eitherpayments legacy_
orpayments card_
is active. Similarly, update code that relies on an account’s ability to accept transfers to run when eitherpayments legacy_
orpayments transfers
is active. The updated code works throughout the process of transitioning to the new capabilities, regardless of when the new capabilities become active.After the new capabilities are active for all of your connected accounts, remove references to
legacy_
from your code.payments
Note
You can’t unrequest the legacy_
capability. Stripe will notify you in advance before we remove it.
If you do business in Canada, Stripe automatically requests card_
and transfers
for your accounts that use legacy_
, in order to comply with updated requirements. During the process, you might see the following values in your connected accounts’ API responses.
Before requesting new capabilities | New capabilities requested | New requirements completed |
---|---|---|
|
|
|
Note
During the transition, card_
and transfers
requirements might appear in past_
. However, if legacy_
is active, then charges, transfers, and payouts remain enabled.