tao-test/app/ltiDeliveryProvider/scripts/update/Updater.php

377 lines
17 KiB
PHP
Raw 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;
*/
namespace oat\ltiDeliveryProvider\scripts\update;
use common_report_Report as Report;
use oat\ltiDeliveryProvider\controller\DeliveryTool;
use oat\ltiDeliveryProvider\model\actions\GetActiveDeliveryExecution;
use oat\ltiDeliveryProvider\model\AttemptService;
use oat\ltiDeliveryProvider\model\delivery\DeliveryContainerService;
use oat\ltiDeliveryProvider\model\execution\implementation\LtiDeliveryExecutionService;
use oat\ltiDeliveryProvider\model\LtiAssignment;
use oat\ltiDeliveryProvider\model\LtiDeliveryFactory;
use oat\ltiDeliveryProvider\model\LTIDeliveryToolFactory;
use oat\ltiDeliveryProvider\model\LtiLaunchDataService;
use oat\ltiDeliveryProvider\model\LtiOutcomeService;
use oat\ltiDeliveryProvider\model\LtiResultAliasStorage;
use oat\ltiDeliveryProvider\model\metrics\ActiveLimitRestriction;
use oat\ltiDeliveryProvider\model\metrics\implementation\activeExecutionsMetrics;
use oat\ltiDeliveryProvider\model\navigation\DefaultMessageFactory;
use oat\ltiDeliveryProvider\model\navigation\LtiNavigationService;
use oat\ltiDeliveryProvider\model\options\DataAccess\Mapper\OptionCollectionMapper;
use oat\ltiDeliveryProvider\model\options\DataAccess\Repository\OverriddenLtiToolsRepository;
use oat\ltiDeliveryProvider\model\ResultAliasService;
use oat\oatbox\event\EventManager;
use oat\oatbox\session\SessionService;
use oat\tao\model\accessControl\func\AccessRule;
use oat\tao\model\accessControl\func\AclProxy;
use oat\tao\model\actionQueue\ActionQueue;
use oat\tao\model\actionQueue\implementation\InstantActionQueue;
use oat\tao\model\metadata\exception\InconsistencyConfigException;
use oat\tao\model\metrics\MetricsService;
use oat\taoDelivery\model\AttemptServiceInterface;
use oat\taoDelivery\model\execution\Counter\DeliveryExecutionCounterInterface;
use oat\taoDelivery\model\execution\Counter\DeliveryExecutionCounterService;
use oat\taoDelivery\models\classes\execution\event\DeliveryExecutionCreated;
use oat\taoDelivery\models\classes\execution\event\DeliveryExecutionState;
use oat\taoLti\models\classes\LtiRoles;
use oat\taoQtiTest\models\TestCategoryPresetProvider;
/**
* @deprecated use migrations instead. See https://github.com/oat-sa/generis/wiki/Tao-Update-Process
*/
class Updater extends \common_ext_ExtensionUpdater
{
/**
* @param string $initialVersion
* @return string|void
*/
public function update($initialVersion)
{
$this->skip('0', '1.7.1');
if ($this->isVersion('1.7.1')) {
if (!$this->getServiceManager()->has(LtiAssignment::SERVICE_ID)) {
$service = new LtiAssignment();
$service->setServiceLocator($this->getServiceManager());
$this->getServiceManager()->register(LtiAssignment::SERVICE_ID, $service);
}
$this->setVersion('2.0.0');
}
$this->skip('2.0.0', '2.0.1');
if ($this->isVersion('2.0.1')) {
$extension = \common_ext_ExtensionsManager::singleton()->getExtensionById('ltiDeliveryProvider');
$config = $extension->getConfig('deliveryRunner');
$config['showControls'] = false;
$extension->setConfig('deliveryRunner', $config);
$this->setVersion('2.1.0');
}
if ($this->isVersion('2.1.0')) {
$service = new LtiDeliveryExecutionService([]);
$this->getServiceManager()->register(LtiDeliveryExecutionService::SERVICE_ID, $service);
$this->setVersion('2.2.0');
}
$this->skip('2.2.0', '2.3.0');
if ($this->isVersion('2.3.0')) {
$extension = \common_ext_ExtensionsManager::singleton()->getExtensionById('ltiDeliveryProvider');
$extension->unsetConfig('deliveryRunner');
$this->setVersion('2.4.0');
}
$this->skip('2.4.0', '3.2.1');
if ($this->isVersion('3.2.1')) {
$service = new LtiResultAliasStorage([
LtiResultAliasStorage::OPTION_PERSISTENCE => 'default'
]);
$service->setServiceManager($this->getServiceManager());
$migration = new \oat\ltiDeliveryProvider\scripts\dbMigrations\LtiResultAliasStorage_v1();
$migration->apply(
$this->getServiceManager()->get(\common_persistence_Manager::SERVICE_ID)->getPersistenceById('default')
);
$this->getServiceManager()->register(LtiResultAliasStorage::SERVICE_ID, $service);
$this->getServiceManager()->register(ResultAliasService::SERVICE_ID, new ResultAliasService());
$this->setVersion('3.3.0');
}
$this->skip('3.3.0', '3.5.1');
if ($this->isVersion('3.5.1')) {
AclProxy::applyRule(new AccessRule('grant', LtiRoles::CONTEXT_LEARNER, DeliveryTool::class, 'launchQueue'));
$launchQueueConfig = new \oat\oatbox\config\ConfigurationService([
'config' => [
'relaunchInterval' => 30,
'relaunchIntervalDeviation' => 5,
]
]);
$this->getServiceManager()->register('ltiDeliveryProvider/LaunchQueue', $launchQueueConfig);
$actionQueue = $this->getServiceManager()->get(ActionQueue::SERVICE_ID);
$actions = $actionQueue->getOption(ActionQueue::OPTION_ACTIONS);
$actions[GetActiveDeliveryExecution::class] = [
ActionQueue::ACTION_PARAM_LIMIT => 0,
ActionQueue::ACTION_PARAM_TTL => 3600, //one hour
];
$actionQueue->setOption(ActionQueue::OPTION_ACTIONS, $actions);
$this->getServiceManager()->register(ActionQueue::SERVICE_ID, $actionQueue);
$ltiDeliveryExecutionService = $this->getServiceManager()->get(LtiDeliveryExecutionService::SERVICE_ID);
$ltiDeliveryExecutionService->setOption(LtiDeliveryExecutionService::OPTION_QUEUE_PERSISTENCE, 'cache');
$this->getServiceManager()->register(LtiDeliveryExecutionService::SERVICE_ID, $ltiDeliveryExecutionService);
/** @var EventManager $eventManager */
$eventManager = $this->getServiceManager()->get(EventManager::SERVICE_ID);
$eventManager->attach(DeliveryExecutionState::class, [LtiDeliveryExecutionService::SERVICE_ID, 'executionStateChanged']);
$eventManager->attach(DeliveryExecutionCreated::class, [LtiDeliveryExecutionService::SERVICE_ID, 'executionCreated']);
$this->getServiceManager()->register(EventManager::SERVICE_ID, $eventManager);
$this->setVersion('3.6.0');
}
if ($this->isVersion('3.6.0')) {
$ltiDeliveryExecutionService = $this->getServiceManager()->get(LtiDeliveryExecutionService::SERVICE_ID);
$ltiDeliveryExecutionService->setOption(LtiDeliveryExecutionService::OPTION_QUEUE_PERSISTENCE, 'cache');
$this->getServiceManager()->register(LtiDeliveryExecutionService::SERVICE_ID, $ltiDeliveryExecutionService);
$this->setVersion('3.7.0');
}
$this->skip('3.7.0', '3.8.1');
if ($this->isVersion('3.8.1')) {
$ltiLaunchDataService = new LtiLaunchDataService();
$this->getServiceManager()->register(LtiLaunchDataService::SERVICE_ID, $ltiLaunchDataService);
$this->setVersion('3.9.0');
}
$this->skip('3.9.0', '3.11.5');
if ($this->isVersion('3.11.5')) {
$ltiOutcome = new LtiOutcomeService();
$this->getServiceManager()->register(LtiOutcomeService::SERVICE_ID, $ltiOutcome);
/** @var EventManager $eventManager */
$eventManager = $this->getServiceManager()->get(EventManager::SERVICE_ID);
$eventManager->attach(DeliveryExecutionState::class, [LtiOutcomeService::SERVICE_ID, 'deferTransmit']);
$this->getServiceManager()->register(EventManager::SERVICE_ID, $eventManager);
$this->setVersion('4.0.0');
}
$this->skip('4.0.0', '5.4.0');
if ($this->isVersion('5.4.0')) {
$this->getServiceManager()->register(
DeliveryContainerService::SERVICE_ID,
new DeliveryContainerService([])
);
$this->setVersion('5.5.0');
}
$this->skip('5.5.0', '6.0.0');
if ($this->isVersion('6.0.0')) {
$attemptService = $this->safeLoadService(AttemptServiceInterface::SERVICE_ID);
if (!$attemptService instanceof AttemptServiceInterface) {
$attemptService = new AttemptService([]);
}
$statesToExclude = $attemptService->getStatesToExclude();
$newAttemptService = new AttemptService([]);
$newAttemptService->setStatesToExclude($statesToExclude);
$this->getServiceManager()->register(AttemptServiceInterface::SERVICE_ID, $newAttemptService);
$this->setVersion('6.1.0');
}
if ($this->isVersion('6.1.0')) {
$this->getServiceManager()->register(
DeliveryExecutionCounterInterface::SERVICE_ID,
new DeliveryExecutionCounterService([
DeliveryExecutionCounterService::OPTION_PERSISTENCE => 'cache'
])
);
$this->addReport(new Report(Report::TYPE_WARNING, 'Set persistence of ' . DeliveryExecutionCounterInterface::SERVICE_ID . ' to common one'));
$this->setVersion('6.2.0');
}
$this->skip('6.2.0', '6.3.0');
if ($this->isVersion('6.3.0')) {
$service = $this->getServiceManager()->get(InstantActionQueue::class);
$actions = $service->getOption('actions');
foreach ($actions as $action => $params) {
if (array_key_exists('limit', $params)) {
$limit = $params['limit'];
$params['restrictions'][ActiveLimitRestriction::class] = $limit;
unset($params['limit']);
$actions[$action] = $params;
}
}
$service->setOption('actions', $actions);
$this->getServiceManager()->register(InstantActionQueue::SERVICE_ID, $service);
$metricService = $this->getServiceManager()->get(MetricsService::class);
$limitMetric = new activeExecutionsMetrics();
$limitMetric->setOptions([
activeExecutionsMetrics::OPTION_TTL => 360,
activeExecutionsMetrics::OPTION_PERSISTENCE => 'cache',
]);
$metricService->setOption(MetricsService::OPTION_METRICS, [activeExecutionsMetrics::class => $limitMetric]);
$this->getServiceManager()->register(MetricsService::SERVICE_ID, $metricService);
$this->setVersion('6.4.0');
}
if ($this->isVersion('6.4.0')) {
$metricService = $this->getServiceManager()->get(MetricsService::class);
try {
$limitMetric = $metricService->getOneMetric(activeExecutionsMetrics::class);
} catch (InconsistencyConfigException $exception) {
$limitMetric = new activeExecutionsMetrics();
}
$limitMetric->setOptions([
activeExecutionsMetrics::OPTION_TTL => 1,
activeExecutionsMetrics::OPTION_PERSISTENCE => 'cache',
]);
$metricService->setOption(MetricsService::OPTION_METRICS, [activeExecutionsMetrics::class => $limitMetric]);
$this->getServiceManager()->register(MetricsService::SERVICE_ID, $metricService);
$this->setVersion('6.4.1');
}
if ($this->isVersion('6.4.1')) {
/** @var \common_persistence_Manager $pm */
$pm = $this->getServiceManager()->get(\common_persistence_Manager::SERVICE_ID);
$pm->registerPersistence('metricsCache', ['driver' => 'phpfile', 'ttlMode' => true,]);
$metricService = $this->getServiceManager()->get(MetricsService::class);
$limitMetric = $metricService->getOneMetric(activeExecutionsMetrics::class);
$limitMetric->setOption(activeExecutionsMetrics::OPTION_PERSISTENCE, 'metricsCache');
$metricService->setOption(MetricsService::OPTION_METRICS, [activeExecutionsMetrics::class => $limitMetric]);
$this->getServiceManager()->register(MetricsService::SERVICE_ID, $metricService);
$this->addReport(new Report(Report::TYPE_WARNING, 'Set persistence named *metricsCache* to common one ( like redis )'));
$this->setVersion('6.4.2');
}
if ($this->isVersion('6.4.2')) {
$pm = $this->getServiceManager()->register(LtiNavigationService::SERVICE_ID, new LtiNavigationService([
LtiNavigationService::OPTION_THANK_YOU_SCREEN => true,
LtiNavigationService::OPTION_MESSAGE_FACTORY => new DefaultMessageFactory()
]));
$this->setVersion('6.5.0');
}
$this->skip('6.5.0', '9.0.1');
if ($this->isVersion('9.0.1')) {
$service = $this->getServiceManager()->get(LtiNavigationService::SERVICE_ID);
if (!$service->getOption(LtiNavigationService::OPTION_DELIVERY_RETURN_STATUS)) {
$service->setOption(LtiNavigationService::OPTION_DELIVERY_RETURN_STATUS, false);
$this->getServiceManager()->register(LtiNavigationService::SERVICE_ID, $service);
}
$this->setVersion('9.1.0');
}
$this->skip('9.1.0', '9.3.0');
if ($this->isVersion('9.3.0')) {
$this->getServiceManager()->register(LtiDeliveryFactory::SERVICE_ID, new LtiDeliveryFactory());
$this->getServiceManager()->register(LTIDeliveryToolFactory::SERVICE_ID, new LTIDeliveryToolFactory());
$this->setVersion('9.4.0');
}
$this->skip('9.4.0', '10.5.0');
if ($this->isVersion('10.5.0')) {
$serviceManager = $this->getServiceManager();
$serviceManager->register(
OptionCollectionMapper::SERVICE_ID,
new OptionCollectionMapper()
);
$serviceManager->register(
OverriddenLtiToolsRepository::SERVICE_ID,
new OverriddenLtiToolsRepository(
$serviceManager->get(TestCategoryPresetProvider::SERVICE_ID),
$serviceManager->get(SessionService::SERVICE_ID),
$serviceManager->get(OptionCollectionMapper::SERVICE_ID)
)
);
$this->setVersion('10.6.0');
}
$this->skip('10.6.0', '11.1.0');
if ($this->isVersion('11.1.0')) {
if ($this->getServiceManager()->has(ActionQueue::SERVICE_ID)) {
$actionQueueService = $this->getServiceManager()->get(ActionQueue::SERVICE_ID);
$options = $actionQueueService->getOptions();
if (isset($options[ActionQueue::OPTION_ACTIONS][GetActiveDeliveryExecution::class]['restrictions'])) {
$restrictions = $options[ActionQueue::OPTION_ACTIONS][GetActiveDeliveryExecution::class]['restrictions'];
$renamedClassname = 'oat\\ltiDeliveryProvider\\model\\metrics\\activeLimitRestriction';
if (isset($restrictions[$renamedClassname])) {
$restrictionOptions = $restrictions[$renamedClassname];
unset($restrictions[$renamedClassname]);
$restrictions[ActiveLimitRestriction::class] = $restrictionOptions;
}
$options[ActionQueue::OPTION_ACTIONS][GetActiveDeliveryExecution::class]['restrictions'] = $restrictions;
$actionQueueService->setOptions($options);
$this->getServiceManager()->register(ActionQueue::SERVICE_ID, $actionQueueService);
}
}
$this->setVersion('11.2.0');
}
$this->skip('11.2.0', '11.2.1');
//Updater files are deprecated. Please use migrations.
//See: https://github.com/oat-sa/generis/wiki/Tao-Update-Process
$this->setVersion($this->getExtension()->getManifest()->getVersion());
}
}