mirror of
https://github.com/shlinkio/shlink.git
synced 2024-12-26 08:51:13 -06:00
43 lines
1.2 KiB
PHP
43 lines
1.2 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\ClassMetadata;
|
|
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();
|
|
|
|
$builder->createField('roleName', Types::STRING)
|
|
->columnName('role_name')
|
|
->length(256)
|
|
->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');
|
|
};
|