Charge SaaS fees to your connected accountsPublic preview
Use Billing to charge SaaS fee subscriptions directly to your connected accounts.
This guide explains how to use Accounts v2 to integrate Billing and Connect into your SaaS platform, which lets you charge subscription fees directly to your connected accounts.
You can enable Accounts v2 for your Connect platform from your Dashboard.
Test environment
To try this integration, you must use a Sandbox. You can’t use test mode.
Onboard your platform to Connect
Set up your Stripe account as a Connect platform by following the onboarding process in your Dashboard.
The Connect integration guide explains the platform configuration options.
If you have an existing platform, this integration doesn’t support your connected accounts that use Accounts v1. If you want to include them, you have to recreate them, following the process explained here, then remove their old accounts.
Create your connected accounts using the Accounts v2 API
Note
This integration uses only Accounts, Account Links, Events, EventDestinations, and Persons from API v2. All other objects belong to API v1.
For each connected account, use the Accounts v2 API to create an Account object with the customer and merchant configurations.
- The customerconfiguration allows theAccountto pay your platform a subscription fee using a payment method that you attach to theAccount.
- The merchantconfiguration makes theAccounta connected account that can accept card payments from its own customers. When you assign themerchantconfiguration, you also define other aspects of the connected account, such as:- Request the ability to accept card payments by setting configuration.merchant.capabilities.card_payments.requested to true.
- Specify access to a Stripe Dashboard by setting dashboard. In the following example, we set dashboardtofull, which means theAccounthas access to the full Stripe Dashboard.
- Specify responsibility for collecting fees from the Accountby setting defaults.responsibilities.fees_collector tostripeorapplication.
- Specify responsibility for negative balances on the Accountby setting defaults.responsibilities.losses_collector tostripeorapplication.
 
Use include to populate objects in the response
When you create, retrieve, or update an Account in API v2, certain properties are only populated in the response if you specify them in the include parameter. For any of those properties that you don’t specify, the response includes them as null, regardless of their actual value.
The response includes the ID, which you use to reference the Account throughout your integration.
{ "id": "acct_xxxxxxxxxxxxxxxx", "object": "v2.core.account", "applied_configurations": [ "customer", "merchant" ], "configuration": { "customer": { "automatic_indirect_tax": { "exempt": "none", "ip_address": null, "location": null, "location-source": "identity_address" }, "billing": { ... }, "capabilities": { "automatic_indirect_tax": { "requested": true, "status": "restricted", "status_details": [ { "code": "requirements_past_due", "resolution": "provide_info" } ] } }, "shipping": ..., "test_clock": ... }, "merchant": { "bacs_debit_payments": null, "branding": { ... }, "capabilities": { ... "card_payments": { "requested": true, "status": "restricted", "status_details": [ { "code": "requirements_past_due", "resolution": "provide_info" } ] }, "stripe_balance": { "payouts": { "requested": true, "status": "restricted", "status_details": [ { "code": "requirements_past_due", "resolution": "provide_info" } ] } }, ... }, "card_payments": { "decline_on": { "avs_failure": false, "cvc_failure": false } }, "mcc": null, ... "statement_descriptor": { ... }, "support": { "address": { ... }, ... } }, "recipient": null }, "contact_email": "furever_contact@example.com", "created": "2025-03-04T02:23:20.000Z", "dashboard": "full", "identity": { "attestations": { ... }, "terms_of_service": { "account": null }, "business_details": { ... "registered_name": "Furever", ... }, "country": "US", "entity_type": "company", "individual": null }, "defaults": null, "display_name": "Furever", "metadata": {}, "requirements": { "collector": "stripe", "entries": [ { "awaiting_action_from": "user", "description": "representative.surname", "errors": [], "impact": { "restricts_capabilities": [ { "capability": "card_payments", "configuration": "merchant", "deadline": { "status": "past_due" } }, { "capability": "stripe_balance.payouts", "configuration": "merchant", "deadline": { "status": "past_due" } } ] }, "minimum_deadline": { "status": "past_due" }, "reference": null, "requested_reasons": [ { "code": "routine_onboarding" } ] } ], "summary": { "minimum_deadline": { "status": "past_due", "time": null } } } }
Account Responsibilities
Responsibilities define certain behaviors of connected accounts, such as how they pay Stripe fees and responsibility for negative balances. You set them when you add the merchant configuration to your connected accounts.
To enable your Accounts to collect payments as connected accounts, set the following responsibilities:
| Property | Description | Values | 
|---|---|---|
| defaults.responsibilities.fees_collector | Defines how Stripe collects payment fees for direct charges on the connected account. (For destination or separate charges, Stripe always collects fees from your platform.) | 
 | 
| defaults.responsibilities.losses_collector | Assigns responsibility for negative balances incurred by the connected account. | 
 | 
Responsibilities are subject to the following restrictions:
- If you set losses_tocollector application, then you must also setfees_tocollector application.
- If you use destination charges with an Account, we recommend that you set both losses_andcollector fees_tocollector application.
For more information about supported configurations, see Integration recommendations.
Charge types
The preview release supports only direct and destination charges for connected accounts. You can’t use separate charges and transfers.
To use destination charges, you must set the on_behalf_of parameter to make the connected account the settlement merchant. You must also add the recipient configuration to your connected accounts and request the stripe_ capability for them.
Add the recipient configuration to connected accounts
To allow the transfer of funds from your platform’s Stripe balance to the connected account’s Stripe balance, add the recipient configuration and request the stripe_ capability. Destination charges require this capability.
Requesting stripe_ also automatically requests the recipient configuration’s stripe_ capability, which allows the connected account to pay out to their external bank account.
The merchant configuration automatically requests its own stripe_ capability, which is identical to the recipient configuration’s stripe_ capability. If the account doesn’t need any other recipient capabilities, you don’t need to add the recipient configuration.
Note
The preview release doesn’t support cross-border payouts.
To add the recipient configuration and request the stripe_ capability, update the Account and set the configuration.recipient.capabilities.stripe_balance.stripe_transfers.requested parameter to true.
Onboard your connected accounts
Before your connected accounts can accept payments through your platform, you must onboard them. You can direct your accounts to Stripe-hosted onboarding, offer a branded flow using a Connect embedded component, or code your own custom onboarding flow. Stripe-hosted onboarding is the simplest option. Using an embedded component allows for some customization while handling most of the process automatically. A custom onboarding flow gives your platform full control, but requires the most resources for implementation and ongoing updates.
Create external accounts for your connected accounts
The process for creating an external account depends on your connected accounts’ Dashboard access:
- If an Account’sdashboardisfullorexpress, the account owner adds its external account using their Dashboard.
- If an Account’sdashboardisnone, you can create its external account using the /v1/external_accounts endpoint.
Note
Set up payments for your connected accounts
To set up payments for your connected accounts, follow the instructions in Direct charges or Destination charges. To use destination charges, you must set the on_behalf_of parameter.
Set up payouts for your connected accounts
You can configure your connected accounts’ payout settings, including the schedule, statement descriptor, and delay days, using either your Dashboard or the API.
Listen for requirements changes on your connected accounts
Account requirements can change, often due to changes implemented by financial regulators, card networks, and other financial institutions. To set up webhook notifications of requirement changes, create an event destination to listen for Account v2 update events.
- In your Stripe Dashboard, open the Developers menu by clicking Developers in the navigation menu footer, then select Webhooks.
- Click + Add destination.
- In the Events from section, select Connected accounts.
- Select Show advanced options. In the Payload style section, select Thin.
- In the Events field, type “v2” to search for v2 event types. Select v2.account[requirements].updated and the v2.account[configuration.configuration_type].capability_status_updated type for each configuration type used by your connected accounts.
Continue setting up your event destination by following the interactive webhook endpoint builder.
Configure your application to respond to update events by collecting any updated requirements.
Set up a local listener during development
You can send events to your local server for development purposes by installing the Stripe CLI and setting up a local listener.
- Log in to the Stripe Dashboard.
- In the Stripe CLI, enter the stripe logincommand. It redirects you to your browser to confirm and authenticate your account.
- Return to the CLI and run the following command. It listens to all available V2 events on your platform and connected accounts, and forwards them to http://localhost:4242.
stripe listen --thin-events 'v2.core.account[requirements].updated,v2.core.account[configuration.recipient].capability_status_updated,v2.core.account[configuration.merchant].capability_status_updated,v2.core.account[configuration.customer].capability_status_updated' --forward-thin-to http://localhost:4242
Integrate Billing to collect recurring fees
Collecting recurring fees from your connected accounts with Stripe Billing involves the following steps:
- Create one or more products to represent the recurring fees.
- Create subscriptions for your fee products with the accounts as customers.
- (Optional) To collect subscription fees directly from connected accounts’ Stripe balances, avoiding transaction fees associated with other payment methods such as cards, configure it as a payment method.
Note
A connected account can pay using its Stripe balance only if it has a sufficient available balance to make the payment. We provide recommendations for avoiding balance payment failures later in these instructions.
1. Create a product with a recurring price
Create a product and price representing your subscription fee. You can use the API or the Dashboard.
2. Create subscriptions to charge your connected accounts
You can collect SaaS subscription fees directly from a connected account’s Stripe balance. The connected account must meet the following requirements:
- It must have both the merchantandcustomerconfigurations.
- Its merchantconfiguration’scard_capability must be active.payments 
- Its available balance must have sufficient funds to make a full payment.
Configure your integration to manage Stripe balance payment failures
When you collect a payment from a connected account’s Stripe balance, the account’s available balance must have sufficient funds to make the full payment. Otherwise, the payment fails. If you plan to collect payments directly from your connected accounts’ Stripe balances, we recommend configuring your integration to manage balance-related payment failures.
Avoid balance payment failures
Because payments from a connected account’s Stripe balance rely on its available funds, you can avoid payment failures by taking steps to maximize your connected accounts’ balances.
Tailor connected account payout schedules
Coordinate your payout schedules with your subscription billing cycles. For example, if you charge subscription fees on the first day of each month, and schedule weekly payouts on Mondays, then months with more Mondays have more payouts. Those months have lower available balances than months with fewer payouts, making payment failures more likely.
Another way to avoid payment failures due to payouts is to change to manual payouts before a subscription payment. At a set time before each subscription payment, if a connected account has sufficient available funds, switch it to manual payouts so the subscription payment gets paid before the automatic payout clears the account. After the subscription payment, resume automatic payouts.
Set a minimum balance on connected accounts
You can prevent automatic payouts from reducing a connected account’s available balance below a certain amount by defining a minimum balance for that account.
- Find the account in your Dashboard.
- From the account’s overflow menu (), select View Dashboard as….
- Click the gear icon and select Settings.
- Under Account Settings, click Business.
- Select the External payout accounts and scheduling tab.
- Turn on Keep a minimum amount in your payments balance and enter an amount.
You must manually set the minimum balance for each connected account.
Handle balance payment failures
Set up webhooks and event destinations to receive notifications about subscription payments. Identify payment failures by listening for the invoice. event. When a payment fails:
- The PaymentIntent status changes to requires_.action 
- The Subscription status remains incompletefor the current invoice.
- The Subscription continues to generate invoices, which remain in draftstatus.
Automatic retries
Enable retries for failed balance payments due to insufficient available funds on recurring subscription invoices. Automatic retries schedules 2 payment attempts following an insufficient funds failure:
- The first retry happens at least 24 hours after the failed payment.
- If needed, the second retry happens on the next Sunday following the first retry.
This retry schedule aims to give your connected account time to accumulate more funds in their Stripe balance and to avoid conflicts with scheduled payouts.
You can enable retries for any amount for no additional fee.
Manually retrying
If a payment from a Stripe balance fails due to insufficient available funds, you can manually retry it by following these steps:
- Set the connected account’s payout schedule interval to manual.
- Listen for the next payment that comes into the connected account, then check the account’s available balance.
- If the available balance is equal to or greater than the subscription fee, set the unpaid invoice’s payment method to stripe_and retry it. Otherwise, continue listening for payments until the available balance is enough to pay the invoice.balance 
- If the payment succeeds, restore the connected account’s normal payout schedule.
Instead of retrying a failed payment from a Stripe balance, you can try using a different payment method by specifying it directly on the invoice. You can also implement a flow that allows connected accounts to update their own subscription payment methods.
Preview considerations
Accounts v2 allows you to use a single, configurable account for each business on your platform that collects payments directly. The preview release doesn’t support Financial Accounts for platforms, Issuing, or payment methods that are in preview. You can still use Financial Accounts for platforms, Issuing, or payment methods in preview with Accounts v1.
Enable Accounts v2 for your Connect platform from your Dashboard.