Integrate Laravel Cashier Stripe support into Filament's multi-tenant panels.
You can support me by buying Model States for Filament.
-
Install the package via composer:
composer require maartenpaauw/filament-cashier-billing-provider
-
Make sure your
Billable
model is the same as your Filament tenant model.
Tip
For more information configuring a Billable
model, refer to the official
Laravel documentation.
Add plans to your cashier.php
config file:
'plans' => [
'default' => [
'product_id' => ENV('CASHIER_STRIPE_SUBSCRIPTION_DEFAULT_PRODUCT_ID'),
'price_id' => ENV('CASHIER_STRIPE_SUBSCRIPTION_DEFAULT_PRICE_ID'),
'type' => 'default', // Optional, by default it uses the array key as type.
'trial_days' => 14, // Optional
'has_generic_trial' => true, // Optional, only `trial_days` OR `has_generic_trial` can be used.
'allow_promotion_codes' => true, // Optional
'collect_tax_ids' => true, // Optional
'metered_price' => true, // Optional
],
],
Caution
The current implementation only supports recurring subscriptions.
Add the following code to your AdminPanelProvider
(or other panel providers):
use Maartenpaauw\Filament\Cashier\Stripe\BillingProvider;
// ...
public function panel(Panel $panel): Panel
{
return $panel
// ...
->tenantBillingProvider(new BillingProvider('default'))
->requiresTenantSubscription()
// ...
}
Note
Requiring tenant subscription is optional. You can remove ->requiresTenantSubscription()
if you wish.
composer test
Please see CHANGELOG for more information on what has changed recently.
Please see UPGRADING for more details.
Please see CONTRIBUTING for details.
Please review our security policy on how to report security vulnerabilities.
The MIT License (MIT). Please see License File for more information.