Each major release, such as Acacia, includes changes that aren’t backward-compatible with previous releases. Upgrading to a new major release can require updates to existing code. Each monthly release includes only backward-compatible changes, and uses the same name as the last major release. You can safely upgrade to a new monthly release without breaking any existing code. The current version is 2025-06-30.basil. For information on all API versions, view our API changelog.
- Starting from
stripe-ruby v9
, the requests you send usingstripe-ruby
align with the API version that was current when your version ofstripe-ruby
was released. - On
stripe-ruby v8
or lower, requests made withstripe-ruby
use your Stripe account’s default API version, controlled in Workbench.
You can override the API version in your code in all versions.
To override the API version, assign the version to the Stripe.
property, or set it per-request. When overriding it per-request, methods on the returned object reuse the same Stripe version.
Webhook events use the API version that’s set during your webhook’s endpoint creation. Otherwise, they use your Stripe account’s default API version (controlled in Workbench). If you’re on stripe-ruby v9
or later, match your webhook endpoint API version to the version pinned by your stripe-ruby
version (Stripe.
property).
You can upgrade your API version in Workbench. As a precaution, use API versioning to test a new API version before committing to an upgrade.
This is an object representing your Stripe balance. You can retrieve it to see the balance currently on your Stripe account.
You can also retrieve the balance history, which contains a list of transactions that contributed to the balance (charges, payouts, and so forth).
The available and pending amounts for each currency are broken down further by payment source types.
Related guide: Understanding Connect account balances
Balance transactions represent funds moving through your Stripe account. Stripe creates them for every type of transaction that enters or leaves your Stripe account balance.
Related guide: Balance transaction types
The Charge
object represents a single attempt to move money into your Stripe account. PaymentIntent confirmation is the most common way to create Charges, but transferring money to a different Stripe account through Connect also creates Charges. Some legacy payment flows create Charges directly, which is not recommended for new integrations.
This object represents a customer of your business. Use it to create recurring charges, save payment and contact information, and track payments that belong to the same customer.