Looking to hire Laravel developers? Try LaraJobs

laravel-vouchers maintained by 3neti

Description
Voucher system for Laravel 10+
Last update
2026/04/10 08:57 (dev-master)
License
Links
Downloads
40

Comments
comments powered by Disqus

Laravel Vouchers (3neti Fork)

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