3neti / laravel-vouchers
Voucher system for Laravel 10+
v1.1.0
2026-04-10 06:57 UTC
Requires
- php: ^8.2
- illuminate/collections: ^10.0|^11.0|^12.0|^13.0
- illuminate/config: ^10.0|^11.0|^12.0|^13.0
- illuminate/console: ^10.0|^11.0|^12.0|^13.0
- illuminate/database: ^10.0|^11.0|^12.0|^13.0
- illuminate/support: ^10.0|^11.0|^12.0|^13.0
Requires (Dev)
- laravel/pint: ^1.20
- nesbot/carbon: ^2.63|^3.8.4
- orchestra/testbench: ^8.0|^9.0|^10.0|^11.0
- pestphp/pest: ^2.2|^3.0|^4.0
This package is auto-updated.
Last update: 2026-04-10 06:57:47 UTC
README
⚠️ 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:publishfor migrations
✅ This fork
- Uses
loadMigrationsFrom() - No publishing required
- Migrations are loaded automatically
php artisan migrate
🧠 Ownership Rule
This package owns:
voucherstablevoucherablestable- 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 alignmentv2.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 logiccash→ financial ledgersettlement-envelope→ settlement gatingwallet→ 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