mdcoderu / sequential-code
Laravel пакет для генерации последовательных 6-значных кодов для моделей
v1.0.2
2026-04-24 13:18 UTC
Requires
- php: ^8.1
- illuminate/database: ^10.0|^11.0|^12.0
- illuminate/support: ^10.0|^11.0|^12.0
This package is auto-updated.
Last update: 2026-04-24 13:20:02 UTC
README
Laravel пакет для генерации последовательных -значных кодов для моделей с поддержкой ручного указания кода.
Возможности
- ✅ Автоматическая генерация уникальных 6-значных кодов
- ✅ Возможность ручного указания кода
- ✅ Потокобезопасность через транзакции и блокировки
- ✅ Отдельная таблица счетчиков для каждой модели
- ✅ Конфигурируемые границы кодов
Установка
1. Добавление пакета через Composer
composer require mdcoderu/sequential-code
2. Публикация миграции
php artisan vendor:publish --tag="sequential-code-migrations"
3. Запуск миграций
php artisan migrate
Использование
Базовое использование
Примените trait HasSequentialCode к вашей модели:
<?php namespace App\Models; use Illuminate\Database\Eloquent\Model; use Mdcode\SequentialCode\Traits\HasSequentialCode; use Mdcoderu\SequentialCode\Traits\HasSequentialCode; class Order extends Model { use HasSequentialCode; // ... }
Теперь при создании новой записи код будет генерироваться автоматически:
$order = Order::create([ // другие поля... ]); echo $order->code; // "100000", "100001", ...
Ручное указание кода
Вы можете указать код вручную:
$order = Order::create([ 'code' => 123456, // другие поля... ]);
Кастомный ключ счетчика
По умолчанию в качестве ключа счетчика используется имя таблицы модели. Если нужно использовать кастомный ключ, переопределите метод getSequentialCodeKey():
class Order extends Model { use HasSequentialCode; protected function getSequentialCodeKey(): string { return 'order_' . $this->type; } }
Конфигурация
Пакет имеет конфигурационный файл config/sequential-code.php:
return [ 'min_code' => 100000, // Минимальное значение кода 'max_code' => 999999, // Максимальное значение кода ];
Вы можете опубликовать конфигурацию:
php artisan vendor:publish --tag="sequential-code-config"
Таблица model_counters
Пакет использует таблицу model_counters для хранения текущих значений счетчиков:
| Поле | Тип | Описание |
|---|---|---|
| key | string (primary) | Уникальный ключ счетчика |
| value | unsigned integer | Текущее значение счетчика |
Ограничения
- Код должен быть 6-значным числом (от 100000 до 999999)
- При достижении максимума (999999) будет выброшено исключение
RuntimeException - Для каждого ключа счетчика хранится отдельное значение
Лицензия
MIT