netbums/laravel-subscription-preset

This is a preset for laravel subscription through stripe

v0.1.0 2022-07-09 15:06 UTC

README

Total Downloads Total Downloads Latest Stable Version Latest Stable Version

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:

License

The MIT License (MIT). Please see License File for more information.