mirror of
https://github.com/alchemy-fr/Phraseanet.git
synced 2025-10-24 10:23:17 +00:00
123 lines
3.0 KiB
PHP
123 lines
3.0 KiB
PHP
<?php
|
|
|
|
/**
|
|
* This file is part of Phraseanet
|
|
*
|
|
* (c) 2005-2016 Alchemy
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
use Alchemy\Phrasea\Application;
|
|
use Alchemy\Phrasea\Core\Configuration\PropertyAccess;
|
|
use Alchemy\Phrasea\Model\Manipulator\ApiApplicationManipulator;
|
|
use Alchemy\Phrasea\Model\Entities\ApiApplication;
|
|
use Alchemy\Phrasea\Model\Repositories\ApiApplicationRepository;
|
|
|
|
|
|
class patch_410alpha13a implements patchInterface
|
|
{
|
|
/** @var string */
|
|
private $release = '4.1.0-alpha.13';
|
|
|
|
/** @var array */
|
|
private $concern = [base::DATA_BOX];
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function get_release()
|
|
{
|
|
return $this->release;
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function getDoctrineMigrations()
|
|
{
|
|
return [];
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function require_all_upgrades()
|
|
{
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function concern()
|
|
{
|
|
return $this->concern;
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function apply(base $databox, Application $app)
|
|
{
|
|
// @see : https://phraseanet.atlassian.net/browse/PHRAS-2468
|
|
// to be able to migrate from 3.5 to 4.0.8, we must not delete the table anymore
|
|
// so the cli "bin/setup patch:log_coll_id" can be executed.
|
|
|
|
/*
|
|
$sql = "DROP TABLE IF EXISTS `log_colls`";
|
|
$databox->get_connection()->prepare($sql)->execute();
|
|
*/
|
|
|
|
/*
|
|
* no need to do those ops, it's done by system:upgrade after fixing the xml scheme
|
|
*
|
|
$sql = "ALTER TABLE `log_docs`\n"
|
|
. "CHANGE `action` `action` ENUM(\n"
|
|
. " 'push',\n"
|
|
. " 'add',\n"
|
|
. " 'validate',\n"
|
|
. " 'edit',\n"
|
|
. " 'collection',\n"
|
|
. " 'status',\n"
|
|
. " 'print',\n"
|
|
. " 'substit',\n"
|
|
. " 'publish',\n"
|
|
. " 'download',\n"
|
|
. " 'mail',\n"
|
|
. " 'ftp',\n"
|
|
. " 'delete',\n"
|
|
. " 'collection_from',\n"
|
|
. " ''\n"
|
|
. ")\n"
|
|
. "CHARACTER SET ascii BINARY NOT NULL DEFAULT ''";
|
|
try {
|
|
$databox->get_connection()->prepare($sql)->execute();
|
|
}
|
|
catch(\Exception $e) {
|
|
// no-op
|
|
}
|
|
|
|
$sql = "ALTER TABLE `log_docs` ADD `coll_id` INT(11) UNSIGNED NULL DEFAULT NULL,\n"
|
|
. " ADD INDEX(coll_id)";
|
|
try {
|
|
$databox->get_connection()->prepare($sql)->execute();
|
|
}
|
|
catch(\Exception $e) {
|
|
// no-op (the field exists ?)
|
|
}
|
|
|
|
$sql = "ALTER TABLE `log_view` ADD `coll_id` INT(11) UNSIGNED NULL DEFAULT NULL,\n"
|
|
. " ADD INDEX(coll_id)";
|
|
try {
|
|
$databox->get_connection()->prepare($sql)->execute();
|
|
}
|
|
catch(\Exception $e) {
|
|
// no-op (the field exists ?)
|
|
}
|
|
*/
|
|
|
|
return true;
|
|
}
|
|
}
|