mirror of
https://github.com/archtechx/tenancy.git
synced 2025-12-12 11:14:04 +00:00
[4.x] Improve id generators (#1300)
* add RandomIntGenerator * remove string assertions * make int ranges configurable * update test to use min & max
This commit is contained in:
parent
7ce7629864
commit
25360f6b6a
7 changed files with 43 additions and 4 deletions
|
|
@ -33,6 +33,7 @@ return [
|
||||||
*
|
*
|
||||||
* @see \Stancl\Tenancy\UniqueIdentifierGenerators\UUIDGenerator
|
* @see \Stancl\Tenancy\UniqueIdentifierGenerators\UUIDGenerator
|
||||||
* @see \Stancl\Tenancy\UniqueIdentifierGenerators\RandomHexGenerator
|
* @see \Stancl\Tenancy\UniqueIdentifierGenerators\RandomHexGenerator
|
||||||
|
* @see \Stancl\Tenancy\UniqueIdentifierGenerators\RandomIntGenerator
|
||||||
* @see \Stancl\Tenancy\UniqueIdentifierGenerators\RandomStringGenerator
|
* @see \Stancl\Tenancy\UniqueIdentifierGenerators\RandomStringGenerator
|
||||||
*/
|
*/
|
||||||
'id_generator' => UniqueIdentifierGenerators\UUIDGenerator::class,
|
'id_generator' => UniqueIdentifierGenerators\UUIDGenerator::class,
|
||||||
|
|
|
||||||
|
|
@ -11,5 +11,5 @@ interface UniqueIdentifierGenerator
|
||||||
/**
|
/**
|
||||||
* Generate a unique identifier for a model.
|
* Generate a unique identifier for a model.
|
||||||
*/
|
*/
|
||||||
public static function generate(Model $model): string;
|
public static function generate(Model $model): string|int;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -18,7 +18,7 @@ class RandomHexGenerator implements UniqueIdentifierGenerator
|
||||||
{
|
{
|
||||||
public static int $bytes = 6;
|
public static int $bytes = 6;
|
||||||
|
|
||||||
public static function generate(Model $model): string
|
public static function generate(Model $model): string|int
|
||||||
{
|
{
|
||||||
return bin2hex(random_bytes(static::$bytes));
|
return bin2hex(random_bytes(static::$bytes));
|
||||||
}
|
}
|
||||||
|
|
|
||||||
22
src/UniqueIdentifierGenerators/RandomIntGenerator.php
Normal file
22
src/UniqueIdentifierGenerators/RandomIntGenerator.php
Normal file
|
|
@ -0,0 +1,22 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
|
namespace Stancl\Tenancy\UniqueIdentifierGenerators;
|
||||||
|
|
||||||
|
use Illuminate\Database\Eloquent\Model;
|
||||||
|
use Stancl\Tenancy\Contracts\UniqueIdentifierGenerator;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Generates a cryptographically secure random integer for the tenant key.
|
||||||
|
*/
|
||||||
|
class RandomIntGenerator implements UniqueIdentifierGenerator
|
||||||
|
{
|
||||||
|
public static int $min = 0;
|
||||||
|
public static int $max = PHP_INT_MAX;
|
||||||
|
|
||||||
|
public static function generate(Model $model): string|int
|
||||||
|
{
|
||||||
|
return random_int(static::$min, static::$max);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -18,7 +18,7 @@ class RandomStringGenerator implements UniqueIdentifierGenerator
|
||||||
{
|
{
|
||||||
public static int $length = 8;
|
public static int $length = 8;
|
||||||
|
|
||||||
public static function generate(Model $model): string
|
public static function generate(Model $model): string|int
|
||||||
{
|
{
|
||||||
return Str::random(static::$length);
|
return Str::random(static::$length);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -13,7 +13,7 @@ use Stancl\Tenancy\Contracts\UniqueIdentifierGenerator;
|
||||||
*/
|
*/
|
||||||
class UUIDGenerator implements UniqueIdentifierGenerator
|
class UUIDGenerator implements UniqueIdentifierGenerator
|
||||||
{
|
{
|
||||||
public static function generate(Model $model): string
|
public static function generate(Model $model): string|int
|
||||||
{
|
{
|
||||||
return Uuid::uuid4()->toString();
|
return Uuid::uuid4()->toString();
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -20,8 +20,14 @@ use Stancl\Tenancy\Tests\Etc\Tenant;
|
||||||
use Stancl\Tenancy\UniqueIdentifierGenerators\UUIDGenerator;
|
use Stancl\Tenancy\UniqueIdentifierGenerators\UUIDGenerator;
|
||||||
use Stancl\Tenancy\Exceptions\TenancyNotInitializedException;
|
use Stancl\Tenancy\Exceptions\TenancyNotInitializedException;
|
||||||
use Stancl\Tenancy\UniqueIdentifierGenerators\RandomHexGenerator;
|
use Stancl\Tenancy\UniqueIdentifierGenerators\RandomHexGenerator;
|
||||||
|
use Stancl\Tenancy\UniqueIdentifierGenerators\RandomIntGenerator;
|
||||||
use Stancl\Tenancy\UniqueIdentifierGenerators\RandomStringGenerator;
|
use Stancl\Tenancy\UniqueIdentifierGenerators\RandomStringGenerator;
|
||||||
|
|
||||||
|
afterEach(function () {
|
||||||
|
RandomIntGenerator::$min = 0;
|
||||||
|
RandomIntGenerator::$max = PHP_INT_MAX;
|
||||||
|
});
|
||||||
|
|
||||||
test('created event is dispatched', function () {
|
test('created event is dispatched', function () {
|
||||||
Event::fake([TenantCreated::class]);
|
Event::fake([TenantCreated::class]);
|
||||||
|
|
||||||
|
|
@ -87,6 +93,16 @@ test('hex ids are supported', function () {
|
||||||
RandomHexGenerator::$bytes = 6; // reset
|
RandomHexGenerator::$bytes = 6; // reset
|
||||||
});
|
});
|
||||||
|
|
||||||
|
test('random ints are supported', function () {
|
||||||
|
app()->bind(UniqueIdentifierGenerator::class, RandomIntGenerator::class);
|
||||||
|
RandomIntGenerator::$min = 200;
|
||||||
|
RandomIntGenerator::$max = 1000;
|
||||||
|
|
||||||
|
$tenant1 = Tenant::create();
|
||||||
|
expect($tenant1->id >= 200)->toBeTrue();
|
||||||
|
expect($tenant1->id <= 1000)->toBeTrue();
|
||||||
|
});
|
||||||
|
|
||||||
test('random string ids are supported', function () {
|
test('random string ids are supported', function () {
|
||||||
app()->bind(UniqueIdentifierGenerator::class, RandomStringGenerator::class);
|
app()->bind(UniqueIdentifierGenerator::class, RandomStringGenerator::class);
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue