tao-test/app/generis/helpers/class.InstallHelper.php

153 lines
5.2 KiB
PHP
Raw Permalink Normal View History

2022-08-29 20:14:13 +02:00
<?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) 2015 (original work) Open Assessment Technologies SA;
*
*
*/
/**
* Helper class for instalation.
*/
class helpers_InstallHelper
{
/**
* @var \Pimple\Container
*/
protected static $container;
/**
* @var \Psr\Log\LoggerInterface
*/
protected static $logger;
/**
* Initialize the container and the logger.
*
* @param \Pimple\Container $container
*/
public static function initContainer($container)
{
if ($container instanceof \Pimple\Container) {
static::$container = $container;
static::$logger = static::$container
->offsetGet(\oat\oatbox\log\LoggerService::SERVICE_ID)
->getLogger();
}
}
/**
*
* @param array $extensionIDs
* @param array $installData
* @throws common_exception_Error
* @throws common_ext_ExtensionException
* @return array installed extensions ids
*/
public static function installRecursively($extensionIDs, $installData = [])
{
$toInstall = [];
$installed = [];
foreach ($extensionIDs as $id) {
$ext = common_ext_ExtensionsManager::singleton()->getExtensionById($id);
if (!common_ext_ExtensionsManager::singleton()->isInstalled($ext->getId())) {
static::log('d', 'Extension ' . $id . ' needs to be installed');
$toInstall[$id] = $ext;
}
}
while (!empty($toInstall)) {
$modified = false;
foreach ($toInstall as $key => $extension) {
// if all dependencies are installed
static::log('d', 'Considering extension ' . $key);
$allInstalled = array_keys(common_ext_ExtensionsManager::singleton()->getinstalledextensions());
$missing = array_diff(array_keys($extension->getDependencies()), $allInstalled);
if (count($missing) == 0) {
static::install($extension, $installData);
$installed[] = $extension->getId();
static::log('i', 'Extension ' . $extension->getId() . ' installed');
unset($toInstall[$key]);
$modified = true;
break;
} else {
$missing = array_diff($missing, array_keys($toInstall));
foreach ($missing as $extID) {
static::log('d', 'Extension ' . $extID . ' is required but missing, added to install list');
$toInstall = [$extID => common_ext_ExtensionsManager::singleton()->getExtensionById($extID)] + $toInstall;
$modified = true;
}
}
}
// no extension could be installed, and no new requirements was added
if (!$modified) {
throw new \common_exception_Error('Unfulfilable/Cyclic reference found in extensions');
}
}
return $installed;
}
protected static function install($extension, $installData)
{
$importLocalData = (isset($installData['import_local']) && $installData['import_local'] == true);
$extinstaller = static::getInstaller($extension, $importLocalData);
helpers_TimeOutHelper::setTimeOutLimit(helpers_TimeOutHelper::LONG);
$extinstaller->install();
helpers_TimeOutHelper::reset();
;
}
protected static function getInstaller($extension, $importLocalData)
{
$instance = new \common_ext_ExtensionInstaller($extension, $importLocalData);
$instance->initContainer(static::$container);
return $instance;
}
/**
* Log message
*
* @see common_Logger class
*
* @param string $logLevel
* <ul>
* <li>'w' - warning</li>
* <li>'t' - trace</li>
* <li>'d' - debug</li>
* <li>'i' - info</li>
* <li>'e' - error</li>
* <li>'f' - fatal</li>
* </ul>
* @param string $message
* @param array $tags
*/
public static function log($logLevel, $message, $tags = [])
{
if (static::$logger instanceof \Psr\Log\LoggerInterface) {
static::$logger->log(
common_log_Logger2Psr::getPsrLevelFromCommon($logLevel),
$message
);
}
if (method_exists('common_Logger', $logLevel)) {
call_user_func('common_Logger::' . $logLevel, $message, $tags);
}
}
}