netbums / laravel-subscription-preset
This is a preset for laravel subscription through stripe
Requires
- php: ^8.0
- illuminate/contracts: ^9.0
- illuminate/support: ^9.0
- laravel/cashier: ^13.11
- laravel/ui: ^3.4
- livewire/livewire: ^2.10
- spatie/laravel-package-tools: ^1.9.2
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.8
- nunomaduro/collision: ^6.0
- nunomaduro/larastan: ^2.0.1
- orchestra/testbench: ^7.0
- pestphp/pest: ^1.21
- pestphp/pest-plugin-laravel: ^1.1
- phpstan/extension-installer: ^1.1
- phpstan/phpstan-deprecation-rules: ^1.0
- phpstan/phpstan-phpunit: ^1.0
- phpunit/phpunit: ^9.5
This package is auto-updated.
Last update: 2025-03-09 06:00:18 UTC
README
About
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
Caution
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.
Installation
You can install the package via composer:
composer require netbums/laravel-subscription-preset
After installing, you can run the installer by running:
Copying the files
php artisan laravel-subscription-preset
This will copy all stubs from the preset into your Laravel project.
Install npm packages
npm install
Then run either npm run dev
to start the Vite server or npm run build
compile production ready assets.
Configure .env file
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
Configure Plan seeder
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' ]);
Usage
Using middleware
subscribed
and not.subscribed
.
Blade directives
@if(auth()->user()->subscribed())
@can directive
Two policies exist. You can add your own custom in \App\Policies\SubscriptionPolicy.php
@can('cancel', auth()->user()->subscription()) @can('resume', auth()->user()->subscription())
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
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
License
The MIT License (MIT). Please see License File for more information.