Basil
Basil is the second release in our new API versioning model. As the first version in the Basil release, 2025-03-31.
introduces both breaking changes and new features—subsequent Basil versions will include only additive changes. (Our last release was Acacia: every time we introduce a breaking change version, we move to the next release.)
March 31, 2025
This version introduces a significant number of breaking changes. Make sure to review the complete changelog below. Most notably:
- Billing changes: We removed or reorganized a number of capabilities, including legacy usage-based billing and a migration from the Upcoming Invoice API to the Create Preview API. Many of these breaking changes are preparing our APIs for future updates later this year in the Basil release.
- Total counts no longer supported on lists: You can no longer expand the
total_
property on lists, because this is no longer a recommended integration pattern.count - Checkout Session changes: Checkout Sessions for subscriptions now postpone creation of subscriptions until after the user completes payment—this both improves latency on all Checkout Session API calls and fixes a common bug where customers couldn’t modify billing details after the first payment attempt.
We’ve also included some new features:
- Payment method improvements: Klarna can now be used on Hosted Invoice Pages, and we’ve introduced support for Naver Pay, Billie, Satispay, and New Zealand’s BECS Direct Debit.
- Build custom UIs for Checkout Sessions: You can now specify a
ui_
ofmode custom
to use Elements and Checkout Sessions to design your own checkout page. - Billing meter improvements: We’ve introduced new webhook events for billing meters and credits, and new aggregation formula (
last
) to use the final meter event in a time range as the total value for a bill.
To get started with these updates, review the changelog and upgrade your API version.
2025-03-31.basil
Breaking changes
Coupons enhancements
Increase Invoice flexibility
Replaces top-level price fields with improved price modeling on Invoice Items and Invoice Line Items
Billing+ 1 more
Replaces top-level tax-related properties with improved tax modeling on Invoices, Invoice Line Items and Credit Note Line Items
Billing+ 1 more
Adds jurisdiction level and taxability reason to manual tax amounts on invoices
Invoicing
Billing enhancements
Adds subscription item-level billing periods and removes subscription-level periods
Billing
Invoicing resources now specify how they were generated
Billing+ 1 more
Adds support for last aggregation formula on meters
Billing
Adds new webhook event types for Billing Meters
Billing
Adds new webhook event types for billing credits
Billing
Elements with Checkout Session
Deprecations to billing features
Issuing enhancements
Payment enhancements
Updates the Vault and Forward API to return a 402 status code for upstream request timeouts
Payments
Deprecates manual capture method for Interac cards
Payments+ 1 more
Payment Methods won’t allow modifying fields for Naver Pay once the object is first created
Payments
Partially capturing or canceling payments no longer creates a Refund
Payments
Adds support for Klarna in the Hosted Invoice Page
Billing
Adds ability to configure saved payment methods for one-time payments on the Hosted Invoice Page
Connect+ 1 more
Adds support for saving and reusing Naver Pay payment methods
Billing+ 4 more
Adds support for the Billie local payment method
Checkout+ 5 more
Adds support for the Satispay local payment method
Checkout+ 5 more
Makes the client parameter optional for WeChat Pay until confirmation
Invoicing
Adds support for the New Zealand BECS Direct Debit local payment method
Billing+ 6 more
Checkout enhancements
Additional updates
Deprecates total count expansion for list API methods
Affects all products
Adds new error codes for required verifications
Connect
Updates the default layout for Payment Element
Elements
Adds support for multiple (partial) payments on invoices
Billing+ 2 more
Changes the political exposure property of the Person object from a string to an enum
Connect
Adds default value to custom fields on Payment Links
Payment Links
Expanded availability of Account KYC data
Connect
Adds new error code for failures with the Setup Intents API using mobile wallets
Payments+ 1 more
Adds presentment details for Adaptive Pricing
Checkout
Adds optional items to Checkout Sessions and Payment Links
Checkout+ 1 more
Adds BalanceTransaction types related to pay with Stripe balance
Connect+ 1 more
Introduces new customer balance transaction types
Billing
Removes support for the page parameter
Affects all products
Adds ability to configure WiFi for Terminal readers
Terminal