121 lines
4.0 KiB
PHP
121 lines
4.0 KiB
PHP
|
<?php
|
||
|
|
||
|
/**
|
||
|
* This program is free software; you can redistribute it and/or
|
||
|
* modify it under the terms of the GNU General Public License
|
||
|
* as published by the Free Software Foundation; under version 2
|
||
|
* of the License (non-upgradable).
|
||
|
*
|
||
|
* This program is distributed in the hope that it will be useful,
|
||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
* GNU General Public License for more details.
|
||
|
*
|
||
|
* You should have received a copy of the GNU General Public License
|
||
|
* along with this program; if not, write to the Free Software
|
||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||
|
*
|
||
|
* Copyright (c) 2021 (original work) Open Assessment Technologies SA;
|
||
|
*/
|
||
|
|
||
|
declare(strict_types=1);
|
||
|
|
||
|
namespace oat\tao\migrations;
|
||
|
|
||
|
use Doctrine\DBAL\Schema\Schema;
|
||
|
use oat\oatbox\reporting\Report;
|
||
|
use oat\generis\persistence\PersistenceManager;
|
||
|
use oat\tao\scripts\tools\migrations\AbstractMigration;
|
||
|
use common_persistence_SqlPersistence as SqlPersistence;
|
||
|
use oat\tao\model\Lists\DataAccess\Repository\RdsValueCollectionRepository;
|
||
|
|
||
|
final class Version202108101839442234_tao extends AbstractMigration
|
||
|
{
|
||
|
public function getDescription(): string
|
||
|
{
|
||
|
return sprintf('Create "%s" table', RdsValueCollectionRepository::TABLE_LIST_ITEMS_DEPENDENCIES);
|
||
|
}
|
||
|
|
||
|
public function up(Schema $schema): void
|
||
|
{
|
||
|
$fromSchema = clone $schema;
|
||
|
$this->createTable($schema);
|
||
|
$this->migrate($fromSchema, $schema);
|
||
|
|
||
|
$this->addReport(
|
||
|
Report::createSuccess(
|
||
|
sprintf(
|
||
|
'Table "%s" successfully created',
|
||
|
RdsValueCollectionRepository::TABLE_LIST_ITEMS_DEPENDENCIES
|
||
|
)
|
||
|
)
|
||
|
);
|
||
|
}
|
||
|
|
||
|
public function down(Schema $schema): void
|
||
|
{
|
||
|
$schema->dropTable(RdsValueCollectionRepository::TABLE_LIST_ITEMS_DEPENDENCIES);
|
||
|
|
||
|
$this->addReport(
|
||
|
Report::createSuccess(
|
||
|
sprintf(
|
||
|
'Table "%s" successfully dropped',
|
||
|
RdsValueCollectionRepository::TABLE_LIST_ITEMS_DEPENDENCIES
|
||
|
)
|
||
|
)
|
||
|
);
|
||
|
}
|
||
|
|
||
|
private function createTable(Schema $schema): void
|
||
|
{
|
||
|
$listItemsDependenciesTable = $schema->createTable(
|
||
|
RdsValueCollectionRepository::TABLE_LIST_ITEMS_DEPENDENCIES
|
||
|
);
|
||
|
|
||
|
$listItemsDependenciesTable->addColumn(
|
||
|
RdsValueCollectionRepository::FIELD_LIST_ITEM_ID,
|
||
|
'integer'
|
||
|
);
|
||
|
$listItemsDependenciesTable->addColumn(
|
||
|
RdsValueCollectionRepository::FIELD_LIST_ITEM_FIELD,
|
||
|
'string',
|
||
|
['length' => 255]
|
||
|
);
|
||
|
$listItemsDependenciesTable->addColumn(
|
||
|
RdsValueCollectionRepository::FIELD_LIST_ITEM_VALUE,
|
||
|
'string',
|
||
|
['length' => 255]
|
||
|
);
|
||
|
|
||
|
$listItemsDependenciesTable->addIndex([RdsValueCollectionRepository::FIELD_LIST_ITEM_ID]);
|
||
|
$listItemsDependenciesTable->addIndex([RdsValueCollectionRepository::FIELD_LIST_ITEM_FIELD]);
|
||
|
$listItemsDependenciesTable->addIndex([RdsValueCollectionRepository::FIELD_LIST_ITEM_VALUE]);
|
||
|
|
||
|
$listItemsDependenciesTable->addForeignKeyConstraint(
|
||
|
RdsValueCollectionRepository::TABLE_LIST_ITEMS,
|
||
|
[RdsValueCollectionRepository::FIELD_LIST_ITEM_ID],
|
||
|
[RdsValueCollectionRepository::FIELD_ITEM_ID]
|
||
|
);
|
||
|
}
|
||
|
|
||
|
private function migrate(Schema $fromSchema, Schema $schema): void
|
||
|
{
|
||
|
$queries = $this->getPersistence()->getPlatForm()->getMigrateSchemaSql($fromSchema, $schema);
|
||
|
|
||
|
foreach ($queries as $query) {
|
||
|
$this->getPersistence()->exec($query);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
private function getPersistence(): SqlPersistence
|
||
|
{
|
||
|
if (!isset($this->persistence)) {
|
||
|
$persistenceManager = $this->getServiceLocator()->get(PersistenceManager::SERVICE_ID);
|
||
|
|
||
|
$this->persistence = $persistenceManager->getPersistenceById('default');
|
||
|
}
|
||
|
|
||
|
return $this->persistence;
|
||
|
}
|
||
|
}
|