3neti/laravel-vouchers

Voucher system for Laravel 10+

Maintainers

๐Ÿ‘ 3neti

Package info

github.com/3neti/laravel-vouchers

pkg:composer/3neti/laravel-vouchers

Statistics

Installs: 42

Dependents: 1

Suggesters: 0

Stars: 0

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

Requires

Requires (Dev)

Suggests

None

Provides

None

Conflicts

None

Replaces

None

MIT 6c30b9afc70b3846ecf6c2991845ac9398970d35

  • Frederik Sauer <fritten.keez.woop@gmail.com>
  • Lester Hurtado <lester.woop@hurtado.ph>

laraveldiscountcouponvoucher

This package is auto-updated.

Last update: 2026-06-10 07:22:17 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