Looking to hire Laravel developers? Try LaraJobs

laravel-sequence maintained by tenthfeet

Description
A flexible laravel package for generating sequential numbers with various patterns and reset policies.
Last update
2026/04/14 09:39 (dev-main)
License
Downloads
38

Comments
comments powered by Disqus

Laravel Sequence

A lightweight, flexible Laravel package for generating format-based sequential values with safe DB locking and reset policies.

Features

  • Concurrent-safe sequence generation with DB row locking
  • Custom patterns: {YYYY}, {MM}, {DD}, {H}, {M}, {S}, {SEQ}, {SEQ:N}, {FY}
  • Reset policies: none, yearly, monthly, daily, financial_year
  • Model-scoped sequences (per record)
  • Preview next value without incrementing

Installation

Install via Composer:

composer require tenthfeet/laravel-sequence

Publish config and migration:

php artisan vendor:publish --provider="Tenthfeet\Sequence\SequenceServiceProvider" --tag="config"
php artisan vendor:publish --provider="Tenthfeet\Sequence\SequenceServiceProvider" --tag="migrations"

Run migrations:

php artisan migrate

Configuration

Published config: config/sequences.php

return [
    'table' => 'sequences',
    'default_pattern' => '{SEQ:3}',
    'default_padding_character' => '0',
    'default_reset_policy' => \Tenthfeet\Sequence\Enums\ResetPolicy::None,
    'financial_year' => [
        'start_month' => \Carbon\Month::April,
    ],
];

Define a sequence

Create a sequence definition:

php artisan make:sequence InvoiceSequence

Example class:

namespace App\Sequences;

use Tenthfeet\Sequence\SequenceDefinition;
use Tenthfeet\Sequence\Enums\ResetPolicy;

final class InvoiceSequence extends SequenceDefinition
{
    public function key(): string
    {
        return 'invoice';
    }

    public function __construct()
    {
        $this->pattern('INV-{YYYY}-{SEQ:4}')
            ->resetPolicy(ResetPolicy::Yearly);
    }
}

Generate sequences

use Tenthfeet\Sequence\Sequence;
use App\Sequences\InvoiceSequence;

$sequence = new InvoiceSequence();
$value = Sequence::using($sequence)->next();
$preview = Sequence::using($sequence)->previewNext();

Model-specific sequences

use App\Sequences\ProjectTaskSequence;
use Tenthfeet\Sequence\Sequence;

$project = App\Models\Project::find(1);
$definition = (new ProjectTaskSequence())->forModel($project);
$value = Sequence::using($definition)->next();

Runtime overrides

$definition = (new InvoiceSequence())
    ->pattern('INV-{YYYY}-{MM}-{SEQ:5}')
    ->padWith('0')
    ->usingDate(now());
$value = Sequence::using($definition)->next();

Pattern tokens

Token Output example Description
{YYYY} 2026 4-digit year
{YY} 26 2-digit year
{MM} 03 month
{DD} 16 day
{H} 13 hour
{M} 45 minute
{S} 09 second
{SEQ} 1 counter raw
{SEQ:N} 0001 padded counter
{FY} 2025-26 financial year
{FY:YY-YY} 25-26 financial year
{FY:YYYY-YY} 2025-26 financial year
{FY:YYYY-YYYY} 2025-2026 financial year

Reset policies

use Tenthfeet\Sequence\Enums\ResetPolicy;

ResetPolicy::None;
ResetPolicy::Yearly;
ResetPolicy::Monthly;
ResetPolicy::Daily;
ResetPolicy::FinancialYear;

Notes

Sequence rows are grouped by key, reset_value, and optional model_type / model_id.

License

MIT