3neti/laravel-vouchers
Voucher system for Laravel 10+
Maintainers
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
Suggests
None
Provides
None
Conflicts
None
Replaces
None
This package is auto-updated.
Last update: 2026-06-10 07:22:17 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
