ILIAS  trunk Revision v12.0_alpha-1227-g7ff6d300864
class.ilScormAiccDataSet.php
Go to the documentation of this file.
1<?php
2
19declare(strict_types=1);
20
22{
23 private string $db_table;
24 public array $properties;
25 private array $_archive;
26 private array $element_db_mapping;
27
28 public function __construct()
29 {
30 $this->db_table = "sahs_lm";
31 $this->_archive = [];
32 $this->properties = [
33 "Id" => ["db_col" => "id", "db_type" => "integer"],
34 "APIAdapterName" => ["db_col" => "api_adapter", "db_type" => "text"],
35 "APIFunctionsPrefix" => ["db_col" => "api_func_prefix", "db_type" => "text"],
36 "AssignedGlossary" => ["db_col" => "glossary", "db_type" => "integer"],
37 "AutoContinue" => ["db_col" => "auto_continue", "db_type" => "text"],
38 "AutoReviewChar" => ["db_col" => "auto_review", "db_type" => "text"],
39 "AutoSuspend" => ["db_col" => "auto_suspend", "db_type" => "text"],
40 "Auto_last_visited" => ["db_col" => "auto_last_visited", "db_type" => "text"],
41 "Check_values" => ["db_col" => "check_values", "db_type" => "text"],
42 "Comments" => ["db_col" => "comments", "db_type" => "text"],
43 "CreditMode" => ["db_col" => "credit", "db_type" => "text"],
44 "Debug" => ["db_col" => "debug", "db_type" => "text"],
45 "DebugPw" => ["db_col" => "debugpw", "db_type" => "text"],
46 "DefaultLessonMode" => ["db_col" => "default_lesson_mode", "db_type" => "text"],
47 "Editable" => ["db_col" => "editable", "db_type" => "integer"],
48 "Fourth_edition" => ["db_col" => "fourth_edition", "db_type" => "text"],
49 "Height" => ["db_col" => "height", "db_type" => "integer"],
50 "HideNavig" => ["db_col" => "hide_navig", "db_type" => "text"],
51 "Ie_force_render" => ["db_col" => "ie_force_render", "db_type" => "text"],
52 "Interactions" => ["db_col" => "interactions", "db_type" => "text"],
53 "Localization" => ["db_col" => "localization", "db_type" => "text"],
54 "MasteryScore" => ["db_col" => "mastery_score", "db_type" => "integer"],
55 "MaxAttempt" => ["db_col" => "max_attempt", "db_type" => "integer"],
56 "ModuleVersion" => ["db_col" => "module_version", "db_type" => "integer"],
57 "NoMenu" => ["db_col" => "no_menu", "db_type" => "text"],
58 "Objectives" => ["db_col" => "objectives", "db_type" => "text"],
59 "OfflineMode" => ["db_col" => "offline_mode", "db_type" => "text"],
60 "OpenMode" => ["db_col" => "open_mode", "db_type" => "integer"],
61 "Sequencing" => ["db_col" => "sequencing", "db_type" => "text"],
62 "SequencingExpertMode" => ["db_col" => "seq_exp_mode", "db_type" => "integer"],
63 "Session" => ["db_col" => "unlimited_session", "db_type" => "text"],
64 "StyleSheetId" => ["db_col" => "stylesheet", "db_type" => "integer"],
65 "SubType" => ["db_col" => "c_type", "db_type" => "text"],
66 "Time_from_lms" => ["db_col" => "time_from_lms", "db_type" => "text"],
67 "Tries" => ["db_col" => "question_tries", "db_type" => "integer"],
68 "Width" => ["db_col" => "width", "db_type" => "integer"],
69 "IdSetting" => ["db_col" => "id_setting", "db_type" => "integer"],
70 "NameSetting" => ["db_col" => "name_setting", "db_type" => "integer"]
71 ];
72
73 $this->element_db_mapping = [];
74
76
77 foreach ($this->properties as $key => $value) {
78 $this->element_db_mapping [$value["db_col"]] = $key;
79 }
80 }
81
82 protected function getDependencies(
83 string $a_entity,
84 string $a_version,
85 ?array $a_rec = null,
86 ?array $a_ids = null
87 ): array {
88 return [];
89 }
90
91 public function writeData(string $a_entity, string $a_version, int $a_id, array $data): void
92 {
93 global $DIC;
94 $ilDB = $DIC->database();
95 $ilLog = ilLoggerFactory::getLogger('sahs');
96 if (count($data) > 0) {
97 $columns = [];
98 foreach ($this->properties as $key => $value) {
99 if ($key === "Id" || $key === "title" || $key === "description") {
100 continue;
101 }
102 //fix localization and mastery_score
103 if ($key === "MasteryScore" && isset($data[$key][0]) && $data[$key][0] == 0) {
104 continue;
105 }
106 if ($key === "Localization" && isset($data[$key][0]) && $data[$key][0] == "") {
107 continue;
108 }
109 //end fix
110 if ( isset( $data[ $key ] ) ) {
111 $data_value = '';
112 if ( is_array( $data[ $key ] ) ) {
113 $data_value = $data[ $key ][ 0 ] ?? '';
114 }
115 else {
116 $data_value = $data[ $key ];
117 }
118 $columns [ $value[ "db_col" ] ] = [
119 $value[ "db_type" ],
120 $data_value
121 ];
122 }
123 }
124 if (is_array($columns)) {
125 if (count($columns) > 0) {
126 $conditions ["id"] = ["integer", $a_id];
127 $ilDB->update($this->db_table, $columns, $conditions);
128 }
129 }
130
131 //setting title and description in table object_data
132 $od_table = "object_data";
133 $od_properties = [
134 "Title" => ["db_col" => "title", "db_type" => "text"],
135 "Description" => ["db_col" => "description", "db_type" => "text"]
136 ];
137 foreach ($od_properties as $key => $value) {
138 if ( isset( $data[ $key ] ) ) {
139 $data_value = '';
140 if ( is_array( $data[ $key ] ) ) {
141 $data_value = $data[ $key ][ 0 ] ?? '';
142 }
143 else {
144 $data_value = $data[ $key ];
145 }
146 $od_columns [ $value[ "db_col" ] ] = [
147 $value[ "db_type" ],
148 $data_value
149 ];
150 }
151
152 if (isset($od_columns) && is_array($od_columns)) {
153 if (count($od_columns) > 0) {
154 $od_conditions ["obj_id"] = ["integer", $a_id];
155 $ilDB->update("object_data", $od_columns, $od_conditions);
156 }
157 }
158 }
159 } else {
160 $ilLog->write("no module properties for imported object");
161 }
162 }
163
168 string $exportArchiveDir,
169 string $a_entity,
170 string $a_schema_version,
171 array $a_ids,
172 string $a_field = "",
173 bool $a_omit_header = false,
174 bool $a_omit_types = false
175 ): string {
176
177 global $DIC;
178 $ilLog = ilLoggerFactory::getLogger('sahs');
179
180 $ilLog->write(json_encode($this->getTypes("sahs", "5.1.0"), JSON_PRETTY_PRINT));
181
182 $this->dircnt = 1;
183
184 $this->readData($a_entity, $a_schema_version, $a_ids, $a_field = "");
185 $id = (int) $this->data["id"];
186
187 $this->_archive['files'] = [
188 "properties" => "properties.xml",
189 'scormFile' => "content.zip"
190 ];
191
192 // build content zip file
193 if (isset($this->_archive['files']['scormFile'])) {
194 $lmDir = './' . ILIAS_WEB_DIR . "/" . CLIENT_ID . "/lm_data/lm_" . $id;
195 // Important: content zip should not contain a 'lm_x' directory
196 $DIC->legacyArchives()->zip(
197 $lmDir,
198 $exportArchiveDir . "/" . $this->_archive['files']['scormFile'],
199 false
200 );
201 }
202
203 // build property xml file
204 file_put_contents(
205 $exportArchiveDir . "/" . $this->_archive['files']['properties'],
206 $this->buildProperties($a_entity, $a_omit_header)
207 );
208
209 return $exportArchiveDir . '.zip';
210 }
211
218 protected function getTypes(string $a_entity, string $a_version): array
219 {
220 if ($a_entity === "sahs") {
221 switch ($a_version) {
222 case "5.1.0":
223 $types = [];
224 foreach ($this->properties as $key => $value) {
225 $types[$key] = $value["db_type"];
226 }
227 return $types;
228 }
229 }
230 return [];
231 }
232
233 public function readData(string $a_entity, string $a_version, array $a_ids, string $a_field = ""): void
234 {
235 global $DIC;
236 $ilDB = $DIC->database();
237
238 $obj_id = (int) $a_ids[0];
239 $columns = [];
240 foreach ($this->properties as $property) {
241 $columns[] = $property["db_col"];
242 }
243
244 $query = "SELECT " . implode(",", $columns) . " FROM " . $this->db_table;
245 $query .= " WHERE id=" . $ilDB->quote($obj_id, "integer");
246 $result = $ilDB->query($query);
247 $this->data = [];
248 if ($dataset = $ilDB->fetchAssoc($result)) {
249 $this->data = $dataset;
250 }
251
252 $query = "SELECT title,description FROM object_data";
253 $query .= " WHERE obj_id=" . $ilDB->quote($obj_id, "integer");
254 $result = $ilDB->query($query);
255 while ($dataset = $ilDB->fetchAssoc($result)) {
256 $this->data ["title"] = $dataset["title"];
257 $this->data ["description"] = $dataset["description"];
258 }
259 }
260
264 public function getElementNameByDbColumn(string $db_col_name): string
265 {
266 if ($db_col_name === "title") {
267 return "Title";
268 }
269 if ($db_col_name === "description") {
270 return "Description";
271 }
272 return $this->element_db_mapping[$db_col_name];
273 }
274
278 protected function getXmlNamespace(string $a_entity, string $a_schema_version): string
279 {
280 return "http://www.ilias.de/xml/Modules/ScormAicc/" . $a_entity;
281 }
282
286 public function getSupportedVersions(): array
287 {
288 return ["5.1.0"];
289 }
290
294 private function buildManifest(): string
295 {
296 $manWriter = new ilXmlWriter();
297 $manWriter->xmlHeader();
298 foreach ($this->_archive['files'] as $key => $value) {
299 $manWriter->xmlElement($key, null, $value, true, true);
300 }
301
302 return $manWriter->xmlDumpMem(true);
303 }
304
310 private function buildProperties($a_entity, bool $a_omit_header = false): string
311 {
312 $writer = new ilXmlWriter();
313
314 if (!$a_omit_header) {
315 $writer->xmlHeader();
316 }
317
318 $writer->appendXML("\n");
319 $writer->xmlStartTag('DataSet', array(
320 "InstallationId" => IL_INST_ID,
321 "InstallationUrl" => ILIAS_HTTP_PATH,
322 "TopEntity" => $a_entity
323 ));
324
325 $writer->appendXML("\n");
326
327 foreach ($this->data as $key => $value) {
328 $writer->xmlElement($this->getElementNameByDbColumn($key), null, $value, true, true);
329 $writer->appendXML("\n");
330 }
331
332 $writer->xmlEndTag("DataSet");
333
334 return $writer->xmlDumpMem(false);
335 }
336}
$id
plugin.php for ilComponentBuildPluginInfoObjectiveTest::testAddPlugins
Definition: plugin.php:23
A dataset contains in data in a common structure that can be shared and transformed for different pur...
static getLogger(string $a_component_id)
Get component logger.
getElementNameByDbColumn(string $db_col_name)
retrieve element name by database column name
buildProperties($a_entity, bool $a_omit_header=false)
getExtendedXmlRepresentation(string $exportArchiveDir, string $a_entity, string $a_schema_version, array $a_ids, string $a_field="", bool $a_omit_header=false, bool $a_omit_types=false)
own getXmlRepresentation function to embed zipfile in xml
getXmlNamespace(string $a_entity, string $a_schema_version)
Get xml namespace.
getTypes(string $a_entity, string $a_version)
Get field types for entity.
getDependencies(string $a_entity, string $a_version, ?array $a_rec=null, ?array $a_ids=null)
writeData(string $a_entity, string $a_version, int $a_id, array $data)
readData(string $a_entity, string $a_version, array $a_ids, string $a_field="")
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
const CLIENT_ID
Definition: constants.php:41
const ILIAS_WEB_DIR
Definition: constants.php:45
const IL_INST_ID
Definition: constants.php:40
return['delivery_method'=> 'php',]
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
__construct(Container $dic, ilPlugin $plugin)
@inheritDoc
global $DIC
Definition: shib_login.php:26