Providers & accounts
How Owostack abstracts payment providers
Providers & accounts
Owostack is designed to work with multiple payment providers through a single interface. This page explains the abstraction layer and how provider differences are handled.
Why multiple providers?
Different payment providers serve different markets and have different strengths. Paystack dominates in Nigeria and West Africa. Dodo Payments and Polar handle global billing flows. Rather than lock you into one provider, Owostack abstracts the differences so your application code stays the same regardless of which provider processes the payment.
Your app calls attach(), check(), and track(). Owostack figures out which provider to use, translates the request into the provider's API format, and normalizes the webhooks back into a common event model.
The adapter model
Each supported provider has an adapter — an implementation of a shared interface that handles:
- Checkout sessions — creating a payment page for the customer
- Subscriptions — creating, fetching, and canceling recurring billing
- Webhook verification — validating that incoming events are genuine
- Event normalization — translating provider-specific events into Owostack's internal format
- Refunds — reversing charges (e.g. for card setup verification)
- Products/plans — creating the provider-side representation of your plans
The adapter interface is designed so that core billing logic (plan switching, trial management, overage billing) works identically across providers. Provider-specific quirks are isolated inside the adapter.
Currently Supported providers
| Provider | ID | Markets | Key differences |
|---|---|---|---|
| Paystack | paystack | Nigeria, Ghana, South Africa, Kenya | Card authorization codes for recurring charges; webhook verification via HMAC-SHA512 |
| Dodo Payments | dodopayments | Global (USD, EUR, GBP) | Product-centric checkout (requires product ID); on-demand subscriptions for card-on-file; Standard Webhooks spec |
| Polar | polar | Global | Product-centric checkout (supports multiple products); native subscription lifecycle webhooks; Standard Webhooks signature model |
Provider accounts
A provider account stores the credentials for a specific provider within your organization:
- Secret key — the provider's API key (encrypted at rest)
- Webhook secret — used to verify incoming webhook payloads
- Environment — test or live
Each organization can have multiple provider accounts — for example, a Paystack test account, a Paystack live account, and a Polar live account.
How providers are selected
When a customer starts a checkout, Owostack picks a provider using this priority:
- Explicit
providerparameter — if you passprovider: "dodopayments"toattach() - Plan's provider — the provider selected when the plan was created
- Customer's existing provider — if they've paid before, use the same provider
- Fallback — the first configured provider account
This means you can run multiple providers side by side and control routing at the plan level, the request level, or let Owostack pick automatically.
Provider-specific behavior
Some billing features work differently depending on the provider:
Trials:
- Paystack — small verification charge (auto-refunded), Owostack manages trial billing
- Dodo — native trial period, provider defers first charge automatically
- Polar — native trial support via provider-side subscription lifecycle
Card on file:
- Paystack — stores a reusable authorization code from the first charge
- Dodo — creates an on-demand subscription that can be charged with arbitrary amounts
- Polar — stores provider-managed subscription IDs for recurring lifecycle events
Checkout:
- Paystack — raw amount checkout, no pre-created product needed
- Dodo — product-centric, requires a synced product ID for every checkout
- Polar — product-centric checkout with support for single- or multi-product sessions
These differences are handled internally. Your application code is the same regardless of provider.
Adding a new provider
Owostack's adapter interface is designed to be extended. At a high level:
- Implement
ProviderAdapterinpackages/adapters - Register it in the provider registry
- Add credential fields to the dashboard
- Configure a provider account
Once registered, all billing flows (checkout, plan switching, webhooks, overage billing) work through the new adapter automatically.