mirror of
https://github.com/shlinkio/shlink.git
synced 2025-01-11 16:42:07 -06:00
48 lines
1.4 KiB
PHP
48 lines
1.4 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace Shlinkio\Shlink\Rest;
|
|
|
|
use Doctrine\DBAL\Types\Types;
|
|
use Doctrine\ORM\Mapping\Builder\ClassMetadataBuilder;
|
|
use Doctrine\ORM\Mapping\Builder\FieldBuilder;
|
|
use Doctrine\ORM\Mapping\ClassMetadata;
|
|
use Shlinkio\Shlink\Rest\ApiKey\Role;
|
|
use Shlinkio\Shlink\Rest\Entity\ApiKey;
|
|
|
|
use function Shlinkio\Shlink\Core\determineTableName;
|
|
|
|
return static function (ClassMetadata $metadata, array $emConfig): void {
|
|
$builder = new ClassMetadataBuilder($metadata);
|
|
|
|
$builder->setTable(determineTableName('api_key_roles', $emConfig));
|
|
|
|
$builder->createField('id', Types::BIGINT)
|
|
->makePrimaryKey()
|
|
->generatedValue('IDENTITY')
|
|
->option('unsigned', true)
|
|
->build();
|
|
|
|
(new FieldBuilder($builder, [
|
|
'fieldName' => 'roleName',
|
|
'type' => Types::STRING,
|
|
'enumType' => Role::class,
|
|
]))->columnName('role_name')
|
|
->length(255)
|
|
->nullable(false)
|
|
->build();
|
|
|
|
$builder->createField('meta', Types::JSON)
|
|
->columnName('meta')
|
|
->nullable(false)
|
|
->build();
|
|
|
|
$builder->createManyToOne('apiKey', ApiKey::class)
|
|
->addJoinColumn('api_key_id', 'id', false, false, 'CASCADE')
|
|
->cascadePersist()
|
|
->build();
|
|
|
|
$builder->addUniqueConstraint(['role_name', 'api_key_id'], 'UQ_role_plus_api_key');
|
|
};
|