3neti/laravel-vouchers 问题修复 & 功能扩展

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

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

3neti/laravel-vouchers

最新稳定版本:v1.1.0

Composer 安装命令:

composer require 3neti/laravel-vouchers

包简介

Voucher system for Laravel 10+

README 文档

README

License

⚠️ Fork Notice

This package is a maintained fork of the original
frittenkeez/laravel-vouchers.

Why this fork exists

  • ✅ Adds Laravel 13 compatibility
  • ✅ Aligns with 3neti migration ownership architecture
  • 🔄 Will evolve independently to support:
    • settlement integration
    • idempotency
    • metadata improvements

This package is now the source of truth for the vouchers table schema in the 3neti ecosystem.

📦 Installation

composer require 3neti/laravel-vouchers

🚨 Migration Policy (Important)

Unlike the original package:

❌ Original behavior

  • Requires vendor:publish for migrations

✅ This fork

  • Uses loadMigrationsFrom()
  • No publishing required
  • Migrations are loaded automatically
php artisan migrate

🧠 Ownership Rule

This package owns:

  • vouchers table
  • voucherables table
  • all schema updates related to vouchers

Other packages (e.g., 3neti/voucher, 3neti/cash)
must NOT modify voucher tables directly

🔄 Versioning Strategy

Current: v1.0.0

Upcoming releases will follow:

  • v1.x → compatibility + internal alignment
  • v2.x → schema ownership + architectural changes

⚙️ Configuration

php artisan vendor:publish --tag=config --provider="FrittenKeeZ\\Vouchers\\VouchersServiceProvider"

🚀 Usage

This package provides the Vouchers facade:

use FrittenKeeZ\\Vouchers\\Facades\\Vouchers;

Generate Codes

$code = Vouchers::generate('***-***-***', '1234567890');

$codes = Vouchers::batch(10);

Create Vouchers

$voucher = Vouchers::create();
$vouchers = Vouchers::create(10);

Redeem Vouchers

Vouchers::redeem('123-456-789', $user);

Handles exceptions:

  • VoucherNotFoundException
  • VoucherRedeemedException
  • VoucherExpiredException
  • VoucherUnstartedException

Unredeem Vouchers

Vouchers::unredeem('123-456-789', $user);

🧩 Traits

HasVouchers

use FrittenKeeZ\\Vouchers\\Concerns\\HasVouchers;

$user->vouchers;
$user->createVoucher();

HasRedeemers

use FrittenKeeZ\\Vouchers\\Concerns\\HasRedeemers;

$user->redeemers;

🧠 Architectural Notes (3neti)

This fork is part of a larger system:

  • voucher → business logic
  • cash → financial ledger
  • settlement-envelope → settlement gating
  • wallet → balance orchestration

Role of this package

Schema + Core Voucher Engine

It should remain:

  • deterministic
  • storage-focused
  • side-effect minimal

🚫 Anti-Patterns

Do NOT:

  • modify voucher tables outside this package
  • duplicate voucher schema in other packages
  • treat vouchers as business logic containers

🧪 Testing

composer test

🙏 Acknowledgement

Original package by: Frederik Sauer
https://github.com/FrittenKeeZ/laravel-vouchers

📄 License

MIT

统计信息

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

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 14
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-04-04

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固