3neti/laravel-vouchers

Voucher system for Laravel 10+

Maintainers

Package info

github.com/3neti/laravel-vouchers

pkg:composer/3neti/laravel-vouchers

Statistics

Installs: 32

Dependents: 1

Suggesters: 0

Stars: 0

v1.1.0 2026-04-10 06:57 UTC

This package is auto-updated.

Last update: 2026-04-10 06:57:47 UTC


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