19 declare(strict_types=1);
44 'user_id' => array(
'pattern' =>
null,
'permission' => self::NONE,
'default' =>
null,
'dbfield' =>
'user_id'),
45 'learner_name' => array(
'pattern' =>
null,
'permission' => self::NONE,
'default' =>
null,
'dbfield' =>
'learner_name'),
46 'slm_id' => array(
'pattern' =>
null,
'permission' => self::NONE,
'default' =>
null,
'dbfield' =>
'slm_id'),
47 'mode' => array(
'pattern' =>
null,
'permission' => self::NONE,
'default' =>
null,
'dbfield' =>
'c_mode'),
48 'credit' => array(
'pattern' =>
null,
'permission' => self::NONE,
'default' =>
null,
'dbfield' =>
'credit'),
51 'accesscount' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'accesscount'),
52 'accessduration' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'accessduration'),
53 'accessed' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'accessed'),
54 'activityAbsoluteDuration' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'activityabsduration'),
55 'activityAttemptCount' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'activityattemptcount'),
56 'activityExperiencedDuration' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'activityexpduration'),
57 'activityProgressStatus' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'activityprogstatus'),
58 'attemptAbsoluteDuration' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'attemptabsduration'),
59 'attemptCompletionAmount' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'attemptcomplamount'),
60 'attemptCompletionStatus' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'attemptcomplstatus'),
61 'attemptExperiencedDuration' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'attemptexpduration'),
62 'attemptProgressStatus' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'attemptprogstatus'),
63 'audio_captioning' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'audio_captioning'),
64 'audio_level' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'audio_level'),
65 'availableChildren' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'availablechildren'),
66 'cmi_node_id' => array(
'pattern' =>
null,
'permission' => self::NONE,
'default' =>
null,
'dbfield' =>
'cmi_node_id'),
67 'completion' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'completion'),
68 'completion_status' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'completion_status'),
69 'completion_threshold' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'completion_threshold'),
70 'cp_node_id' => array(
'pattern' =>
null,
'permission' => self::NONE,
'default' =>
null,
'dbfield' =>
'cp_node_id'),
71 'created' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'created'),
72 'credit' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'credit'),
73 'delivery_speed' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'delivery_speed'),
74 'entry' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'c_entry'),
75 'exit' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'c_exit'),
76 'language' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'c_language'),
77 'launch_data' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'launch_data'),
78 'learner_name' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'learner_name'),
79 'location' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'location'),
80 'max' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'c_max'),
81 'min' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'c_min'),
82 'mode' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'c_mode'),
83 'modified' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'modified'),
84 'progress_measure' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'progress_measure'),
85 'raw' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'c_raw'),
86 'scaled' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'scaled'),
87 'scaled_passing_score' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'scaled_passing_score'),
88 'session_time' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'session_time'),
89 'success_status' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'success_status'),
90 'suspend_data' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'suspend_data'),
91 'total_time' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'total_time'),
92 'user_id' => array(
'pattern' =>
null,
'permission' => self::NONE,
'default' =>
null,
'dbfield' =>
'user_id'),
95 'cmi_comment_id' => array(
'pattern' =>
null,
'permission' => self::NONE,
'default' =>
null,
'dbfield' =>
'cmi_comment_id'),
96 'cmi_node_id' => array(
'pattern' =>
null,
'permission' => self::NONE,
'default' =>
null,
'dbfield' =>
'cmi_node_id'),
97 'comment' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'c_comment'),
98 'timestamp' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'c_timestamp'),
99 'location' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'location'),
100 'sourceIsLMS' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'sourceislms'),
102 'correct_response' => array(
103 'cmi_correct_response_id' => array(
'pattern' =>
null,
'permission' => self::NONE,
'default' =>
null,
'dbfield' =>
'cmi_correct_resp_id'),
104 'cmi_interaction_id' => array(
'pattern' =>
null,
'permission' => self::NONE,
'default' =>
null,
'dbfield' =>
'cmi_interaction_id'),
105 'pattern' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'pattern'),
107 'interaction' => array(
108 'cmi_interaction_id' => array(
'pattern' =>
null,
'permission' => self::NONE,
'default' =>
null,
'dbfield' =>
'cmi_interaction_id'),
109 'cmi_node_id' => array(
'pattern' =>
null,
'permission' => self::NONE,
'default' =>
null,
'dbfield' =>
'cmi_node_id'),
110 'description' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'description'),
111 'id' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'id'),
112 'latency' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'latency'),
113 'learner_response' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'learner_response'),
114 'result' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'result'),
115 'timestamp' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'c_timestamp'),
116 'type' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'c_type'),
117 'weighting' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'weighting'),
119 'objective' => array(
120 'cmi_interaction_id' => array(
'pattern' =>
null,
'permission' => self::NONE,
'default' =>
null,
'dbfield' =>
'cmi_interaction_id'),
121 'cmi_node_id' => array(
'pattern' =>
null,
'permission' => self::NONE,
'default' =>
null,
'dbfield' =>
'cmi_node_id'),
122 'cmi_objective_id' => array(
'pattern' =>
null,
'permission' => self::NONE,
'default' =>
null,
'dbfield' =>
'cmi_objective_id'),
123 'completion_status' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'completion_status'),
124 'description' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'description'),
125 'id' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'id'),
126 'max' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'c_max'),
127 'min' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'c_min'),
128 'raw' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'c_raw'),
129 'scaled' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'scaled'),
130 'progress_measure' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'progress_measure'),
131 'success_status' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'success_status'),
132 'scope' => array(
'pattern' =>
null,
'permission' => self::READWRITE,
'default' =>
null,
'dbfield' =>
'scope'),
151 $this->
ctrl = $DIC->ctrl();
152 $this->userId = $DIC->user()->getId();
153 $this->
lng = $DIC->language();
156 $this->jsMode = strpos(
$_SERVER[
'HTTP_ACCEPT'],
'text/javascript') !==
false;
158 if ($DIC->http()->wrapper()->query()->has(
'page')) {
159 $this->page = $DIC->http()->wrapper()->query()->retrieve(
'page', $DIC->refinery()->kindlyTo()->string());
162 $this->ref_id = $DIC->http()->wrapper()->query()->retrieve(
'ref_id', $DIC->refinery()->kindlyTo()->int());
174 $ilAccess = $DIC->access();
175 $lng = $DIC->language();
178 $next_class = $this->
ctrl->getNextClass($this);
179 $cmd = $this->
ctrl->getCmd();
181 if (!$ilAccess->checkAccess(
"read",
"", $this->ref_id)) {
186 if ($DIC->http()->wrapper()->query()->has(
'node_id')) {
187 $nodeId = $DIC->http()->wrapper()->query()->retrieve(
'node_id', $DIC->refinery()->kindlyTo()->int());
218 case 'getGobjective':
222 case 'getSharedData':
226 case 'setSharedData':
232 if (
$_SERVER[
'REQUEST_METHOD'] ===
'POST') {
236 $this->slm->getDefaultLessonMode(),
237 $this->slm->getComments(),
238 $this->slm->getInteractions(),
239 $this->slm->getObjectives(),
240 $this->slm->getTime_from_lms(),
260 case 'liveLogContent':
273 case 'scormPlayerUnload':
288 $js_data = file_get_contents(
"../components/ILIAS/Scorm2004/scripts/buildrte/rte.js");
289 if (self::ENABLE_GZIP == 1) {
290 ob_start(
"ob_gzhandler");
292 header(
'Content-Type: text/javascript; charset=UTF-8');
299 $webdir = str_replace(
"/ilias.php",
"",
$_SERVER[
"SCRIPT_NAME"]);
301 $lm_dir = $webdir .
"/" .
ILIAS_WEB_DIR .
"/" .
CLIENT_ID .
"/lm_data" .
"/lm_" . (string) $this->packageId;
312 $ilUser = $DIC->user();
314 $initSuspendData =
null;
317 'learner_id' => (
string) $ilUser->getID(),
318 'cmi_learner_id' => (string) $this->slm->getApiStudentId(),
319 'course_id' => (string) $this->packageId,
320 'learner_name' => (
string) $this->slm->getApiStudentName(),
321 'mode' => $this->slm->getDefaultLessonMode(),
322 'credit' => $this->slm->getCreditMode(),
323 'auto_review' => $this->slm->getAutoReviewChar(),
324 'hide_navig' => $this->slm->getHideNavig(),
325 'hide_menu' => $this->slm->getNoMenu(),
326 'ie_force_render' => $this->slm->getIe_force_render(),
327 'fourth_edition' => $this->slm->getFourth_edition(),
328 'sequencing_enabled' => $this->slm->getSequencing(),
329 'interactions_storable' => $this->slm->getInteractions(),
330 'objectives_storable' => $this->slm->getObjectives(),
331 'comments_storable' => $this->slm->getComments(),
332 'time_from_lms' => $this->slm->getTime_from_lms(),
333 'auto_last_visited' => $this->slm->getAuto_last_visited(),
334 'lesson_mastery_score' => $this->slm->getMasteryScore(),
335 'checkSetValues' => $this->slm->getCheck_values(),
336 'auto_suspend' => $this->slm->getAutoSuspend(),
337 'suspend_data' => $initSuspendData,
340 'adlact_data' =>
null,
341 'globalobj_data' =>
null 357 $lng = $DIC->language();
363 $initSuspendData =
null;
364 $initAdlactData =
null;
365 $initGlobalobjData =
null;
366 if ($this->slm->getSequencing() ==
true) {
375 if ($this->slm->getSession()) {
378 if ($session_timeout > $max_idle) {
379 $session_timeout = $max_idle;
382 if ($session_timeout > $min_idle) {
383 $session_timeout = $min_idle;
385 $session_timeout -= 10;
387 $session_timeout = 0;
389 $config[
'session_ping'] = $session_timeout;
392 $store_url =
'ilias.php?baseClass=ilSAHSPresentationGUI' .
'&cmd=cmi&ref_id=' .
$this->ref_id;
393 $unload_url =
'ilias.php?baseClass=ilSAHSPresentationGUI' .
'&cmd=scormPlayerUnload&ref_id=' .
$this->ref_id;
394 if ($this->slm->getSessionDeactivated()) {
395 $store_url =
'storeScorm2004.php?package_id=' . $this->packageId .
'&ref_id=' . $this->ref_id .
'&client_id=' .
CLIENT_ID .
'&do=store';
396 $unload_url =
'storeScorm2004.php?package_id=' . $this->packageId .
'&ref_id=' . $this->ref_id .
'&client_id=' .
CLIENT_ID .
'&do=unload';
398 $config[
'cp_url'] =
'ilias.php?baseClass=ilSAHSPresentationGUI' .
'&cmd=cp&ref_id=' .
$this->ref_id;
399 $config[
'cmi_url'] =
'ilias.php?baseClass=ilSAHSPresentationGUI' .
'&cmd=cmi&ref_id=' .
$this->ref_id;
400 $config[
'store_url'] = $store_url;
401 $config[
'get_adldata_url'] =
'ilias.php?baseClass=ilSAHSPresentationGUI' .
'&cmd=getSharedData&ref_id=' .
$this->ref_id;
402 $config[
'set_adldata_url'] =
'ilias.php?baseClass=ilSAHSPresentationGUI' .
'&cmd=setSharedData&ref_id=' .
$this->ref_id;
403 $config[
'adlact_url'] =
'ilias.php?baseClass=ilSAHSPresentationGUI' .
'&cmd=adlact&ref_id=' .
$this->ref_id;
404 $config[
'specialpage_url'] =
'ilias.php?baseClass=ilSAHSPresentationGUI' .
'&cmd=specialPage&ref_id=' .
$this->ref_id;
405 $config[
'suspend_url'] =
'ilias.php?baseClass=ilSAHSPresentationGUI' .
'&cmd=suspend&ref_id=' .
$this->ref_id;
406 $config[
'get_suspend_url'] =
'ilias.php?baseClass=ilSAHSPresentationGUI' .
'&cmd=getSuspend&ref_id=' .
$this->ref_id;
408 $config[
'gobjective_url'] =
'ilias.php?baseClass=ilSAHSPresentationGUI' .
'&cmd=gobjective&ref_id=' .
$this->ref_id;
409 $config[
'get_gobjective_url'] =
'ilias.php?baseClass=ilSAHSPresentationGUI' .
'&cmd=getGobjective&ref_id=' .
$this->ref_id;
410 $config[
'ping_url'] =
'ilias.php?baseClass=ilSAHSPresentationGUI' .
'&cmd=pingSession&ref_id=' .
$this->ref_id;
411 $config[
'scorm_player_unload_url'] = $unload_url;
412 $config[
'post_log_url'] =
'ilias.php?baseClass=ilSAHSPresentationGUI' .
'&cmd=postLogEntry&ref_id=' .
$this->ref_id;
413 $config[
'livelog_url'] =
'ilias.php?baseClass=ilSAHSPresentationGUI' .
'&cmd=liveLogContent&ref_id=' .
$this->ref_id;
417 $config[
'envEditor'] = 0;
420 $config[
'debug'] = $this->slm->getDebug();
425 $langstrings[
'btnStart'] = $lng->
txt(
'scplayer_start');
426 $langstrings[
'btnExit'] = $lng->
txt(
'scplayer_exit');
427 $langstrings[
'btnExitAll'] = $lng->
txt(
'scplayer_exitall');
428 $langstrings[
'btnSuspendAll'] = $lng->
txt(
'scplayer_suspendall');
429 $langstrings[
'btnPrevious'] = $lng->
txt(
'scplayer_previous');
430 $langstrings[
'btnContinue'] = $lng->
txt(
'scplayer_continue');
431 $langstrings[
'btnhidetree'] = $lng->
txt(
'scplayer_hidetree');
432 $langstrings[
'btnshowtree'] = $lng->
txt(
'scplayer_showtree');
433 $langstrings[
'linkexpandTree'] = $lng->
txt(
'scplayer_expandtree');
434 $langstrings[
'linkcollapseTree'] = $lng->
txt(
'scplayer_collapsetree');
435 $langstrings[
'contCreditOff'] = $lng->
txt(
'cont_credit_off');
436 if ($this->slm->getAutoReviewChar() ===
"s") {
437 $langstrings[
'contCreditOff'] = $lng->
txt(
'cont_sc_score_was_higher_message');
439 $config[
'langstrings'] = $langstrings;
443 $this->tpl =
new ilGlobalTemplate(
"tpl.scorm2004.player.html",
true,
true,
"components/ILIAS/Scorm2004");
447 $rte_css = $this->slm->getDataDirectory() .
"/ilias_css_4_2/css/style.css";
448 if (is_file($rte_css)) {
449 $this->tpl->setCurrentBlock(
"rte_css");
450 $this->tpl->setVariable(
"RTE_CSS", $rte_css);
451 $this->tpl->parseCurrentBlock();
455 $this->tpl->setVariable(
'JSON_LANGSTRINGS', json_encode($langstrings));
459 $this->tpl->setVariable(
'TREE_JS',
"../components/ILIAS/Scorm2004/scripts/ilNestedList.js");
460 foreach ($langstrings as $key => $value) {
461 $this->tpl->setVariable($key, $value);
463 $this->tpl->setVariable(
'DOC_TITLE',
'ILIAS: ' . $this->slm->getTitle());
465 $this->tpl->setVariable(
'INIT_CP_DATA', json_encode(json_decode($this->
getCPDataInit())));
466 $this->tpl->setVariable(
'INIT_CMI_DATA', json_encode($this->
getCMIData($this->userId, $this->packageId)));
467 $this->tpl->setVariable(
'INIT_ADLACT_DATA', json_encode($initAdlactData));
468 $this->tpl->setVariable(
'INIT_GLOBALOBJ_DATA', json_encode($initGlobalobjData));
469 $this->tpl->setVariable(
'JS_DATA', json_encode($config));
470 list($tsfrac, $tsint) = explode(
' ', microtime());
471 $this->tpl->setVariable(
'TIMESTAMP', sprintf(
'%d%03d', $tsint, 1000 * (
float) $tsfrac));
472 $this->tpl->setVariable(
'BASE_DIR',
'../components/ILIAS/Scorm2004/');
473 $this->tpl->setVariable(
'TXT_COLLAPSE', $lng->
txt(
'scplayer_collapsetree'));
474 if ($this->slm->getDebug()) {
475 $this->tpl->setVariable(
'TXT_DEBUGGER', $lng->
txt(
'scplayer_debugger'));
476 $this->tpl->setVariable(
'DEBUG_URL',
"PopupCenter('ilias.php?baseClass=ilSAHSPresentationGUI&cmd=debugGUI&ref_id=" . $this->ref_id .
"','Debug',800,600);");
478 $this->tpl->setVariable(
'TXT_DEBUGGER',
'');
479 $this->tpl->setVariable(
'DEBUG_URL',
'');
483 $this->tpl->setVariable(
'INLINE_CSS', ilSCORM13PlayerGUI::getInlineCss());
486 if ($this->slm->getCacheDeactivated()) {
487 $this->tpl->setVariable(
'JS_SCRIPTS',
'ilias.php?baseClass=ilSAHSPresentationGUI' .
'&cmd=getRTEjs&ref_id=' . $this->ref_id);
489 $this->tpl->setVariable(
'JS_SCRIPTS',
'../components/ILIAS/Scorm2004/scripts/buildrte/rte-min.js');
493 if ($this->slm->getNoMenu() ===
true) {
494 $this->tpl->setVariable(
"VAL_DISPLAY",
"style=\"display:none;\"");
496 $this->tpl->setVariable(
"VAL_DISPLAY",
"");
513 $this->tpl->printToStdout(
"DEFAULT",
false);
518 $is_tpl =
new ilTemplate(
"tpl.scorm2004.inlinecss.html",
true,
true,
"components/ILIAS/Scorm2004");
527 return $is_tpl->get();
534 header(
'Content-Type: text/javascript; charset=UTF-8');
537 header(
'Content-Type: text/plain; charset=UTF-8');
538 $jsdata = json_decode($jsdata);
546 $ilDB = $DIC->database();
549 'SELECT jsdata FROM cp_package WHERE obj_id = %s',
551 array($this->packageId)
555 $jsdata = $packageData[
'jsdata'] ??
false;
567 $ilDB = $DIC->database();
570 'SELECT activitytree FROM cp_package WHERE obj_id = %s',
572 array($this->packageId)
576 $activitytree =
$data[
'activitytree'] ??
false;
578 if (!$activitytree) {
579 $activitytree =
'null';
581 return $activitytree;
588 header(
'Content-Type: text/javascript; charset=UTF-8');
589 print($activitytree);
591 header(
'Content-Type: text/plain; charset=UTF-8');
592 $activitytree = json_decode($activitytree);
593 print_r($activitytree);
601 header(
'Content-Type: text/plain; charset=UTF-8');
608 $ilDB = $DIC->database();
609 $ilUser = $DIC->user();
612 'SELECT global_to_system FROM cp_package WHERE obj_id = %s',
614 array($this->packageId)
618 $gystem =
$data[
'global_to_system'] ?? 1;
622 $gsystem = (string) $this->packageId;
631 $ilDB = $DIC->database();
632 $ilUser = $DIC->user();
635 'SELECT data FROM cp_suspend WHERE obj_id = %s AND user_id = %s',
636 array(
'integer',
'integer'),
637 array($this->packageId, $ilUser->getId())
643 'DELETE FROM cp_suspend WHERE obj_id = %s AND user_id = %s',
644 array(
'integer',
'integer'),
645 array($this->packageId, $ilUser->getId())
647 if (is_array(
$data)) {
648 return $data[
'data'];
657 header(
'Content-Type: text/javascript; charset=UTF-8');
658 print($suspend_data);
660 header(
'Content-Type: text/plain; charset=UTF-8');
661 $suspend_data = json_decode($suspend_data);
662 print_r($suspend_data);
669 $ilDB = $DIC->database();
670 $ilUser = $DIC->user();
673 'SELECT * FROM cp_suspend WHERE obj_id = %s AND user_id = %s',
674 array(
'integer',
'integer'),
675 array($this->packageId, $ilUser->getId())
679 $ilDB->insert(
'cp_suspend', array(
680 'data' => array(
'clob', file_get_contents(
'php://input')),
681 'obj_id' => array(
'integer', $this->packageId),
682 'user_id' => array(
'integer', $ilUser->getId())
688 'data' => array(
'clob', file_get_contents(
'php://input'))
691 'obj_id' => array(
'integer', $this->packageId),
692 'user_id' => array(
'integer', $ilUser->getId())
701 $ilDB = $DIC->database();
702 $ilUser = $DIC->user();
707 $global_to_system = 1;
710 'SELECT global_to_system FROM cp_package WHERE obj_id = %s',
712 array($this->packageId)
715 $global_to_system =
$data[
'global_to_system'];
718 $query =
'SELECT objective_id, scope_id, satisfied, measure, user_id, 719 score_min, score_max, score_raw, completion_status, 721 .
'FROM cmi_gobjective, cp_node, cp_mapinfo ' 722 .
'WHERE (cmi_gobjective.objective_id <> %s AND cmi_gobjective.status IS NULL ' 723 .
'AND cp_node.slm_id = %s AND cp_node.nodename = %s ' 724 .
'AND cp_node.cp_node_id = cp_mapinfo.cp_node_id ' 725 .
'AND cmi_gobjective.objective_id = cp_mapinfo.targetobjectiveid) ' 726 .
'GROUP BY objective_id, scope_id, satisfied, measure, user_id, 727 score_min, score_max, score_raw, completion_status, 731 array(
'text',
'integer',
'text'),
732 array(
'-course_overall_status-', $this->packageId,
'mapInfo')
735 if (($global_to_system == 1 && $row[
'scope_id'] == 0) || ($global_to_system == 0 && $row[
'scope_id'] ==
$this->packageId)) {
736 $learner = $row[
'user_id'];
737 $objective_id = $row[
'objective_id'];
738 if ($row[
'scope_id'] == 0) {
741 $scope = $row[
'scope_id'];
744 if ($row[
'satisfied'] !=
null) {
745 $toset = $row[
'satisfied'];
746 $g_data[
"satisfied"][$objective_id][$learner][
$scope] = $toset;
749 if ($row[
'measure'] !=
null) {
750 $toset = $row[
'measure'];
751 $g_data[
"measure"][$objective_id][$learner][
$scope] = $toset;
754 if ($row[
'score_raw'] !=
null) {
755 $toset = $row[
'score_raw'];
756 $g_data[
"score_raw"][$objective_id][$learner][
$scope] = $toset;
759 if ($row[
'score_min'] !=
null) {
760 $toset = $row[
'score_min'];
761 $g_data[
"score_min"][$objective_id][$learner][
$scope] = $toset;
764 if ($row[
'score_max'] !=
null) {
765 $toset = $row[
'score_max'];
766 $g_data[
"score_max"][$objective_id][$learner][
$scope] = $toset;
769 if ($row[
'progress_measure'] !=
null) {
770 $toset = $row[
'progress_measure'];
771 $g_data[
"progress_measure"][$objective_id][$learner][
$scope] = $toset;
774 if ($row[
'completion_status'] !=
null) {
775 $toset = $row[
'completion_status'];
776 $g_data[
"completion_status"][$objective_id][$learner][
$scope] = $toset;
787 header(
'Content-Type: text/javascript; charset=UTF-8');
788 print($gobjective_data);
790 header(
'Content-Type: text/plain; charset=UTF-8');
791 $gobjective_data = json_decode($gobjective_data);
792 print_r($gobjective_data);
801 $ilDB = $DIC->database();
802 $ilUser = $DIC->user();
803 $dataStores = array(
"data" => array(),
804 "permissions" => array());
805 $readPermissions = array();
807 $query =
'SELECT target_id, read_shared_data, write_shared_data ' 809 .
'WHERE slm_id = %s ' 810 .
'AND sco_node_id = %s ' 811 .
'GROUP BY target_id, read_shared_data, write_shared_data';
816 array(
'integer',
'integer'),
817 array($this->packageId, $sco_node_id)
823 $storeVal = ($row[
'read_shared_data'] == 0 && $row[
'write_shared_data'] == 1)
827 $dataStores[
"data"][$row[
'target_id']] = array(
"store" => $storeVal,
828 "readSharedData" => $row[
'read_shared_data'],
829 "writeSharedData" => $row[
'write_shared_data']);
830 $dataStores[
"readPermissions"][$row[
'target_id']] = $row[
'read_shared_data'];
833 if (count($dataStores) < 1) {
839 if ($dataStores[
"readPermissions"] !=
null && array_sum($dataStores[
"readPermissions"]) != 0) {
844 $params = array(
"types" => array(
"integer",
"integer"),
845 "values" => array($this->userId, $this->packageId));
851 foreach ($dataStores[
"data"] as $key => $val) {
852 if ($dataStores[
"readPermissions"][(
string) $key] == 1
853 && $dataStores[
"data"][(
string) $key][
"store"] !==
'notWritten') {
856 $paramTemplate .=
'%s, ';
861 $paramTemplate = substr($paramTemplate, 0, -2);
864 $query =
'SELECT target_id, store ' 865 .
'FROM adl_shared_data ' 866 .
'WHERE user_id = %s ' 868 .
'AND target_id IN (' . $paramTemplate .
')';
878 $dataStores[
"data"][$row[
'target_id']][
"store"] = $row[
'store'];
882 header(
'Content-Type: text/javascript; charset=UTF-8');
884 echo json_encode($dataStores[
"data"]);
890 $ilDB = $DIC->database();
891 $ilUser = $DIC->user();
892 $g_data = json_decode(file_get_contents(
'php://input'));
894 if ($g_data ==
null)
return;
897 $query =
'SELECT dm.target_id, sd.store ' 898 .
'FROM cp_datamap dm ' 899 .
'LEFT JOIN adl_shared_data sd ' 900 .
'ON(dm.slm_id = sd.slm_id AND dm.target_id = sd.target_id) ' 901 .
'WHERE sco_node_id = %s ' 902 .
'AND dm.slm_id = %s ' 903 .
'AND write_shared_data = 1 ' 904 .
'AND user_id = %s';
908 array(
'integer',
'integer',
'integer'),
909 array($sco_node_id, $this->packageId, $this->userId)
912 $dataStores = array();
913 $originalVals = array();
915 $id = $row[
'target_id'];
916 $dataStores[
$id] = $g_data->{
$id};
917 $originalVals[
$id] = $row[
'store'];
922 foreach ($g_data as $key => $obj) {
925 if (array_key_exists($key, $dataStores)) {
926 if ($obj ===
'notWritten') {
930 $query =
'UPDATE adl_shared_data ' 932 .
'WHERE user_id = %s ' 933 .
'AND target_id = %s ' 934 .
'AND slm_id = %s ';
938 array(
'text',
'integer',
'text',
'integer'),
939 array($dataStores[$key], $this->userId, $key, $this->packageId)
944 'SELECT write_shared_data, cp_node_id ' 946 .
'WHERE target_id = %s ' 948 .
'AND sco_node_id = %s',
949 array(
'text',
'integer',
'integer'),
950 array($key, $this->packageId, $sco_node_id)
954 if ($row[
"write_shared_data"] != 1) {
960 'INSERT INTO adl_shared_data (slm_id, user_id, target_id, store, cp_node_id) VALUES (%s, %s, %s, %s, %s)',
961 array(
'integer',
'integer',
'text',
'text',
'integer'),
962 array($this->packageId, $this->userId, $key, $obj, $row[
"cp_node_id"])
973 $lng = $DIC->language();
975 $specialpages = array(
976 "_COURSECOMPLETE_" =>
"seq_coursecomplete",
977 "_ENDSESSION_" =>
"seq_endsession",
978 "_SEQBLOCKED_" =>
"seq_blocked",
979 "_NOTHING_" =>
"seq_nothing",
980 "_ERROR_" =>
"seq_error",
981 "_DEADLOCK_" =>
"seq_deadlock",
982 "_INVALIDNAVREQ_" =>
"seq_invalidnavreq",
983 "_SEQABANDON_" =>
"seq_abandon",
984 "_SEQABANDONALL_" =>
"seq_abandonall",
985 "_TOC_" =>
"seq_toc",
989 $this->tpl =
new ilGlobalTemplate(
"tpl.scorm2004.specialpages.html",
false,
false,
"components/ILIAS/Scorm2004");
991 $this->tpl->setVariable(
'TXT_SPECIALPAGE',
$lng->
txt($specialpages[$this->page]));
992 if ($this->page !==
"_TOC_" && $this->page !==
"_SEQABANDON_" && $this->page !==
"_SEQABANDONALL_") {
993 $this->tpl->setVariable(
'CLOSE_WINDOW',
$lng->
txt(
'seq_close'));
995 $this->tpl->setVariable(
'CLOSE_WINDOW',
"");
997 $this->tpl->printToStdout(
"DEFAULT",
false);
1004 if ($this->jsMode) {
1005 header(
'Content-Type: text/javascript; charset=UTF-8');
1006 print(json_encode(
$data));
1008 header(
'Content-Type: text/plain; charset=UTF-8');
1009 print(var_export(
$data,
true));
1035 $ilDB = $DIC->database();
1039 'schema' => array(),
1043 foreach (self::$schema as $k => &$v) {
1044 $result[
'schema'][$k] = array_keys($v);
1048 $q =
'SELECT cmi_node.* 1050 INNER JOIN cp_node ON cmi_node.cp_node_id = cp_node.cp_node_id 1051 WHERE cmi_node.user_id = %s 1052 AND cp_node.slm_id = %s';
1059 if ($this->slm->getComments()) {
1061 cmi_comment.cmi_comment_id, 1062 cmi_comment.cmi_node_id, 1063 cmi_comment.c_comment, 1064 cmi_comment.c_timestamp, 1065 cmi_comment.location, 1066 cmi_comment.sourceislms 1068 INNER JOIN cmi_node ON cmi_node.cmi_node_id = cmi_comment.cmi_node_id 1069 INNER JOIN cp_node ON cp_node.cp_node_id = cmi_node.cp_node_id 1070 WHERE cmi_node.user_id = %s 1071 AND cp_node.slm_id = %s 1072 ORDER BY cmi_comment.cmi_comment_id';
1078 case "correct_response":
1081 if ($this->slm->getInteractions()) {
1082 $q =
'SELECT cmi_correct_response.* 1083 FROM cmi_correct_response 1084 INNER JOIN cmi_interaction 1085 ON cmi_interaction.cmi_interaction_id = cmi_correct_response.cmi_interaction_id 1086 INNER JOIN cmi_node ON cmi_node.cmi_node_id = cmi_interaction.cmi_node_id 1087 INNER JOIN cp_node ON cp_node.cp_node_id = cmi_node.cp_node_id 1088 WHERE cmi_node.user_id = %s 1089 AND cp_node.slm_id = %s 1090 ORDER BY cmi_correct_response.cmi_correct_resp_id';
1098 if ($this->slm->getInteractions()) {
1100 cmi_interaction.cmi_interaction_id, 1101 cmi_interaction.cmi_node_id, 1102 cmi_interaction.description, 1104 cmi_interaction.latency, 1105 cmi_interaction.learner_response, 1106 cmi_interaction.result, 1107 cmi_interaction.c_timestamp, 1108 cmi_interaction.c_type, 1109 cmi_interaction.weighting 1110 FROM cmi_interaction 1111 INNER JOIN cmi_node ON cmi_node.cmi_node_id = cmi_interaction.cmi_node_id 1112 INNER JOIN cp_node ON cp_node.cp_node_id = cmi_node.cp_node_id 1113 WHERE cmi_node.user_id = %s 1114 AND cp_node.slm_id = %s 1115 ORDER BY cmi_interaction.cmi_interaction_id';
1122 if ($this->slm->getObjectives()) {
1124 cmi_objective.cmi_interaction_id, 1125 cmi_objective.cmi_node_id, 1126 cmi_objective.cmi_objective_id, 1127 cmi_objective.completion_status, 1128 cmi_objective.description, 1130 cmi_objective.c_max, 1131 cmi_objective.c_min, 1132 cmi_objective.c_raw, 1133 cmi_objective.scaled, 1134 cmi_objective.progress_measure, 1135 cmi_objective.success_status, 1138 INNER JOIN cmi_node ON cmi_node.cmi_node_id = cmi_objective.cmi_node_id 1139 INNER JOIN cp_node ON cp_node.cp_node_id = cmi_node.cp_node_id 1140 WHERE cmi_node.user_id = %s 1141 AND cp_node.slm_id = %s 1142 ORDER BY cmi_objective.cmi_objective_id';
1148 $q =
'SELECT usr_data.usr_id user_id, 1149 CONCAT(CONCAT(COALESCE(usr_data.firstname, \'\'), \' \'), COALESCE(usr_data.lastname, \'\')) learner_name, 1150 sahs_lm.id slm_id , sahs_lm.default_lesson_mode "mode", sahs_lm.credit 1151 FROM usr_data, cp_package 1152 INNER JOIN sahs_lm ON cp_package.obj_id = sahs_lm.id 1153 WHERE usr_data.usr_id = %s 1154 AND sahs_lm.id = %s';
1159 $result[
'data'][$k] = array();
1161 $types = array(
'integer',
'integer');
1162 $values = array($userId, $packageId);
1165 while ($row =
$ilDB->fetchAssoc(
$res)) {
1166 $tmp_result = array();
1167 foreach ($row as $key => $value) {
1168 if ($k ===
"comment" && $key ===
"c_timestamp" && strpos($value,
' ') == 10) {
1169 $value = str_replace(
' ',
'T', $value);
1171 $tmp_result[] = $value;
1172 if ($k ===
"node" && $key ===
"additional_tables" && $i_check < $value) {
1177 $result[
'data'][$k][] = $tmp_result;
1190 $ilDB = $DIC->database();
1192 if (!is_array($a_array) or !count($a_array)) {
1196 foreach ($a_array as $k => $item) {
1197 if ($item !=
null) {
1198 $a_array[$k] =
$ilDB->quote($item);
1200 $a_array[$k] =
"NULL";
1233 $ilDB = $DIC->database();
1236 'SELECT module_version FROM sahs_lm WHERE id = %s',
1238 array($this->packageId)
1242 return (
int) $row[
'module_version'];
1251 $ilDB = $DIC->database();
1252 $ilUser = $DIC->user();
1253 $val_set =
$ilDB->queryF(
1254 'SELECT package_attempts FROM sahs_user WHERE obj_id = %s AND user_id = %s',
1255 array(
'integer',
'integer'),
1256 array($this->packageId,$this->userId)
1258 $val_rec =
$ilDB->fetchAssoc($val_set);
1259 $attempts = $val_rec[
"package_attempts"];
1260 if ($attempts ==
null) {
1263 return (
int) $attempts;
1272 $ilDB = $DIC->database();
1273 $ilUser = $DIC->user();
1275 'SELECT package_attempts,count(*) cnt FROM sahs_user WHERE obj_id = %s AND user_id = %s GROUP BY package_attempts',
1276 array(
'integer',
'integer'),
1277 array($this->slm->getId(),$ilUser->getId())
1280 if ($val_rec[
"cnt"] == 0) {
1283 'INSERT INTO sahs_user (obj_id,user_id,package_attempts,module_version,last_access) VALUES(%s,%s,%s,%s,%s)',
1284 array(
'integer',
'integer',
'integer',
'integer',
'timestamp'),
1285 array($this->slm->getId(), $ilUser->getId(), $attempts, $this->slm->getModuleVersion(), date(
'Y-m-d H:i:s'))
1288 $attempts = $val_rec[
"package_attempts"];
1289 if ($attempts ==
null) {
1294 'UPDATE sahs_user SET package_attempts = %s, module_version = %s, last_access=%s WHERE obj_id = %s AND user_id = %s ',
1295 array(
'integer',
'integer',
'timestamp',
'integer',
'integer'),
1296 array($attempts, $this->slm->getModuleVersion(), date(
'Y-m-d H:i:s'), $this->slm->getId(), $ilUser->getId())
1304 $ilDB = $DIC->database();
1307 'SELECT shared_data_global_to_system FROM cp_package WHERE obj_id = %s',
1309 array($this->packageId)
1312 $shared_global_to_sys =
$ilDB->fetchObject(
$res)->shared_data_global_to_system ?? 0;
1315 'SELECT data FROM cp_suspend WHERE obj_id = %s AND user_id = %s',
1316 array(
'integer',
'integer'),
1317 array($this->packageId, $this->userId)
1322 $dat =
$data[
'data'];
1323 if ($dat !=
null && $dat !=
'') {
1328 if ($shared_global_to_sys == 0 && !$suspended) {
1330 'DELETE FROM adl_shared_data WHERE slm_id = %s AND user_id = %s',
1331 array(
'integer',
'integer'),
1332 array($this->packageId, $this->userId)
1344 $ilDB = $DIC->database();
1347 $fieldList =
"cmi_node.cp_node_id, cmi_node.completion_threshold, cmi_node.c_exit, cmi_node.completion_status, cmi_node.progress_measure, cmi_node.success_status, cmi_node.scaled, cmi_node.session_time," .
1348 "cmi_node.c_min, cmi_node.c_max, cmi_node.c_raw, cmi_node.location, cmi_node.suspend_data, cmi_node.scaled_passing_score, cmi_node.total_time";
1353 SELECT ' . $fieldList .
' 1354 FROM cmi_node,cp_node,cp_item 1355 WHERE cp_node.slm_id = %s 1356 AND cp_node.cp_node_id = cp_item.cp_node_id 1358 AND cmi_node.cp_node_id = cp_item.cp_node_id 1359 AND cmi_node.user_id = %s',
1360 array(
'integer',
'text',
'integer'),
1361 array($this->packageId, $sco_id, $this->userId)
1372 $fHandle = fopen(
$filename,
'a') or die(
"can't open file");
1373 fwrite($fHandle,
"");
1385 while (file_exists(
$filename .
"_" . $adder . $suffix)) {
1387 $adder = (string) $i;
1389 $retname =
$filename .
"_" . $adder . $suffix;
1391 if (!file_exists($retname)) {
1393 $fHandle = fopen($retname,
'a') or die(
"can't open file");
1394 fwrite($fHandle,
"");
1403 $lng = $DIC->language();
1409 if (!file_exists($path_csv)) {
1411 $fHandle = fopen($path_csv,
'a') or die(
"can't open file");
1412 $string =
'"CourseId";"ScoId";"ScoTitle";"Timestamp";"Action";"Key";"Value";"Return Value";"Errorcode";"Timespan";"ErrorDescription"' .
"\n";
1413 fwrite($fHandle, $string);
1416 if (!file_exists($path_txt)) {
1421 $fHandle2 = fopen($path_txt,
'a') or die(
"can't open file");
1423 $logtpl->setCurrentBlock(
'NewLog');
1424 $logtpl->setVariable(
"COURSETITLE", $this->slm->getTitle());
1425 $logtpl->setVariable(
"COURSEID", $this->packageId);
1426 $logtpl->setVariable(
"TIMESTAMP", date(
"d.m.Y H:i", time()));
1428 $logtpl->setVariable(
"error0",
$lng->
txt(
"error0"));
1429 $logtpl->setVariable(
"error101",
$lng->
txt(
"error101"));
1430 $logtpl->setVariable(
"error102",
$lng->
txt(
"error102"));
1431 $logtpl->setVariable(
"error103",
$lng->
txt(
"error103"));
1432 $logtpl->setVariable(
"error104",
$lng->
txt(
"error104"));
1433 $logtpl->setVariable(
"error111",
$lng->
txt(
"error111"));
1434 $logtpl->setVariable(
"error112",
$lng->
txt(
"error112"));
1435 $logtpl->setVariable(
"error113",
$lng->
txt(
"error113"));
1436 $logtpl->setVariable(
"error122",
$lng->
txt(
"error122"));
1437 $logtpl->setVariable(
"error123",
$lng->
txt(
"error123"));
1438 $logtpl->setVariable(
"error132",
$lng->
txt(
"error132"));
1439 $logtpl->setVariable(
"error133",
$lng->
txt(
"error133"));
1440 $logtpl->setVariable(
"error142",
$lng->
txt(
"error142"));
1441 $logtpl->setVariable(
"error143",
$lng->
txt(
"error143"));
1442 $logtpl->setVariable(
"error201",
$lng->
txt(
"error201"));
1443 $logtpl->setVariable(
"error301",
$lng->
txt(
"error301"));
1444 $logtpl->setVariable(
"error351",
$lng->
txt(
"error351"));
1445 $logtpl->setVariable(
"error391",
$lng->
txt(
"error391"));
1446 $logtpl->setVariable(
"error401",
$lng->
txt(
"error401"));
1447 $logtpl->setVariable(
"error402",
$lng->
txt(
"error402"));
1448 $logtpl->setVariable(
"error403",
$lng->
txt(
"error403"));
1449 $logtpl->setVariable(
"error404",
$lng->
txt(
"error404"));
1450 $logtpl->setVariable(
"error405",
$lng->
txt(
"error405"));
1451 $logtpl->setVariable(
"error406",
$lng->
txt(
"error406"));
1452 $logtpl->setVariable(
"error407",
$lng->
txt(
"error407"));
1453 $logtpl->setVariable(
"error408",
$lng->
txt(
"error408"));
1454 $logtpl->setVariable(
"SetValue",
$lng->
txt(
"SetValue"));
1455 $logtpl->setVariable(
"GetValue",
$lng->
txt(
"GetValue"));
1456 $logtpl->setVariable(
"Commit",
$lng->
txt(
"Commit"));
1457 $logtpl->setVariable(
"Initialize",
$lng->
txt(
"Initialize"));
1458 $logtpl->setVariable(
"Terminate",
$lng->
txt(
"Terminate"));
1459 $logtpl->setVariable(
"GetErrorString",
$lng->
txt(
"GetErrorString"));
1460 $logtpl->setVariable(
"GetLastError",
$lng->
txt(
"GetLastError"));
1461 $logtpl->setVariable(
"GetDiagnostic",
$lng->
txt(
"GetDiagnostic"));
1462 $logtpl->setVariable(
"cmi._version",
$lng->
txt(
"cmi._version"));
1463 $logtpl->setVariable(
"cmi.comments_from_learner._children",
$lng->
txt(
"cmi.comments_from_learner._children"));
1464 $logtpl->setVariable(
"cmi.comments_from_learner._count",
$lng->
txt(
"cmi.comments_from_learner._count"));
1465 $logtpl->setVariable(
"cmi.comments_from_learner.n.comment",
$lng->
txt(
"cmi.comments_from_learner.n.comment"));
1466 $logtpl->setVariable(
"cmi.comments_from_learner.n.location",
$lng->
txt(
"cmi.comments_from_learner.n.location"));
1467 $logtpl->setVariable(
"cmi.comments_from_learner.n.timestamp",
$lng->
txt(
"cmi.comments_from_learner.n.timestamp"));
1468 $logtpl->setVariable(
"cmi.comments_from_lms._children",
$lng->
txt(
"cmi.comments_from_lms._children"));
1469 $logtpl->setVariable(
"cmi.comments_from_lms._count",
$lng->
txt(
"cmi.comments_from_lms._count"));
1470 $logtpl->setVariable(
"cmi.comments_from_lms.n.comment",
$lng->
txt(
"cmi.comments_from_lms.n.comment"));
1471 $logtpl->setVariable(
"cmi.comments_from_lms.n.location",
$lng->
txt(
"cmi.comments_from_lms.n.location"));
1472 $logtpl->setVariable(
"cmi.comments_from_lms.n.timestamp",
$lng->
txt(
"cmi.comments_from_lms.n.timestamp"));
1473 $logtpl->setVariable(
"cmi.completion_status",
$lng->
txt(
"cmi.completion_status"));
1474 $logtpl->setVariable(
"cmi.completion_threshold",
$lng->
txt(
"cmi.completion_threshold"));
1475 $logtpl->setVariable(
"cmi.credit",
$lng->
txt(
"cmi.credit"));
1476 $logtpl->setVariable(
"cmi.entry",
$lng->
txt(
"cmi.entry"));
1477 $logtpl->setVariable(
"cmi.exit",
$lng->
txt(
"cmi.exit"));
1478 $logtpl->setVariable(
"cmi.interactions._children",
$lng->
txt(
"cmi.interactions._children"));
1479 $logtpl->setVariable(
"cmi.interactions._count",
$lng->
txt(
"cmi.interactions._count"));
1480 $logtpl->setVariable(
"cmi.interactions.n.id",
$lng->
txt(
"cmi.interactions.n.id"));
1481 $logtpl->setVariable(
"cmi.interactions.n.type",
$lng->
txt(
"cmi.interactions.n.type"));
1482 $logtpl->setVariable(
"cmi.interactions.n.objectives._count",
$lng->
txt(
"cmi.interactions.n.objectives._count"));
1483 $logtpl->setVariable(
"cmi.interactions.n.objectives.n.id",
$lng->
txt(
"cmi.interactions.n.objectives.n.id"));
1484 $logtpl->setVariable(
"cmi.interactions.n.timestamp",
$lng->
txt(
"cmi.interactions.n.timestamp"));
1485 $logtpl->setVariable(
"cmi.interactions.n.correct_responses._count",
$lng->
txt(
"cmi.interactions.n.correct_responses._count"));
1486 $logtpl->setVariable(
"cmi.interactions.n.correct_responses.n.pattern",
$lng->
txt(
"cmi.interactions.n.correct_responses.n.pattern"));
1487 $logtpl->setVariable(
"cmi.interactions.n.weighting",
$lng->
txt(
"cmi.interactions.n.weighting"));
1488 $logtpl->setVariable(
"cmi.interactions.n.learner_response",
$lng->
txt(
"cmi.interactions.n.learner_response"));
1489 $logtpl->setVariable(
"cmi.interactions.n.result",
$lng->
txt(
"cmi.interactions.n.result"));
1490 $logtpl->setVariable(
"cmi.interactions.n.latency",
$lng->
txt(
"cmi.interactions.n.latency"));
1491 $logtpl->setVariable(
"cmi.interactions.n.description",
$lng->
txt(
"cmi.interactions.n.description"));
1492 $logtpl->setVariable(
"cmi.launch_data",
$lng->
txt(
"cmi.launch_data"));
1493 $logtpl->setVariable(
"cmi.learner_id",
$lng->
txt(
"cmi.learner_id"));
1494 $logtpl->setVariable(
"cmi.learner_name",
$lng->
txt(
"cmi.learner_name"));
1495 $logtpl->setVariable(
"cmi.learner_preference._children",
$lng->
txt(
"cmi.learner_preference._children"));
1496 $logtpl->setVariable(
"cmi.learner_preference.audio_level",
$lng->
txt(
"cmi.learner_preference.audio_level"));
1497 $logtpl->setVariable(
"cmi.learner_preference.language",
$lng->
txt(
"cmi.learner_preference.language"));
1498 $logtpl->setVariable(
"cmi.learner_preference.delivery_speed",
$lng->
txt(
"cmi.learner_preference.delivery_speed"));
1499 $logtpl->setVariable(
"cmi.learner_preference.audio_captioning",
$lng->
txt(
"cmi.learner_preference.audio_captioning"));
1500 $logtpl->setVariable(
"cmi.location",
$lng->
txt(
"cmi.location"));
1501 $logtpl->setVariable(
"cmi.max_time_allowed",
$lng->
txt(
"cmi.max_time_allowed"));
1502 $logtpl->setVariable(
"cmi.mode",
$lng->
txt(
"cmi.mode"));
1503 $logtpl->setVariable(
"cmi.objectives._children",
$lng->
txt(
"cmi.objectives._children"));
1504 $logtpl->setVariable(
"cmi.objectives._count",
$lng->
txt(
"cmi.objectives._count"));
1505 $logtpl->setVariable(
"cmi.objectives.n.id",
$lng->
txt(
"cmi.objectives.n.id"));
1506 $logtpl->setVariable(
"cmi.objectives.n.score._children",
$lng->
txt(
"cmi.objectives.n.score._children"));
1507 $logtpl->setVariable(
"cmi.objectives.n.score.scaled",
$lng->
txt(
"cmi.objectives.n.score.scaled"));
1508 $logtpl->setVariable(
"cmi.objectives.n.score.raw",
$lng->
txt(
"cmi.objectives.n.score.raw"));
1509 $logtpl->setVariable(
"cmi.objectives.n.score.min",
$lng->
txt(
"cmi.objectives.n.score.min"));
1510 $logtpl->setVariable(
"cmi.objectives.n.score.max",
$lng->
txt(
"cmi.objectives.n.score.max"));
1511 $logtpl->setVariable(
"cmi.objectives.n.success_status",
$lng->
txt(
"cmi.objectives.n.success_status"));
1512 $logtpl->setVariable(
"cmi.objectives.n.completion_status",
$lng->
txt(
"cmi.objectives.n.completion_status"));
1513 $logtpl->setVariable(
"cmi.objectives.n.progress_measure",
$lng->
txt(
"cmi.objectives.n.progress_measure"));
1514 $logtpl->setVariable(
"cmi.objectives.n.description",
$lng->
txt(
"cmi.objectives.n.description"));
1515 $logtpl->setVariable(
"cmi.progress_measure",
$lng->
txt(
"cmi.progress_measure"));
1516 $logtpl->setVariable(
"cmi.scaled_passing_score",
$lng->
txt(
"cmi.scaled_passing_score"));
1517 $logtpl->setVariable(
"cmi.score._children",
$lng->
txt(
"cmi.score._children"));
1518 $logtpl->setVariable(
"cmi.score.scaled",
$lng->
txt(
"cmi.score.scaled"));
1519 $logtpl->setVariable(
"cmi.score.raw",
$lng->
txt(
"cmi.score.raw"));
1520 $logtpl->setVariable(
"cmi.score.min",
$lng->
txt(
"cmi.score.min"));
1521 $logtpl->setVariable(
"cmi.score.max",
$lng->
txt(
"cmi.score.max"));
1522 $logtpl->setVariable(
"cmi.session_time",
$lng->
txt(
"cmi.session_time"));
1523 $logtpl->setVariable(
"cmi.success_status",
$lng->
txt(
"cmi.success_status"));
1524 $logtpl->setVariable(
"cmi.suspend_data",
$lng->
txt(
"cmi.suspend_data"));
1525 $logtpl->setVariable(
"cmi.time_limit_action",
$lng->
txt(
"cmi.time_limit_action"));
1526 $logtpl->setVariable(
"cmi.total_time",
$lng->
txt(
"cmi.total_time"));
1527 $logtpl->setVariable(
"adl.nav.request",
$lng->
txt(
"adl.nav.request"));
1528 $logtpl->setVariable(
"adl.nav.request_valid.continue",
$lng->
txt(
"adl.nav.request_valid.continue"));
1529 $logtpl->setVariable(
"adl.nav.request_valid.previous",
$lng->
txt(
"adl.nav.request_valid.previous"));
1530 $logtpl->setVariable(
"adl.nav.request_valid.choice",
$lng->
txt(
"adl.nav.request_valid.choice"));
1531 $logtpl->setVariable(
"i_green",
$lng->
txt(
"i_green"));
1532 $logtpl->setVariable(
"i_red",
$lng->
txt(
"i_red"));
1533 $logtpl->setVariable(
"i_orange",
$lng->
txt(
"i_orange"));
1534 $logtpl->setVariable(
"i_fuchsia",
$lng->
txt(
"i_fuchsia"));
1535 $logtpl->setVariable(
"i_gray",
$lng->
txt(
"i_gray"));
1536 $logtpl->setVariable(
"error",
$lng->
txt(
"error"));
1537 $logtpl->setVariable(
"strange_error",
$lng->
txt(
"strange_error"));
1538 $logtpl->setVariable(
"strange_API-Call",
$lng->
txt(
"strange_API-Call"));
1539 $logtpl->setVariable(
"unknown",
$lng->
txt(
"unknown"));
1540 $logtpl->setVariable(
"undefined_color",
$lng->
txt(
"undefined_color"));
1541 $logtpl->setVariable(
"description_for",
$lng->
txt(
"description_for"));
1542 $logtpl->setVariable(
"hide",
$lng->
txt(
"hide"));
1543 $logtpl->setVariable(
"all_API-calls_shown",
$lng->
txt(
"all_API-calls_shown"));
1544 $logtpl->setVariable(
"show_only_important_API-calls",
$lng->
txt(
"show_only_important_API-calls"));
1545 $logtpl->setVariable(
"only_important_API-Calls_shown",
$lng->
txt(
"only_important_API-Calls_shown"));
1546 $logtpl->setVariable(
"show_all_API-calls",
$lng->
txt(
"show_all_API-calls"));
1547 $logtpl->setVariable(
"log_for",
$lng->
txt(
"log_for"));
1548 $logtpl->setVariable(
"started",
$lng->
txt(
"started"));
1549 $logtpl->setVariable(
"nr_session",
$lng->
txt(
"nr_session"));
1550 $logtpl->setVariable(
"id_learning_module",
$lng->
txt(
"id_learning_module"));
1551 if ($this->slm->getCheck_values() ==
false) {
1552 $logtpl->setVariable(
"CHECK_VALUES",
$lng->
txt(
"sent_values_not_checked"));
1554 $logtpl->parseCurrentBlock();
1555 fwrite($fHandle2, $logtpl->get());
1563 $webdir = str_replace(
"/ilias.php",
"",
$_SERVER[
"SCRIPT_NAME"]);
1573 $logDir = $this->slm->getDataDirectory() .
"/logs";
1574 if (!file_exists($logDir)) {
1586 header(
'Content-Type: text/html; charset=UTF-8');
1598 header(
"Cache-Control: private");
1599 header(
"Cache-Control: must-revalidate, post-check=0, pre-check=0");
1601 header(
"Content-Description: File Transfer");
1602 header(
"Content-Type: application/octet-stream");
1603 header(
"Content-disposition: attachment; filename=$filename");
1611 private function getLogFileList(
string $s_delete,
string $s_download,
string $s_open): array
1615 if ($fileInfo->isDot()) {
1618 $item[
'filename'] = $fileInfo->getFilename();
1619 $parts = pathinfo($item[
'filename']);
1620 $fnameparts = preg_split(
'/_/',
$parts[
'filename'], -1, PREG_SPLIT_NO_EMPTY);
1621 $deleteUrl =
' <a href=#' .
" onclick=\"javascript:deleteFile('" . $item[
'filename'] .
"');\">" . $s_delete .
"</a>";
1627 $urlDownload =
'ilias.php?baseClass=ilSAHSPresentationGUI' .
'&cmd=downloadLog&ref_id=' . $this->ref_id .
'&logFile=' . $fileInfo->getFilename();
1628 $urlOpen =
'ilias.php?baseClass=ilSAHSPresentationGUI' .
'&cmd=openLog&ref_id=' . $this->ref_id .
'&logFile=' . $fileInfo->getFilename();
1629 $item[
'date'] = date(
'Y/m/d H:i:s', $fileInfo->getCTime());
1630 if (
$parts[
'extension'] ===
"html") {
1631 $item[
'action'] = $deleteUrl .
" <a href=" . $urlDownload .
">" . $s_download .
"</a> <a target=_new href=" . $urlOpen .
">" . $s_open .
"</a>";
1633 $item[
'action'] = $deleteUrl .
" <a href=" . $urlDownload .
">" . $s_download .
"</a>";
1635 if (
$parts[
'extension'] ===
"html" ||
$parts[
'extension'] ===
"csv") {
1639 usort(
$data,
"datecmp");
1645 header(
'Content-Type: text/html; charset=UTF-8');
1646 print file_get_contents($this->
logFileName() .
".html");
1652 $lng = $DIC->language();
1665 $this->tpl =
new ilGlobalTemplate(
"tpl.scorm2004.debug.html",
false,
false,
"../components/ILIAS/Scorm2004");
1666 $this->tpl->setVariable(
'CONSOLE',
$lng->
txt(
"debugwindow_console"));
1667 $this->tpl->setVariable(
'LOGS',
$lng->
txt(
"debugwindow_logs"));
1668 $this->tpl->setVariable(
'COMMENT',
$lng->
txt(
"debugwindow_comment"));
1669 $this->tpl->setVariable(
'COMMENT_ENTER',
$lng->
txt(
"debugwindow_comment_enter"));
1670 $this->tpl->setVariable(
'START_RECORDING',
$lng->
txt(
"debugwindow_start_recording"));
1671 $this->tpl->setVariable(
'STOP_RECORDING',
$lng->
txt(
"debugwindow_stop_recording"));
1672 $this->tpl->setVariable(
'DELETE_LOGFILE',
$lng->
txt(
"debugwindow_delete_logfile"));
1673 $this->tpl->setVariable(
'SUBMISSION_FAILED',
$lng->
txt(
"debugwindow_submission_failed"));
1674 $this->tpl->setVariable(
'SUBMIT',
$lng->
txt(
"debugwindow_submit"));
1675 $this->tpl->setVariable(
'CANCEL',
$lng->
txt(
"debugwindow_cancel"));
1676 $this->tpl->setVariable(
'FILENAME',
$lng->
txt(
"debugwindow_filename"));
1677 $this->tpl->setVariable(
'DATE',
$lng->
txt(
"debugwindow_date"));
1678 $this->tpl->setVariable(
'ACTION',
$lng->
txt(
"debugwindow_action"));
1679 $this->tpl->setVariable(
'RECORD_IMG',
ilUtil::getImagePath(
"record.png",
"../components/ILIAS/Scorm2004"));
1680 $this->tpl->setVariable(
'STOP_IMG',
ilUtil::getImagePath(
"stop.png",
"../components/ILIAS/Scorm2004"));
1681 $this->tpl->setVariable(
'COMMENT_IMG',
ilUtil::getImagePath(
"comment.png",
"../components/ILIAS/Scorm2004"));
1683 $this->tpl->setVariable(
'LOGFILE', $this->
logFileName() .
".html");
1684 $this->tpl->setVariable(
'FILES_DATA', json_encode($this->
getLogFileList(
$lng->
txt(
"debugwindow_delete"),
$lng->
txt(
"debugwindow_download"),
$lng->
txt(
"debugwindow_open"))));
1687 echo $this->tpl->get(
"DEFAULT",
true);
1692 return new ilTemplate(
"tpl.scorm2004.debugtxt.txt",
true,
true,
"components/ILIAS/Scorm2004");
1701 $ilDB = $DIC->database();
1716 $debug_fields = parse_ini_file(
"../components/ILIAS/Scorm2004/scripts/rtemain/debug_default.ini",
true);
1719 $ini_array = $debug_fields[
'test_sco'];
1721 $ini_array = $debug_fields[
'normal_sco'];
1723 foreach ($ini_array as $key => $value) {
1735 $lng = $DIC->language();
1738 $logdata = json_decode(file_get_contents(
'php://input'));
1742 $fh_txt = fopen(
$filename .
".html",
'a') or die(
"can't open txt file");
1743 $fh_csv = fopen(
$filename .
".csv",
'a') or die(
"can't open csv file");
1744 $fh_tmp = fopen($tmp_name,
'r') or die(
"can't open tmp file");
1747 if (filesize($tmp_name) > 0) {
1748 $tmp_content = unserialize(fread($fh_tmp, filesize($tmp_name)));
1750 $tmp_content =
null;
1757 if ($logdata->action !=
"SUMMARY") {
1759 $fh_tmp2 = fopen($tmp_name,
'w') or die(
"can't open tmp file");
1762 $tmp_content[$logdata->scoid][$logdata->key][
'value'] = $logdata->value;
1763 $tmp_content[$logdata->scoid][$logdata->key][
'status'] = $logdata->result;
1764 $tmp_content[$logdata->scoid][$logdata->key][
'action'] = $logdata->action;
1766 fwrite($fh_tmp2, serialize($tmp_content));
1769 $errorcode = (
int) $logdata->errorcode;
1770 $fixedFailure =
false;
1771 $toleratedFailure =
false;
1772 $extraErrorDescription =
"";
1773 if ($errorcode == 200000) {
1775 $toleratedFailure =
true;
1776 $extraErrorDescription =
"tolerated failure";
1778 if ($errorcode > 99999) {
1779 $errorcode -= 100000;
1780 $fixedFailure =
true;
1781 $extraErrorDescription =
" failure corrected by ILIAS";
1783 if (strpos($logdata->action,
"ANALYZE") ===
false) {
1784 $errorDescriptions = array(
"0" =>
"",
1785 "101" =>
"General Exeption",
1786 "102" =>
"General Initialization Failure",
1787 "103" =>
"Already Initialized",
1788 "104" =>
"Content Instance Terminated",
1789 "111" =>
"General Termination Failure",
1790 "112" =>
"Termination Before Initialization",
1791 "113" =>
"Termination After Termination",
1792 "122" =>
"Retrieve Data Before Initialization",
1793 "123" =>
"Retrieve Data After Termination",
1794 "132" =>
"Store Data Before Initialization",
1795 "133" =>
"Store Data After Termination",
1796 "142" =>
"Commit Before Initialization",
1797 "143" =>
"Commit After Termination",
1798 "201" =>
"General Argument Error",
1799 "301" =>
"General Get Failure",
1800 "351" =>
"General Set Failure",
1801 "391" =>
"General Commit Failure",
1802 "401" =>
"Undefined Data Model Element",
1803 "402" =>
"Unimplemented Data Model Element",
1804 "403" =>
"Data Model Element Value Not Initialized",
1805 "404" =>
"Data Model Element Is Read Only",
1806 "405" =>
"Data Model Element Is Write Only",
1807 "406" =>
"Data Model Element Type Mismatch",
1808 "407" =>
"Data Model Element Value Out Of Range",
1809 "408" =>
"Data Model Dependency Not Established" 1811 $csv_string = $this->packageId .
';"' 1812 . $logdata->scoid .
'";"' 1813 . $logdata->scotitle .
'";' 1814 . date(
"d.m.Y H:i", time()) .
';"' 1815 . $logdata->action .
'";"' 1816 . $logdata->key .
'";"' 1817 . str_replace(
"\"",
"\"\"", $logdata->value) .
'";"' 1818 . str_replace(
"\"",
"\"\"", $logdata->result) .
'";' 1820 . $logdata->timespan .
';"' 1821 . $errorDescriptions[(string) $errorcode] . $extraErrorDescription .
'"' .
"\n";
1822 fwrite($fh_csv, $csv_string);
1827 if ($logdata->action ===
"Commit" || $logdata->action ===
"Terminate") {
1830 if (count($sql_data) != 0) {
1831 foreach ($sql_data as $key => $value) {
1832 $sql_string = $this->packageId .
';"' 1833 . $logdata->scoid .
'";"' 1834 . $logdata->scotitle .
'";' 1837 . str_replace(
"\"",
"\"\"", (
string) $value) .
'";;;;' .
"\n";
1838 fwrite($fh_csv, $sql_string);
1844 if ($logdata->action ===
"DELETE") {
1856 $ArGetValues = array(
'comments_from_lms',
'completion_threshold',
'credit',
'entry',
'launch_data',
'learner_id',
'learner_name',
'max_time_allowed',
'mode',
'scaled_passing_score',
'time_limit_action',
'total_time');
1858 switch ($logdata->action) {
1860 if ($logdata->result ===
"true" && $errorcode == 0) {
1863 if ($color ===
"green" && $logdata->key ===
"cmi.exit" && $logdata->value !==
"suspend") {
1866 if ($fixedFailure ==
false && $errorcode != 406) {
1867 $logdata->value =
'"' . $logdata->value .
'"';
1869 if ($toleratedFailure ==
true) {
1872 if ($fixedFailure ==
true) {
1877 if ($errorcode == 0) {
1882 if ($errorcode == 0) {
1884 $logtpl->setCurrentBlock(
"InitializeStart");
1885 $logtpl->setVariable(
"SCO-title",
$lng->
txt(
"SCO-title"));
1886 $logtpl->setVariable(
"SCO_TITLE", $logdata->scotitle);
1887 $logtpl->setVariable(
"SCO-name",
$lng->
txt(
"SCO-name"));
1888 $logtpl->setVariable(
"SCO_NAME", $logdata->scoid);
1889 $logtpl->setVariable(
"started",
$lng->
txt(
"started"));
1890 $logtpl->setVariable(
"TIMESTAMP",
$timestamp);
1891 $logtpl->setVariable(
"milliseconds",
$lng->
txt(
"milliseconds"));
1892 $logtpl->setVariable(
"API-call",
$lng->
txt(
"API-call"));
1893 $logtpl->setVariable(
"return_value",
$lng->
txt(
"return_value"));
1894 $logtpl->setVariable(
"error",
$lng->
txt(
"error"));
1895 $logtpl->parseCurrentBlock();
1899 if ($errorcode == 0) {
1902 if ($fixedFailure ==
true) {
1907 if ($errorcode == 0) {
1911 case 'GetErrorString':
1913 if ($errorcode == 0) {
1917 case 'GetLastError':
1918 $logtpl->setCurrentBlock(
"GetLastError");
1919 $logtpl->setVariable(
"TIMESPAN", $logdata->timespan);
1920 $logtpl->setVariable(
"RESULT", $logdata->result);
1921 $logtpl->parseCurrentBlock();
1923 case 'GetDiagnostic':
1924 $logtpl->setCurrentBlock(
"GetDiagnostic");
1925 $logtpl->setVariable(
"TIMESPAN", $logdata->timespan);
1926 $logtpl->setVariable(
"KEY", $logdata->key);
1927 $logtpl->setVariable(
"RESULT", $logdata->result);
1928 $logtpl->parseCurrentBlock();
1931 $logtpl->setCurrentBlock(
"INFO");
1932 $logtpl->setVariable(
"hint",
$lng->
txt(
"hint"));
1933 $logtpl->setVariable(
"KEY",
$lng->
txt($logdata->key));
1934 $logtpl->setVariable(
"VALUE", $logdata->value);
1935 $logtpl->parseCurrentBlock();
1938 $logtpl->setCurrentBlock(
"COMMENT");
1939 $logtpl->setVariable(
"comment",
$lng->
txt(
"comment"));
1940 $logtpl->setVariable(
"generated",
$lng->
txt(
"generated"));
1941 $logtpl->setVariable(
"TIMESTAMP",
$timestamp);
1942 $logtpl->setVariable(
"VALUE", $logdata->value);
1943 $logtpl->parseCurrentBlock();
1946 $logtpl->setCurrentBlock(
"ANALYZE");
1947 if (count($logdata->value) == 0) {
1949 $logtpl->setVariable(
"ANALYZE_SUMMARY",
$lng->
txt(
"no_missing_API-calls"));
1950 $logtpl->setVariable(
"VALUE",
"");
1952 $tmpvalue =
"SetValue(\"" . implode(
"\", ... ),<br/>SetValue(\"", $logdata->value) .
"\", ... )";
1953 foreach ($ArGetValues as $value) {
1954 $tmpvalue = str_replace(
"SetValue(\"cmi." . $value .
"\", ... )",
"GetValue(\"cmi." . $value .
"\")", $tmpvalue);
1956 $logtpl->setVariable(
"ANALYZE_SUMMARY",
$lng->
txt(
"missing_API-calls"));
1957 $logtpl->setVariable(
"VALUE", $tmpvalue);
1959 $logtpl->setVariable(
"summary_for_SCO_without_test",
$lng->
txt(
"summary_for_SCO_without_test"));
1960 $logtpl->setVariable(
"generated",
$lng->
txt(
"generated"));
1961 $logtpl->setVariable(
"TIMESTAMP",
$timestamp);
1962 $logtpl->setVariable(
"COLOR", $color);
1963 $logtpl->parseCurrentBlock();
1966 $logtpl->setCurrentBlock(
"ANALYZETEST");
1967 if (count($logdata->value) == 0) {
1969 $logtpl->setVariable(
"ANALYZE_SUMMARY",
$lng->
txt(
"no_missing_API-calls"));
1970 $logtpl->setVariable(
"VALUE",
"");
1972 $tmpvalue =
"SetValue(\"" . implode(
"\", ... ),<br/>SetValue(\"", $logdata->value) .
"\", ... )";
1973 foreach ($ArGetValues as $value) {
1974 $tmpvalue = str_replace(
"SetValue(\"cmi." . $value .
"\", ... )",
"GetValue(\"cmi." . $value .
"\")", $tmpvalue);
1976 $logtpl->setVariable(
"ANALYZE_SUMMARY",
$lng->
txt(
"missing_API-calls"));
1977 $logtpl->setVariable(
"VALUE", $tmpvalue);
1979 $logtpl->setVariable(
"summary_for_SCO_with_test",
$lng->
txt(
"summary_for_SCO_with_test"));
1980 $logtpl->setVariable(
"generated",
$lng->
txt(
"generated"));
1981 $logtpl->setVariable(
"TIMESTAMP",
$timestamp);
1982 $logtpl->setVariable(
"COLOR", $color);
1983 $logtpl->parseCurrentBlock();
1986 $logtpl->setCurrentBlock(
"SUMMARY");
1987 $logtpl->setVariable(
"summary_csv",
$lng->
txt(
"summary_csv"));
1988 $logtpl->setVariable(
"TIMESTAMP",
$timestamp);
1989 $logtpl->setVariable(
"summary_download",
$lng->
txt(
"summary_download"));
1990 $logtpl->parseCurrentBlock();
1997 if ($logdata->action ===
'SetValue' || $logdata->action ===
'GetValue') {
1998 $logtpl->setCurrentBlock($logdata->action);
1999 $logtpl->setVariable(
"ACTION", $logdata->action);
2000 $logtpl->setVariable(
"TIMESPAN", $logdata->timespan);
2001 $logtpl->setVariable(
"KEY", $logdata->key);
2002 $logtpl->setVariable(
"VALUE", $logdata->value);
2003 $logtpl->setVariable(
"RESULT", $logdata->result);
2004 $logtpl->setVariable(
"ERRORCODE", $errorcode);
2007 foreach ($debugfields as $value) {
2008 if ($logdata->key == $value) {
2012 $logtpl->setVariable(
"IMPORTANTKEY",
"" . $importantkey);
2013 $logtpl->setVariable(
"COLOR", $color);
2014 $logtpl->parseCurrentBlock();
2015 } elseif ($logdata->action !==
'INFO' && $logdata->action !==
'ANALYZE' && $logdata->action !==
'ANALYZETEST' && $logdata->action !==
'SUMMARY' && $logdata->action !==
'COMMENT' && $logdata->action !==
'GetDiagnostic' && $logdata->action !==
'GetLastError') {
2016 $logtpl->setCurrentBlock(
"defaultCall");
2017 $logtpl->setVariable(
"ACTION", $logdata->action);
2018 $logtpl->setVariable(
"TIMESPAN", $logdata->timespan);
2019 $logtpl->setVariable(
"KEY", $logdata->key);
2020 $logtpl->setVariable(
"VALUE", $logdata->value);
2021 $logtpl->setVariable(
"RESULT", $logdata->result);
2022 $logtpl->setVariable(
"ERRORCODE", $errorcode);
2023 $logtpl->setVariable(
"IMPORTANTKEY",
"" . $importantkey);
2024 $logtpl->setVariable(
"COLOR", $color);
2025 $logtpl->parseCurrentBlock();
2038 if ($logdata->action ===
"SUMMARY") {
2042 fwrite($fh_txt, $logtpl->get());
2049 foreach ($data as $i => $value) {
2051 $element[
'title'] = $value[
'title'];
2052 $element[
'id'] = $value[
'id'];
2053 if ($value[
'sco'] == 1) {
2054 $element[
'sco'] =
"sco";
2056 $element[
'sco'] =
"asset";
2058 if ($value[
'href'] !=
null) {
2059 $this->flat_structure[] = $element;
2061 if (isset($value[
'item']) && $value[
'item'] !=
null) {
2070 $ilDB = $DIC->database();
2074 $columns_fixed = array(
'id',
'title',
'type',
'attempted');
2076 $ini_data = parse_ini_file(
"./components/ILIAS/Scorm2004/scripts/rtemain/debug_default.ini",
true);
2077 $ini_array = $ini_data[
'summary'];
2078 $colums_variable = array();
2079 $api_keys = array();
2081 foreach ($ini_array as $key => $value) {
2083 $colums_variable[] = $key;
2085 $colums_variable[] =
"Status";
2089 $header_array = array_merge($columns_fixed, $colums_variable);
2091 $csv_header = implode(
";", $header_array);
2095 'SELECT jsdata FROM cp_package WHERE obj_id = %s',
2097 array($this->packageId)
2102 $structure = json_decode($packageData[
'jsdata'],
true);
2105 $this->flat_structure = array();
2109 foreach ($this->flat_structure as $tree_element) {
2110 $csv_data = $csv_data . $tree_element[
'id'] .
";" . $tree_element[
'title'] .
";" . $tree_element[
'sco'] .
";";
2111 if (isset($api_data[$tree_element[
'id']])) {
2112 $csv_data = $csv_data .
"X" .
";";
2114 $csv_data = $csv_data .
";";
2118 $id = $tree_element[
'id'];
2119 foreach ($api_keys as $api_element) {
2120 if (isset($api_data[
$id])) {
2121 if (isset($api_data[$id][$api_element])) {
2122 $csv_data = $csv_data . $api_data[
$id][$api_element][
'value'] .
";" . $api_data[
$id][$api_element][
'status'] .
";";
2124 $csv_data = $csv_data .
";;";
2128 $csv_data = $csv_data .
"\n";
2132 fwrite($fh, $csv_header .
"\n" . $csv_data);
2155 if (strtotime($a[
'date']) == strtotime($b[
'date'])) {
2158 return (strtotime($a[
'date']) < strtotime($b[
'date'])) ? 1 : -1;
static getStyleSheetLocation(string $mode="output", string $a_css_name="")
get full style sheet file name (path inclusive) of current user
static persistCMIData(int $packageId, int $refId, string $defaultLessonMode, bool $comments, bool $interactions, bool $objectives, bool $time_from_lms, ?string $data=null, ?int $userId=null)
static getCookieMaxLifetimeInSeconds()
static getLogger(string $a_component_id)
Get component logger.
txt(string $a_topic, string $a_default_lang_fallback_mod="")
gets the text for a given topic if the topic is not in the list, the topic itself with "-" will be re...
get_actual_attempts()
Get number of actual attempts for the user.
special template class to simplify handling of ITX/PEAR
get_Module_Version()
estimate content type for a filename by extension first do it for common static web files from extern...
if($clientAssertionType !='urn:ietf:params:oauth:client-assertion-type:jwt-bearer'|| $grantType !='client_credentials') $parts
static getLocalPath(string $a_name="")
Get local path of a YUI js file.
if(! $DIC->user() ->getId()||!ilLTIConsumerAccess::hasCustomProviderCreationAccess()) $params
readSharedData(int $sco_node_id)
static stripSlashes(string $a_str, bool $a_strip_html=true, string $a_allow="")
if(!file_exists('../ilias.ini.php'))
executeCommand()
execute command
static getIdleValue()
Returns the idle time in seconds.
writeSharedData(int $sco_node_id)
loadLanguageModule(string $a_module)
Load language module.
datecmp(array $a, array $b)
const DEFAULT_MIN_IDLE
default value for settings that have not been defined in setup or administration yet ...
getLogFileList(string $s_delete, string $s_download, string $s_open)
while($session_entry=$r->fetchRow(ilDBConstants::FETCHMODE_ASSOC)) return null
ilObjSCORM2004LearningModule $slm
static scormPlayerUnload(int $packageId, int $refId, bool $time_from_lms, ?int $userId=null)
quoteJSONArray(?array $a_array)
static signFolderOfStartFile(string $start_file_path)
increase_attemptAndsave_module_version()
Increases attempts by one and saves module_version for this package.
static getImagePath(string $image_name, string $module_path="", string $mode="output", bool $offline=false)
get image path (for images located in a template directory)
static _lookupObjectId(int $ref_id)
$structure
TOTAL STRUCTURE.
static getStatus(int $a_packageId, int $a_user_id, bool $auto_last_visited, string $scormType="1.2")
foreach($mandatory_scripts as $file) $timestamp
getCMIData(int $userId, int $packageId)
maps API data structure type to internal datatype on a node and accepts only valid values...
$id
plugin.php for ilComponentBuildPluginInfoObjectiveTest::testAddPlugins
createSummary(array $api_data)
Class ilObjSCORM2004LearningModule.
$a
thx to https://mlocati.github.io/php-cs-fixer-configurator for the examples
getDebugValues(?bool $test_sco=false)
static getLocaljQueryPath()
exit
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
getStructureFlat(array $data)
getNodeData(string $sco_id)
static makeDir(string $a_dir)
creates a new directory and inherits all filesystem permissions of the parent directory You may pass ...