macmotp / codegen-laravel
Generate human friendly codes - Laravel Extension
Requires
- php: >=8.1
- macmotp/codegen: ^0.2.0
- spatie/laravel-package-tools: ^1.15
Requires (Dev)
- orchestra/testbench: ^v8.5
- phpunit/phpunit: ^10.2
This package is auto-updated.
Last update: 2024-11-08 10:39:53 UTC
README
Generate human friendly codes
Useful for generation of referral codes based on names, receipt numbers, unique references.
This is the Laravel extension for the package Codegen - Generate Human Friendly Codes
Requirements
- PHP >=8.1
- Laravel >= 5
if you use PHP 7.4, please make sure to use v0.1.2
if you use PHP 8.0, please make sure to use v0.2.0
Installation
You can install the package via composer:
composer require macmotp/codegen-laravel
Usage
Create semantic and sanitized reference codes from any model by applying the trait
use Illuminate\Database\Eloquent\Model; use Macmotp\HasCodegen; class User extends Model { use HasCodegen; protected $fillable = [ 'name', 'code', ]; /** * Attribute of the model used to generate the code * * @return string */ protected function buildCodeFrom(): string { return $this->name; } }
On the creating
event, it will generate a human readable code to the specified column
$user = User::create([ 'name' => 'Bob McLovin', ]); dump($user->code); // (string) 'BBMCLV';
Configuration
Publish default configuration
Create config/codegen.php
file, where you can adjust a few settings:
<?php // config for Macmotp/HasCodegen return [ /* |-------------------------------------------------------------------------- | The attribute of the model to build the code from. | For example, if your model has a column 'name' you can build the code from this attribute. | If empty, will generate random codes. |-------------------------------------------------------------------------- */ 'build-from' => '', /* |-------------------------------------------------------------------------- | The column use to save the code into the model. |-------------------------------------------------------------------------- */ 'code-column' => 'code', /* |-------------------------------------------------------------------------- | The length of the code to generate. |-------------------------------------------------------------------------- */ 'code-length' => 6, /* |-------------------------------------------------------------------------- | Sanitize level. | 1. Low/Default: will filter out anything is not a letter or a digit; | 2. Medium: will filter out (O - 0 - Q - I - 1) characters; | 3. High: will filter out (2 - Z - 4 - A - 5 - S - 8 - B - U - V - Y) characters; | Levels are inclusive, e.g. the highest level will apply also regex of level low and medium. |-------------------------------------------------------------------------- */ 'sanitize-level' => 1, /* |-------------------------------------------------------------------------- | Prepend a string. |-------------------------------------------------------------------------- */ 'prepend' => '', /* |-------------------------------------------------------------------------- | Append a string. |-------------------------------------------------------------------------- */ 'append' => '', /* |-------------------------------------------------------------------------- | Maximum accepted number of attempts for the generation. |-------------------------------------------------------------------------- */ 'max-attempts' => 10000, ];
Custom configuration per model
Override custom configuration for a single model.
use Illuminate\Database\Eloquent\Model; use Macmotp\HasCodegen; class Foo extends Model { use HasCodegen; protected $fillable = [ 'title', 'reference', ]; /** * Attribute of the model used to generate the code * * @return string */ protected function buildCodeFrom(): string { return $this->title; } /** * Column used to save the unique code * * @return string */ protected function getCodeColumn(): string { return 'reference'; } /** * Get char length of the code * * @return int */ protected function getCodeLength(): int { return 12; } /** * Force to prepend this portion of string in the code * * @return string */ protected function prependToCode(): string { return 'PR'; } /** * Force to append this portion of string in the code * * @return string */ protected function appendToCode(): string { return 'AP'; } /** * Get the sanitize level to apply * * @return int */ protected function getCodeSanitizeLevel(): int { return 3; // Level High } }
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.