Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
0.00% covered (danger)
0.00%
0 / 48
0.00% covered (danger)
0.00%
0 / 4
CRAP
0.00% covered (danger)
0.00%
0 / 1
ImportQtiTest
0.00% covered (danger)
0.00%
0 / 48
0.00% covered (danger)
0.00%
0 / 4
72
0.00% covered (danger)
0.00%
0 / 1
 __invoke
0.00% covered (danger)
0.00%
0 / 21
0.00% covered (danger)
0.00%
0 / 1
6
 jsonSerialize
0.00% covered (danger)
0.00%
0 / 1
0.00% covered (danger)
0.00%
0 / 1
2
 createTask
0.00% covered (danger)
0.00%
0 / 20
0.00% covered (danger)
0.00%
0 / 1
2
 getClass
0.00% covered (danger)
0.00%
0 / 6
0.00% covered (danger)
0.00%
0 / 1
20
1<?php
2
3/**
4 * This program is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU General Public License
6 * as published by the Free Software Foundation; under version 2
7 * of the License (non-upgradable).
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12 * GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
17 *
18 * Copyright (c) 2016-2024 (original work) Open Assessment Technologies SA;
19 */
20
21namespace oat\taoQtiTest\models\tasks;
22
23use common_exception_Error;
24use common_exception_MissingParameter;
25use common_ext_ExtensionException;
26use common_report_Report;
27use oat\oatbox\service\exception\InvalidServiceManagerException;
28use oat\oatbox\task\AbstractTaskAction;
29use oat\oatbox\service\ServiceManager;
30use oat\tao\model\import\ImporterNotFound;
31use oat\tao\model\import\ImportersService;
32use oat\tao\model\TaoOntology;
33use oat\tao\model\taskQueue\QueueDispatcherInterface;
34use oat\tao\model\taskQueue\Task\TaskInterface;
35use oat\taoQtiTest\models\import\QtiTestImporter;
36
37/**
38 * Class ImportQtiTest
39 * @package oat\taoQtiTest\models\tasks
40 * @author Aleh Hutnikau, <hutnikau@1pt.com>
41 */
42class ImportQtiTest extends AbstractTaskAction implements \JsonSerializable
43{
44    public const FILE_DIR = 'ImportQtiTestTask';
45    public const PARAM_CLASS_URI = 'class_uri';
46    public const PARAM_FILE = 'file';
47    public const PARAM_ENABLE_GUARDIANS = 'enable_guardians';
48    public const PARAM_ENABLE_VALIDATORS = 'enable_validators';
49    public const PARAM_ITEM_MUST_EXIST = 'item_must_exist';
50    public const PARAM_ITEM_MUST_BE_OVERWRITTEN = 'item_must_be_overwritten';
51    public const PARAM_ITEM_CLASS_URI = 'item_class_uri';
52    /**
53     * @deprecated Use oat\taoQtiTest\models\tasks\ImportQtiTest::PARAM_OVERWRITE_TEST_URI instead with the URI of the
54     *             test to be replaced
55     */
56    public const PARAM_OVERWRITE_TEST = 'overwrite_test';
57    public const PARAM_OVERWRITE_TEST_URI = 'overwrite_test_uri';
58    public const PARAM_PACKAGE_LABEL = 'package_label';
59
60    protected $service;
61
62    /**
63     * @param $params
64     * @return common_report_Report
65     * @throws common_exception_Error
66     * @throws common_exception_MissingParameter
67     * @throws common_ext_ExtensionException
68     * @throws InvalidServiceManagerException
69     * @throws ImporterNotFound
70     */
71    public function __invoke($params)
72    {
73        if (!isset($params[self::PARAM_FILE])) {
74            throw new common_exception_MissingParameter(
75                'Missing parameter `' . self::PARAM_FILE . '` in ' . self::class
76            );
77        }
78
79        \common_ext_ExtensionsManager::singleton()->getExtensionById('taoQtiTest');
80
81        $file = $this->getFileReferenceSerializer()->unserializeFile($params['file']);
82
83        /** @var ImportersService $importersService */
84        $importersService = $this->getServiceManager()->get(ImportersService::SERVICE_ID);
85
86        /** @var QtiTestImporter $importer */
87        $importer = $importersService->getImporter(QtiTestImporter::IMPORTER_ID);
88
89        $report = $importer->import(
90            $file,
91            $this->getClass($params),
92            $params[self::PARAM_ENABLE_GUARDIANS] ?? true,
93            $params[self::PARAM_ENABLE_VALIDATORS] ?? true,
94            $params[self::PARAM_ITEM_MUST_EXIST] ?? false,
95            $params[self::PARAM_ITEM_MUST_BE_OVERWRITTEN] ?? false,
96            $params[self::PARAM_OVERWRITE_TEST] ?? false,
97            $params[self::PARAM_ITEM_CLASS_URI] ?? null,
98            $params[self::PARAM_OVERWRITE_TEST_URI] ?? null,
99            $params[self::PARAM_PACKAGE_LABEL] ?? null,
100        );
101
102        return $report;
103    }
104
105    /**
106     * @return string
107     */
108    public function jsonSerialize()
109    {
110        return __CLASS__;
111    }
112
113    /**
114     * Create task in queue
115     * @param array $packageFile uploaded file
116     * @param \core_kernel_classes_Class $class uploaded file
117     * @param bool $enableGuardians Flag that marks use or not metadata guardians during the import.
118     * @param bool $enableValidators Flag that marks use or not metadata validators during the import.
119     * @param bool $itemMustExist Flag to indicate that all items must exist in database (via metadata guardians) to
120     *                            make the test import successful.
121     * @param bool $itemMustBeOverwritten Flag to indicate that items found by metadata guardians will be overwritten.
122     * @return TaskInterface
123     */
124    public static function createTask(
125        $packageFile,
126        \core_kernel_classes_Class $class,
127        $enableGuardians = true,
128        $enableValidators = true,
129        $itemMustExist = false,
130        $itemMustBeOverwritten = false,
131        bool $overwriteTest = false,
132        ?string $itemClassUri = null,
133        ?string $overwriteTestUri = null,
134        ?string $packageLabel = null
135    ) {
136        $action = new self();
137        $action->setServiceLocator(ServiceManager::getServiceManager());
138
139        $fileUri = $action->saveFile($packageFile['tmp_name'], $packageFile['name']);
140
141        /** @var QueueDispatcherInterface $queueDispatcher */
142        $queueDispatcher = ServiceManager::getServiceManager()->get(QueueDispatcherInterface::SERVICE_ID);
143
144        return $queueDispatcher->createTask(
145            $action,
146            [
147                self::PARAM_FILE => $fileUri,
148                self::PARAM_CLASS_URI => $class->getUri(),
149                self::PARAM_ENABLE_GUARDIANS => $enableGuardians,
150                self::PARAM_ENABLE_VALIDATORS => $enableValidators,
151                self::PARAM_ITEM_MUST_EXIST => $itemMustExist,
152                self::PARAM_ITEM_MUST_BE_OVERWRITTEN => $itemMustBeOverwritten,
153                self::PARAM_OVERWRITE_TEST => $overwriteTest,
154                self::PARAM_ITEM_CLASS_URI => $itemClassUri,
155                self::PARAM_OVERWRITE_TEST_URI => $overwriteTestUri,
156                self::PARAM_PACKAGE_LABEL => $packageLabel,
157            ],
158            __('Import QTI TEST into "%s"', $class->getLabel())
159        );
160    }
161
162    /**
163     * @param array $taskParams
164     * @return \core_kernel_classes_Class
165     */
166    private function getClass(array $taskParams)
167    {
168        $class = null;
169        if (isset($taskParams[self::PARAM_CLASS_URI])) {
170            $class = new \core_kernel_classes_Class($taskParams[self::PARAM_CLASS_URI]);
171        }
172        if ($class === null || !$class->exists()) {
173            $class = new \core_kernel_classes_Class(TaoOntology::CLASS_URI_TEST);
174        }
175        return $class;
176    }
177}