This is a Laravel Preset Package that will quickly get your app up and running with subscriptions via Stripe and Laravel Cashier.
It comes with an opinionated set of dependencies/requirements, such as Laravel Livewire, Laravel Cashier, PestPHP. It will also set up Vite to have auto-reload when changes occur to .blade.php files.
If this package helps you in any way, consider ☕ buying me a cup of coffee
This package is intended to be used on a FRESH install of Laravel. Do NOT use on an existing Laravel, as it will override some files.
You can install the package via composer:
composer require netbums/laravel-subscription-preset
After installing, you can run the installer by running:
php artisan laravel-subscription-preset
This will copy all stubs from the preset into your Laravel project.
npm install
Then run either npm run dev
to start the Vite server or npm run build
compile production ready assets.
Next you should copy the following into your .env
file, and set the Stripe variables with your own data:
CASHIER_MODEL=App\Models\User
STRIPE_KEY=pk_test_XXXXXXXXXXXXXX
STRIPE_SECRET=sk_test_XXXXXXXXXXXXXXXXXX
STRIPE_WEBHOOK_SECRET=whsec_XXXXXXXXXXXXXXXXXXXXX
CASHIER_PAYMENT_NOTIFICATION=Laravel\Cashier\Notifications\ConfirmPayment
Get the values for the Stripe keys in your Stripe Dashboard
Inside database\seeders\DatabaseSeeder.php
you should set up your Plans.
use App\Models\Plan;
Plan::query()->create([
'title' => 'Pro - $99 / month',
'slug' => 'monthly',
'stripe_id' => 'price_XXXXXXXXXXXXX'
]);
Plan::query()->create([
'title' => 'Pro - $999 / year',
'slug' => 'yearly',
'stripe_id' => 'price_XXXXXXXXXXXXX'
]);
subscribed
and not.subscribed
.
@if(auth()->user()->subscribed())
Two policies exist. You can add your own custom in \App\Policies\SubscriptionPolicy.php
@can('cancel', auth()->user()->subscription())
@can('resume', auth()->user()->subscription())
composer test
Please see CHANGELOG for more information on what has changed recently.
Please see CONTRIBUTING for details.
Please review our security policy on how to report security vulnerabilities.
The Tall Stack included in this preset is created by:
- Dan Harrin
- Liam Hammett
- Ryan Chandler
- Tailwind UI for the default authentication and pagination views
The MIT License (MIT). Please see License File for more information.