Files
Phraseanet/lib/Alchemy/Phrasea/Setup/Version/Migration/Migration31.php
Nicolas Le Goff 949bf06cac Merge branch '3.8'
Conflicts:
	CHANGELOG.md
	bin/console
	bin/developer
	bin/setup
	bower.json
	composer.json
	composer.lock
	features/bootstrap/FeatureContext.php
	features/bootstrap/GuiContext.php
	lib/Alchemy/Phrasea/Authentication/Token/TokenValidator.php
	lib/Alchemy/Phrasea/Command/BuildMissingSubdefs.php
	lib/Alchemy/Phrasea/Command/CreateCollection.php
	lib/Alchemy/Phrasea/Command/Developer/JavascriptBuilder.php
	lib/Alchemy/Phrasea/Controller/Admin/Collection.php
	lib/Alchemy/Phrasea/Controller/Admin/Databoxes.php
	lib/Alchemy/Phrasea/Controller/Admin/TaskManager.php
	lib/Alchemy/Phrasea/Controller/Api/V1.php
	lib/Alchemy/Phrasea/Controller/Client/Baskets.php
	lib/Alchemy/Phrasea/Controller/Client/Root.php
	lib/Alchemy/Phrasea/Controller/Prod/Basket.php
	lib/Alchemy/Phrasea/Controller/Prod/Export.php
	lib/Alchemy/Phrasea/Controller/Prod/Property.php
	lib/Alchemy/Phrasea/Controller/Prod/Records.php
	lib/Alchemy/Phrasea/Controller/Prod/Tools.php
	lib/Alchemy/Phrasea/Controller/Prod/Upload.php
	lib/Alchemy/Phrasea/Controller/Root/Login.php
	lib/Alchemy/Phrasea/Controller/Thesaurus/Thesaurus.php
	lib/Alchemy/Phrasea/Core/Event/ApiLoadEndEvent.php
	lib/Alchemy/Phrasea/Core/Event/ApiLoadStartEvent.php
	lib/Alchemy/Phrasea/Core/Provider/TaskManagerServiceProvider.php
	lib/Alchemy/Phrasea/Core/Version.php
	lib/Alchemy/Phrasea/Exception/XMLParseErrorException.php
	lib/Alchemy/Phrasea/Helper/DatabaseHelper.php
	lib/Alchemy/Phrasea/Helper/User/Edit.php
	lib/Alchemy/Phrasea/SearchEngine/Phrasea/PhraseaEngine.php
	lib/Alchemy/Phrasea/SearchEngine/SearchEngineOptions.php
	lib/Doctrine/Entities/AuthFailure.php
	lib/Doctrine/Entities/Basket.php
	lib/Doctrine/Entities/BasketElement.php
	lib/Doctrine/Entities/LazaretAttribute.php
	lib/Doctrine/Entities/LazaretCheck.php
	lib/Doctrine/Entities/LazaretFile.php
	lib/Doctrine/Entities/LazaretSession.php
	lib/Doctrine/Entities/Session.php
	lib/Doctrine/Entities/SessionModule.php
	lib/Doctrine/Entities/StoryWZ.php
	lib/Doctrine/Entities/UsrList.php
	lib/Doctrine/Entities/UsrListEntry.php
	lib/Doctrine/Entities/UsrListOwner.php
	lib/Doctrine/Entities/ValidationData.php
	lib/Doctrine/Entities/ValidationParticipant.php
	lib/Doctrine/Entities/ValidationSession.php
	lib/Doctrine/Logger/MonologSQLLogger.php
	lib/Doctrine/Repositories/BasketRepository.php
	lib/Doctrine/Repositories/ValidationParticipantRepository.php
	lib/Doctrine/Types/Binary.php
	lib/Doctrine/Types/Blob.php
	lib/Doctrine/Types/Enum.php
	lib/Doctrine/Types/LongBlob.php
	lib/Doctrine/Types/VarBinary.php
	lib/classes/API/OAuth2/Account.php
	lib/classes/API/OAuth2/Application.php
	lib/classes/API/OAuth2/Application/OfficePlugin.php
	lib/classes/API/OAuth2/AuthCode.php
	lib/classes/API/OAuth2/RefreshToken.php
	lib/classes/API/OAuth2/Token.php
	lib/classes/API/V1/Abstract.php
	lib/classes/API/V1/Interface.php
	lib/classes/API/V1/adapter.php
	lib/classes/API/V1/exception/abstract.php
	lib/classes/API/V1/exception/badrequest.php
	lib/classes/API/V1/exception/forbidden.php
	lib/classes/API/V1/exception/internalservererror.php
	lib/classes/API/V1/exception/maintenance.php
	lib/classes/API/V1/exception/methodnotallowed.php
	lib/classes/API/V1/exception/notfound.php
	lib/classes/API/V1/exception/unauthorized.php
	lib/classes/API/V1/result.php
	lib/classes/Exception/Feed/EntryNotFound.php
	lib/classes/Exception/Feed/ItemNotFound.php
	lib/classes/Exception/Feed/PublisherNotFound.php
	lib/classes/Feed/Abstract.php
	lib/classes/Feed/Adapter.php
	lib/classes/Feed/Aggregate.php
	lib/classes/Feed/Collection.php
	lib/classes/Feed/CollectionInterface.php
	lib/classes/Feed/Entry/Adapter.php
	lib/classes/Feed/Entry/Collection.php
	lib/classes/Feed/Entry/CollectionInterface.php
	lib/classes/Feed/Entry/Interface.php
	lib/classes/Feed/Entry/Item.php
	lib/classes/Feed/Entry/ItemInterface.php
	lib/classes/Feed/Interface.php
	lib/classes/Feed/Link.php
	lib/classes/Feed/LinkInterface.php
	lib/classes/Feed/Publisher/Adapter.php
	lib/classes/Feed/Publisher/Interface.php
	lib/classes/Feed/Token.php
	lib/classes/Feed/TokenAggregate.php
	lib/classes/Feed/XML/Abstract.php
	lib/classes/Feed/XML/Atom.php
	lib/classes/Feed/XML/Cooliris.php
	lib/classes/Feed/XML/Interface.php
	lib/classes/Feed/XML/RSS.php
	lib/classes/Feed/XML/RSS/Image.php
	lib/classes/Feed/XML/RSS/ImageInterface.php
	lib/classes/User/Adapter.php
	lib/classes/User/Interface.php
	lib/classes/appbox/register.php
	lib/classes/connection.php
	lib/classes/connection/abstract.php
	lib/classes/connection/interface.php
	lib/classes/connection/pdo.php
	lib/classes/connection/pdoStatementDebugger.php
	lib/classes/deprecated/countries.php
	lib/classes/deprecated/inscript.api.php
	lib/classes/eventsmanager/event/test.php
	lib/classes/ftpclient.php
	lib/classes/http/request.php
	lib/classes/media/subdef.php
	lib/classes/module/console/schedulerStart.php
	lib/classes/module/console/schedulerState.php
	lib/classes/module/console/schedulerStop.php
	lib/classes/module/console/taskState.php
	lib/classes/module/console/tasklist.php
	lib/classes/module/console/taskrun.php
	lib/classes/patch/320alpha4b.php
	lib/classes/patch/3715alpha1a.php
	lib/classes/patch/379alpha1a.php
	lib/classes/patch/380alpha10a.php
	lib/classes/patch/380alpha11a.php
	lib/classes/patch/380alpha13a.php
	lib/classes/patch/380alpha14a.php
	lib/classes/patch/380alpha15a.php
	lib/classes/patch/380alpha16a.php
	lib/classes/patch/380alpha17a.php
	lib/classes/patch/380alpha18a.php
	lib/classes/patch/380alpha3a.php
	lib/classes/patch/380alpha4a.php
	lib/classes/patch/380alpha6a.php
	lib/classes/patch/380alpha8a.php
	lib/classes/patch/380alpha9a.php
	lib/classes/patch/381alpha1b.php
	lib/classes/patch/381alpha2a.php
	lib/classes/patch/381alpha3a.php
	lib/classes/patch/381alpha4a.php
	lib/classes/patch/383alpha1a.php
	lib/classes/patch/383alpha2a.php
	lib/classes/patch/383alpha3a.php
	lib/classes/patch/383alpha4a.php
	lib/classes/record/adapter.php
	lib/classes/record/preview.php
	lib/classes/recordutils.php
	lib/classes/recordutils/audio.php
	lib/classes/recordutils/document.php
	lib/classes/recordutils/map.php
	lib/classes/recordutils/video.php
	lib/classes/registry.php
	lib/classes/registryInterface.php
	lib/classes/set/order.php
	lib/classes/system/url.php
	lib/classes/task/Scheduler.php
	lib/classes/task/appboxAbstract.php
	lib/classes/task/databoxAbstract.php
	lib/classes/task/manager.php
	lib/classes/task/period/RecordMover.php
	lib/classes/task/period/apibridge.php
	lib/classes/task/period/apiwebhooks.php
	lib/classes/task/period/archive.php
	lib/classes/task/period/cindexer.php
	lib/classes/task/period/emptyColl.php
	lib/classes/task/period/ftp.php
	lib/classes/task/period/ftpPull.php
	lib/classes/task/period/subdef.php
	lib/classes/task/period/test.php
	lib/classes/task/period/writemeta.php
	lib/conf.d/PhraseaFixture/AbstractWZ.php
	lib/conf.d/PhraseaFixture/Basket/LoadFiveBaskets.php
	lib/conf.d/PhraseaFixture/Basket/LoadOneBasket.php
	lib/conf.d/PhraseaFixture/Basket/LoadOneBasketEnv.php
	lib/conf.d/PhraseaFixture/Lazaret/LoadOneFile.php
	lib/conf.d/PhraseaFixture/Story/LoadOneStory.php
	lib/conf.d/PhraseaFixture/UsrLists/ListAbstract.php
	lib/conf.d/PhraseaFixture/UsrLists/UsrList.php
	lib/conf.d/PhraseaFixture/UsrLists/UsrListEntry.php
	lib/conf.d/PhraseaFixture/UsrLists/UsrListOwner.php
	lib/conf.d/PhraseaFixture/ValidationParticipant/LoadOneParticipant.php
	lib/conf.d/PhraseaFixture/ValidationParticipant/LoadParticipantWithSession.php
	lib/conf.d/PhraseaFixture/ValidationSession/LoadOneValidationSession.php
	templates/web/admin/collection/collection.html.twig
	templates/web/common/dialog_export.html.twig
	templates/web/common/menubar.html.twig
	templates/web/prod/actions/Tools/index.html.twig
	templates/web/prod/index.html.twig
	templates/web/prod/upload/upload-flash.html.twig
	templates/web/prod/upload/upload.html.twig
	templates/web/report/report_layout_child.html.twig
	templates/web/setup/step2.html.twig
	templates/web/thesaurus/new-synonym-dialog.html.twig
	templates/web/thesaurus/properties.html.twig
	templates/web/thesaurus/search.html.twig
	tests/Alchemy/Tests/Phrasea/Application/ApiAbstract.php
	tests/Alchemy/Tests/Phrasea/Cache/FactoryTest.php
	tests/Alchemy/Tests/Phrasea/Controller/Admin/AdminCollectionTest.php
	tests/Alchemy/Tests/Phrasea/Controller/Client/RootTest.php
2015-02-05 18:38:49 +01:00

511 lines
17 KiB
PHP

<?php
/*
* This file is part of Phraseanet
*
* (c) 2005-2015 Alchemy
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Alchemy\Phrasea\Setup\Version\Migration;
use Alchemy\Phrasea\Application;
class Migration31 implements MigrationInterface
{
private $app;
public function __construct(Application $app)
{
$this->app = $app;
}
public function migrate()
{
if (!file_exists(__DIR__ . '/../../../../../../config/_GV.php')) {
throw new \LogicException('Required config files not found');
}
require __DIR__ . '/../../../../../../config/_GV.php';
$GV = [
[
'type' => 'string',
'name' => 'GV_default_lng',
'default' => 'fr_FR',
],
[
'type' => 'string',
'name' => 'GV_STATIC_URL',
'default' => '',
],
[
'type' => 'string',
'name' => 'GV_message',
'default' => "May the force be with you"
],
[
'type' => 'boolean',
'name' => 'GV_message_on',
'default' => false
],
[
'type' => 'boolean',
'name' => 'GV_log_errors',
'default' => false
],
[
'type' => 'boolean',
'name' => 'GV_google_api',
'default' => true,
],
[
'type' => 'string',
'name' => 'GV_i18n_service',
'default' => 'https://geonames.alchemyasp.com/',
],
[
'type' => 'boolean',
'name' => 'GV_captchas',
'default' => false,
],
[
'type' => 'string',
'name' => 'GV_captcha_public_key',
'default' => ''
],
[
'type' => 'string',
'name' => 'GV_captcha_private_key',
'default' => ''
],
[
'type' => 'boolean',
'name' => 'GV_youtube_api',
'default' => false,
],
[
'type' => 'string',
'name' => 'GV_youtube_client_id',
'default' => ''
],
[
'type' => 'string',
'name' => 'GV_youtube_client_secret',
'default' => ''
],
[
'type' => 'string',
'name' => 'GV_youtube_dev_key',
'default' => ''
],
[
'type' => 'boolean',
'name' => 'GV_flickr_api',
'default' => false,
],
[
'type' => 'string',
'name' => 'GV_flickr_client_id',
'default' => ''
],
[
'type' => 'string',
'name' => 'GV_flickr_client_secret',
'default' => ''
],
[
'type' => 'boolean',
'name' => 'GV_dailymotion_api',
'default' => false,
],
[
'type' => 'string',
'name' => 'GV_dailymotion_client_id',
'default' => ''
],
[
'type' => 'string',
'name' => 'GV_dailymotion_client_secret',
'default' => ''
],
[
'type' => 'boolean',
'name' => 'GV_client_navigator',
'default' => true,
],
[
'type' => 'boolean',
'name' => 'GV_client_officeplugin',
'default' => true,
],
[
'type' => 'string',
'name' => 'GV_base_datapath_noweb',
'default' => '',
],
[
'type' => 'boolean',
'name' => 'GV_h264_streaming',
'default' => false
],
[
'type' => 'string',
'name' => 'GV_mod_auth_token_directory',
'default' => false
],
[
'type' => 'string',
'name' => 'GV_mod_auth_token_directory_path',
'default' => false
],
[
'type' => 'string',
'name' => 'GV_mod_auth_token_passphrase',
'default' => false
],
[
'type' => 'string',
'name' => 'GV_PHP_INI',
'default' => ''
],
[
'type' => 'string',
'name' => 'GV_imagine_driver',
'default' => '',
],
[
'type' => 'integer',
'name' => 'GV_ffmpeg_threads',
'default' => 2
],
[
'type' => 'integer',
'name' => 'GV_pdfmaxpages',
'default' => 5
],
[
'type' => 'string',
'name' => 'GV_adminMail',
'default' => 'support@alchemy.fr'
],
[
'type' => 'boolean',
'name' => 'GV_view_bas_and_coll',
'default' => true,
],
[
'type' => 'boolean',
'name' => 'GV_choose_export_title',
'default' => false,
],
[
'type' => 'string',
'name' => 'GV_default_export_title',
'default' => 'title',
],
[
'type' => 'string',
'name' => 'GV_social_tools',
'default' => 'none',
],
[
'type' => 'string',
'name' => 'GV_home_publi',
'default' => 'COOLIRIS',
],
[
'type' => 'integer',
'name' => 'GV_min_letters_truncation',
'default' => 1
],
[
'type' => 'string',
'name' => 'GV_defaultQuery',
'default' => 'all'
],
[
'type' => 'string',
'name' => 'GV_defaultQuery_type',
'default' => '0'
],
[
'type' => 'boolean',
'name' => 'GV_anonymousReport',
'default' => false,
],
[
'type' => 'boolean',
'name' => 'GV_thesaurus',
'default' => true
],
[
'type' => 'boolean',
'name' => 'GV_multiAndReport',
'default' => true
],
[
'type' => 'boolean',
'name' => 'GV_seeOngChgDoc',
'default' => false
],
[
'type' => 'boolean',
'name' => 'GV_seeNewThumb',
'default' => false
],
[
'type' => 'string',
'name' => 'GV_defaulmailsenderaddr',
'default' => 'phraseanet@example.com'
],
[
'type' => 'string',
'name' => 'GV_email_prefix',
'default' => ''
],
[
'type' => 'boolean',
'name' => 'GV_smtp',
'default' => false
],
[
'type' => 'boolean',
'name' => 'GV_smtp_auth',
'default' => false
],
[
'type' => 'string',
'name' => 'GV_smtp_host',
'default' => ''
],
[
'type' => 'string',
'name' => 'GV_smtp_port',
'default' => ''
],
[
'type' => 'string',
'name' => 'GV_smtp_secure',
'default' => 'tls',
],
[
'type' => 'string',
'name' => 'GV_smtp_user',
'default' => ''
],
[
'type' => 'string',
'name' => 'GV_smtp_password',
'default' => ''
],
[
'type' => 'boolean',
'name' => 'GV_activeFTP',
'default' => false
],
[
'type' => 'boolean',
'name' => 'GV_ftp_for_user',
'default' => false
],
[
'type' => 'integer',
'name' => 'GV_download_max',
'default' => 120
],
[
'type' => 'integer',
'name' => 'GV_ong_search',
'default' => 1
],
[
'type' => 'integer',
'name' => 'GV_ong_advsearch',
'default' => 2
],
[
'type' => 'integer',
'name' => 'GV_ong_topics',
'default' => 0
],
[
'type' => 'integer',
'name' => 'GV_ong_actif',
'default' => 1
],
[
'type' => 'string',
'name' => 'GV_client_render_topics',
'default' => 'tree'
],
[
'type' => 'boolean',
'name' => 'GV_rollover_reg_preview',
'default' => true
],
[
'type' => 'boolean',
'name' => 'GV_rollover_chu',
'default' => true
],
[
'type' => 'string',
'name' => 'GV_client_coll_ckbox',
'default' => 'checkbox',
],
[
'type' => 'boolean',
'name' => 'GV_viewSizeBaket',
'default' => true
],
[
'type' => 'boolean',
'name' => 'GV_clientAutoShowProposals',
'default' => true
],
[
'type' => 'boolean',
'name' => 'GV_needAuth2DL',
'default' => true
],
[
'type' => 'boolean',
'name' => 'GV_requireTOUValidationForExport',
'default' => false
],
[
'type' => 'boolean',
'name' => 'GV_autoselectDB',
'default' => true
],
[
'type' => 'boolean',
'name' => 'GV_autoregister',
'default' => false
],
[
'type' => 'integer',
'name' => 'GV_validation_reminder',
'default' => 2
],
[
'type' => 'integer',
'name' => 'GV_val_expiration',
'default' => 10
],
[
'type' => 'string',
'name' => 'GV_homeTitle',
'default' => 'Phraseanet'
],
[
'type' => 'string',
'name' => 'GV_metaKeywords',
'default' => ''
],
[
'type' => 'string',
'name' => 'GV_metaDescription',
'default' => ''
],
[
'type' => 'string',
'name' => 'GV_googleAnalytics',
'default' => ''
],
[
'type' => 'boolean',
'name' => 'GV_allow_search_engine',
'default' => true
],
];
$retrieve_old_credentials = function () {
require __DIR__ . '/../../../../../../config/connexion.inc';
return [
'hostname' => $hostname,
'port' => $port,
'user' => $user,
'password' => $password,
'dbname' => $dbname,
];
};
$params = $retrieve_old_credentials();
$dsn = 'mysql:dbname=' . $params['dbname'] . ';host=' . $params['hostname'] . ';port=' . $params['port'] . ';';
$connection = new \PDO($dsn, $params['user'], $params['password']);
$connection->setAttribute(\PDO::ATTR_ERRMODE, \PDO::ERRMODE_EXCEPTION);
$connection->query("
SET character_set_results = 'utf8', character_set_client = 'utf8',
character_set_connection = 'utf8', character_set_database = 'utf8',
character_set_server = 'utf8'");
$connection->exec("CREATE TABLE IF NOT EXISTS `registry` (
`id` int(11) unsigned NOT NULL AUTO_INCREMENT,
`key` char(32) CHARACTER SET ascii COLLATE ascii_bin NOT NULL,
`value` varchar(1024) COLLATE utf8_unicode_ci NOT NULL,
`type` enum('string','boolean','array','integer') COLLATE utf8_unicode_ci NOT NULL DEFAULT 'string',
PRIMARY KEY (`id`),
UNIQUE KEY `UNIQUE` (`key`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci AUTO_INCREMENT=1 ;");
$sql = 'REPLACE INTO registry (`id`, `key`, `value`, `type`)
VALUES (null, :key, :value, :type)';
$stmt = $connection->prepare($sql);
foreach ($GV as $datas) {
if (defined($datas["name"])) {
$val = constant($datas["name"]);
} elseif (isset($datas['default'])) {
$val = $datas['default'];
} else {
continue;
}
$val = $val === true ? '1' : $val;
$val = $val === false ? '0' : $val;
$type = $datas['type'];
switch ($datas['type']) {
case 'integer':
$val = (int) $val;
break;
case 'boolean':
$val = $val ? '1' : '0';
break;
case 'string':
$val = (string) $val;
break;
default:
$val = (string) $val;
$type = 'string';
break;
}
$stmt->execute([
':key' => $datas['name'],
':value' => $val,
':type' => $type,
]);
}
$stmt->execute([
':key' => 'GV_sit',
':value' => constant("GV_sit"),
':type' => 'string',
]);
$stmt->closeCursor();
rename(__DIR__ . '/../../../../../../config/_GV.php', __DIR__ . '/../../../../../../config/_GV.php.old');
$servername = defined('GV_ServerName') ? constant('GV_ServerName') : '';
file_put_contents(__DIR__ . '/../../../../../../config/config.inc', "<?php\n\$servername = \"" . str_replace('"', '\"', $servername) . "\";\n");
return;
}
}