netbums/laravel-subscription-preset 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

netbums/laravel-subscription-preset

最新稳定版本:v0.1.0

Composer 安装命令:

composer require netbums/laravel-subscription-preset

包简介

This is a preset for laravel subscription through stripe

README 文档

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.

统计信息

  • 总下载量: 7
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 5
  • 点击次数: 3
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 4
  • Watchers: 1
  • Forks: 2
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2022-07-07

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固