tao-test/app/tao/migrations/Version202108101839442234_tao.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;
}
}