19 require_once
'Modules/Test/classes/inc.AssessmentConstants.php';
275 public function __construct($a_id = 0,
bool $a_call_by_reference =
true)
278 $this->db = $DIC[
'ilDB'];
283 $this->testrequest = $DIC->test()->internal()->request();
287 $this->mark_schema->createSimpleSchema(
298 $this->score_settings = null;
300 $this->author =
$ilUser->fullname;
301 $this->introductionEnabled =
false;
302 $this->introduction =
"";
303 $this->questions = array();
305 $this->instant_verification = 0;
306 $this->answer_feedback_points = 0;
307 $this->reporting_date =
"";
308 $this->nr_of_tries = 0;
310 $this->use_previous_answers = 1;
311 $this->title_output = 0;
312 $this->starting_time =
"";
313 $this->ending_time =
"";
314 $this->processing_time =
"";
315 $this->enable_processing_time =
"0";
316 $this->reset_processing_time = 0;
317 $this->ects_output =
false;
318 $this->ects_fx = null;
319 $this->shuffle_questions =
false;
320 $this->mailnottype = 0;
321 $this->show_summary = 8;
322 $this->answer_feedback = 0;
323 $this->password =
"";
324 $this->allowedUsers =
"";
325 $this->_showfinalstatement =
false;
326 $this->_finalstatement =
"";
327 $this->_showinfo =
true;
328 $this->_forcejs =
true;
329 $this->_customStyle =
"";
330 $this->allowedUsersTimeGap =
"";
331 $this->anonymity = 0;
332 $this->show_cancel = 0;
333 $this->show_marker = 0;
334 $this->fixed_participants = 0;
335 $this->testSession =
false;
336 $this->testSequence =
false;
337 $this->mailnotification = 0;
339 $this->ects_grades = array(
347 $this->autosave =
false;
348 $this->autosave_ival = 30000;
350 $this->enable_examview =
false;
351 $this->show_examview_html =
false;
352 $this->show_examview_pdf =
false;
353 $this->enable_archiving =
false;
355 $this->template_id =
'';
356 $this->redirection_mode = 0;
357 $this->redirection_url = null;
358 $this->show_exam_id_in_test_pass_enabled =
false;
359 $this->sign_submission =
false;
360 $this->char_selector_availability = 0;
361 $this->char_selector_definition = null;
363 $this->showGradingStatusEnabled =
true;
364 $this->showGradingMarkEnabled =
true;
366 $this->followupQuestionAnswerFixationEnabled =
false;
367 $this->instantFeedbackAnswerFixationEnabled =
false;
369 $this->testFinalBroken =
false;
371 $this->tmpCopyWizardCopyId = null;
397 $id = parent::create();
404 if (!parent::update()) {
419 public function delete():
bool 422 if (!parent::delete()) {
433 $qsaImportFails->deleteRegisteredImportFails();
435 $sltImportFails->deleteRegisteredImportFails();
443 $tree = $DIC[
'tree'];
444 $ilDB = $DIC[
'ilDB'];
445 $component_repository = $DIC[
'component.repository'];
449 $participantData->load($this->
getTestId());
453 "DELETE FROM tst_mark WHERE test_fi = %s",
459 "DELETE FROM tst_tests WHERE test_id = %s",
465 $testQuestionSetConfigFactory->getQuestionSetConfig()->removeQuestionSetRelatedData();
468 $directory = $tst_data_dir .
"/tst_" . $this->
getId();
469 if (is_dir($directory)) {
477 foreach (
$mobs as $mob) {
495 if (!is_writable($tst_data_dir)) {
496 $this->
ilias->raiseError(
"Test Data Directory (" . $tst_data_dir
497 .
") not writeable.", $this->
ilias->error_obj->MESSAGE);
501 $tst_dir = $tst_data_dir .
"/tst_" . $this->
getId();
503 if (!@is_dir($tst_dir)) {
504 $this->
ilias->raiseError(
"Creation of Test Directory failed.", $this->
ilias->error_obj->MESSAGE);
507 $export_dir = $tst_dir .
"/export";
509 if (!@is_dir($export_dir)) {
510 $this->
ilias->raiseError(
"Creation of Export Directory failed.", $this->
ilias->error_obj->MESSAGE);
525 public function getExportFiles(
string $dir =
''): array
528 if (!@is_dir($dir) || !is_writable($dir)) {
533 foreach (
new DirectoryIterator($dir) as $file) {
537 if ($file->isDir()) {
541 $files[] = $file->getBasename();
551 if (strlen($a_import_dir)) {
589 if (!is_writable($tst_data_dir)) {
591 .
") not writeable.",
$ilias->error_obj->FATAL);
595 $tst_dir = $tst_data_dir .
"/tst_import";
597 if (!@is_dir($tst_dir)) {
610 $ilDB = $DIC[
'ilDB'];
612 $result =
$ilDB->queryF(
613 "SELECT DISTINCT(qpl_qst_type.type_tag) foundtypes FROM qpl_questions, tst_test_result, qpl_qst_type, tst_active WHERE tst_test_result.question_fi = qpl_questions.question_id AND qpl_questions.question_type_fi = qpl_qst_type.question_type_id AND tst_test_result.active_fi = tst_active.active_id AND tst_active.test_fi = %s",
618 while ($row =
$ilDB->fetchAssoc($result)) {
619 if (strcmp($row[
'foundtypes'],
'assSingleChoice') == 0) {
629 $ilDB = $DIC[
'ilDB'];
631 $result =
$ilDB->queryF(
632 "SELECT DISTINCT(qpl_qst_type.type_tag) foundtypes FROM qpl_questions, tst_test_result, qpl_qst_type, tst_active WHERE tst_test_result.question_fi = qpl_questions.question_id AND qpl_questions.question_type_fi = qpl_qst_type.question_type_id AND tst_test_result.active_fi = tst_active.active_id AND tst_active.test_fi = %s",
636 if ($result->numRows() == 1) {
637 $row =
$ilDB->fetchAssoc($result);
638 if (strcmp($row[
'foundtypes'],
'assSingleChoice') == 0) {
650 $ilDB = $DIC[
'ilDB'];
656 $result =
$ilDB->queryF(
658 SELECT DISTINCT(qpl_qst_sc.shuffle) foundshuffles 664 WHERE tst_test_result.question_fi = qpl_questions.question_id 665 AND qpl_questions.question_type_fi = qpl_qst_type.question_type_id 666 AND tst_test_result.active_fi = tst_active.active_id 667 AND qpl_questions.question_id = qpl_qst_sc.question_fi 668 AND tst_active.test_fi = %s 669 AND qpl_qst_type.type_tag = %s 671 array(
'integer',
'text'),
672 array($this->
getTestId(),
'assSingleChoice')
674 if ($result->numRows() == 1) {
675 $row =
$ilDB->fetchAssoc($result);
676 return ($row[
'foundshuffles'] == 0);
683 if (!count($this->mark_schema->mark_steps)) {
697 $tree = $DIC[
'tree'];
698 $ilDB = $DIC[
'ilDB'];
699 $component_repository = $DIC[
'component.repository'];
706 return $test->isComplete($testQuestionSetConfigFactory->getQuestionSetConfig());
715 $ilDB = $DIC[
'ilDB'];
721 SET ects_output = %s, ects_a = %s, ects_b = %s, ects_c = %s, ects_d = %s, ects_e = %s, ects_fx = %s 723 array(
'text',
'float',
'float',
'float',
'float',
'float',
'float',
'integer'),
726 $grades[
'A'], $grades[
'B'], $grades[
'C'], $grades[
'D'], $grades[
'E'],
737 $ilDB = $DIC[
'ilDB'];
740 if ($this->
isComplete($testQuestionSetConfig)) {
745 "UPDATE tst_tests SET complete = %s WHERE test_id = %s",
746 array(
'text',
'integer'),
747 array($complete, $this->test_id)
769 $completecontent =
"";
771 $completecontent .= $content;
780 public function saveToDb(
bool $properties_only =
false): void
783 $tree = $DIC[
'tree'];
784 $ilDB = $DIC[
'ilDB'];
785 $component_repository = $DIC[
'component.repository'];
793 $testQuestionSetConfig = $testQuestionSetConfigFactory->getQuestionSetConfig();
795 if ($this->test_id == -1) {
797 $next_id =
$ilDB->nextId(
'tst_tests');
799 $ilDB->insert(
'tst_tests', array(
800 'test_id' => array(
'integer', $next_id),
801 'obj_fi' => array(
'integer', $this->
getId()),
802 'author' => array(
'text', $this->
getAuthor()),
806 'showinfo' => array(
'integer', $this->
getShowInfo()),
807 'forcejs' => array(
'integer', $this->
getForceJS()),
819 'nr_of_tries' => array(
'integer', $this->
getNrOfTries()),
821 'kiosk' => array(
'integer', $this->
getKiosk()),
831 'complete' => array(
'text', $this->
isComplete($testQuestionSetConfig)),
833 'ects_a' => array(
'float', strlen($this->ects_grades[
"A"]) ? $this->ects_grades[
"A"] : 90),
834 'ects_b' => array(
'float', strlen($this->ects_grades[
"B"]) ? $this->ects_grades[
"B"] : 65),
835 'ects_c' => array(
'float', strlen($this->ects_grades[
"C"]) ? $this->ects_grades[
"C"] : 35),
836 'ects_d' => array(
'float', strlen($this->ects_grades[
"D"]) ? $this->ects_grades[
"D"] : 10),
837 'ects_e' => array(
'float', strlen($this->ects_grades[
"E"]) ? $this->ects_grades[
"E"] : 0),
838 'ects_fx' => array(
'float', $this->
getECTSFX()),
848 'created' => array(
'integer', time()),
849 'tstamp' => array(
'integer', time()),
851 'template_id' => array(
'integer', $this->
getTemplate()),
855 'autosave' => array(
'integer', (
int) $this->
getAutosave()),
877 $this->test_id = $next_id;
886 $result =
$ilDB->queryF(
887 "SELECT * FROM tst_tests WHERE test_id = %s",
889 array($this->test_id)
891 if ($result->numRows() == 1) {
892 $oldrow =
$ilDB->fetchAssoc($result);
899 'author' => array(
'text', $this->
getAuthor()),
903 'showinfo' => array(
'integer', $this->
getShowInfo()),
904 'forcejs' => array(
'integer', $this->
getForceJS()),
916 'nr_of_tries' => array(
'integer', $this->
getNrOfTries()),
918 'kiosk' => array(
'integer', $this->
getKiosk()),
928 'complete' => array(
'text', $this->
isComplete($testQuestionSetConfig)),
930 'ects_a' => array(
'float', strlen($this->ects_grades[
"A"]) ? $this->ects_grades[
"A"] : null),
931 'ects_b' => array(
'float', strlen($this->ects_grades[
"B"]) ? $this->ects_grades[
"B"] : null),
932 'ects_c' => array(
'float', strlen($this->ects_grades[
"C"]) ? $this->ects_grades[
"C"] : null),
933 'ects_d' => array(
'float', strlen($this->ects_grades[
"D"]) ? $this->ects_grades[
"D"] : null),
934 'ects_e' => array(
'float', strlen($this->ects_grades[
"E"]) ? $this->ects_grades[
"E"] : null),
935 'ects_fx' => array(
'float', $this->
getECTSFX()),
946 'tstamp' => array(
'integer', time()),
948 'template_id' => array(
'integer', $this->
getTemplate()),
952 'autosave' => array(
'integer', (
int) $this->
getAutosave()),
976 'test_id' => array(
'integer', $this->
getTestId())
981 $logresult =
$ilDB->queryF(
982 "SELECT * FROM tst_tests WHERE test_id = %s",
987 if ($logresult->numRows() == 1) {
988 $newrow =
$ilDB->fetchAssoc($logresult);
990 $changed_fields = array();
991 foreach ($oldrow as
$key => $value) {
992 if (strcmp($oldrow[
$key], $newrow[$key]) != 0) {
993 array_push($changed_fields,
"$key: " . $oldrow[$key] .
" => " . $newrow[$key]);
996 $changes = join(
", ", $changed_fields);
997 if (count($changed_fields) > 0) {
1005 $aresult =
$ilDB->queryF(
1006 "SELECT active_id FROM tst_active WHERE test_fi = %s AND tries >= %s AND submitted = %s",
1007 array(
'integer',
'integer',
'integer'),
1010 while ($row =
$ilDB->fetchAssoc($aresult)) {
1012 "UPDATE tst_active SET submitted = %s, submittimestamp = %s WHERE active_id = %s",
1013 array(
'integer',
'timestamp',
'integer'),
1014 array(1, date(
'Y-m-d H:i:s'), $row[
"active_id"])
1019 $aresult =
$ilDB->queryF(
1020 "SELECT active_id FROM tst_active WHERE test_fi = %s AND tries < %s AND submitted = %s",
1021 array(
'integer',
'integer',
'integer'),
1024 while ($row =
$ilDB->fetchAssoc($aresult)) {
1026 "UPDATE tst_active SET submitted = %s, submittimestamp = %s WHERE active_id = %s",
1027 array(
'integer',
'timestamp',
'integer'),
1028 array(0, null, $row[
"active_id"])
1033 $aresult =
$ilDB->queryF(
1034 "SELECT active_id FROM tst_active WHERE test_fi = %s AND submitted = %s",
1035 array(
'integer',
'integer'),
1038 while ($row =
$ilDB->fetchAssoc($aresult)) {
1040 "UPDATE tst_active SET submitted = %s, submittimestamp = %s WHERE active_id = %s",
1041 array(
'integer',
'timestamp',
'integer'),
1042 array(0, null, $row[
"active_id"])
1053 $newsItem->setContext($this->
getId(),
'tst');
1055 $newsItem->setTitle(
'new_test_online');
1056 $newsItem->setContentIsLangVar(
true);
1057 $newsItem->setContent(
'');
1058 $newsItem->setUserId(
$ilUser->getId());
1060 $newsItem->create();
1067 $newsItem->setTitle(
'new_test_online');
1068 $newsItem->setContentIsLangVar(
true);
1069 $newsItem->setContent(
'');
1070 $newsItem->update();
1075 if ($this->ref_id) {
1088 $item->update($this->ref_id);
1091 if (!$properties_only) {
1096 $this->mark_schema->saveToDb($this->test_id);
1103 $ilDB = $DIC[
'ilDB'];
1105 $oldquestions = array();
1107 $result =
$ilDB->queryF(
1108 "SELECT question_fi FROM tst_test_question WHERE test_fi = %s ORDER BY sequence",
1112 if ($result->numRows() > 0) {
1113 while ($row =
$ilDB->fetchAssoc($result)) {
1114 array_push($oldquestions, $row[
"question_fi"]);
1120 $currentQuestionsObligationsQuery =
'SELECT question_fi, obligatory FROM tst_test_question WHERE test_fi = %s';
1121 $rset =
$ilDB->queryF($currentQuestionsObligationsQuery, array(
'integer'), array($this->
getTestId()));
1122 while ($row =
$ilDB->fetchAssoc($rset)) {
1123 $obligatoryQuestionState[$row[
'question_fi']] = $row[
'obligatory'];
1126 $affectedRows =
$ilDB->manipulateF(
1127 "DELETE FROM tst_test_question WHERE test_fi = %s",
1132 foreach ($this->questions as
$key => $value) {
1134 if (!isset($obligatoryQuestionState[$value]) || is_null($obligatoryQuestionState[$value])) {
1135 $obligatoryQuestionState[$value] = 0;
1139 $next_id =
$ilDB->nextId(
'tst_test_question');
1140 $ilDB->insert(
'tst_test_question', array(
1141 'test_question_id' => array(
'integer', $next_id),
1142 'test_fi' => array(
'integer', $this->
getTestId()),
1143 'question_fi' => array(
'integer', $value),
1144 'sequence' => array(
'integer',
$key),
1145 'obligatory' => array(
'integer', $obligatoryQuestionState[$value]),
1146 'tstamp' => array(
'integer', time())
1150 $result =
$ilDB->queryF(
1151 "SELECT question_fi FROM tst_test_question WHERE test_fi = %s ORDER BY sequence",
1155 $newquestions = array();
1156 if ($result->numRows() > 0) {
1157 while ($row =
$ilDB->fetchAssoc($result)) {
1158 array_push($newquestions, $row[
"question_fi"]);
1161 foreach ($oldquestions as
$index => $question_id) {
1162 if (strcmp($newquestions[
$index], $question_id) != 0) {
1163 $pos = array_search($question_id, $newquestions);
1164 if ($pos ===
false) {
1171 foreach ($newquestions as
$index => $question_id) {
1172 if (array_search($question_id, $oldquestions) ===
false) {
1187 $ilDB = $DIC[
'ilDB'];
1188 $result =
$ilDB->queryF(
1189 'SELECT copy_id FROM tst_rnd_cpy WHERE tst_fi = %s',
1193 return $result->numRows() > 0;
1204 int $nr_of_questions,
1211 $rbacsystem = $DIC[
'rbacsystem'];
1212 $ilDB = $DIC[
'ilDB'];
1215 if (($questionpool != 0) && (!$use_obj_id)) {
1220 $result =
$ilDB->queryF(
1221 "SELECT qpl_questions.original_id FROM qpl_questions, tst_test_question WHERE qpl_questions.question_id = tst_test_question.question_fi AND qpl_questions.tstamp > 0 AND tst_test_question.test_fi = %s",
1225 $original_ids = array();
1226 $paramtypes = array();
1227 $paramvalues = array();
1228 while ($row =
$ilDB->fetchAssoc($result)) {
1229 array_push($original_ids, $row[
'original_id']);
1234 if (($questionpool == 0) && (!is_array($qpls))) {
1236 if (count($available_pools)) {
1237 $available =
" AND " .
$ilDB->in(
'obj_fi', $available_pools,
false,
'integer');
1243 $constraint_qpls =
"";
1244 $result_array = array();
1245 if ($questionpool == 0) {
1246 if (is_array($qpls)) {
1247 if (count($qpls) > 0) {
1248 $constraint_qpls =
" AND " .
$ilDB->in(
'obj_fi', $qpls,
false,
'integer');
1253 $original_clause =
"";
1254 if (count($original_ids)) {
1255 $original_clause =
" AND " .
$ilDB->in(
'question_id', $original_ids,
true,
'integer');
1258 if ($questionpool == 0) {
1259 $result =
$ilDB->queryF(
1260 "SELECT question_id FROM qpl_questions WHERE original_id IS NULL $available $constraint_qpls AND owner > %s AND complete = %s $original_clause",
1261 array(
'integer',
'text'),
1265 $result =
$ilDB->queryF(
1266 "SELECT question_id FROM qpl_questions WHERE original_id IS NULL AND obj_fi = %s AND owner > %s AND complete = %s $original_clause",
1267 array(
'integer',
'integer',
'text'),
1268 array($questionpool, 0,
"1")
1271 $found_ids = array();
1272 while ($row =
$ilDB->fetchAssoc($result)) {
1273 array_push($found_ids, $row[
'question_id']);
1275 $nr_of_questions = ($nr_of_questions > count($found_ids)) ? count($found_ids) : $nr_of_questions;
1276 if ($nr_of_questions == 0) {
1279 $rand_keys = array_rand($found_ids, $nr_of_questions);
1281 if (is_array($rand_keys)) {
1282 foreach ($rand_keys as
$key) {
1283 $result[$found_ids[
$key]] = $found_ids[
$key];
1286 $result[$found_ids[$rand_keys]] = $found_ids[$rand_keys];
1297 $ilDB = $DIC[
'ilDB'];
1299 $result =
$ilDB->queryF(
1300 "SELECT test_result_id FROM tst_test_result WHERE active_fi = %s AND pass = %s",
1301 array(
'integer',
'integer'),
1302 array($active_id, $pass)
1304 return $result->numRows();
1314 $ilDB = $DIC[
'ilDB'];
1315 $result =
$ilDB->queryF(
1316 "SELECT test_random_question_id FROM tst_test_rnd_qst WHERE active_fi = %s AND pass = %s",
1317 array(
'integer',
'integer'),
1318 array($active_id, $pass)
1320 return ($result->numRows() > 0) ?
true :
false;
1326 $ilDB = $DIC[
'ilDB'];
1328 $result =
$ilDB->queryF(
1329 "SELECT * FROM tst_tests WHERE obj_fi = %s",
1331 array($this->
getId())
1333 if ($result->numRows() == 1) {
1337 if (
$data->author) {
1379 "A" =>
$data->ects_a,
1380 "B" =>
$data->ects_b,
1381 "C" =>
$data->ects_c,
1382 "D" =>
$data->ects_d,
1383 "E" =>
$data->ects_e
1387 $this->mark_schema->flush();
1388 $this->mark_schema->loadFromDb($this->
getTestId());
1425 if (isset($this->ref_id)) {
1427 switch ($activation[
"timing_type"]) {
1452 $ilDB = $DIC[
'ilDB'];
1454 $tags_trafo = $this->
refinery->string()->stripTags();
1456 $this->questions = array();
1458 if (strcmp($active_id,
"") == 0) {
1461 if (is_null($pass)) {
1462 $pass = self::_getPass($active_id);
1464 $result =
$ilDB->queryF(
1465 "SELECT tst_test_rnd_qst.* FROM tst_test_rnd_qst, qpl_questions WHERE tst_test_rnd_qst.active_fi = %s AND qpl_questions.question_id = tst_test_rnd_qst.question_fi AND tst_test_rnd_qst.pass = %s ORDER BY sequence",
1466 array(
'integer',
'integer'),
1467 array($active_id, $pass)
1473 if ($result->numRows() == 0) {
1474 $result =
$ilDB->queryF(
1475 "SELECT tst_test_rnd_qst.* FROM tst_test_rnd_qst, qpl_questions WHERE tst_test_rnd_qst.active_fi = %s AND qpl_questions.question_id = tst_test_rnd_qst.question_fi AND tst_test_rnd_qst.pass = 0 ORDER BY sequence",
1481 $result =
$ilDB->queryF(
1482 "SELECT tst_test_question.* FROM tst_test_question, qpl_questions WHERE tst_test_question.test_fi = %s AND qpl_questions.question_id = tst_test_question.question_fi ORDER BY sequence",
1484 array($this->test_id)
1488 if ($this->test_id !== -1) {
1491 $this->questions[
$index++] =
$data[
"question_fi"];
1521 $this->_finalstatement = $a_statement;
1533 $this->_showinfo = ($a_info) ? 1 : 0;
1545 $this->_forcejs = ($a_js) ? 1 : 0;
1557 $this->_customStyle = $a_customStyle;
1566 return (strlen($this->_customStyle)) ? $this->_customStyle : null;
1578 $this->_showfinalstatement = ($show) ? 1 : 0;
1595 return ($this->_showinfo) ? 1 : 0;
1607 return ($this->_forcejs) ? 1 : 0;
1619 return ($this->_showfinalstatement) ? 1 : 0;
1636 return ($this->ects_output) ? 1 : 0;
1641 $this->ects_output = $a_ects_output ? 1 : 0;
1651 $this->ects_fx = (float) str_replace(
",",
".", $a_ects_fx);
1661 $this->ects_grades = $a_ects_grades;
1671 return ($this->sequence_settings) ? $this->sequence_settings : 0;
1702 switch ($instant_feedback) {
1704 $this->instant_verification = 1;
1707 $this->instant_verification = 0;
1720 switch ($answer_feedback) {
1722 $this->answer_feedback = 1;
1725 $this->answer_feedback = 0;
1732 switch ($generic_answer_feedback) {
1734 $this->answer_feedback = 1;
1737 $this->answer_feedback = 0;
1750 switch ($answer_feedback_points) {
1752 $this->answer_feedback_points = 1;
1755 $this->answer_feedback_points = 0;
1767 $this->reporting_date =
'';
1783 return $this->
getScoreSettings()->getResultSummarySettings()->getScoreReporting();
1791 case self::SCORE_REPORTING_FINISHED:
1792 case self::SCORE_REPORTING_IMMIDIATLY:
1793 case self::SCORE_REPORTING_DATE:
1794 case self::SCORE_REPORTING_AFTER_PASSED:
1798 case self::SCORE_REPORTING_DISABLED:
1814 return ($this->instant_verification) ? $this->instant_verification : 0;
1827 return ($this->answer_feedback) ? $this->answer_feedback : 0;
1838 return ($this->answer_feedback) ? $this->answer_feedback : 0;
1850 return ($this->answer_feedback_points) ? $this->answer_feedback_points : 0;
1875 $ilDB = $DIC[
'ilDB'];
1876 $result =
$ilDB->queryF(
1877 "SELECT tst_tests.count_system FROM tst_tests, tst_active WHERE tst_active.active_id = %s AND tst_active.test_fi = tst_tests.test_id",
1881 if ($result->numRows()) {
1882 $row =
$ilDB->fetchAssoc($result);
1883 return $row[
"count_system"];
1922 $ilDB = $DIC[
'ilDB'];
1923 $result =
$ilDB->queryF(
1924 "SELECT tst_tests.pass_scoring FROM tst_tests, tst_active WHERE tst_tests.test_id = tst_active.test_fi AND tst_active.active_id = %s",
1928 if ($result->numRows()) {
1929 $row =
$ilDB->fetchAssoc($result);
1930 return $row[
"pass_scoring"];
1945 $ilDB = $DIC[
'ilDB'];
1946 $result =
$ilDB->queryF(
1947 "SELECT tst_tests.score_cutting FROM tst_tests, tst_active WHERE tst_active.active_id = %s AND tst_tests.test_id = tst_active.test_fi",
1951 if ($result->numRows()) {
1952 $row =
$ilDB->fetchAssoc($result);
1953 return $row[
"score_cutting"];
1968 return $this->
getScoreSettings()->getResultSummarySettings()->getReportingDate();
1980 return ($this->nr_of_tries) ? $this->nr_of_tries : 0;
2008 return ($this->_kiosk) ? $this->_kiosk : 0;
2021 $this->_kiosk = $kiosk;
2033 if (($this->_kiosk & 1) > 0) {
2050 $this->_kiosk = $this->_kiosk | 1;
2053 $this->_kiosk = $this->_kiosk ^ 1;
2067 if (($this->_kiosk & 2) > 0) {
2083 $this->_kiosk = $this->_kiosk | 2;
2086 $this->_kiosk = $this->_kiosk ^ 2;
2100 if (($this->_kiosk & 4) > 0) {
2115 if ($a_participant) {
2116 $this->_kiosk = $this->_kiosk | 4;
2119 $this->_kiosk = $this->_kiosk ^ 4;
2133 return ($this->use_previous_answers) ? $this->use_previous_answers : 0;
2145 return ($this->title_output) ? $this->title_output : 0;
2159 $ilDB = $DIC[
'ilDB'];
2161 $result =
$ilDB->queryF(
2162 "SELECT tst_tests.title_output FROM tst_tests, tst_active WHERE tst_tests.test_id = tst_active.test_fi AND tst_active.active_id = %s",
2166 if ($result->numRows()) {
2167 $row =
$ilDB->fetchAssoc($result);
2168 return $row[
"title_output"];
2175 $result = $this->db->queryF(
2176 "SELECT tst_tests.use_previous_answers FROM tst_tests, tst_active WHERE tst_tests.test_id = tst_active.test_fi AND tst_active.active_id = %s",
2180 if ($result->numRows()) {
2181 $row = $this->db->fetchAssoc($result);
2182 $test_allows_reuse = $row[
"use_previous_answers"];
2185 if ($test_allows_reuse ===
'1') {
2186 $res = $this->
user->getPref(
"tst_use_previous_answers");
2203 return (strlen($this->processing_time)) ? $this->processing_time : null;
2211 if (strlen($this->processing_time)) {
2212 if (preg_match(
"/(\d{2}):(\d{2}):(\d{2})/is", $this->processing_time, $matches)) {
2213 if ((
int) $matches[1] + (
int) $matches[2] + (
int) $matches[3] == 0) {
2217 'hh' => $matches[1],
2218 'mm' => $matches[2],
2219 'ss' => $matches[3],
2229 if (strlen($this->processing_time)) {
2230 if (preg_match(
"/(\d{2}):(\d{2}):(\d{2})/is", $this->processing_time, $matches)) {
2231 return ($matches[1] * 60) + $matches[2];
2235 return self::DEFAULT_PROCESSING_TIME_MINUTES;
2247 if (preg_match(
"/(\d{2}):(\d{2}):(\d{2})/", $this->
getProcessingTime(), $matches)) {
2249 return ($matches[1] * 3600) + ($matches[2] * 60) + $matches[3] + $extratime;
2267 return $ending - $now;
2282 return ($this->enable_processing_time) ? $this->enable_processing_time : 0;
2294 return ($this->reset_processing_time) ? $this->reset_processing_time : 0;
2319 return ($this->starting_time != 0) ? $this->starting_time : 0;
2356 return ($this->ending_time != 0) ? $this->ending_time : 0;
2392 if ($use_previous_answers) {
2393 $this->use_previous_answers = 1;
2395 $this->use_previous_answers = 0;
2425 switch ($title_output) {
2427 $this->title_output = 1;
2430 $this->title_output = 2;
2433 $this->title_output = 0;
2452 $this->processing_time = sprintf(
"%02d:%02d:00", floor($minutes / 60), $minutes % 60);
2465 $this->enable_processing_time =
"1";
2467 $this->enable_processing_time =
"0";
2481 $this->reset_processing_time = 1;
2483 $this->reset_processing_time = 0;
2505 return (strlen($this->password)) ? $this->password : null;
2517 $this->password = $a_password;
2525 return $this->pass_waiting ??
'';
2559 $DIC[
'component.repository'],
2563 foreach ($activeIds as $activeId) {
2567 foreach ($passSelector->getExistingPasses() as $pass) {
2568 $testSequence = $testSequenceFactory->getSequenceByActiveIdAndPass($activeId, $pass);
2571 $testSequence->removeQuestion($questionId, $reindexedSequencePositionMap);
2582 foreach ($removeQuestionIds as $value) {
2592 $question = self::_instanciateQuestion($question_id);
2599 $question->delete($question_id);
2601 $this->log->error($e->getMessage());
2602 $this->log->error($e->getTraceAsString());
2619 $ilDB = $DIC[
'ilDB'];
2623 $participantData->setUserIdsFilter($userIds);
2624 $participantData->load($this->
getTestId());
2638 $testLP->setTestObject($this);
2639 $testLP->resetLPDataForUserIds($participantData->
getUserIds(),
false);
2653 $participantData->setUserIdsFilter($userIds);
2654 $participantData->load($this->
getTestId());
2656 $IN_userIds =
$ilDB->in(
'usr_id', $participantData->getUserIds(),
false,
'integer');
2658 "DELETE FROM usr_pref WHERE $IN_userIds AND keyword = %s",
2660 array(
"tst_password_" . $this->
getTestId())
2663 if (count($participantData->getActiveIds())) {
2672 $IN_activeIds =
$ilDB->in(
'active_fi', $activeIds,
false,
'integer');
2674 $ilDB->manipulate(
"DELETE FROM tst_solutions WHERE $IN_activeIds");
2675 $ilDB->manipulate(
"DELETE FROM tst_qst_solved WHERE $IN_activeIds");
2676 $ilDB->manipulate(
"DELETE FROM tst_test_result WHERE $IN_activeIds");
2677 $ilDB->manipulate(
"DELETE FROM tst_pass_result WHERE $IN_activeIds");
2678 $ilDB->manipulate(
"DELETE FROM tst_result_cache WHERE $IN_activeIds");
2679 $ilDB->manipulate(
"DELETE FROM tst_sequence WHERE $IN_activeIds");
2680 $ilDB->manipulate(
"DELETE FROM tst_times WHERE $IN_activeIds");
2683 $ilDB->manipulate(
"DELETE FROM tst_test_rnd_qst WHERE $IN_activeIds");
2685 $ilDB->manipulate(
"DELETE FROM tst_seq_qst_tracking WHERE $IN_activeIds");
2686 $ilDB->manipulate(
"DELETE FROM tst_seq_qst_answstatus WHERE $IN_activeIds");
2687 $ilDB->manipulate(
"DELETE FROM tst_seq_qst_postponed WHERE $IN_activeIds");
2688 $ilDB->manipulate(
"DELETE FROM tst_seq_qst_checked WHERE $IN_activeIds");
2691 foreach ($activeIds as $active_id) {
2708 $ilDB = $DIC[
'ilDB'];
2710 $IN_activeIds =
$ilDB->in(
'active_id', $activeIds,
false,
'integer');
2711 $ilDB->manipulate(
"DELETE FROM tst_active WHERE $IN_activeIds");
2724 $ilDB = $DIC[
'ilDB'];
2727 $result =
$ilDB->queryF(
2728 "SELECT * FROM tst_test_question WHERE test_fi=%s AND question_fi=%s",
2729 array(
'integer',
'integer'),
2733 if (
$data->sequence > 1) {
2735 $result =
$ilDB->queryF(
2736 "SELECT * FROM tst_test_question WHERE test_fi=%s AND sequence=%s",
2737 array(
'integer',
'integer'),
2740 $data_previous =
$ilDB->fetchObject($result);
2743 "UPDATE tst_test_question SET sequence=%s WHERE test_question_id=%s",
2744 array(
'integer',
'integer'),
2745 array(
$data->sequence, $data_previous->test_question_id)
2749 "UPDATE tst_test_question SET sequence=%s WHERE test_question_id=%s",
2750 array(
'integer',
'integer'),
2751 array(
$data->sequence - 1,
$data->test_question_id)
2770 $ilDB = $DIC[
'ilDB'];
2773 $result =
$ilDB->queryF(
2774 "SELECT * FROM tst_test_question WHERE test_fi=%s AND question_fi=%s",
2775 array(
'integer',
'integer'),
2779 $result =
$ilDB->queryF(
2780 "SELECT * FROM tst_test_question WHERE test_fi=%s AND sequence=%s",
2781 array(
'integer',
'integer'),
2784 if ($result->numRows() == 1) {
2786 $data_next =
$ilDB->fetchObject($result);
2789 "UPDATE tst_test_question SET sequence=%s WHERE test_question_id=%s",
2790 array(
'integer',
'integer'),
2791 array(
$data->sequence, $data_next->test_question_id)
2795 "UPDATE tst_test_question SET sequence=%s WHERE test_question_id=%s",
2796 array(
'integer',
'integer'),
2797 array(
$data->sequence + 1,
$data->test_question_id)
2815 $duplicate_id = $question->duplicate(
true,
'',
'',
'', $this->
getId());
2816 return $duplicate_id;
2830 $ilDB = $DIC[
'ilDB'];
2832 $duplicate_id = $question_id;
2838 $result =
$ilDB->queryF(
2839 "SELECT MAX(sequence) seq FROM tst_test_question WHERE test_fi=%s",
2845 if ($result->numRows() == 1) {
2847 $sequence =
$data->seq + 1;
2850 $next_id =
$ilDB->nextId(
'tst_test_question');
2851 $affectedRows =
$ilDB->manipulateF(
2852 "INSERT INTO tst_test_question (test_question_id, test_fi, question_fi, sequence, tstamp) VALUES (%s, %s, %s, %s, %s)",
2853 array(
'integer',
'integer',
'integer',
'integer',
'integer'),
2854 array($next_id, $this->
getTestId(), $duplicate_id, $sequence, time())
2856 if ($affectedRows == 1) {
2862 $affectedRows =
$ilDB->manipulateF(
2863 "DELETE FROM tst_active WHERE test_fi = %s",
2869 return $duplicate_id;
2884 $ilDB = $DIC[
'ilDB'];
2885 $result =
$ilDB->queryF(
2886 "SELECT qpl_questions.title FROM tst_test_question, qpl_questions WHERE tst_test_question.test_fi = %s AND tst_test_question.question_fi = qpl_questions.question_id ORDER BY tst_test_question.sequence",
2890 while ($row =
$ilDB->fetchAssoc($result)) {
2891 array_push($titles, $row[
"title"]);
2909 $ilDB = $DIC[
'ilDB'];
2910 $result =
$ilDB->queryF(
2911 "SELECT qpl_questions.title, qpl_questions.question_id FROM tst_test_question, qpl_questions WHERE tst_test_question.test_fi = %s AND tst_test_question.question_fi = qpl_questions.question_id ORDER BY tst_test_question.sequence",
2915 while ($row =
$ilDB->fetchAssoc($result)) {
2916 $titles[$row[
'question_id']] = $row[
"title"];
2939 return $this->
lng->txt(
"ass_question") .
' ' . $nr;
2942 return $this->
lng->txt(
"ass_question");
2957 $ilDB = $DIC[
'ilDB'];
2959 $result =
$ilDB->queryF(
2960 "SELECT qpl_questions.*, qpl_qst_type.type_tag FROM qpl_questions, qpl_qst_type WHERE qpl_questions.question_id = %s AND qpl_questions.question_type_fi = qpl_qst_type.question_type_id",
2964 $row =
$ilDB->fetchObject($result);
2978 $ilDB = $DIC[
'ilDB'];
2980 $existing_questions = array();
2983 if (is_null($pass)) {
2986 $result =
$ilDB->queryF(
2987 "SELECT qpl_questions.original_id FROM qpl_questions, tst_test_rnd_qst WHERE tst_test_rnd_qst.active_fi = %s AND tst_test_rnd_qst.question_fi = qpl_questions.question_id AND tst_test_rnd_qst.pass = %s",
2988 array(
'integer',
'integer'),
2989 array($active_id, $pass)
2992 $result =
$ilDB->queryF(
2993 "SELECT qpl_questions.original_id FROM qpl_questions, tst_test_question WHERE tst_test_question.test_fi = %s AND tst_test_question.question_fi = qpl_questions.question_id",
2998 while (
$data =
$ilDB->fetchObject($result)) {
2999 if (
$data->original_id === null) {
3003 array_push($existing_questions,
$data->original_id);
3005 return $existing_questions;
3018 $ilDB = $DIC[
'ilDB'];
3020 if ($question_id < 1) {
3023 $result =
$ilDB->queryF(
3024 "SELECT type_tag FROM qpl_questions, qpl_qst_type WHERE qpl_questions.question_id = %s AND qpl_questions.question_type_fi = qpl_qst_type.question_type_id",
3028 if ($result->numRows() == 1) {
3030 return $data->type_tag;
3045 $ilDB = $DIC[
'ilDB'];
3047 $next_id =
$ilDB->nextId(
'tst_times');
3048 $affectedRows =
$ilDB->manipulateF(
3049 "INSERT INTO tst_times (times_id, active_fi, started, finished, pass, tstamp) VALUES (%s, %s, %s, %s, %s, %s)",
3050 array(
'integer',
'integer',
'timestamp',
'timestamp',
'integer',
'integer'),
3051 array($next_id, $active_id, date(
"Y-m-d H:i:s"), date(
"Y-m-d H:i:s"), $pass, time())
3065 $ilDB = $DIC[
'ilDB'];
3067 $affectedRows =
$ilDB->manipulateF(
3068 "UPDATE tst_times SET finished = %s, tstamp = %s WHERE times_id = %s",
3069 array(
'timestamp',
'integer',
'integer'),
3070 array(date(
'Y-m-d H:i:s'), time(), $times_id)
3084 $ilDB = $DIC[
'ilDB'];
3086 if (is_null($pass)) {
3087 $result =
$ilDB->queryF(
3088 "SELECT question_fi FROM tst_solutions WHERE active_fi = %s AND pass = %s GROUP BY question_fi",
3089 array(
'integer',
'integer'),
3090 array($active_id, 0)
3093 $result =
$ilDB->queryF(
3094 "SELECT question_fi FROM tst_solutions WHERE active_fi = %s AND pass = %s GROUP BY question_fi",
3095 array(
'integer',
'integer'),
3096 array($active_id, $pass)
3099 $result_array = array();
3100 while ($row =
$ilDB->fetchAssoc($result)) {
3101 array_push($result_array, $row[
"question_fi"]);
3103 return $result_array;
3117 return ((($currentpass > 0) && ($num == 0)) || $this->
isTestFinished($active_id)) ? true :
false;
3130 $ilDB = $DIC[
'ilDB'];
3132 $result_array = array();
3136 if (count($this->questions) == 0) {
3137 return $result_array;
3139 if (is_null($pass)) {
3140 $pass = self::_getPass($active_id);
3142 $result =
$ilDB->queryF(
3143 "SELECT qpl_questions.* FROM qpl_questions, tst_test_rnd_qst WHERE tst_test_rnd_qst.question_fi = qpl_questions.question_id AND tst_test_rnd_qst.active_fi = %s AND tst_test_rnd_qst.pass = %s AND " .
$ilDB->in(
'qpl_questions.question_id', $this->questions,
false,
'integer'),
3144 array(
'integer',
'integer'),
3145 array($active_id, $pass)
3148 if (count($this->questions) == 0) {
3149 return $result_array;
3151 $result =
$ilDB->query(
"SELECT qpl_questions.* FROM qpl_questions, tst_test_question WHERE tst_test_question.question_fi = qpl_questions.question_id AND " .
$ilDB->in(
'qpl_questions.question_id', $this->questions,
false,
'integer'));
3153 while ($row =
$ilDB->fetchAssoc($result)) {
3154 $result_array[$row[
"question_id"]] = $row;
3156 return $result_array;
3170 $ilDB = $DIC[
'ilDB'];
3178 if (is_array($tst_access_code) &&
3180 isset($tst_access_code[$this->
getTestId()]) &&
3181 $tst_access_code[$this->
getTestId()] !==
'') {
3182 $result =
$ilDB->queryF(
3183 'SELECT active_id FROM tst_active WHERE user_fi = %s AND test_fi = %s AND anonymous_id = %s',
3184 [
'integer',
'integer',
'text'],
3185 [$user_id, $this->test_id, $tst_access_code[$this->
getTestId()]]
3187 } elseif ((
string) $anonymous_id !==
'') {
3188 $result =
$ilDB->queryF(
3189 'SELECT active_id FROM tst_active WHERE user_fi = %s AND test_fi = %s AND anonymous_id = %s',
3190 [
'integer',
'integer',
'text'],
3191 [$user_id, $this->test_id, $anonymous_id]
3197 $result =
$ilDB->queryF(
3198 'SELECT active_id FROM tst_active WHERE user_fi = %s AND test_fi = %s',
3199 [
'integer',
'integer'],
3200 [$user_id, $this->test_id]
3204 if ($result->numRows()) {
3205 $row =
$ilDB->fetchAssoc($result);
3206 return (
int) $row[
'active_id'];
3215 $ilDB = $DIC[
'ilDB'];
3224 $result =
$ilDB->queryF(
3225 "SELECT tst_active.active_id FROM tst_active WHERE user_fi = %s AND test_fi = %s",
3226 array(
'integer',
'integer'),
3227 array($user_id, $test_id)
3229 if ($result->numRows()) {
3230 $row =
$ilDB->fetchAssoc($result);
3231 return $row[
"active_id"];
3245 $keys = array_keys($array);
3263 bool $ordered_sequence =
false,
3264 bool $considerHiddenQuestions =
true,
3265 bool $considerOptionalQuestions =
true 3268 $tree = $DIC[
'tree'];
3269 $ilDB = $DIC[
'ilDB'];
3271 $refinery = $DIC[
'refinery'];
3272 $component_repository = $DIC[
'component.repository'];
3276 if ($pass === null) {
3281 $testSession = $testSessionFactory->getSession($active_id);
3284 $testSequence = $testSequenceFactory->getSequenceByActiveIdAndPass($active_id, $pass);
3288 $dynamicQuestionSetConfig->loadFromDb();
3295 $testSequence->setConsiderHiddenQuestionsEnabled($considerHiddenQuestions);
3296 $testSequence->setConsiderOptionalQuestionsEnabled($considerOptionalQuestions);
3301 if ($ordered_sequence) {
3311 SELECT tst_test_result.question_fi, 3312 tst_test_result.points reached, 3313 tst_test_result.hint_count requested_hints, 3314 tst_test_result.hint_points hint_points, 3315 tst_test_result.answered answered 3317 FROM tst_test_result 3319 LEFT JOIN tst_solutions 3320 ON tst_solutions.active_fi = tst_test_result.active_fi 3321 AND tst_solutions.question_fi = tst_test_result.question_fi 3323 WHERE tst_test_result.active_fi = %s 3324 AND tst_test_result.pass = %s 3327 $solutionresult =
$ilDB->queryF(
3329 array(
'integer',
'integer'),
3330 array($active_id, $pass)
3333 while ($row =
$ilDB->fetchAssoc($solutionresult)) {
3334 $arrResults[ $row[
'question_fi'] ] = $row;
3337 $numWorkedThrough = count($arrResults);
3339 $IN_question_ids =
$ilDB->in(
'qpl_questions.question_id', $sequence,
false,
'integer');
3342 SELECT qpl_questions.*, 3343 qpl_qst_type.type_tag, 3344 qpl_sol_sug.question_fi has_sug_sol 3349 LEFT JOIN qpl_sol_sug 3350 ON qpl_sol_sug.question_fi = qpl_questions.question_id 3352 WHERE qpl_qst_type.question_type_id = qpl_questions.question_type_fi 3353 AND $IN_question_ids 3362 $obligationsAnswered =
true;
3364 while ($row =
$ilDB->fetchAssoc($result)) {
3365 if (!isset($arrResults[ $row[
'question_id'] ])) {
3366 $percentvalue = 0.0;
3369 $row[
'points'] ? $arrResults[$row[
'question_id']][
'reached'] / $row[
'points'] : 0
3372 if ($percentvalue < 0) {
3373 $percentvalue = 0.0;
3379 "max" => round($row[
'points'], 2),
3380 "reached" => round($arrResults[$row[
'question_id']][
'reached'] ?? 0, 2),
3381 'requested_hints' => $arrResults[$row[
'question_id']][
'requested_hints'] ?? 0,
3382 'hint_points' => $arrResults[$row[
'question_id']][
'hint_points'] ?? 0,
3383 "percent" => sprintf(
"%2.2f ", ($percentvalue) * 100) .
"%",
3385 "type" => $row[
"type_tag"],
3386 "qid" => $row[
'question_id'],
3387 "original_id" => $row[
"original_id"],
3388 "workedthrough" => isset($arrResults[$row[
'question_id']]) ? 1 : 0,
3389 'answered' => $arrResults[$row[
'question_id']][
'answered'] ?? 0
3392 if (!isset($arrResults[ $row[
'question_id'] ][
'answered']) || !$arrResults[ $row[
'question_id'] ][
'answered']) {
3393 $obligationsAnswered =
false;
3396 $unordered[ $row[
'question_id'] ] =
$data;
3401 $numQuestionsTotal = count($unordered);
3405 $pass_requested_hints = 0;
3406 $pass_hint_points = 0;
3411 foreach ($sequence as $qid) {
3414 $pass_max += round($unordered[$qid][
'max'], 2);
3415 $pass_reached += round($unordered[$qid][
'reached'], 2);
3416 $pass_requested_hints += $unordered[$qid][
'requested_hints'];
3417 $pass_hint_points += $unordered[$qid][
'hint_points'];
3421 $unordered[$qid][
'nr'] =
$key;
3422 array_push($found, $unordered[$qid]);
3431 if (
$results[
'reached_points'] < 0) {
3435 if ($pass_reached < 0) {
3440 $found[
'pass'][
'total_max_points'] = $pass_max;
3441 $found[
'pass'][
'total_reached_points'] = $pass_reached;
3442 $found[
'pass'][
'total_requested_hints'] = $pass_requested_hints;
3443 $found[
'pass'][
'total_hint_points'] = $pass_hint_points;
3444 $found[
'pass'][
'percent'] = ($pass_max > 0) ? $pass_reached / $pass_max : 0;
3445 $found[
'pass'][
'obligationsAnswered'] = $obligationsAnswered;
3446 $found[
'pass'][
'num_workedthrough'] = $numWorkedThrough;
3447 $found[
'pass'][
'num_questions_total'] = $numQuestionsTotal;
3449 $found[
"test"][
"total_max_points"] =
$results[
'max_points'];
3450 $found[
"test"][
"total_reached_points"] =
$results[
'reached_points'];
3451 $found[
"test"][
"total_requested_hints"] =
$results[
'hint_count'];
3452 $found[
"test"][
"total_hint_points"] =
$results[
'hint_points'];
3453 $found[
"test"][
"result_pass"] =
$results[
'pass'];
3454 $found[
'test'][
'result_tstamp'] =
$results[
'tstamp'];
3455 $found[
'test'][
'obligations_answered'] =
$results[
'obligations_answered'];
3457 if ((!$found[
'pass'][
'total_reached_points']) or (!$found[
'pass'][
'total_max_points'])) {
3460 $percentage = ($found[
'pass'][
'total_reached_points'] / $found[
'pass'][
'total_max_points']) * 100.0;
3462 if ($percentage < 0) {
3467 $found[
"test"][
"passed"] =
$results[
'passed'];
3481 $ilDB = $DIC[
'ilDB'];
3483 $result =
$ilDB->queryF(
3484 "SELECT COUNT(active_id) total FROM tst_active WHERE test_fi = %s",
3488 $row =
$ilDB->fetchAssoc($result);
3489 return $row[
"total"];
3501 $ilDB = $DIC[
'ilDB'];
3503 $result =
$ilDB->queryF(
3504 "SELECT tst_times.* FROM tst_active, tst_times WHERE tst_active.test_fi = %s AND tst_active.active_id = tst_times.active_fi AND tst_active.user_fi = %s",
3505 array(
'integer',
'integer'),
3509 while ($row =
$ilDB->fetchAssoc($result)) {
3510 preg_match(
"/(\d{4})-(\d{2})-(\d{2}) (\d{2}):(\d{2}):(\d{2})/", $row[
"started"], $matches);
3511 $epoch_1 = mktime($matches[4], $matches[5], $matches[6], $matches[2], $matches[3], $matches[1]);
3512 preg_match(
"/(\d{4})-(\d{2})-(\d{2}) (\d{2}):(\d{2}):(\d{2})/", $row[
"finished"], $matches);
3513 $epoch_2 = mktime($matches[4], $matches[5], $matches[6], $matches[2], $matches[3], $matches[1]);
3514 $time += ($epoch_2 - $epoch_1);
3540 $ilDB = $DIC[
'ilDB'];
3542 $result =
$ilDB->queryF(
3543 "SELECT tst_times.* FROM tst_active, tst_times WHERE tst_active.test_fi = %s AND tst_active.active_id = tst_times.active_fi ORDER BY tst_times.active_fi, tst_times.started",
3549 while ($row =
$ilDB->fetchAssoc($result)) {
3550 if (!array_key_exists($row[
"active_fi"], $times)) {
3551 $times[$row[
"active_fi"]] = 0;
3553 preg_match(
"/(\d{4})-(\d{2})-(\d{2}) (\d{2}):(\d{2}):(\d{2})/", $row[
"started"], $matches);
3554 $epoch_1 = mktime($matches[4], $matches[5], $matches[6], $matches[2], $matches[3], $matches[1]);
3555 preg_match(
"/(\d{4})-(\d{2})-(\d{2}) (\d{2}):(\d{2}):(\d{2})/", $row[
"finished"], $matches);
3556 $epoch_2 = mktime($matches[4], $matches[5], $matches[6], $matches[2], $matches[3], $matches[1]);
3557 $times[$row[
"active_fi"]] += ($epoch_2 - $epoch_1);
3571 $ilDB = $DIC[
'ilDB'];
3573 $result =
$ilDB->queryF(
3574 "SELECT tst_times.* FROM tst_active, tst_times WHERE tst_active.test_fi = %s AND tst_active.active_id = tst_times.active_fi AND tst_active.active_id = %s ORDER BY tst_times.active_fi, tst_times.started",
3575 array(
'integer',
'integer'),
3579 while ($row =
$ilDB->fetchAssoc($result)) {
3580 preg_match(
"/(\d{4})-(\d{2})-(\d{2}) (\d{2}):(\d{2}):(\d{2})/", $row[
"started"], $matches);
3581 $epoch_1 = mktime($matches[4], $matches[5], $matches[6], $matches[2], $matches[3], $matches[1]);
3582 preg_match(
"/(\d{4})-(\d{2})-(\d{2}) (\d{2}):(\d{2}):(\d{2})/", $row[
"finished"], $matches);
3583 $epoch_2 = mktime($matches[4], $matches[5], $matches[6], $matches[2], $matches[3], $matches[1]);
3584 $time += ($epoch_2 - $epoch_1);
3598 $ilDB = $DIC[
'ilDB'];
3600 $result =
$ilDB->queryF(
3601 "SELECT * FROM tst_times WHERE active_fi = %s AND pass = %s ORDER BY started",
3602 array(
'integer',
'integer'),
3603 array($active_id, $pass)
3606 while ($row =
$ilDB->fetchAssoc($result)) {
3607 preg_match(
"/(\d{4})-(\d{2})-(\d{2}) (\d{2}):(\d{2}):(\d{2})/", $row[
"started"], $matches);
3608 $epoch_1 = mktime($matches[4], $matches[5], $matches[6], $matches[2], $matches[3], $matches[1]);
3609 preg_match(
"/(\d{4})-(\d{2})-(\d{2}) (\d{2}):(\d{2}):(\d{2})/", $row[
"finished"], $matches);
3610 $epoch_2 = mktime($matches[4], $matches[5], $matches[6], $matches[2], $matches[3], $matches[1]);
3611 $time += ($epoch_2 - $epoch_1);
3639 $ilDB = $DIC[
'ilDB'];
3641 $result =
$ilDB->queryF(
3642 "SELECT tst_times.* FROM tst_active, tst_times WHERE tst_active.test_fi = %s AND tst_active.active_id = tst_times.active_fi AND tst_active.active_id = %s ORDER BY tst_times.started",
3643 array(
'integer',
'integer'),
3644 array($test_id, $active_id)
3648 while ($row =
$ilDB->fetchAssoc($result)) {
3649 preg_match(
"/(\d{4})-(\d{2})-(\d{2}) (\d{2}):(\d{2}):(\d{2})/", $row[
"started"], $matches);
3650 $epoch_1 = mktime($matches[4], $matches[5], $matches[6], $matches[2], $matches[3], $matches[1]);
3651 if ($firstvisit == 0 || $epoch_1 < $firstvisit) {
3652 $firstvisit = $epoch_1;
3654 preg_match(
"/(\d{4})-(\d{2})-(\d{2}) (\d{2}):(\d{2}):(\d{2})/", $row[
"finished"], $matches);
3655 $epoch_2 = mktime($matches[4], $matches[5], $matches[6], $matches[2], $matches[3], $matches[1]);
3656 if ($epoch_2 > $lastvisit) {
3657 $lastvisit = $epoch_2;
3660 return array(
"firstvisit" => $firstvisit,
"lastvisit" => $lastvisit);
3669 $ilDB = $DIC[
'ilDB'];
3673 $result =
$ilDB->queryF(
3674 "SELECT tst_times.* FROM tst_active, tst_times WHERE tst_active.active_id = %s AND tst_active.active_id = tst_times.active_fi",
3681 while ($row =
$ilDB->fetchObject($result)) {
3682 preg_match(
"/(\d{4})-(\d{2})-(\d{2}) (\d{2}):(\d{2}):(\d{2})/", $row->started, $matches);
3683 $epoch_1 = mktime($matches[4], $matches[5], $matches[6], $matches[2], $matches[3], $matches[1]);
3684 if (!$first_visit) {
3685 $first_visit = $epoch_1;
3687 if ($epoch_1 < $first_visit) {
3688 $first_visit = $epoch_1;
3690 preg_match(
"/(\d{4})-(\d{2})-(\d{2}) (\d{2}):(\d{2}):(\d{2})/", $row->finished, $matches);
3691 $epoch_2 = mktime($matches[4], $matches[5], $matches[6], $matches[2], $matches[3], $matches[1]);
3693 $last_visit = $epoch_2;
3695 if ($epoch_2 > $last_visit) {
3696 $last_visit = $epoch_2;
3698 $times[$row->active_fi] += ($epoch_2 - $epoch_1);
3701 foreach ($times as
$key => $value) {
3702 $max_time += $value;
3704 if ((!$test_result[
"test"][
"total_reached_points"]) or (!$test_result[
"test"][
"total_max_points"])) {
3707 $percentage = ($test_result[
"test"][
"total_reached_points"] / $test_result[
"test"][
"total_max_points"]) * 100.0;
3708 if ($percentage < 0) {
3712 $mark_obj = $this->mark_schema->getMatchingMark($percentage);
3713 $first_date = getdate($first_visit);
3714 $last_date = getdate($last_visit);
3715 $qworkedthrough = 0;
3716 foreach ($test_result as
$key => $value) {
3717 if (preg_match(
"/\d+/",
$key)) {
3718 $qworkedthrough += $value[
"workedthrough"];
3721 if (!$qworkedthrough) {
3724 $atimeofwork = $max_time / $qworkedthrough;
3727 $obligationsAnswered = $test_result[
"test"][
"obligations_answered"];
3733 $result_mark = $mark_obj->getShortName();
3735 if ($mark_obj->getPassed() && $obligationsAnswered) {
3741 $percent_worked_through = 0;
3742 if (count($this->questions)) {
3743 $percent_worked_through = $qworkedthrough / count($this->questions);
3745 $result_array = array(
3746 "qworkedthrough" => $qworkedthrough,
3747 "qmax" => count($this->questions),
3748 "pworkedthrough" => $percent_worked_through,
3749 "timeofwork" => $max_time,
3750 "atimeofwork" => $atimeofwork,
3751 "firstvisit" => $first_date,
3752 "lastvisit" => $last_date,
3753 "resultspoints" => $test_result[
"test"][
"total_reached_points"],
3754 "maxpoints" => $test_result[
"test"][
"total_max_points"],
3755 "resultsmarks" => $result_mark,
3756 "passed" => $passed,
3757 "distancemedian" =>
"0" 3759 foreach ($test_result as
$key => $value) {
3760 if (preg_match(
"/\d+/",
$key)) {
3761 $result_array[
$key] = $value;
3764 return $result_array;
3776 $totalpoints_array = array();
3778 foreach ($all_users as $active_id => $user_name) {
3780 $reached = $test_result[
"test"][
"total_reached_points"];
3781 $total = $test_result[
"test"][
"total_max_points"];
3782 $percentage = $total != 0 ? $reached / $total : 0;
3783 $mark = $this->mark_schema->getMatchingMark($percentage * 100.0);
3785 $obligationsAnswered = $test_result[
"test"][
"obligations_answered"];
3788 if ($mark->getPassed() && $obligationsAnswered) {
3789 array_push($totalpoints_array, $test_result[
"test"][
"total_reached_points"]);
3793 return $totalpoints_array;
3804 $ilDB = $DIC[
'ilDB'];
3805 $result =
$ilDB->queryF(
3806 "SELECT tst_active.active_id, usr_data.usr_id, usr_data.firstname, usr_data.lastname, usr_data.title, usr_data.login FROM tst_active LEFT JOIN usr_data ON tst_active.user_fi = usr_data.usr_id WHERE tst_active.test_fi = %s ORDER BY usr_data.lastname ASC",
3810 $persons_array = array();
3811 while ($row =
$ilDB->fetchAssoc($result)) {
3812 $name = $this->
lng->txt(
"anonymous");
3813 $fullname = $this->
lng->txt(
"anonymous");
3816 if (strlen($row[
"firstname"] . $row[
"lastname"] . $row[
"title"]) == 0) {
3817 $name = $this->
lng->txt(
"deleted_user");
3818 $fullname = $this->
lng->txt(
"deleted_user");
3819 $login = $this->
lng->txt(
"unknown");
3821 $login = $row[
"login"];
3823 $name = $this->
lng->txt(
"anonymous");
3824 $fullname = $this->
lng->txt(
"anonymous");
3826 $name = trim($row[
"lastname"] .
", " . $row[
"firstname"] .
" " . $row[
"title"]);
3827 $fullname = trim($row[
"title"] .
" " . $row[
"firstname"] .
" " . $row[
"lastname"]);
3831 $persons_array[$row[
"active_id"]] = array(
3833 "fullname" => $fullname,
3837 return $persons_array;
3849 $ilDB = $DIC[
'ilDB'];
3850 $result =
$ilDB->queryF(
3851 "SELECT tst_active.user_fi, tst_active.active_id, usr_data.firstname, usr_data.lastname, usr_data.title FROM tst_active LEFT JOIN usr_data ON tst_active.user_fi = usr_data.usr_id WHERE tst_active.test_fi = %s ORDER BY usr_data.lastname " . strtoupper($name_sort_order),
3855 $persons_array = array();
3856 while ($row =
$ilDB->fetchAssoc($result)) {
3862 $persons_array[$row[
"active_id"]] = $this->
lng->txt(
"anonymous");
3864 if (strlen($row[
"firstname"] . $row[
"lastname"] . $row[
"title"]) == 0) {
3865 $persons_array[$row[
"active_id"]] = $this->
lng->txt(
"deleted_user");
3868 $persons_array[$row[
"active_id"]] = $row[
"lastname"];
3870 $persons_array[$row[
"active_id"]] = trim($row[
"lastname"] .
", " . $row[
"firstname"] .
" " . $row[
"title"]);
3875 return $persons_array;
3886 $ilDB = $DIC[
'ilDB'];
3887 $result =
$ilDB->queryF(
3888 "SELECT tst_active.user_fi, tst_active.active_id, usr_data.login, usr_data.firstname, usr_data.lastname, usr_data.title FROM tst_active LEFT JOIN usr_data ON tst_active.user_fi = usr_data.usr_id WHERE tst_active.test_fi = %s ORDER BY usr_data.lastname " . strtoupper($name_sort_order),
3892 $persons_array = array();
3893 while ($row =
$ilDB->fetchAssoc($result)) {
3895 $persons_array[$row[
"active_id"]] = array(
"name" => $this->
lng->txt(
"anonymous"));
3897 if (strlen($row[
"firstname"] . $row[
"lastname"] . $row[
"title"]) == 0) {
3898 $persons_array[$row[
"active_id"]] = array(
"name" => $this->
lng->txt(
"deleted_user"));
3901 $persons_array[$row[
"active_id"]] = array(
"name" => $row[
"lastname"]);
3903 $persons_array[$row[
"active_id"]] = array(
"name" => trim($row[
"lastname"] .
", " . $row[
"firstname"] .
" " . $row[
"title"]),
"login" => $row[
"login"]);
3908 return $persons_array;
3920 $ilDB = $DIC[
'ilDB'];
3923 $result =
$ilDB->queryF(
3924 "SELECT tst_test_rnd_qst.sequence, tst_test_rnd_qst.question_fi, " .
3925 "tst_test_rnd_qst.pass, qpl_questions.points " .
3926 "FROM tst_test_rnd_qst, qpl_questions " .
3927 "WHERE tst_test_rnd_qst.question_fi = qpl_questions.question_id " .
3928 "AND tst_test_rnd_qst.active_fi = %s ORDER BY tst_test_rnd_qst.sequence",
3933 $result =
$ilDB->queryF(
3934 "SELECT tst_test_question.sequence, tst_test_question.question_fi, " .
3935 "qpl_questions.points " .
3936 "FROM tst_test_question, tst_active, qpl_questions " .
3937 "WHERE tst_test_question.question_fi = qpl_questions.question_id " .
3938 "AND tst_active.active_id = %s AND tst_active.test_fi = tst_test_question.test_fi",
3944 if ($result->numRows()) {
3945 while ($row =
$ilDB->fetchAssoc($result)) {
3946 array_push($qtest, $row);
3961 $ilDB = $DIC[
'ilDB'];
3964 $result =
$ilDB->queryF(
3965 "SELECT tst_test_rnd_qst.sequence, tst_test_rnd_qst.question_fi, " .
3966 "qpl_questions.points " .
3967 "FROM tst_test_rnd_qst, qpl_questions " .
3968 "WHERE tst_test_rnd_qst.question_fi = qpl_questions.question_id " .
3969 "AND tst_test_rnd_qst.active_fi = %s AND tst_test_rnd_qst.pass = %s " .
3970 "ORDER BY tst_test_rnd_qst.sequence",
3971 array(
'integer',
'integer'),
3972 array($active_id, $pass)
3975 $result =
$ilDB->queryF(
3976 "SELECT tst_test_question.sequence, tst_test_question.question_fi, " .
3977 "qpl_questions.points " .
3978 "FROM tst_test_question, tst_active, qpl_questions " .
3979 "WHERE tst_test_question.question_fi = qpl_questions.question_id " .
3980 "AND tst_active.active_id = %s AND tst_active.test_fi = tst_test_question.test_fi",
3986 if ($result->numRows()) {
3987 while ($row =
$ilDB->fetchAssoc($result)) {
3988 array_push($qpass, $row);
4021 $list = $list->getAccessFilteredList(
4033 $ilDB = $DIC->database();
4038 SELECT tst_test_result.*, 4039 qpl_questions.original_id, 4040 qpl_questions.title questiontitle, 4041 qpl_questions.points maxpoints 4043 FROM tst_test_result, qpl_questions, tst_active 4045 WHERE tst_active.active_id = tst_test_result.active_fi 4046 AND qpl_questions.question_id = tst_test_result.question_fi 4047 AND tst_active.test_fi = %s 4049 ORDER BY tst_active.active_id ASC, tst_test_result.pass ASC, tst_test_result.tstamp DESC 4052 $result =
$ilDB->queryF(
4063 while ($row =
$ilDB->fetchAssoc($result)) {
4064 if (!
$data->participantExists($row[
"active_fi"])) {
4068 $participantObject =
$data->getParticipant($row[
"active_fi"]);
4069 $passObject = $participantObject->getPass($row[
"pass"]);
4075 $passObject->addAnsweredQuestion(
4076 $row[
"question_fi"],
4085 foreach (array_keys(
$data->getParticipants()) as $active_id) {
4087 for ($testpass = 0; $testpass <=
$data->getParticipant($active_id)->getLastPass(); $testpass++) {
4091 SELECT tst_test_rnd_qst.sequence, tst_test_rnd_qst.question_fi, qpl_questions.original_id, 4092 tst_test_rnd_qst.pass, qpl_questions.points, qpl_questions.title 4093 FROM tst_test_rnd_qst, qpl_questions 4094 WHERE tst_test_rnd_qst.question_fi = qpl_questions.question_id 4095 AND tst_test_rnd_qst.pass = %s 4096 AND tst_test_rnd_qst.active_fi = %s ORDER BY tst_test_rnd_qst.sequence 4099 $result =
$ilDB->queryF(
4101 array(
'integer',
'integer'),
4102 array($testpass, $active_id)
4105 if ($result->numRows()) {
4106 while ($row =
$ilDB->fetchAssoc($result)) {
4107 $tpass = array_key_exists(
"pass", $row) ? $row[
"pass"] : 0;
4109 $data->getParticipant($active_id)->addQuestion(
4110 $row[
"original_id"],
4111 $row[
"question_fi"],
4117 $data->addQuestionTitle($row[
"question_fi"], $row[
"title"]);
4122 $lastPass =
$data->getParticipant($active_id)->getLastPass();
4123 for ($testpass = 0; $testpass <= $lastPass; $testpass++) {
4125 $DIC->repositoryTree(),
4127 $DIC[
'component.repository'],
4132 $testSequenceFactory =
new ilTestSequenceFactory($DIC->database(), $DIC->language(), $DIC[
'refinery'], $DIC[
'component.repository'], $this);
4133 $testSequence = $testSequenceFactory->getSequenceByActiveIdAndPass($active_id, $testpass);
4135 $testSequence->loadFromDb($dynamicQuestionSetConfig);
4138 $sequence = $testSequence->getUserSequenceQuestions();
4140 $questionsIdsToRequest = array_diff(array_values($sequence), array_values($questionData));
4141 if (count($questionsIdsToRequest) > 0) {
4142 $questionIdsCondition =
' ' . $DIC->database()->in(
'question_id', array_values($questionsIdsToRequest),
false,
'integer') .
' ';
4144 $res = $DIC->database()->queryF(
4148 WHERE {$questionIdsCondition}",
4152 while ($row = $DIC->database()->fetchAssoc(
$res)) {
4153 $questionData[$row[
'question_id']] = $row;
4154 $data->addQuestionTitle($row[
'question_id'], $row[
'title']);
4158 foreach ($sequence as $questionId) {
4159 if (!isset($questionData[$questionId])) {
4163 $row = $questionData[$questionId];
4165 $data->getParticipant(
4168 $row[
'original_id'],
4169 $row[
'question_id'],
4178 SELECT tst_test_question.sequence, tst_test_question.question_fi, 4179 qpl_questions.points, qpl_questions.title, qpl_questions.original_id 4180 FROM tst_test_question, tst_active, qpl_questions 4181 WHERE tst_test_question.question_fi = qpl_questions.question_id 4182 AND tst_active.active_id = %s 4183 AND tst_active.test_fi = tst_test_question.test_fi 4184 ORDER BY tst_test_question.sequence 4187 $result =
$ilDB->queryF(
4193 if ($result->numRows()) {
4194 $questionsbysequence = array();
4196 while ($row =
$ilDB->fetchAssoc($result)) {
4197 $questionsbysequence[$row[
"sequence"]] = $row;
4200 $seqresult =
$ilDB->queryF(
4201 "SELECT * FROM tst_sequence WHERE active_fi = %s",
4206 while ($seqrow =
$ilDB->fetchAssoc($seqresult)) {
4207 $questionsequence = unserialize($seqrow[
"sequence"]);
4209 foreach ($questionsequence as $sidx => $seq) {
4210 $data->getParticipant($active_id)->addQuestion(
4211 $questionsbysequence[$seq][
"original_id"],
4212 $questionsbysequence[$seq][
"question_fi"],
4213 $questionsbysequence[$seq][
"points"],
4218 $data->addQuestionTitle(
4219 $questionsbysequence[$seq][
"question_fi"],
4220 $questionsbysequence[$seq][
"title"]
4232 foreach (array_keys(
$data->getParticipants()) as $active_id) {
4233 $tstUserData =
$data->getParticipant($active_id);
4235 $percentage = $tstUserData->getReachedPointsInPercent();
4237 $obligationsAnswered = $tstUserData->areObligationsAnswered();
4239 $mark = $this->mark_schema->getMatchingMark($percentage);
4241 if (is_object($mark)) {
4242 $tstUserData->setMark($mark->getShortName());
4243 $tstUserData->setMarkOfficial($mark->getOfficialName());
4245 $tstUserData->setPassed(
4246 $mark->getPassed() && $tstUserData->areObligationsAnswered()
4253 $tstUserData->getReached(),
4254 $tstUserData->getMaxPoints()
4257 $tstUserData->setECTSMark($ects_mark);
4262 $tstUserData->setFirstVisit($visitingTime[
"firstvisit"]);
4263 $tstUserData->setLastVisit($visitingTime[
"lastvisit"]);
4272 $ilDB = $DIC[
'ilDB'];
4276 switch ($questionSetType) {
4281 SELECT COUNT(qpl_questions.question_id) qcount, 4282 SUM(qpl_questions.points) qsum 4284 INNER JOIN tst_tests 4285 ON tst_tests.test_id = tst_active.test_fi 4286 INNER JOIN tst_dyn_quest_set_cfg 4287 ON tst_dyn_quest_set_cfg.test_fi = tst_tests.test_id 4288 INNER JOIN qpl_questions 4289 ON qpl_questions.obj_fi = tst_dyn_quest_set_cfg.source_qpl_fi 4290 AND qpl_questions.original_id IS NULL 4291 AND qpl_questions.complete = %s 4292 WHERE tst_active.active_id = %s 4294 array(
'integer',
'integer'),
4295 array(1, $active_id)
4304 SELECT tst_test_rnd_qst.pass, 4305 COUNT(tst_test_rnd_qst.question_fi) qcount, 4306 SUM(qpl_questions.points) qsum 4308 FROM tst_test_rnd_qst, 4311 WHERE tst_test_rnd_qst.question_fi = qpl_questions.question_id 4312 AND tst_test_rnd_qst.active_fi = %s 4315 GROUP BY tst_test_rnd_qst.active_fi, 4316 tst_test_rnd_qst.pass 4318 array(
'integer',
'integer'),
4319 array($active_id, $pass)
4328 SELECT COUNT(tst_test_question.question_fi) qcount, 4329 SUM(qpl_questions.points) qsum 4331 FROM tst_test_question, 4335 WHERE tst_test_question.question_fi = qpl_questions.question_id 4336 AND tst_test_question.test_fi = tst_active.test_fi 4337 AND tst_active.active_id = %s 4339 GROUP BY tst_test_question.test_fi 4349 throw new ilTestException(
"not supported question set type: $questionSetType");
4354 if (is_array($row)) {
4355 return array(
"count" => $row[
"qcount"],
"points" => $row[
"qsum"]);
4358 return array(
"count" => 0,
"points" => 0);
4363 $data = $this->getUnfilteredEvaluationData();
4364 if ($withStatistics) {
4365 $data->calculateStatistics();
4367 $data->setFilter($filterby, $filtertext);
4391 $ilDB = $DIC[
'ilDB'];
4393 $result =
$ilDB->queryF(
4394 "SELECT usr_data.usr_id, usr_data.firstname, usr_data.lastname, usr_data.title, usr_data.login, " .
4395 "tst_test_result.*, qpl_questions.original_id, qpl_questions.title questiontitle, " .
4396 "qpl_questions.points maxpoints " .
4397 "FROM tst_test_result, qpl_questions, tst_active " .
4398 "LEFT JOIN usr_data ON tst_active.user_fi = usr_data.usr_id " .
4399 "WHERE tst_active.active_id = tst_test_result.active_fi " .
4400 "AND qpl_questions.question_id = tst_test_result.question_fi " .
4401 "AND tst_active.test_fi = %s " .
4402 "ORDER BY tst_active.active_id, tst_test_result.pass, tst_test_result.tstamp",
4406 $overview = array();
4407 while ($row =
$ilDB->fetchAssoc($result)) {
4408 if (!array_key_exists($row[
"active_fi"], $overview)) {
4409 $overview[$row[
"active_fi"]] = array();
4410 $overview[$row[
"active_fi"]][
"firstname"] = $row[
"firstname"];
4411 $overview[$row[
"active_fi"]][
"lastname"] = $row[
"lastname"];
4412 $overview[$row[
"active_fi"]][
"title"] = $row[
"title"];
4413 $overview[$row[
"active_fi"]][
"login"] = $row[
"login"];
4414 $overview[$row[
"active_fi"]][
"usr_id"] = $row[
"usr_id"];
4415 $overview[$row[
"active_fi"]][
"started"] = $row[
"started"];
4416 $overview[$row[
"active_fi"]][
"finished"] = $row[
"finished"];
4418 if (!array_key_exists($row[
"pass"], $overview[$row[
"active_fi"]])) {
4419 $overview[$row[
"active_fi"]][$row[
"pass"]] = array();
4420 $overview[$row[
"active_fi"]][$row[
"pass"]][
"reached"] = 0;
4421 $overview[$row[
"active_fi"]][$row[
"pass"]][
"maxpoints"] = $row[
"maxpoints"];
4423 array_push($overview[$row[
"active_fi"]][$row[
"pass"]], $row);
4424 $overview[$row[
"active_fi"]][$row[
"pass"]][
"reached"] += $row[
"points"];
4439 $ilDB = $DIC[
'ilDB'];
4441 $result =
$ilDB->queryF(
4442 "SELECT usr_data.usr_id, usr_data.firstname, usr_data.lastname, usr_data.title, usr_data.login, " .
4443 "tst_test_result.*, qpl_questions.original_id, qpl_questions.title questiontitle, " .
4444 "qpl_questions.points maxpoints " .
4445 "FROM tst_test_result, qpl_questions, tst_active " .
4446 "LEFT JOIN usr_data ON tst_active.user_fi = usr_data.usr_id " .
4447 "WHERE tst_active.active_id = tst_test_result.active_fi " .
4448 "AND qpl_questions.question_id = tst_test_result.question_fi " .
4449 "AND tst_active.test_fi = %s AND tst_active.active_id = %s" .
4450 "ORDER BY tst_active.active_id, tst_test_result.pass, tst_test_result.tstamp",
4451 array(
'integer',
'integer'),
4454 $overview = array();
4455 while ($row =
$ilDB->fetchAssoc($result)) {
4456 if (!array_key_exists($row[
"active_fi"], $overview)) {
4457 $overview[$row[
"active_fi"]] = array();
4458 $overview[$row[
"active_fi"]][
"firstname"] = $row[
"firstname"];
4459 $overview[$row[
"active_fi"]][
"lastname"] = $row[
"lastname"];
4460 $overview[$row[
"active_fi"]][
"title"] = $row[
"title"];
4461 $overview[$row[
"active_fi"]][
"login"] = $row[
"login"];
4462 $overview[$row[
"active_fi"]][
"usr_id"] = $row[
"usr_id"];
4463 $overview[$row[
"active_fi"]][
"started"] = $row[
"started"];
4464 $overview[$row[
"active_fi"]][
"finished"] = $row[
"finished"];
4466 if (!array_key_exists($row[
"pass"], $overview[$row[
"active_fi"]])) {
4467 $overview[$row[
"active_fi"]][$row[
"pass"]] = array();
4468 $overview[$row[
"active_fi"]][$row[
"pass"]][
"reached"] = 0;
4469 $overview[$row[
"active_fi"]][$row[
"pass"]][
"maxpoints"] = $row[
"maxpoints"];
4471 array_push($overview[$row[
"active_fi"]][$row[
"pass"]], $row);
4472 $overview[$row[
"active_fi"]][$row[
"pass"]][
"reached"] += $row[
"points"];
4491 if (strlen($firstname . $lastname .
$title) == 0) {
4492 $name = $this->
lng->txt(
"deleted_user");
4497 $name = trim($lastname .
", " . $firstname .
" " . $title);
4500 $name = $this->
lng->txt(
"anonymous");
4523 if (strlen($firstname . $lastname .
$title) == 0) {
4529 $name = trim($lastname .
", " . $firstname .
" " . $title);
4531 if ($is_anonymous) {
4548 $query =
"SELECT tst_times.* FROM tst_active, tst_times WHERE tst_active.test_fi = %s AND tst_active.active_id = tst_times.active_fi";
4550 if (is_array($activeIdsFilter) && count($activeIdsFilter)) {
4551 $query .=
" AND " . $DIC->database()->in(
'active_id', $activeIdsFilter,
false,
'integer');
4554 $result = $DIC->database()->queryF(
$query, array(
'integer'), array($this->
getTestId()));
4556 while ($row = $DIC->database()->fetchObject($result)) {
4557 preg_match(
"/(\d{4})-(\d{2})-(\d{2}) (\d{2}):(\d{2}):(\d{2})/", $row->started, $matches);
4558 $epoch_1 = mktime($matches[4], $matches[5], $matches[6], $matches[2], $matches[3], $matches[1]);
4559 preg_match(
"/(\d{4})-(\d{2})-(\d{2}) (\d{2}):(\d{2}):(\d{2})/", $row->finished, $matches);
4560 $epoch_2 = mktime($matches[4], $matches[5], $matches[6], $matches[2], $matches[3], $matches[1]);
4561 if (isset($times[$row->active_fi])) {
4562 $times[$row->active_fi] += ($epoch_2 - $epoch_1);
4564 $times[$row->active_fi] = ($epoch_2 - $epoch_1);
4569 foreach ($times as
$key => $value) {
4570 $max_time += $value;
4574 $average_time = round($max_time / $counter);
4578 return $average_time;
4587 public function getAvailableQuestionpools($use_object_id =
false, $equal_points =
false, $could_be_offline =
false, $show_path =
false, $with_questioncount =
false, $permission =
"read"): array
4600 $time_in_seconds = 0;
4601 foreach ($this->questions as $question_id) {
4603 $est_time = $question->getEstimatedWorkingTime();
4604 $time_in_seconds += $est_time[
"h"] * 3600 + $est_time[
"m"] * 60 + $est_time[
"s"];
4606 $hours = (
int) ($time_in_seconds / 3600) ;
4607 $time_in_seconds = $time_in_seconds - ($hours * 3600);
4608 $minutes = (
int) ($time_in_seconds / 60);
4609 $time_in_seconds = $time_in_seconds - ($minutes * 60);
4610 $result = array(
"hh" => $hours,
"mm" => $minutes,
"ss" => $time_in_seconds);
4651 if ((!$question_type) and ($question_id > 0)) {
4655 if (!strlen($question_type)) {
4661 $question_type_gui = $question_type .
'GUI';
4662 $question =
new $question_type_gui();
4664 if ($question_id > 0) {
4665 $question->object->loadFromDb($question_id);
4668 $ilCtrl = $DIC[
'ilCtrl'];
4669 $ilDB = $DIC[
'ilDB'];
4674 $question->object->feedbackOBJ =
new $feedbackObjectClassname($question->object, $ilCtrl,
$ilDB,
$lng);
4676 $assSettings =
new ilSetting(
'assessment');
4678 $processLockerFactory->setQuestionId($question->object->getId());
4679 $processLockerFactory->setUserId(
$ilUser->getId());
4681 $question->object->setProcessLocker($processLockerFactory->getLocker());
4695 if (strcmp((
string) $question_id,
"") !== 0) {
4712 $this->questions = array_values($this->questions);
4713 $array_pos = array_search($target_index, $this->questions);
4714 if ($insert_mode == 0) {
4715 $part1 = array_slice($this->questions, 0, $array_pos);
4716 $part2 = array_slice($this->questions, $array_pos);
4717 } elseif ($insert_mode == 1) {
4718 $part1 = array_slice($this->questions, 0, $array_pos + 1);
4719 $part2 = array_slice($this->questions, $array_pos + 1);
4721 foreach ($move_questions as $question_id) {
4722 if (!(array_search($question_id, $part1) ===
false)) {
4723 unset($part1[array_search($question_id, $part1)]);
4725 if (!(array_search($question_id, $part2) ===
false)) {
4726 unset($part2[array_search($question_id, $part2)]);
4729 $part1 = array_values($part1);
4730 $part2 = array_values($part2);
4731 $new_array = array_values(array_merge($part1, $move_questions, $part2));
4732 $this->questions = array();
4734 foreach ($new_array as $question_id) {
4735 $this->questions[$counter] = $question_id;
4786 $component_repository = $DIC[
'component.repository'];
4787 $component_factory = $DIC[
'component.factory'];
4790 $ilDB = $DIC[
'ilDB'];
4794 if (count($available_pools)) {
4795 $available =
" AND " .
$ilDB->in(
'qpl_questions.obj_fi', $available_pools,
false,
'integer');
4799 if ($completeonly) {
4800 $available .=
" AND qpl_questions.complete = " .
$ilDB->quote(
"1",
'text');
4804 if (is_array($arrFilter)) {
4805 if (array_key_exists(
'title', $arrFilter) && strlen($arrFilter[
'title'])) {
4806 $where .=
" AND " .
$ilDB->like(
'qpl_questions.title',
'text',
"%%" . $arrFilter[
'title'] .
"%%");
4808 if (array_key_exists(
'description', $arrFilter) && strlen($arrFilter[
'description'])) {
4809 $where .=
" AND " .
$ilDB->like(
'qpl_questions.description',
'text',
"%%" . $arrFilter[
'description'] .
"%%");
4811 if (array_key_exists(
'author', $arrFilter) && strlen($arrFilter[
'author'])) {
4812 $where .=
" AND " .
$ilDB->like(
'qpl_questions.author',
'text',
"%%" . $arrFilter[
'author'] .
"%%");
4814 if (array_key_exists(
'type', $arrFilter) && strlen($arrFilter[
'type'])) {
4815 $where .=
" AND qpl_qst_type.type_tag = " .
$ilDB->quote($arrFilter[
'type'],
'text');
4817 if (array_key_exists(
'qpl', $arrFilter) && strlen($arrFilter[
'qpl'])) {
4818 $where .=
" AND " .
$ilDB->like(
'object_data.title',
'text',
"%%" . $arrFilter[
'qpl'] .
"%%");
4823 $original_clause =
" qpl_questions.original_id IS NULL";
4824 if (count($original_ids)) {
4825 $original_clause =
" qpl_questions.original_id IS NULL AND " .
$ilDB->in(
'qpl_questions.question_id', $original_ids,
true,
'integer');
4828 $query_result =
$ilDB->query(
" 4829 SELECT qpl_questions.*, qpl_questions.tstamp, 4830 qpl_qst_type.type_tag, qpl_qst_type.plugin, qpl_qst_type.plugin_name, 4831 object_data.title parent_title 4832 FROM qpl_questions, qpl_qst_type, object_data 4833 WHERE $original_clause $available 4834 AND object_data.obj_id = qpl_questions.obj_fi 4835 AND qpl_questions.tstamp > 0 4836 AND qpl_questions.question_type_fi = qpl_qst_type.question_type_id 4841 if ($query_result->numRows()) {
4842 while ($row =
$ilDB->fetchAssoc($query_result)) {
4845 if (!$row[
'plugin']) {
4846 $row[
'ttype' ] =
$lng->
txt($row[
"type_tag" ]);
4852 $plugin = $component_repository->getPluginByName($row[
'plugin_name']);
4857 $pl = $component_factory->getPlugin(
$plugin->getId());
4858 $row[
'ttype' ] = $pl->getQuestionTypeTranslation();
4878 foreach ($assessment->objectives as
$objectives) {
4879 foreach ($objectives->materials as $material) {
4894 foreach ($assessment->assessmentcontrol as $assessmentcontrol) {
4895 switch ($assessmentcontrol->getSolutionswitch()) {
4916 foreach ($assessment->qtimetadata as
$metadata) {
4917 switch ($metadata[
"label"]) {
4920 $type = $metadata[
"entry"];
4939 case "sequence_settings":
4942 case "solution_details":
4943 $result_details_settings = $result_details_settings->withShowSolutionDetails((
bool) $metadata[
"entry"]);
4945 case "print_bs_with_res":
4946 $result_details_settings = $result_details_settings->withPrintBestSolutionWithResult((
bool) $metadata[
"entry"]);
4954 case 'block_after_passed':
4957 case "pass_waiting":
4961 $this->
setKiosk($metadata[
"entry"]);
4963 case "showfinalstatement":
4976 case "highscore_enabled":
4977 $gamification_settings = $gamification_settings->withHighscoreEnabled((
bool) $metadata[
"entry"]);
4980 case "highscore_anon":
4981 $gamification_settings = $gamification_settings->withHighscoreAnon((
bool) $metadata[
"entry"]);
4984 case "highscore_achieved_ts":
4985 $gamification_settings = $gamification_settings->withHighscoreAchievedTS((
bool) $metadata[
"entry"]);
4988 case "highscore_score":
4989 $gamification_settings = $gamification_settings->withHighscoreScore((
bool) $metadata[
"entry"]);
4992 case "highscore_percentage":
4993 $gamification_settings = $gamification_settings->withHighscorePercentage((
bool) $metadata[
"entry"]);
4996 case "highscore_hints":
4997 $gamification_settings = $gamification_settings->withHighscoreHints((
bool) $metadata[
"entry"]);
5000 case "highscore_wtime":
5001 $gamification_settings = $gamification_settings->withHighscoreWTime((
bool) $metadata[
"entry"]);
5004 case "highscore_own_table":
5005 $gamification_settings = $gamification_settings->withHighscoreOwnTable((
bool) $metadata[
"entry"]);
5008 case "highscore_top_table":
5009 $gamification_settings = $gamification_settings->withHighscoreTopTable((
bool) $metadata[
"entry"]);
5012 case "highscore_top_num":
5013 $gamification_settings = $gamification_settings->withHighscoreTopNum((
int) $metadata[
"entry"]);
5016 case "hide_previous_results":
5017 if ($metadata[
"entry"] == 0) {
5023 case "use_previous_answers":
5026 case "answer_feedback":
5029 case "title_output":
5030 case "hide_title_points":
5033 case "question_set_type":
5037 if ($metadata[
"entry"]) {
5043 case "results_presentation":
5044 $result_details_settings = $result_details_settings->withResultsPresentation((
int) $metadata[
"entry"]);
5046 case "reset_processing_time":
5049 case "instant_verification":
5052 case "follow_qst_answer_fixation":
5055 case "instant_feedback_answer_fixation":
5058 case "force_instant_feedback":
5061 case "answer_feedback_points":
5073 case "fixed_participants":
5076 case "score_reporting":
5077 $result_summary_settings = $result_summary_settings->withScoreReporting((
int) $metadata[
"entry"]);
5079 case "shuffle_questions":
5082 case "count_system":
5083 $scoring_settings = $scoring_settings->withCountSystem((
int) $metadata[
"entry"]);
5085 case "mailnotification":
5091 case "exportsettings":
5092 $result_details_settings = $result_details_settings->withExportSettings((
int) $metadata[
"entry"]);
5094 case "score_cutting":
5095 $scoring_settings = $scoring_settings->withScoreCutting((
int) $metadata[
"entry"]);
5101 case "allowedUsers":
5105 case "allowedUsersTimeGap":
5108 case "pass_scoring":
5109 $scoring_settings = $scoring_settings->withPassScoring((
int) $metadata[
"entry"]);
5111 case 'pass_deletion_allowed':
5112 $result_summary_settings = $result_summary_settings->withPassDeletionAllowed((
bool) $metadata[
"entry"]);
5114 case "show_summary":
5117 case "reporting_date":
5118 $iso8601period = $metadata[
"entry"];
5119 if (preg_match(
"/P(\d+)Y(\d+)M(\d+)DT(\d+)H(\d+)M(\d+)S/", $iso8601period, $matches)) {
5120 $this->
setReportingDate(sprintf(
"%02d%02d%02d%02d%02d%02d", $matches[1], $matches[2], $matches[3], $matches[4], $matches[5], $matches[6]));
5123 case 'enable_processing_time':
5126 case "processing_time":
5129 case "starting_time":
5130 $iso8601period = $metadata[
"entry"];
5131 if (preg_match(
"/P(\d+)Y(\d+)M(\d+)DT(\d+)H(\d+)M(\d+)S/", $iso8601period, $matches)) {
5132 $date_time =
new ilDateTime(sprintf(
"%02d-%02d-%02d %02d:%02d:%02d", $matches[1], $matches[2], $matches[3], $matches[4], $matches[5], $matches[6]),
IL_CAL_DATETIME);
5138 $iso8601period = $metadata[
"entry"];
5139 if (preg_match(
"/P(\d+)Y(\d+)M(\d+)DT(\d+)H(\d+)M(\d+)S/", $iso8601period, $matches)) {
5140 $date_time =
new ilDateTime(sprintf(
"%02d-%02d-%02d %02d:%02d:%02d", $matches[1], $matches[2], $matches[3], $matches[4], $matches[5], $matches[6]),
IL_CAL_DATETIME);
5145 case "enable_examview":
5148 case 'show_examview_html':
5151 case 'show_examview_pdf':
5154 case 'redirection_mode':
5157 case 'redirection_url':
5160 case 'examid_in_kiosk':
5161 case 'examid_in_test_pass':
5164 case 'show_exam_id':
5165 case 'examid_in_test_res':
5166 $result_details_settings = $result_details_settings->withShowExamIdInTestResults((
bool) $metadata[
"entry"]);
5168 case 'enable_archiving':
5171 case 'sign_submission':
5174 case 'char_selector_availability':
5177 case 'char_selector_definition':
5180 case 'skill_service':
5183 case 'result_tax_filters':
5184 $tax_ids = strlen($metadata[
'entry']) ? unserialize($metadata[
'entry']) : [];
5185 $result_details_settings = $result_details_settings->withTaxonomyFilterIds($tax_ids);
5187 case 'show_grading_status':
5188 $result_summary_settings = $result_summary_settings->withShowGradingStatusEnabled((
bool) $metadata[
"entry"]);
5190 case 'show_grading_mark':
5191 $result_summary_settings = $result_summary_settings->withShowGradingMarkEnabled((
bool) $metadata[
"entry"]);
5193 case 'activation_limited':
5196 case 'activation_start_time':
5199 case 'activation_end_time':
5202 case 'activation_visibility':
5208 case 'autosave_ival':
5211 case 'offer_question_hints':
5214 case 'instant_feedback_specific':
5217 case 'obligations_enabled':
5221 if (preg_match(
"/mark_step_\d+/", $metadata[
"label"])) {
5222 $xmlmark = $metadata[
"entry"];
5223 preg_match(
"/<short>(.*?)<\/short>/", $xmlmark, $matches);
5224 $mark_short = $matches[1];
5225 preg_match(
"/<official>(.*?)<\/official>/", $xmlmark, $matches);
5226 $mark_official = $matches[1];
5227 preg_match(
"/<percentage>(.*?)<\/percentage>/", $xmlmark, $matches);
5228 $mark_percentage = $matches[1];
5229 preg_match(
"/<passed>(.*?)<\/passed>/", $xmlmark, $matches);
5230 $mark_passed = $matches[1];
5231 $this->mark_schema->addMarkStep($mark_short, $mark_official, $mark_percentage, $mark_passed);
5236 $result_summary_settings = $result_summary_settings->withShowPassDetails($result_details_settings->getShowPassDetails());
5237 $score_settings = $score_settings
5239 ->withScoringSettings($scoring_settings)
5240 ->withResultDetailsSettings($result_details_settings)
5241 ->withResultSummarySettings($result_summary_settings);
5250 if (file_exists($importfile)) {
5257 $ilLog = $DIC[
'ilLog'];
5258 $ilLog->write(
"Error: Could not open XHTML mob file for test introduction during test import. File $importfile does not exist!");
5274 $a_xml_writer->xmlHeader();
5275 $a_xml_writer->xmlSetDtdDef(
"<!DOCTYPE questestinterop SYSTEM \"ims_qtiasiv1p2p1.dtd\">");
5276 $a_xml_writer->xmlStartTag(
"questestinterop");
5282 $a_xml_writer->xmlStartTag(
"assessment", $attrs);
5284 $a_xml_writer->xmlElement(
"qticomment", null, $this->
getDescription());
5287 if ($this->enable_processing_time) {
5288 preg_match(
"/(\d+):(\d+):(\d+)/", $this->processing_time, $matches);
5289 $a_xml_writer->xmlElement(
"duration", null, sprintf(
"P0Y0M0DT%dH%dM%dS", $matches[1], $matches[2], $matches[3]));
5293 $a_xml_writer->xmlStartTag(
"qtimetadata");
5294 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5295 $a_xml_writer->xmlElement(
"fieldlabel", null,
"ILIAS_VERSION");
5296 $a_xml_writer->xmlElement(
"fieldentry", null,
ILIAS_VERSION);
5297 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5300 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5301 $a_xml_writer->xmlElement(
"fieldlabel", null,
"anonymity");
5302 $a_xml_writer->xmlElement(
"fieldentry", null, sprintf(
"%d", $this->
getAnonymity()));
5303 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5306 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5307 $a_xml_writer->xmlElement(
"fieldlabel", null,
"question_set_type");
5309 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5312 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5313 $a_xml_writer->xmlElement(
"fieldlabel", null,
"sequence_settings");
5315 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5318 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5319 $a_xml_writer->xmlElement(
"fieldlabel", null,
"author");
5320 $a_xml_writer->xmlElement(
"fieldentry", null, $this->
getAuthor());
5321 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5324 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5325 $a_xml_writer->xmlElement(
"fieldlabel", null,
"reset_processing_time");
5327 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5330 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5331 $a_xml_writer->xmlElement(
"fieldlabel", null,
"count_system");
5332 $a_xml_writer->xmlElement(
"fieldentry", null, $this->
getCountSystem());
5333 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5336 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5337 $a_xml_writer->xmlElement(
"fieldlabel", null,
"score_cutting");
5338 $a_xml_writer->xmlElement(
"fieldentry", null, $this->
getScoreCutting());
5339 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5342 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5343 $a_xml_writer->xmlElement(
"fieldlabel", null,
"password");
5344 $a_xml_writer->xmlElement(
"fieldentry", null, $this->
getPassword());
5345 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5348 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5349 $a_xml_writer->xmlElement(
"fieldlabel", null,
"allowedUsers");
5350 $a_xml_writer->xmlElement(
"fieldentry", null, $this->
getAllowedUsers());
5351 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5354 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5355 $a_xml_writer->xmlElement(
"fieldlabel", null,
"allowedUsersTimeGap");
5357 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5360 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5361 $a_xml_writer->xmlElement(
"fieldlabel", null,
"pass_scoring");
5362 $a_xml_writer->xmlElement(
"fieldentry", null, $this->
getPassScoring());
5363 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5365 $a_xml_writer->xmlStartTag(
'qtimetadatafield');
5366 $a_xml_writer->xmlElement(
'fieldlabel', null,
'pass_deletion_allowed');
5368 $a_xml_writer->xmlEndTag(
'qtimetadatafield');
5372 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5373 $a_xml_writer->xmlElement(
"fieldlabel", null,
"reporting_date");
5374 preg_match(
"/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/", $this->reporting_date, $matches);
5375 $a_xml_writer->xmlElement(
"fieldentry", null, sprintf(
"P%dY%dM%dDT%dH%dM%dS", $matches[1], $matches[2], $matches[3], $matches[4], $matches[5], $matches[6]));
5376 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5379 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5380 $a_xml_writer->xmlElement(
"fieldlabel", null,
"nr_of_tries");
5381 $a_xml_writer->xmlElement(
"fieldentry", null, sprintf(
"%d", $this->
getNrOfTries()));
5382 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5385 $a_xml_writer->xmlStartTag(
'qtimetadatafield');
5386 $a_xml_writer->xmlElement(
'fieldlabel', null,
'block_after_passed');
5388 $a_xml_writer->xmlEndTag(
'qtimetadatafield');
5391 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5392 $a_xml_writer->xmlElement(
"fieldlabel", null,
"pass_waiting");
5393 $a_xml_writer->xmlElement(
"fieldentry", null, $this->
getPassWaiting());
5394 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5397 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5398 $a_xml_writer->xmlElement(
"fieldlabel", null,
"kiosk");
5399 $a_xml_writer->xmlElement(
"fieldentry", null, sprintf(
"%d", $this->
getKiosk()));
5400 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5404 $a_xml_writer->xmlStartTag(
'qtimetadatafield');
5405 $a_xml_writer->xmlElement(
"fieldlabel", null,
"redirection_mode");
5407 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5410 $a_xml_writer->xmlStartTag(
'qtimetadatafield');
5411 $a_xml_writer->xmlElement(
"fieldlabel", null,
"redirection_url");
5413 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5416 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5417 $a_xml_writer->xmlElement(
"fieldlabel", null,
"use_previous_answers");
5419 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5422 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5423 $a_xml_writer->xmlElement(
"fieldlabel", null,
"title_output");
5424 $a_xml_writer->xmlElement(
"fieldentry", null, sprintf(
"%d", $this->
getTitleOutput()));
5425 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5428 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5429 $a_xml_writer->xmlElement(
"fieldlabel", null,
"results_presentation");
5431 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5434 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5435 $a_xml_writer->xmlElement(
"fieldlabel", null,
"examid_in_test_pass");
5437 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5440 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5441 $a_xml_writer->xmlElement(
"fieldlabel", null,
"examid_in_test_res");
5443 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5446 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5447 $a_xml_writer->xmlElement(
"fieldlabel", null,
"show_summary");
5449 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5452 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5453 $a_xml_writer->xmlElement(
"fieldlabel", null,
"score_reporting");
5454 $a_xml_writer->xmlElement(
"fieldentry", null, sprintf(
"%d", $this->
getScoreReporting()));
5455 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5457 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5458 $a_xml_writer->xmlElement(
"fieldlabel", null,
"solution_details");
5460 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5461 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5462 $a_xml_writer->xmlElement(
"fieldlabel", null,
"print_bs_with_res");
5464 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5467 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5468 $a_xml_writer->xmlElement(
"fieldlabel", null,
"instant_verification");
5470 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5473 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5474 $a_xml_writer->xmlElement(
"fieldlabel", null,
"answer_feedback");
5475 $a_xml_writer->xmlElement(
"fieldentry", null, sprintf(
"%d", $this->
getAnswerFeedback()));
5476 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5479 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5480 $a_xml_writer->xmlElement(
"fieldlabel", null,
"answer_feedback_points");
5482 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5485 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5486 $a_xml_writer->xmlElement(
"fieldlabel", null,
"follow_qst_answer_fixation");
5488 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5491 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5492 $a_xml_writer->xmlElement(
"fieldlabel", null,
"instant_feedback_answer_fixation");
5494 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5497 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5498 $a_xml_writer->xmlElement(
"fieldlabel", null,
"force_instant_feedback");
5500 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5504 $highscore_metadata = array(
5516 foreach ($highscore_metadata as $label =>
$data) {
5517 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5518 $a_xml_writer->xmlElement(
"fieldlabel", null, $label);
5519 $a_xml_writer->xmlElement(
"fieldentry", null, sprintf(
"%d",
$data[
'value']));
5520 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5524 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5525 $a_xml_writer->xmlElement(
"fieldlabel", null,
"show_cancel");
5526 $a_xml_writer->xmlElement(
"fieldentry", null, sprintf(
"%d", $this->
getShowCancel()));
5527 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5530 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5531 $a_xml_writer->xmlElement(
"fieldlabel", null,
"show_marker");
5532 $a_xml_writer->xmlElement(
"fieldentry", null, sprintf(
"%d", $this->
getShowMarker()));
5533 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5536 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5537 $a_xml_writer->xmlElement(
"fieldlabel", null,
"fixed_participants");
5539 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5542 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5543 $a_xml_writer->xmlElement(
"fieldlabel", null,
"showfinalstatement");
5544 $a_xml_writer->xmlElement(
"fieldentry", null, sprintf(
"%d", (($this->
getShowFinalStatement()) ?
"1" :
"0")));
5545 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5548 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5549 $a_xml_writer->xmlElement(
"fieldlabel", null,
"showinfo");
5550 $a_xml_writer->xmlElement(
"fieldentry", null, sprintf(
"%d", (($this->
getShowInfo()) ?
"1" :
"0")));
5551 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5554 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5555 $a_xml_writer->xmlElement(
"fieldlabel", null,
"mailnotification");
5557 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5560 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5561 $a_xml_writer->xmlElement(
"fieldlabel", null,
"mailnottype");
5563 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5566 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5567 $a_xml_writer->xmlElement(
"fieldlabel", null,
"exportsettings");
5569 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5572 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5573 $a_xml_writer->xmlElement(
"fieldlabel", null,
"forcejs");
5574 $a_xml_writer->xmlElement(
"fieldentry", null, sprintf(
"%d", (($this->
getForceJS()) ?
"1" :
"0")));
5575 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5578 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5579 $a_xml_writer->xmlElement(
"fieldlabel", null,
"customstyle");
5580 $a_xml_writer->xmlElement(
"fieldentry", null, $this->
getCustomStyle());
5581 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5584 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5585 $a_xml_writer->xmlElement(
"fieldlabel", null,
"shuffle_questions");
5586 $a_xml_writer->xmlElement(
"fieldentry", null, sprintf(
"%d", $this->
getShuffleQuestions()));
5587 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5590 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5591 $a_xml_writer->xmlElement(
"fieldlabel", null,
"processing_time");
5593 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5596 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5597 $a_xml_writer->xmlElement(
"fieldlabel", null,
"enable_examview");
5598 $a_xml_writer->xmlElement(
"fieldentry", null, (
int) $this->
getEnableExamview());
5599 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5602 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5603 $a_xml_writer->xmlElement(
"fieldlabel", null,
"show_examview_html");
5605 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5608 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5609 $a_xml_writer->xmlElement(
"fieldlabel", null,
"show_examview_pdf");
5611 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5614 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5615 $a_xml_writer->xmlElement(
"fieldlabel", null,
"enable_archiving");
5617 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5620 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5621 $a_xml_writer->xmlElement(
"fieldlabel", null,
"sign_submission");
5622 $a_xml_writer->xmlElement(
"fieldentry", null, (
int) $this->
getSignSubmission());
5623 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5626 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5627 $a_xml_writer->xmlElement(
"fieldlabel", null,
"char_selector_availability");
5629 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5632 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5633 $a_xml_writer->xmlElement(
"fieldlabel", null,
"char_selector_definition");
5635 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5638 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5639 $a_xml_writer->xmlElement(
"fieldlabel", null,
"skill_service");
5641 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5644 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5645 $a_xml_writer->xmlElement(
"fieldlabel", null,
"result_tax_filters");
5647 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5650 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5651 $a_xml_writer->xmlElement(
"fieldlabel", null,
"show_grading_status");
5653 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5656 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5657 $a_xml_writer->xmlElement(
"fieldlabel", null,
"show_grading_mark");
5659 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5664 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5665 $a_xml_writer->xmlElement(
"fieldlabel", null,
"starting_time");
5667 $a_xml_writer->xmlElement(
"fieldentry", null, $backward_compatibility_format);
5668 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5672 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5673 $a_xml_writer->xmlElement(
"fieldlabel", null,
"ending_time");
5675 $a_xml_writer->xmlElement(
"fieldentry", null, $backward_compatibility_format);
5676 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5681 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5682 $a_xml_writer->xmlElement(
"fieldlabel", null,
"activation_limited");
5684 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5687 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5688 $a_xml_writer->xmlElement(
"fieldlabel", null,
"activation_start_time");
5690 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5693 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5694 $a_xml_writer->xmlElement(
"fieldlabel", null,
"activation_end_time");
5696 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5699 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5700 $a_xml_writer->xmlElement(
"fieldlabel", null,
"activation_visibility");
5702 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5705 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5706 $a_xml_writer->xmlElement(
"fieldlabel", null,
"autosave");
5707 $a_xml_writer->xmlElement(
"fieldentry", null, (
int) $this->
getAutosave());
5708 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5711 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5712 $a_xml_writer->xmlElement(
"fieldlabel", null,
"autosave_ival");
5713 $a_xml_writer->xmlElement(
"fieldentry", null, $this->
getAutosaveIval());
5714 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5717 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5718 $a_xml_writer->xmlElement(
"fieldlabel", null,
"offer_question_hints");
5720 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5723 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5724 $a_xml_writer->xmlElement(
"fieldlabel", null,
"instant_feedback_specific");
5726 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5729 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5730 $a_xml_writer->xmlElement(
"fieldlabel", null,
"instant_feedback_answer_fixation");
5732 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5735 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5736 $a_xml_writer->xmlElement(
"fieldlabel", null,
"obligations_enabled");
5738 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5741 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5742 $a_xml_writer->xmlElement(
"fieldlabel", null,
"enable_processing_time");
5744 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5746 foreach ($this->mark_schema->mark_steps as
$index => $mark) {
5748 $a_xml_writer->xmlStartTag(
"qtimetadatafield");
5749 $a_xml_writer->xmlElement(
"fieldlabel", null,
"mark_step_$index");
5750 $a_xml_writer->xmlElement(
"fieldentry", null, sprintf(
5751 "<short>%s</short><official>%s</official><percentage>%.2f</percentage><passed>%d</passed>",
5752 $mark->getShortName(),
5753 $mark->getOfficialName(),
5754 $mark->getMinimumLevel(),
5757 $a_xml_writer->xmlEndTag(
"qtimetadatafield");
5759 $a_xml_writer->xmlEndTag(
"qtimetadata");
5762 $a_xml_writer->xmlStartTag(
"objectives");
5764 $a_xml_writer->xmlEndTag(
"objectives");
5769 "solutionswitch" =>
"Yes" 5774 $a_xml_writer->xmlElement(
"assessmentcontrol", $attrs, null);
5778 $a_xml_writer->xmlStartTag(
"presentation_material");
5779 $a_xml_writer->xmlStartTag(
"flow_mat");
5781 $a_xml_writer->xmlEndTag(
"flow_mat");
5782 $a_xml_writer->xmlEndTag(
"presentation_material");
5788 $a_xml_writer->xmlElement(
"section", $attrs, null);
5789 $a_xml_writer->xmlEndTag(
"assessment");
5790 $a_xml_writer->xmlEndTag(
"questestinterop");
5792 $xml = $a_xml_writer->xmlDumpMem(
false);
5804 preg_match(
"/(\d{4})-(\d{2})-(\d{2}) (\d{2}):(\d{2}):(\d{2})/", $date_time, $matches);
5805 $iso8601_period = sprintf(
"P%dY%dM%dDT%dH%dM%dS", $matches[1], $matches[2], $matches[3], $matches[4], $matches[5], $matches[6]);
5806 return $iso8601_period;
5818 $ilBench = $DIC[
'ilBench'];
5820 $this->mob_ids = array();
5821 $this->file_ids = array();
5827 $expLog->write(date(
"[y-m-d H:i:s] ") .
"Start Export Page Objects");
5828 $ilBench->start(
"ContentObjectExport",
"exportPageObjects");
5830 $ilBench->stop(
"ContentObjectExport",
"exportPageObjects");
5831 $expLog->write(date(
"[y-m-d H:i:s] ") .
"Finished Export Page Objects");
5834 $expLog->write(date(
"[y-m-d H:i:s] ") .
"Start Export Media Objects");
5835 $ilBench->start(
"ContentObjectExport",
"exportMediaObjects");
5837 $ilBench->stop(
"ContentObjectExport",
"exportMediaObjects");
5838 $expLog->write(date(
"[y-m-d H:i:s] ") .
"Finished Export Media Objects");
5841 $expLog->write(date(
"[y-m-d H:i:s] ") .
"Start Export File Items");
5842 $ilBench->start(
"ContentObjectExport",
"exportFileItems");
5844 $ilBench->stop(
"ContentObjectExport",
"exportFileItems");
5845 $expLog->write(date(
"[y-m-d H:i:s] ") .
"Finished Export File Items");
5857 $md2xml->setExportMode(
true);
5858 $md2xml->startExport();
5859 $a_xml_writer->appendXML($md2xml->getXML());
5869 if ($a_tag ==
"Identifier" && $a_param ==
"Entry") {
5886 $ilBench = $DIC[
'ilBench'];
5888 foreach ($this->questions as $question_id) {
5889 $ilBench->start(
"ContentObjectExport",
"exportPageObject");
5890 $expLog->write(date(
"[y-m-d H:i:s] ") .
"Page Object " . $question_id);
5893 $a_xml_writer->xmlStartTag(
"PageObject", $attrs);
5897 $ilBench->start(
"ContentObjectExport",
"exportPageObject_XML");
5899 $page_object->buildDom();
5900 $page_object->insertInstIntoIDs($a_inst);
5901 $mob_ids = $page_object->collectMediaObjects(
false);
5903 $xml = $page_object->getXMLFromDom(
false,
false,
false,
"",
true);
5904 $xml = str_replace(
"&",
"&", $xml);
5905 $a_xml_writer->appendXML($xml);
5906 $page_object->freeDom();
5907 unset($page_object);
5909 $ilBench->stop(
"ContentObjectExport",
"exportPageObject_XML");
5912 $ilBench->start(
"ContentObjectExport",
"exportPageObject_CollectMedia");
5914 foreach ($mob_ids as $mob_id) {
5915 $this->mob_ids[$mob_id] = $mob_id;
5917 $ilBench->stop(
"ContentObjectExport",
"exportPageObject_CollectMedia");
5920 $ilBench->start(
"ContentObjectExport",
"exportPageObject_CollectFileItems");
5922 foreach ($file_ids as $file_id) {
5923 $this->file_ids[$file_id] = $file_id;
5925 $ilBench->stop(
"ContentObjectExport",
"exportPageObject_CollectFileItems");
5927 $a_xml_writer->xmlEndTag(
"PageObject");
5930 $ilBench->stop(
"ContentObjectExport",
"exportPageObject");
5939 foreach ($this->mob_ids as $mob_id) {
5940 $expLog->write(date(
"[y-m-d H:i:s] ") .
"Media Object " . $mob_id);
5943 $media_obj->exportXML($a_xml_writer, $a_inst);
5944 $media_obj->exportFiles($a_target_dir);
5956 foreach ($this->file_ids as $file_id) {
5957 $expLog->write(date(
"[y-m-d H:i:s] ") .
"File Item " . $file_id);
5958 $file_dir = $target_dir .
'/objects/il_' .
IL_INST_ID .
'_file_' . $file_id;
5960 $file_obj =
new ilObjFile($file_id,
false);
5961 $source_file = $file_obj->getFile($file_obj->getVersion());
5962 if (!is_file($source_file)) {
5963 $source_file = $file_obj->getFile();
5965 if (is_file($source_file)) {
5966 copy($source_file, $file_dir .
'/' . $file_obj->getFileName());
6000 public function getECTSGrade($passed_array, $reached_points, $max_points): string
6002 return self::_getECTSGrade($passed_array, $reached_points, $max_points, $this->ects_grades[
"A"], $this->ects_grades[
"B"], $this->ects_grades[
"C"], $this->ects_grades[
"D"], $this->ects_grades[
"E"], $this->ects_fx);
6012 $passed_statistics->setData($points_passed);
6013 $ects_percentiles = array(
6014 "A" => $passed_statistics->quantile(
$a),
6015 "B" => $passed_statistics->quantile(
$b),
6016 "C" => $passed_statistics->quantile(
$c),
6017 "D" => $passed_statistics->quantile(
$d),
6018 "E" => $passed_statistics->quantile(
$e)
6020 if (count($points_passed) && ($reached_points >= $ects_percentiles[
"A"])) {
6022 } elseif (count($points_passed) && ($reached_points >= $ects_percentiles[
"B"])) {
6024 } elseif (count($points_passed) && ($reached_points >= $ects_percentiles[
"C"])) {
6026 } elseif (count($points_passed) && ($reached_points >= $ects_percentiles[
"D"])) {
6028 } elseif (count($points_passed) && ($reached_points >= $ects_percentiles[
"E"])) {
6030 } elseif (strcmp($fx,
"") != 0) {
6031 if ($max_points > 0) {
6032 $percentage = ($reached_points / $max_points) * 100.0;
6033 if ($percentage < 0) {
6039 if ($percentage >= $fx) {
6054 return $this->mark_schema->checkMarks();
6082 $ilDB = $DIC[
'ilDB'];
6083 $component_repository = $DIC[
'component.repository'];
6084 $tree = $DIC[
'tree'];
6135 $md_life = $md->getLifecycle();
6137 if (strlen($a_author) == 0) {
6140 $a_author =
$ilUser->getFullname();
6143 $md_life = $md->addLifecycle();
6145 $con = $md_life->addContribute();
6146 $con->setRole(
"Author");
6148 $ent = $con->addEntity();
6149 $ent->setEntity($a_author);
6173 $md_life = $md->getLifecycle();
6175 $ids = $md_life->getContributeIds();
6176 foreach ($ids as
$id) {
6177 $md_cont = $md_life->getContribute($id);
6178 if (strcmp($md_cont->getRole(),
"Author") == 0) {
6179 $entids = $md_cont->getEntityIds();
6180 foreach ($entids as $entid) {
6181 $md_ent = $md_cont->getEntity($entid);
6182 array_push($author, $md_ent->getEntity());
6187 return join(
",", $author);
6200 $md =
new ilMD($obj_id, 0,
"tst");
6201 $md_life = $md->getLifecycle();
6203 $ids = $md_life->getContributeIds();
6204 foreach ($ids as
$id) {
6205 $md_cont = $md_life->getContribute($id);
6206 if (strcmp($md_cont->getRole(),
"Author") == 0) {
6207 $entids = $md_cont->getEntityIds();
6208 foreach ($entids as $entid) {
6209 $md_ent = $md_cont->getEntity($entid);
6210 array_push($author, $md_ent->getEntity());
6215 return join(
",", $author);
6228 $ilDB = $DIC[
'ilDB'];
6230 $result_array = array();
6231 $tests = array_slice(
6239 if (count($tests)) {
6242 if ($use_object_id) {
6244 $result_array[$obj_id] = $titles[
$ref_id];
6250 return $result_array;
6261 public function cloneObject(
int $target_id,
int $copy_id = 0,
bool $omit_tree =
false): ?
ilObject 6266 $certificateLogger = $DIC->logger()->cert();
6267 $tree = $DIC[
'tree'];
6268 $ilDB = $DIC->database();
6269 $component_repository = $DIC[
'component.repository'];
6275 $newObj = parent::cloneObject($target_id, $copy_id, $omit_tree);
6276 $newObj->setTmpCopyWizardCopyId($copy_id);
6281 if ($cp_options->isRootNode($this->getRefId())) {
6282 $newObj->setOfflineStatus(
true);
6309 $newObj->setKiosk($this->
getKiosk());
6357 $newObj->saveToDb();
6366 $templateRepository,
6367 $DIC->filesystem()->web(),
6372 $cloneAction->cloneCertificate($this, $newObj);
6375 $testQuestionSetConfigFactory->getQuestionSetConfig()->cloneQuestionSetRelatedData($newObj);
6376 $newObj->saveQuestionsToDb();
6379 $skillLevelThresholdList->setTestId($this->
getTestId());
6380 $skillLevelThresholdList->loadFromDb();
6381 $skillLevelThresholdList->cloneListForTest($newObj->getTestId());
6383 $newObj->saveToDb();
6384 $newObj->updateMetaData();
6388 $score_settings->
withTestId($newObj->getTestId())
6392 $obj_settings->cloneSettings($newObj->getId());
6403 $tree = $DIC[
'tree'];
6404 $ilDB = $DIC[
'ilDB'];
6405 $component_repository = $DIC[
'component.repository'];
6410 $component_repository,
6414 $questionSetConfig->loadFromDb();
6416 if ($questionSetConfig->isQuestionAmountConfigurationModePerPool()) {
6423 $sourcePoolDefinitionList->loadDefinitions();
6425 if (is_int($sourcePoolDefinitionList->getQuestionAmount())) {
6426 $num = $sourcePoolDefinitionList->getQuestionAmount();
6428 } elseif (is_int($questionSetConfig->getQuestionAmountPerTest())) {
6429 $num = $questionSetConfig->getQuestionAmountPerTest();
6433 $num = count($this->questions);
6444 return count($this->questions);
6460 if (strcmp($question_id,
"") != 0) {
6476 $ilDB = $DIC[
'ilDB'];
6478 $result =
$ilDB->queryF(
6479 "SELECT obj_fi FROM tst_tests WHERE test_id = %s",
6483 if ($result->numRows()) {
6484 $row =
$ilDB->fetchAssoc($result);
6485 $object_id = $row[
"obj_fi"];
6500 $ilDB = $DIC[
'ilDB'];
6502 $result =
$ilDB->queryF(
6503 "SELECT tst_tests.obj_fi FROM tst_tests, tst_active WHERE tst_tests.test_id = tst_active.test_fi AND tst_active.active_id = %s",
6507 if ($result->numRows()) {
6508 $row =
$ilDB->fetchAssoc($result);
6509 $object_id = $row[
"obj_fi"];
6524 $ilDB = $DIC[
'ilDB'];
6526 $result =
$ilDB->queryF(
6527 "SELECT test_id FROM tst_tests WHERE obj_fi = %s",
6531 if ($result->numRows()) {
6532 $row =
$ilDB->fetchAssoc($result);
6533 $test_id = $row[
"test_id"];
6549 $ilDB = $DIC[
'ilDB'];
6551 if (!$active_id || !$question_id) {
6552 if ($pass === null) {
6555 if ($pass === null) {
6558 $result =
$ilDB->queryF(
6559 "SELECT value1 FROM tst_solutions WHERE active_fi = %s AND question_fi = %s AND pass = %s",
6560 array(
'integer',
'integer',
'integer'),
6561 array($active_id, $question_id, $pass)
6563 if ($result->numRows() == 1) {
6564 $row =
$ilDB->fetchAssoc($result);
6565 return $row[
"value1"];
6581 $ilDB = $DIC[
'ilDB'];
6585 $result =
$ilDB->queryF(
6586 "SELECT question_text FROM qpl_questions WHERE question_id = %s",
6590 if ($result->numRows() == 1) {
6591 $row =
$ilDB->fetchAssoc($result);
6592 $res = $row[
"question_text"];
6606 return $participantList;
6617 return $participantList;
6626 public function &
getInvitedUsers($user_id =
"", $order =
"login, lastname, firstname"): array
6629 $ilDB = $DIC[
'ilDB'];
6631 $result_array = array();
6634 if (is_numeric($user_id)) {
6635 $result =
$ilDB->queryF(
6636 "SELECT tst_active.active_id, tst_active.tries, usr_id, %s login, %s lastname, %s firstname, tst_invited_user.clientip, " .
6637 "tst_active.submitted test_finished, matriculation, COALESCE(tst_active.last_finished_pass, -1) <> tst_active.last_started_pass unfinished_passes FROM usr_data, tst_invited_user " .
6638 "LEFT JOIN tst_active ON tst_active.user_fi = tst_invited_user.user_fi AND tst_active.test_fi = tst_invited_user.test_fi " .
6639 "WHERE tst_invited_user.test_fi = %s and tst_invited_user.user_fi=usr_data.usr_id AND usr_data.usr_id=%s " .
6641 array(
'text',
'text',
'text',
'integer',
'integer'),
6642 array(
"", $this->
lng->txt(
"anonymous"),
"", $this->
getTestId(), $user_id)
6645 $result =
$ilDB->queryF(
6646 "SELECT tst_active.active_id, tst_active.tries, usr_id, %s login, %s lastname, %s firstname, tst_invited_user.clientip, " .
6647 "tst_active.submitted test_finished, matriculation, COALESCE(tst_active.last_finished_pass, -1) <> tst_active.last_started_pass unfinished_passes FROM usr_data, tst_invited_user " .
6648 "LEFT JOIN tst_active ON tst_active.user_fi = tst_invited_user.user_fi AND tst_active.test_fi = tst_invited_user.test_fi " .
6649 "WHERE tst_invited_user.test_fi = %s and tst_invited_user.user_fi=usr_data.usr_id " .
6651 array(
'text',
'text',
'text',
'integer'),
6652 array(
"", $this->
lng->txt(
"anonymous"),
"", $this->
getTestId())
6656 if (is_numeric($user_id)) {
6657 $result =
$ilDB->queryF(
6658 "SELECT tst_active.active_id, tst_active.tries, usr_id, login, lastname, firstname, tst_invited_user.clientip, " .
6659 "tst_active.submitted test_finished, matriculation, COALESCE(tst_active.last_finished_pass, -1) <> tst_active.last_started_pass unfinished_passes FROM usr_data, tst_invited_user " .
6660 "LEFT JOIN tst_active ON tst_active.user_fi = tst_invited_user.user_fi AND tst_active.test_fi = tst_invited_user.test_fi " .
6661 "WHERE tst_invited_user.test_fi = %s and tst_invited_user.user_fi=usr_data.usr_id AND usr_data.usr_id=%s " .
6663 array(
'integer',
'integer'),
6667 $result =
$ilDB->queryF(
6668 "SELECT tst_active.active_id, tst_active.tries, usr_id, login, lastname, firstname, tst_invited_user.clientip, " .
6669 "tst_active.submitted test_finished, matriculation, COALESCE(tst_active.last_finished_pass, -1) <> tst_active.last_started_pass unfinished_passes FROM usr_data, tst_invited_user " .
6670 "LEFT JOIN tst_active ON tst_active.user_fi = tst_invited_user.user_fi AND tst_active.test_fi = tst_invited_user.test_fi " .
6671 "WHERE tst_invited_user.test_fi = %s and tst_invited_user.user_fi=usr_data.usr_id " .
6678 $result_array = array();
6679 while ($row =
$ilDB->fetchAssoc($result)) {
6680 $result_array[$row[
'usr_id']] = $row;
6682 return $result_array;
6694 $ilDB = $DIC[
'ilDB'];
6698 SELECT tst_active.active_id, 6700 tst_active.user_fi usr_id, 6704 tst_active.submitted test_finished, 6705 usr_data.matriculation, 6707 tst_active.lastindex, 6708 COALESCE(tst_active.last_finished_pass, -1) <> tst_active.last_started_pass unfinished_passes 6711 ON tst_active.user_fi = usr_data.usr_id 6712 WHERE tst_active.test_fi = %s 6713 ORDER BY usr_data.lastname 6715 $result =
$ilDB->queryF(
6717 array(
'text',
'text',
'text',
'integer'),
6718 array(
"", $this->
lng->txt(
"anonymous"),
"", $this->
getTestId())
6722 SELECT tst_active.active_id, 6724 tst_active.user_fi usr_id, 6728 tst_active.submitted test_finished, 6729 usr_data.matriculation, 6731 tst_active.lastindex, 6732 COALESCE(tst_active.last_finished_pass, -1) <> tst_active.last_started_pass unfinished_passes 6735 ON tst_active.user_fi = usr_data.usr_id 6736 WHERE tst_active.test_fi = %s 6737 ORDER BY usr_data.lastname 6739 $result =
$ilDB->queryF(
6746 while ($row =
$ilDB->fetchAssoc($result)) {
6747 $data[$row[
'active_id']] = $row;
6750 if (strlen(trim($participant[
"firstname"] . $participant[
"lastname"])) == 0) {
6760 $ilDB = $DIC[
'ilDB'];
6763 if (count($scoring) == 0) {
6768 $filtered_participants = array();
6769 foreach ($participants as $active_id => $participant) {
6770 $qstType_IN_manScoreableQstTypes =
$ilDB->in(
'qpl_questions.question_type_fi', $scoring,
false,
'integer');
6773 SELECT tst_test_result.manual 6775 FROM tst_test_result 6777 INNER JOIN qpl_questions 6778 ON tst_test_result.question_fi = qpl_questions.question_id 6780 WHERE tst_test_result.active_fi = %s 6781 AND $qstType_IN_manScoreableQstTypes 6784 $result =
$ilDB->queryF(
6790 $count = $result->numRows();
6795 if ($participant[
'active']) {
6796 $filtered_participants[$active_id] = $participant;
6800 if (!$participant[
'active']) {
6801 $filtered_participants[$active_id] = $participant;
6805 $filtered_participants[$active_id] = $participant;
6808 $assessmentSetting =
new ilSetting(
"assessment");
6809 $manscoring_done = $assessmentSetting->get(
"manscoring_done_" . $active_id);
6810 if ($manscoring_done) {
6811 $filtered_participants[$active_id] = $participant;
6815 $assessmentSetting =
new ilSetting(
"assessment");
6816 $manscoring_done = $assessmentSetting->get(
"manscoring_done_" . $active_id);
6817 if (!$manscoring_done) {
6818 $filtered_participants[$active_id] = $participant;
6824 while ($row =
$ilDB->fetchAssoc($result)) {
6825 if ($row[
"manual"]) {
6829 if (($found > 0) && ($found < $count)) {
6830 $filtered_participants[$active_id] = $participant;
6834 $filtered_participants[$active_id] = $participant;
6839 return $filtered_participants;
6851 $ilDB = $DIC[
'ilDB'];
6853 if (!is_array($ids) || count($ids) == 0) {
6858 $result =
$ilDB->queryF(
6859 "SELECT usr_id, %s login, %s lastname, %s firstname, client_ip clientip FROM usr_data WHERE " .
$ilDB->in(
'usr_id', $ids,
false,
'integer') .
" ORDER BY login",
6860 array(
'text',
'text',
'text'),
6861 array(
"", $this->
lng->txt(
"anonymous"),
"")
6864 $result =
$ilDB->query(
"SELECT usr_id, login, lastname, firstname, client_ip clientip FROM usr_data WHERE " .
$ilDB->in(
'usr_id', $ids,
false,
'integer') .
" ORDER BY login");
6867 $result_array = array();
6868 while ($row =
$ilDB->fetchAssoc($result)) {
6869 $result_array[$row[
"usr_id"]] = $row;
6871 return $result_array;
6876 if (!is_array($ids) || count($ids) == 0) {
6889 if (!is_array($ids) || count($ids) == 0) {
6893 foreach ($ids as $obj_id) {
6909 $members = $group->getGroupMemberIds();
6910 foreach ($members as $user_id) {
6924 $rbacreview = $DIC[
'rbacreview'];
6925 $members = $rbacreview->assignedUsers($role_id);
6926 foreach ($members as $user_id) {
6942 $ilDB = $DIC[
'ilDB'];
6944 $affectedRows =
$ilDB->manipulateF(
6945 "DELETE FROM tst_invited_user WHERE test_fi = %s AND user_fi = %s",
6946 array(
'integer',
'integer'),
6960 $ilDB = $DIC[
'ilDB'];
6963 "DELETE FROM tst_invited_user WHERE test_fi = %s AND user_fi = %s",
6964 array(
'integer',
'integer'),
6968 "INSERT INTO tst_invited_user (test_fi, user_fi, clientip, tstamp) VALUES (%s, %s, %s, %s)",
6969 array(
'integer',
'integer',
'text',
'integer'),
6970 array($this->
getTestId(), $user_id, (strlen($client_ip)) ? $client_ip : null, time())
6978 $ilDB = $DIC[
'ilDB'];
6980 $affectedRows =
$ilDB->manipulateF(
6981 "UPDATE tst_invited_user SET clientip = %s, tstamp = %s WHERE test_fi=%s and user_fi=%s",
6982 array(
'text',
'integer',
'integer',
'integer'),
6983 array((strlen($client_ip)) ? $client_ip : null, time(), $this->
getTestId(), $user_id)
6995 $ilDB = $DIC[
'ilDB'];
6996 if (is_numeric($question_fi)) {
6997 $result =
$ilDB->queryF(
6998 "SELECT question_fi, solved FROM tst_qst_solved WHERE active_fi = %s AND question_fi=%s",
6999 array(
'integer',
'integer'),
7000 array($active_id, $question_fi)
7003 $result =
$ilDB->queryF(
7004 "SELECT question_fi, solved FROM tst_qst_solved WHERE active_fi = %s",
7009 $result_array = array();
7010 while ($row =
$ilDB->fetchAssoc($result)) {
7011 $result_array[$row[
"question_fi"]] = $row;
7013 return $result_array;
7023 $ilDB = $DIC[
'ilDB'];
7027 "DELETE FROM tst_qst_solved WHERE active_fi = %s AND question_fi = %s",
7028 array(
'integer',
'integer'),
7029 array($active_id, $question_id)
7032 "INSERT INTO tst_qst_solved (solved, question_fi, active_fi) VALUES (%s, %s, %s)",
7033 array(
'integer',
'integer',
'integer'),
7034 array($value, $question_id, $active_id)
7044 $ilDB = $DIC[
'ilDB'];
7046 $result =
$ilDB->queryF(
7047 "SELECT submitted FROM tst_active WHERE active_id=%s AND submitted=%s",
7048 array(
'integer',
'integer'),
7049 array($active_id, 1)
7051 return $result->numRows() == 1;
7061 $ilDB = $DIC[
'ilDB'];
7063 if (!is_numeric($user_id)) {
7067 $result =
$ilDB->queryF(
7068 "SELECT submitted FROM tst_active WHERE test_fi=%s AND user_fi=%s AND submitted=%s",
7069 array(
'integer',
'integer',
'integer'),
7072 return $result->numRows() == 1;
7107 "user_id" => $this->
lng->txt(
"user_id"),
7108 "matriculation" => $this->
lng->txt(
"matriculation"),
7109 "lastname" => $this->
lng->txt(
"lastname"),
7110 "firstname" => $this->
lng->txt(
"firstname"),
7111 "login" => $this->
lng->txt(
"login"),
7112 "reached_points" => $this->
lng->txt(
"tst_reached_points"),
7113 "max_points" => $this->
lng->txt(
"tst_maximum_points"),
7114 "percent_value" => $this->
lng->txt(
"tst_percent_solved"),
7115 "mark" => $this->
lng->txt(
"tst_mark"),
7116 "ects" => $this->
lng->txt(
"ects_grade"),
7117 "passed" => $this->
lng->txt(
"tst_mark_passed"),
7120 if (count($participants)) {
7124 foreach ($participants as $active_id => $user_rec) {
7125 $mark = $ects_mark =
'';
7127 $reached_points = 0;
7131 if (!is_int($pass)) {
7134 foreach ($this->questions as $value) {
7136 if (is_object($question)) {
7137 $max_points += $question->getMaximumPoints();
7138 $reached_points += $question->getReachedPoints($active_id, $pass);
7141 if ($max_points > 0) {
7142 $percentvalue = $reached_points / $max_points;
7143 if ($percentvalue < 0) {
7144 $percentvalue = 0.0;
7149 $mark_obj = $this->mark_schema->getMatchingMark($percentvalue * 100);
7152 $mark = $mark_obj->getOfficialName();
7154 $ects_mark = $this->
getECTSGrade($passed_array, $reached_points, $max_points);
7158 $user_rec[
'firstname'] =
"";
7159 $user_rec[
'lastname'] = $this->
lng->txt(
"anonymous");
7162 "user_id" => $user_rec[
'usr_id'],
7163 "matriculation" => $user_rec[
'matriculation'],
7164 "lastname" => $user_rec[
'lastname'],
7165 "firstname" => $user_rec[
'firstname'],
7166 "login" => $user_rec[
'login'],
7167 "reached_points" => $reached_points,
7168 "max_points" => $max_points,
7169 "percent_value" => $percentvalue,
7171 "ects" => $ects_mark,
7172 "passed" => $user_rec[
'passed'] ?
'1' :
'0',
7174 $results[] = $prepareForCSV ? $this->
processCSVRow($row,
true) : $row;
7190 public function &
processCSVRow($row, $quoteAll =
false, $separator =
";"): array
7192 $resultarray = array();
7193 foreach ($row as $rowindex => $entry) {
7198 if (strpos($entry,
"\"") !==
false) {
7199 $entry = str_replace(
"\"",
"\"\"", $entry);
7202 if (strpos($entry, $separator) !==
false) {
7206 $entry = str_replace(chr(13) . chr(10), chr(10), $entry);
7209 $entry =
"\"" . $entry .
"\"";
7212 $resultarray[$rowindex] = $entry;
7214 return $resultarray;
7228 $ilDB = $DIC[
'ilDB'];
7229 $result =
$ilDB->queryF(
7230 "SELECT tries FROM tst_active WHERE active_id = %s",
7234 if ($result->numRows()) {
7235 $row =
$ilDB->fetchAssoc($result);
7236 return $row[
"tries"];
7254 $ilDB = $DIC[
'ilDB'];
7255 $result =
$ilDB->queryF(
7256 "SELECT MAX(pass) maxpass FROM tst_pass_result WHERE active_fi = %s",
7261 if ($result->numRows()) {
7262 $row =
$ilDB->fetchAssoc($result);
7263 return $row[
"maxpass"];
7277 $ilDB = $DIC[
'ilDB'];
7279 $result =
$ilDB->queryF(
7280 "SELECT * FROM tst_pass_result WHERE active_fi = %s",
7285 if (!$result->numRows()) {
7291 while ($row =
$ilDB->fetchAssoc($result)) {
7292 if ($row[
"maxpoints"] > 0.0) {
7293 $factor = (float) ($row[
"points"] / $row[
"maxpoints"]);
7297 if ($factor === 0.0 && $bestfactor === 0.0
7298 || $factor > $bestfactor) {
7300 $bestfactor = $factor;
7304 if (is_array($bestrow)) {
7305 return $bestrow[
"pass"];
7321 $counted_pass = null;
7327 return $counted_pass;
7343 $tree = $DIC[
'tree'];
7344 $ilDB = $DIC[
'ilDB'];
7346 $refinery = $DIC[
'refinery'];
7347 $component_repository = $DIC[
'component.repository'];
7350 $testSession = $testSessionFactory->getSession($active_id);
7356 $dynamicQuestionSetConfig->loadFromDb();
7368 foreach ($this->questions as $value) {
7370 $workedthrough += 1;
7373 return $workedthrough;
7385 $ilDB = $DIC[
'ilDB'];
7387 if (is_null($pass)) {
7392 SELECT tst_pass_result.tstamp pass_res_tstamp, 7393 tst_test_result.tstamp quest_res_tstamp 7395 FROM tst_pass_result 7397 LEFT JOIN tst_test_result 7398 ON tst_test_result.active_fi = tst_pass_result.active_fi 7399 AND tst_test_result.pass = tst_pass_result.pass 7401 WHERE tst_pass_result.active_fi = %s 7402 AND tst_pass_result.pass = %s 7404 ORDER BY tst_test_result.tstamp DESC 7407 $result =
$ilDB->queryF(
7409 array(
'integer',
'integer'),
7410 array($active_id, $pass)
7413 while ($row =
$ilDB->fetchAssoc($result)) {
7414 if ($row[
'quest_res_tstamp']) {
7415 return $row[
'quest_res_tstamp'];
7418 return $row[
'pass_res_tstamp'];
7435 "executable" =>
true,
7436 "errormessage" =>
"" 7439 $result[
"executable"] =
false;
7440 $result[
"errormessage"] = ($this->
lng->txt(
"ctm_cannot_be_started"));
7444 $result[
"executable"] =
false;
7449 $result[
"executable"] =
false;
7457 if ($active_id > 0) {
7459 if ($starting_time !==
false) {
7471 $result[
"executable"] =
false;
7472 $result[
"errormessage"] = $this->
lng->txt(
"detail_max_processing_time_reached");
7481 $testPassesSelector->setActiveId($active_id);
7482 $testPassesSelector->setLastFinishedPass(
$testSession->getLastFinishedPass());
7485 $closedPasses = $testPassesSelector->getClosedPasses();
7488 $result[
"executable"] =
false;
7489 $result[
"errormessage"] = $this->
lng->txt(
"maximum_nr_of_tries_reached");
7495 $result[
'executable'] =
false;
7496 $result[
'errormessage'] = $this->
lng->txt(
"tst_addit_passes_blocked_after_passed_msg");
7502 $lastPass = $testPassesSelector->getLastFinishedPassTimestamp();
7505 $time_values = explode(
":", $pass_waiting_string);
7506 $next_pass_allowed = strtotime(
'+ ' . $time_values[0] .
' Months + ' . $time_values[1] .
' Days + ' . $time_values[2] .
' Hours' . $time_values[3] .
' Minutes', $lastPass);
7508 if (time() < $next_pass_allowed) {
7511 $result[
"executable"] =
false;
7512 $result[
"errormessage"] = sprintf($this->
lng->txt(
'wait_for_next_pass_hint_msg'), $date);
7525 $passSelector->setActiveId($testSession->
getActiveId());
7528 return $passSelector->hasReportablePasses();
7535 $passSelector->setActiveId($testSession->
getActiveId());
7538 return $passSelector->hasExistingPasses();
7552 if ($active_id < 1) {
7555 if ($pass === null) {
7558 $result =
$ilDB->queryF(
7559 "SELECT tst_times.started FROM tst_times WHERE tst_times.active_fi = %s AND tst_times.pass = %s ORDER BY tst_times.started",
7560 array(
'integer',
'integer'),
7561 array($active_id, $pass)
7563 if ($result->numRows()) {
7564 $row =
$ilDB->fetchAssoc($result);
7565 if (preg_match(
"/(\d{4})-(\d{2})-(\d{2}) (\d{2}):(\d{2}):(\d{2})/", $row[
"started"], $matches)) {
7566 return mktime($matches[4], $matches[5], $matches[6], $matches[2], $matches[3], $matches[1]);
7599 $ilDB = $DIC[
'ilDB'];
7601 $tags_trafo = $this->
refinery->string()->stripTags();
7605 questtypes.type_tag, 7607 tstquest.obligatory, 7608 origquest.obj_fi orig_obj_fi 7610 FROM qpl_questions questions 7612 INNER JOIN qpl_qst_type questtypes 7613 ON questtypes.question_type_id = questions.question_type_fi 7615 INNER JOIN tst_test_question tstquest 7616 ON tstquest.question_fi = questions.question_id 7618 LEFT JOIN qpl_questions origquest 7619 ON origquest.question_id = questions.original_id 7621 WHERE tstquest.test_fi = %s 7623 ORDER BY tstquest.sequence 7626 $query_result =
$ilDB->queryF(
7632 $questions = array();
7634 while ($row =
$ilDB->fetchAssoc($query_result)) {
7635 $row[
'title'] = $tags_trafo->transform($row[
'title']);
7636 $row[
'description'] = $tags_trafo->transform($row[
'description'] !==
'' && $row[
'description'] !== null ? $row[
'description'] :
' ');
7637 $row[
'author'] = $tags_trafo->transform($row[
'author']);
7638 $row[
'obligationPossible'] = self::isQuestionObligationPossible($row[
'question_id']);
7640 $questions[] = $row;
7653 if ($questionData[
'question_id'] != $questionId) {
7667 $row = $DIC->database()->fetchAssoc($DIC->database()->queryF(
7668 "SELECT COUNT(question_id) cnt FROM qpl_questions WHERE question_id = %s AND obj_fi = %s",
7669 array(
'integer',
'integer'),
7670 array($questionId, $this->
getId())
7673 return (
bool) $row[
'cnt'];
7684 $points += $questionData[
'points'];
7693 public function getPotentialRandomTestQuestions(): array
7699 $ilDB = $DIC[
'ilDB'];
7703 questtypes.type_tag, 7704 origquest.obj_fi orig_obj_fi 7706 FROM qpl_questions questions 7708 INNER JOIN qpl_qst_type questtypes 7709 ON questtypes.question_type_id = questions.question_type_fi 7711 INNER JOIN tst_rnd_cpy tstquest 7712 ON tstquest.qst_fi = questions.question_id 7714 LEFT JOIN qpl_questions origquest 7715 ON origquest.question_id = questions.original_id 7717 WHERE tstquest.tst_fi = %s 7720 $query_result =
$ilDB->queryF(
7726 $questions = array();
7728 while ($row =
$ilDB->fetchAssoc($query_result)) {
7731 $question[
'obligationPossible'] = self::isQuestionObligationPossible($row[
'question_id']);
7733 $questions[] = $question;
7747 return ($this->shuffle_questions) ? 1 : 0;
7758 $this->shuffle_questions = ($a_shuffle) ? 1 : 0;
7775 return ($this->show_summary) ? $this->show_summary : 0;
7792 $this->show_summary = $a_value;
7803 if (($this->show_summary & 1) > 0) {
7819 $this->show_summary = 1;
7821 $this->show_summary = 0;
7833 if (($this->show_summary & 2) > 0) {
7849 $this->show_summary = $this->show_summary | 2;
7853 $this->show_summary = $this->show_summary ^ 2;
7866 if (($this->show_summary & 4) > 0) {
7882 $this->show_summary = $this->show_summary | 4;
7886 $this->show_summary = $this->show_summary ^ 4;
7896 if (($this->show_summary & 8) > 0) {
7912 $this->show_summary = $this->show_summary | 8;
7916 $this->show_summary = $this->show_summary ^ 8;
7929 return $this->
getScoreSettings()->getResultDetailsSettings()->getResultsPresentation();
7937 return $this->
getScoreSettings()->getResultDetailsSettings()->getShowPassDetails();
7945 return $this->
getScoreSettings()->getResultDetailsSettings()->getShowSolutionDetails();
7953 return $this->
getScoreSettings()->getResultDetailsSettings()->getShowSolutionPrintview();
7968 return $this->
getScoreSettings()->getResultDetailsSettings()->getShowSolutionFeedback();
7976 return $this->
getScoreSettings()->getResultDetailsSettings()->getShowSolutionAnswersOnly();
7984 return $this->
getScoreSettings()->getResultDetailsSettings()->getShowSolutionSignature();
7992 return $this->
getScoreSettings()->getResultDetailsSettings()->getShowSolutionSuggested();
8001 return $this->
getScoreSettings()->getResultDetailsSettings()->getShowSolutionListComparison();
8006 return $this->
getScoreSettings()->getResultDetailsSettings()->getShowSolutionListOwnAnswers();
8018 $this->
getScoreSettings()->getResultDetailsSettings()->withShowSolutionPrintview($a_printview === 1);
8032 $ilDB = $DIC[
'ilDB'];
8033 $result =
$ilDB->queryF(
8034 "SELECT user_fi FROM tst_active WHERE active_id = %s",
8038 if ($result->numRows()) {
8039 $row =
$ilDB->fetchAssoc($result);
8040 return $row[
"user_fi"];
8058 return ($this->allowedUsers) ? $this->allowedUsers : 0;
8063 $this->allowedUsers = $a_allowed_users;
8068 return ($this->allowedUsersTimeGap) ? $this->allowedUsersTimeGap : 0;
8073 $this->allowedUsersTimeGap = $a_allowed_users_time_gap;
8079 $ilDB = $DIC[
'ilDB'];
8083 if (($nr_of_users > 0) && ($time_gap > 0)) {
8085 $time_border = $now - $time_gap;
8086 $str_time_border = date(
"YmdHis", $time_border);
8088 SELECT DISTINCT tst_times.active_fi 8090 INNER JOIN tst_active 8091 ON tst_times.active_fi = tst_active.active_id 8093 tst_times.pass > tst_active.last_finished_pass OR tst_active.last_finished_pass IS NULL 8095 WHERE tst_times.tstamp > %s 8096 AND tst_active.test_fi = %s 8098 $result =
$ilDB->queryF(
$query, array(
'integer',
'integer'), array($time_border, $this->
getTestId()));
8099 if ($result->numRows() >= $nr_of_users) {
8114 $ilDB = $DIC[
'ilDB'];
8116 $result =
$ilDB->queryF(
8117 "SELECT finished FROM tst_times WHERE active_fi = %s ORDER BY finished DESC",
8121 if ($result->numRows()) {
8122 $row =
$ilDB->fetchAssoc($result);
8123 return $row[
"finished"];
8133 SELECT MAX(tst_times.tstamp) as last_pass_access 8135 WHERE active_fi = %s 8139 $res = $DIC->database()->queryF(
8141 array(
'integer',
'integer'),
8142 array($activeId, $passIndex)
8145 while ($row = $DIC->database()->fetchAssoc(
$res)) {
8146 return $row[
'last_pass_access'];
8161 if (preg_match(
"/<[^>]*?>/", $a_text)) {
8177 for (
$i = 0;
$i < $a_material->getMaterialCount();
$i++) {
8178 $material = $a_material->getMaterial(
$i);
8179 if (strcmp($material[
"type"],
"mattext") == 0) {
8180 $result .= $material[
"material"]->getContent();
8182 if (strcmp($material[
"type"],
"matimage") == 0) {
8183 $matimage = $material[
"material"];
8184 if (preg_match(
"/(il_([0-9]+)_mob_([0-9]+))/", $matimage->getLabel(), $matches)) {
8190 array_push($import_mob_xhtml, array(
"mob" => $matimage->getLabel(),
"uri" => $matimage->getUri()));
8195 $ilLog = $DIC[
'ilLog'];
8196 $ilLog->write(print_r(
ilSession::get(
"import_mob_xhtml"),
true));
8208 $a_xml_writer->xmlStartTag(
"material");
8211 "texttype" =>
"text/plain" 8213 if ($this->
isHTML($a_material)) {
8214 $attrs[
"texttype"] =
"text/xhtml";
8218 $a_xml_writer->xmlElement(
"mattext", $attrs,
$txt);
8221 foreach (
$mobs as $mob) {
8222 $moblabel =
"il_" .
IL_INST_ID .
"_mob_" . $mob;
8223 if (strpos($a_material,
"mm_$mob") !==
false) {
8227 "label" => $moblabel,
8228 "uri" =>
"objects/" .
"il_" .
IL_INST_ID .
"_mob_" . $mob .
"/" . $mob_obj->getTitle()
8231 $a_xml_writer->xmlElement(
"matimage", $imgattrs, null);
8234 $a_xml_writer->xmlEndTag(
"material");
8245 if ($txt_output == null) {
8250 $prepare_for_latex_output,
8251 $omitNl2BrWhenTextArea
8263 return ($this->anonymity) ? 1 : 0;
8276 $this->anonymity = 1;
8279 $this->anonymity = 0;
8292 return ($this->show_cancel) ? 1 : 0;
8305 $this->show_cancel = 1;
8308 $this->show_cancel = 0;
8321 return ($this->show_marker) ? 1 : 0;
8334 $this->show_marker = 1;
8337 $this->show_marker = 0;
8350 return ($this->fixed_participants) ? 1 : 0;
8363 $this->fixed_participants = 1;
8366 $this->fixed_participants = 0;
8381 $ilDB = $DIC[
'ilDB'];
8383 $result =
$ilDB->queryF(
8384 "SELECT anonymity FROM tst_tests WHERE obj_fi = %s",
8388 while ($row =
$ilDB->fetchAssoc($result)) {
8389 return $row[
'anonymity'];
8403 $ilDB = $DIC[
'ilDB'];
8406 SELECT tst_tests.question_set_type 8408 INNER JOIN tst_tests 8409 ON tst_active.test_fi = tst_tests.test_id 8410 WHERE tst_active.active_id = %s 8415 while ($row =
$ilDB->fetchAssoc(
$res)) {
8416 return $row[
'question_set_type'];
8432 throw new Exception(__METHOD__ .
' is deprecated ... use ilObjTest::lookupQuestionSetTypeByActiveId() instead!');
8435 $ilDB = $DIC[
'ilDB'];
8437 $result =
$ilDB->queryF(
8438 "SELECT tst_tests.random_test FROM tst_tests, tst_active WHERE tst_active.active_id = %s AND tst_active.test_fi = tst_tests.test_id",
8442 while ($row =
$ilDB->fetchAssoc($result)) {
8443 return $row[
'random_test'];
8458 public function userLookupFullName($user_id, $overwrite_anonymity =
false, $sorted_order =
false, $suffix =
""): string
8461 return $this->
lng->txt(
"anonymous") . $suffix;
8464 if (strlen($uname[
"firstname"] . $uname[
"lastname"]) == 0) {
8465 $uname[
"firstname"] = $this->
lng->txt(
"deleted_user");
8467 if ($sorted_order) {
8468 return trim($uname[
"lastname"] .
", " . $uname[
"firstname"]) . $suffix;
8470 return trim($uname[
"firstname"] .
" " . $uname[
"lastname"]) . $suffix;
8485 return $this->
lng->txt(
"tst_start_test");
8487 $active_pass = self::_getPass($active_id);
8490 if ($active_pass == 0) {
8491 return $this->
lng->txt(
"tst_start_test");
8493 return $this->
lng->txt(
"tst_start_new_test_pass");
8496 return $this->
lng->txt(
"tst_resume_test");
8505 public function getAvailableDefaults(): array
8512 $ilDB = $DIC[
'ilDB'];
8515 $result =
$ilDB->queryF(
8516 "SELECT * FROM tst_test_defaults WHERE user_fi = %s ORDER BY name ASC",
8520 $defaults = array();
8521 while ($row =
$ilDB->fetchAssoc($result)) {
8522 $defaults[$row[
"test_defaults_id"]] = $row;
8536 return self::_getTestDefaults($test_defaults_id);
8542 $ilDB = $DIC[
'ilDB'];
8544 $result =
$ilDB->queryF(
8545 "SELECT * FROM tst_test_defaults WHERE test_defaults_id = %s",
8547 array($test_defaults_id)
8549 if ($result->numRows() == 1) {
8550 $row =
$ilDB->fetchAssoc($result);
8566 $ilDB = $DIC[
'ilDB'];
8567 $affectedRows =
$ilDB->manipulateF(
8568 "DELETE FROM tst_test_defaults WHERE test_defaults_id = %s",
8570 array($test_default_id)
8583 $ilDB = $DIC[
'ilDB'];
8585 $testsettings = array(
8678 $next_id =
$ilDB->nextId(
'tst_test_defaults');
8680 'tst_test_defaults',
8682 'test_defaults_id' => array(
'integer', $next_id),
8683 'name' => array(
'text', $a_name),
8684 'user_fi' => array(
'integer',
$ilUser->getId()),
8685 'defaults' => array(
'clob', serialize($testsettings)),
8686 'marks' => array(
'clob', serialize($this->mark_schema)),
8687 'tstamp' => array(
'integer', time())
8701 $testsettings = unserialize($test_defaults[
"defaults"]);
8702 $this->mark_schema = unserialize($test_defaults[
"marks"]);
8704 if (array_key_exists(
'TitleOutput', $testsettings)) {
8708 if (array_key_exists(
'IntroEnabled', $testsettings)) {
8712 if (array_key_exists(
'Introduction', $testsettings)) {
8716 if (array_key_exists(
'FinalStatement', $testsettings)) {
8720 if (array_key_exists(
'ShowInfo', $testsettings)) {
8724 if (array_key_exists(
'ForceJS', $testsettings)) {
8728 if (array_key_exists(
'CustomStyle', $testsettings)) {
8732 if (array_key_exists(
'ShowFinalStatement', $testsettings)) {
8736 if (array_key_exists(
'SequenceSettings', $testsettings)) {
8740 if (array_key_exists(
'SpecificAnswerFeedback', $testsettings)) {
8744 if (array_key_exists(
'InstantFeedbackSolution', $testsettings)) {
8748 if (array_key_exists(
'AnswerFeedback', $testsettings)) {
8752 if (array_key_exists(
'AnswerFeedbackPoints', $testsettings)) {
8756 if (array_key_exists(
'Anonymity', $testsettings)) {
8760 if (array_key_exists(
'ShowCancel', $testsettings)) {
8764 if (array_key_exists(
'Shuffle', $testsettings)) {
8768 if (array_key_exists(
'ShowMarker', $testsettings)) {
8772 if (array_key_exists(
'ReportingDate', $testsettings)) {
8776 if (array_key_exists(
'NrOfTries', $testsettings)) {
8780 if (array_key_exists(
'BlockAfterPassed', $testsettings)) {
8784 if (array_key_exists(
'UsePreviousAnswers', $testsettings)) {
8788 if (array_key_exists(
'redirection_mode', $testsettings)) {
8792 if (array_key_exists(
'redirection_url', $testsettings)) {
8796 if (array_key_exists(
'ProcessingTime', $testsettings)) {
8800 if (array_key_exists(
'ResetProcessingTime', $testsettings)) {
8804 if (array_key_exists(
'EnableProcessingTime', $testsettings)) {
8808 if (array_key_exists(
'StartingTimeEnabled', $testsettings)) {
8812 if (array_key_exists(
'StartingTime', $testsettings)) {
8816 if (array_key_exists(
'Kiosk', $testsettings)) {
8817 $this->
setKiosk($testsettings[
'Kiosk']);
8820 if (array_key_exists(
'EndingTimeEnabled', $testsettings)) {
8824 if (array_key_exists(
'EndingTime', $testsettings)) {
8828 if (array_key_exists(
'ECTSOutput', $testsettings)) {
8832 if (array_key_exists(
'ECTSFX', $testsettings)) {
8833 $this->
setECTSFX($testsettings[
'ECTSFX']);
8836 if (array_key_exists(
'ECTSGrades', $testsettings)) {
8840 if (isset($testsettings[
"isRandomTest"])) {
8841 if ($testsettings[
"isRandomTest"]) {
8846 } elseif (isset($testsettings[
"questionSetType"])) {
8850 if (array_key_exists(
'mailnotification', $testsettings)) {
8854 if (array_key_exists(
'mailnottype', $testsettings)) {
8858 if (array_key_exists(
'exportsettings', $testsettings)) {
8862 if (array_key_exists(
'ListOfQuestionsSettings', $testsettings)) {
8866 if (array_key_exists(
'obligations_enabled', $testsettings)) {
8870 if (array_key_exists(
'offer_question_hints', $testsettings)) {
8874 if (isset($testsettings[
'examid_in_kiosk'])) {
8880 if (array_key_exists(
'enable_examview', $testsettings)) {
8884 if (array_key_exists(
'show_examview_html', $testsettings)) {
8888 if (array_key_exists(
'show_examview_pdf', $testsettings)) {
8892 if (array_key_exists(
'enable_archiving', $testsettings)) {
8896 if (array_key_exists(
'sign_submission', $testsettings)) {
8900 if (array_key_exists(
'char_selector_availability', $testsettings)) {
8904 if (array_key_exists(
'char_selector_definition', $testsettings)) {
8908 if (array_key_exists(
'skill_service', $testsettings)) {
8912 if (array_key_exists(
'show_grading_status', $testsettings)) {
8916 if (array_key_exists(
'show_grading_mark', $testsettings)) {
8920 if (array_key_exists(
'follow_qst_answer_fixation', $testsettings)) {
8924 if (array_key_exists(
'inst_fb_answer_fixation', $testsettings)) {
8928 if (array_key_exists(
'force_inst_fb', $testsettings)) {
8932 if (array_key_exists(
'redirection_mode', $testsettings)) {
8936 if (array_key_exists(
'redirection_url', $testsettings)) {
8940 if (array_key_exists(
'autosave', $testsettings)) {
8944 if (array_key_exists(
'autosave_ival', $testsettings)) {
8948 if (array_key_exists(
'password_enabled', $testsettings)) {
8952 if (array_key_exists(
'password', $testsettings)) {
8956 if (array_key_exists(
'fixed_participants', $testsettings)) {
8960 if (array_key_exists(
'limit_users_enabled', $testsettings)) {
8964 if (array_key_exists(
'allowedusers', $testsettings)) {
8968 if (array_key_exists(
'alloweduserstimegap', $testsettings)) {
8972 if (array_key_exists(
'use_previous_answers', $testsettings)) {
8976 if (array_key_exists(
'activation_limited', $testsettings)) {
8980 if (array_key_exists(
'activation_start_time', $testsettings)) {
8984 if (array_key_exists(
'activation_end_time', $testsettings)) {
8988 if (array_key_exists(
'activation_visibility', $testsettings)) {
8992 if (array_key_exists(
'pass_waiting', $testsettings)) {
8997 $exam_id_in_results =
false;
8998 if (array_key_exists(
'show_exam_id', $testsettings)) {
8999 $exam_id_in_results = (bool) $testsettings[
'show_exam_id'];
9000 } elseif (array_key_exists(
'examid_in_test_res', $testsettings)) {
9001 $exam_id_in_results = (bool) $testsettings[
'examid_in_test_res'];
9005 ->withScoringSettings(
9007 ->withPassScoring((
bool) $testsettings[
"PassScoring"])
9008 ->withScoreCutting((
bool) $testsettings[
'ScoreCutting'])
9009 ->withCountSystem((
bool) $testsettings[
"CountSystem"])
9011 ->withResultSummarySettings(
9013 ->withPassDeletionAllowed($testsettings[
'pass_deletion_allowed'])
9015 ->withResultDetailsSettings(
9017 ->withPrintBestSolutionWithResult((
bool) $testsettings[
'PrintBsWithRes'])
9018 ->withShowExamIdInTestResults($exam_id_in_results)
9019 ->withTaxonomyFilterIds((array) $testsettings[
'result_tax_filters'])
9021 ->withGamificationSettings(
9023 ->withHighscoreEnabled($testsettings[
'highscore_enabled'])
9024 ->withHighscoreAnon($testsettings[
'highscore_anon'])
9025 ->withHighscoreAchievedTS($testsettings[
'highscore_achieved_ts'])
9026 ->withHighscoreScore($testsettings[
'highscore_score'])
9027 ->withHighscorePercentage($testsettings[
'highscore_percentage'])
9028 ->withHighscoreHints($testsettings[
'highscore_hints'])
9029 ->withHighscoreWTime($testsettings[
'highscore_wtime'])
9030 ->withHighscoreOwnTable($testsettings[
'highscore_own_table'])
9031 ->withHighscoreTopTable($testsettings[
'highscore_top_table'])
9032 ->withHighscoreTopNum($testsettings[
'highscore_top_num'])
9050 if (extension_loaded(
"tidy")) {
9053 "output-xml" =>
true,
9054 "numeric-entities" =>
true 9057 $tidy->parseString($print_output,
$config,
'utf8');
9058 $tidy->cleanRepair();
9059 $print_output = tidy_get_output($tidy);
9060 $print_output = preg_replace(
"/^.*?(<html)/",
"\\1", $print_output);
9062 $print_output = str_replace(
" ",
" ", $print_output);
9063 $print_output = str_replace(
"⊗",
"X", $print_output);
9065 $xsl = file_get_contents(
"./Modules/Test/xml/question2fo.xsl");
9070 'font-family="Helvetica, unifont"',
9071 'font-family="' . $DIC[
'ilSetting']->
get(
'rpc_pdf_font',
'Helvetica, unifont') .
'"',
9075 $args = array(
'/_xml' => $print_output,
'/_xsl' => $xsl );
9078 $output = xslt_process($xh,
"arg:/_xml",
"arg:/_xsl", null, $args,
$params);
9092 $content = preg_replace(
"/href=\".*?\"/",
"", $content);
9093 $printbody =
new ilTemplate(
"tpl.il_as_tst_print_body.html",
true,
true,
"Modules/Test");
9095 $printbody->setVariable(
"ADM_CONTENT", $content);
9096 $printbody->setCurrentBlock(
"css_file");
9098 $printbody->parseCurrentBlock();
9099 $printoutput = $printbody->get();
9100 $html = str_replace(
"href=\"./",
"href=\"" . ILIAS_HTTP_PATH .
"/", $printoutput);
9101 $html = preg_replace(
"/<div id=\"dontprint\">.*?<\\/div>/ims",
"", $html);
9102 if (extension_loaded(
"tidy")) {
9105 "output-xml" =>
true,
9106 "numeric-entities" =>
true 9109 $tidy->parseString($html,
$config,
'utf8');
9110 $tidy->cleanRepair();
9111 $html = tidy_get_output($tidy);
9112 $html = preg_replace(
"/^.*?(<html)/",
"\\1", $html);
9114 $html = str_replace(
" ",
" ", $html);
9115 $html = str_replace(
"⊗",
"X", $html);
9117 $html = preg_replace(
"/src=\".\\//ims",
"src=\"" . ILIAS_HTTP_PATH .
"/", $html);
9129 $ilLog = $DIC[
'ilLog'];
9132 $fp = fopen($fo_file,
"w");
9141 $pdf_base64->scalar,
9147 $ilLog->write(__METHOD__ .
': ' . $e->getMessage());
9164 $row = self::getSingleManualFeedback((
int) $active_id, (
int) $question_id, (
int) $pass);
9167 $feedback = $row[
'feedback'] ??
'';
9177 $ilDB = $DIC->database();
9179 $result =
$ilDB->queryF(
9180 "SELECT * FROM tst_manual_fb WHERE active_fi = %s AND question_fi = %s AND pass = %s",
9181 [
'integer',
'integer',
'integer'],
9182 [$active_id, $question_id, $pass]
9185 if (
$ilDB->numRows($result) === 1) {
9186 $row =
$ilDB->fetchAssoc($result);
9188 } elseif (
$ilDB->numRows($result) > 1) {
9189 $DIC->logger()->root()->warning(
9190 "WARNING: Multiple feedback entries on tst_manual_fb for " .
9191 "active_fi = $active_id , question_fi = $question_id and pass = $pass" 9209 $ilDB = $DIC->database();
9210 $feedback = array();
9211 $result =
$ilDB->queryF(
9212 "SELECT * FROM tst_manual_fb WHERE question_fi = %s",
9217 while ($row =
$ilDB->fetchAssoc($result)) {
9218 $active = $row[
'active_fi'];
9219 $pass = $row[
'pass'];
9220 $question = $row[
'question_fi'];
9224 $feedback[$active][$pass][$question] = $row;
9235 bool $finalized =
false,
9236 bool $is_single_feedback =
false 9240 $feedback_old = self::getSingleManualFeedback($active_id, $question_id, $pass);
9242 $finalized_record = (
int) ($feedback_old[
'finalized_evaluation'] ?? 0);
9243 if ($finalized_record === 0 || ($is_single_feedback && $finalized_record === 1)) {
9244 $DIC->database()->manipulateF(
9245 "DELETE FROM tst_manual_fb WHERE active_fi = %s AND question_fi = %s AND pass = %s",
9246 [
'integer',
'integer',
'integer'],
9247 [$active_id, $question_id, $pass]
9250 $this->
insertManualFeedback($active_id, $question_id, $pass, $feedback, $finalized, $feedback_old);
9270 $ilDB = $DIC->database();
9272 $next_id =
$ilDB->nextId(
'tst_manual_fb');
9274 $finalized_time = time();
9277 'manual_feedback_id' => [
'integer', $next_id],
9278 'active_fi' => [
'integer', $active_id],
9279 'question_fi' => [
'integer', $question_id],
9280 'pass' => [
'integer', $pass],
9282 'tstamp' => [
'integer', time()]
9285 if ($feedback_old !== [] && (
int) $feedback_old[
'finalized_evaluation'] === 1) {
9286 $user = $feedback_old[
'finalized_by_usr_id'];
9287 $finalized_time = $feedback_old[
'finalized_tstamp'];
9290 if ($finalized ===
false) {
9291 $update_default[
'finalized_evaluation'] = [
'integer', 0];
9292 $update_default[
'finalized_by_usr_id'] = [
'integer', 0];
9293 $update_default[
'finalized_tstamp'] = [
'integer', 0];
9294 } elseif ($finalized ===
true) {
9295 $update_default[
'finalized_evaluation'] = [
'integer', 1];
9296 $update_default[
'finalized_by_usr_id'] = [
'integer',
$user];
9297 $update_default[
'finalized_tstamp'] = [
'integer', $finalized_time];
9300 $ilDB->insert(
'tst_manual_fb', $update_default);
9315 $lng = $DIC->language();
9353 $this->test_id = $a_id;
9367 if (count($participants)) {
9368 foreach ($participants as $active_id => $user_rec) {
9370 $reached_points = 0;
9373 foreach ($this->questions as $value) {
9375 if (is_object($question)) {
9376 $max_points += $question->getMaximumPoints();
9377 $reached_points += $question->getReachedPoints($active_id, $pass);
9378 if ($max_points > 0) {
9379 $percentvalue = $reached_points / $max_points;
9380 if ($percentvalue < 0) {
9381 $percentvalue = 0.0;
9387 $user_rec[
'firstname'] =
"";
9388 $user_rec[
'lastname'] = $this->
lng->txt(
"anonymous");
9391 "user_id" => $user_rec[
'usr_id'],
9392 "matriculation" => $user_rec[
'matriculation'],
9393 "lastname" => $user_rec[
'lastname'],
9394 "firstname" => $user_rec[
'firstname'],
9395 "login" => $user_rec[
'login'],
9396 "question_id" => $question->getId(),
9397 "question_title" => $question->getTitle(),
9398 "reached_points" => $reached_points,
9399 "max_points" => $max_points,
9400 "passed" => $user_rec[
'passed'] ?
'1' :
'0',
9416 $ilDB = $DIC[
'ilDB'];
9418 $result =
$ilDB->queryF(
9419 "SELECT t.obj_fi obj_id FROM tst_test_question q, tst_tests t WHERE q.test_fi = t.test_id AND q.question_fi = %s",
9423 $rec =
$ilDB->fetchAssoc($result);
9424 return $rec[
"obj_id"] ?? null;
9436 $component_repository = $DIC[
'component.repository'];
9438 if (!$component_repository->getComponentByTypeAndName(
9441 )->getPluginSlotById(
'qst')->hasPluginName($a_pname)) {
9445 return $component_repository
9446 ->getComponentByTypeAndName(
9450 ->getPluginSlotById(
9461 $ilDB = $DIC[
'ilDB'];
9463 $result =
$ilDB->queryF(
9464 "SELECT passed FROM tst_result_cache WHERE active_fi = %s",
9468 if ($result->numRows()) {
9469 $row =
$ilDB->fetchAssoc($result);
9470 return $row[
'passed'];
9473 $result_array = &$this->
getTestResult($active_id, $counted_pass);
9474 return $result_array[
"test"][
"passed"];
9481 public function getParticipantsForTestAndQuestion($test_id, $question_id): array
9485 $ilDB = $DIC[
'ilDB'];
9488 SELECT tst_test_result.active_fi, tst_test_result.question_fi, tst_test_result.pass 9489 FROM tst_test_result 9490 INNER JOIN tst_active ON tst_active.active_id = tst_test_result.active_fi AND tst_active.test_fi = %s 9491 INNER JOIN qpl_questions ON qpl_questions.question_id = tst_test_result.question_fi 9492 LEFT JOIN usr_data ON usr_data.usr_id = tst_active.user_fi 9493 WHERE tst_test_result.question_fi = %s 9494 ORDER BY usr_data.lastname ASC, usr_data.firstname ASC 9497 $result =
$ilDB->queryF(
9499 array(
'integer',
'integer'),
9500 array($test_id, $question_id)
9502 $foundusers = array();
9504 while ($row =
$ilDB->fetchAssoc($result)) {
9509 if (!array_key_exists($row[
"active_fi"], $foundusers)) {
9510 $foundusers[$row[
"active_fi"]] = array();
9512 array_push($foundusers[$row[
"active_fi"]], array(
"pass" => $row[
"pass"],
"qid" => $row[
"question_fi"]));
9525 $foundParticipants =
$data->getParticipants();
9526 $results = array(
"overview" => array(),
"questions" => array());
9527 if (count($foundParticipants)) {
9528 $results[
"overview"][$this->
lng->txt(
"tst_eval_total_persons")] = count($foundParticipants);
9529 $total_finished =
$data->getTotalFinishedParticipants();
9530 $results[
"overview"][$this->
lng->txt(
"tst_eval_total_finished")] = $total_finished;
9532 $diff_seconds = $average_time;
9533 $diff_hours = floor($diff_seconds / 3600);
9534 $diff_seconds -= $diff_hours * 3600;
9535 $diff_minutes = floor($diff_seconds / 60);
9536 $diff_seconds -= $diff_minutes * 60;
9537 $results[
"overview"][$this->
lng->txt(
"tst_eval_total_finished_average_time")] = sprintf(
"%02d:%02d:%02d", $diff_hours, $diff_minutes, $diff_seconds);
9539 $total_passed_reached = 0;
9540 $total_passed_max = 0;
9541 $total_passed_time = 0;
9542 foreach ($foundParticipants as $userdata) {
9543 if ($userdata->getPassed()) {
9545 $total_passed_reached += $userdata->getReached();
9546 $total_passed_max += $userdata->getMaxpoints();
9547 $total_passed_time += $userdata->getTimeOfWork();
9550 $average_passed_reached = $total_passed ? $total_passed_reached / $total_passed : 0;
9551 $average_passed_max = $total_passed ? $total_passed_max / $total_passed : 0;
9552 $average_passed_time = $total_passed ? $total_passed_time / $total_passed : 0;
9553 $results[
"overview"][$this->
lng->txt(
"tst_eval_total_passed")] = $total_passed;
9554 $results[
"overview"][$this->
lng->txt(
"tst_eval_total_passed_average_points")] = sprintf(
"%2.2f", $average_passed_reached) .
" " . strtolower($this->
lng->txt(
"of")) .
" " . sprintf(
"%2.2f", $average_passed_max);
9555 $average_time = $average_passed_time;
9556 $diff_seconds = $average_time;
9557 $diff_hours = floor($diff_seconds / 3600);
9558 $diff_seconds -= $diff_hours * 3600;
9559 $diff_minutes = floor($diff_seconds / 60);
9560 $diff_seconds -= $diff_minutes * 60;
9561 $results[
"overview"][$this->
lng->txt(
"tst_eval_total_passed_average_time")] = sprintf(
"%02d:%02d:%02d", $diff_hours, $diff_minutes, $diff_seconds);
9564 foreach (
$data->getQuestionTitles() as $question_id => $question_title) {
9568 foreach ($foundParticipants as $userdata) {
9569 for (
$i = 0;
$i <= $userdata->getLastPass();
$i++) {
9570 if (is_object($userdata->getPass(
$i))) {
9571 $question = $userdata->getPass(
$i)->getAnsweredQuestionByQuestionId($question_id);
9572 if (is_array($question)) {
9574 $reached += $question[
"reached"];
9575 $max += $question[
"points"];
9580 $percent = $max ? $reached / $max * 100.0 : 0;
9581 $results[
"questions"][$question_id] = array(
9583 sprintf(
"%.2f", $answered ? $reached / $answered : 0) .
" " . strtolower($this->
lng->txt(
"of")) .
" " . sprintf(
"%.2f", $answered ? $max / $answered : 0),
9584 sprintf(
"%.2f", $percent) .
"%",
9586 sprintf(
"%.2f", $answered ? $reached / $answered : 0),
9587 sprintf(
"%.2f", $answered ? $max / $answered : 0),
9600 $test_exp = $expFactory->getExporter(
'xml');
9601 return $test_exp->buildExportFile();
9611 $this->mailnotification = $a_notification;
9619 $mail->sendSimpleNotification($owner_id, $this->
getTitle(), $usr_data);
9630 return $table_gui->getSelectedColumns();
9643 $exportObj = $expFactory->getExporter(
'results');
9644 $exportObj->setForcedAccessFilteredParticipantList($participantList);
9645 $file = $exportObj->exportToExcel($deliver =
false,
'active_id', $active_id, $passedonly =
false);
9647 $fd->copyAttachmentFile($file,
"result_" . $active_id .
".xlsx");
9648 $file_names[] =
"result_" . $active_id .
".xlsx";
9650 $mail->sendAdvancedNotification($owner_id, $this->
getTitle(), $usr_data, $file_names);
9652 if (count($file_names)) {
9653 $fd->unlinkFiles($file_names);
9662 $ilDB = $DIC[
'ilDB'];
9666 FROM tst_result_cache 9667 WHERE active_fi = %s 9670 $result =
$ilDB->queryF(
9676 if (!$result->numRows()) {
9681 FROM tst_result_cache 9682 WHERE active_fi = %s 9685 $result =
$ilDB->queryF(
9692 $row =
$ilDB->fetchAssoc($result);
9699 if ($this->mailnottype == 1) {
9709 $this->mailnottype = 1;
9711 $this->mailnottype = 0;
9717 return $this->
getScoreSettings()->getResultDetailsSettings()->getExportSettings();
9723 $this->exportsettings = $a_settings;
9725 $this->exportsettings = 0;
9731 return $this->
getScoreSettings()->getResultDetailsSettings()->getExportSettingsSingleChoiceShort();
9737 $this->exportsettings = $this->exportsettings | 1;
9740 $this->exportsettings = $this->exportsettings ^ 1;
9752 $this->enabled_view_mode = $mode;
9778 $values[] =
'instant_feedback_specific';
9781 $values[] =
'instant_feedback_generic';
9784 $values[] =
'instant_feedback_points';
9787 $values[] =
'instant_feedback_solution';
9795 if (is_array($options)) {
9814 $tree = $DIC[
'tree'];
9816 $component_repository = $DIC[
'component.repository'];
9819 $questionSetConfig = $qscFactory->getQuestionSetConfig();
9822 $reindexedSequencePositionMap = $questionSetConfig->reindexQuestionOrdering();
9826 return $reindexedSequencePositionMap;
9832 $ilDB = $DIC[
'ilDB'];
9838 foreach ($orders as
$id => $position) {
9842 isset($obligations[
$id]) && $obligations[
$id] ? 1 : 0
9846 UPDATE tst_test_question 9849 WHERE question_fi = %s 9854 array(
'integer',
'integer',
'integer'),
9855 array(
$i, $obligatory, $id)
9865 $ilDB = $DIC[
'ilDB'];
9866 if ($question_before) {
9867 $query =
'SELECT sequence, test_fi FROM tst_test_question WHERE question_fi = %s';
9868 $types = array(
'integer');
9869 $values = array($question_before);
9873 if (!$question_before || ($rset && !($row =
$ilDB->fetchAssoc($rset)))) {
9880 $update =
'UPDATE tst_test_question SET sequence = sequence + 1 WHERE sequence > %s AND test_fi = %s';
9881 $types = array(
'integer',
'integer');
9882 $values = array($row[
'sequence'], $row[
'test_fi']);
9885 $update =
'UPDATE tst_test_question SET sequence = %s WHERE question_fi = %s';
9886 $types = array(
'integer',
'integer');
9887 $values = array($row[
'sequence'] + 1, $question_to_move);
9896 $ilDB = $DIC[
'ilDB'];
9900 $IN_questions =
$ilDB->in(
'q1.question_id', array_keys($questions),
false,
'integer');
9903 SELECT count(q1.question_id) cnt 9905 FROM qpl_questions q1 9907 INNER JOIN qpl_questions q2 9908 ON q2.question_id = q1.original_id 9911 AND q1.obj_fi = q2.obj_fi 9916 $row =
$ilDB->fetchAssoc($rset);
9918 return $row[
'cnt'] > 0;
9930 $ilDB = $DIC[
'ilDB'];
9932 $result =
$ilDB->queryF(
9933 "SELECT test_fi,MAX(pass) AS pass FROM tst_active" .
9934 " JOIN tst_pass_result ON (tst_pass_result.active_fi = tst_active.active_id)" .
9935 " WHERE user_fi=%s" .
9936 " GROUP BY test_fi",
9937 array(
'integer',
'integer'),
9938 array($a_user_id, 1)
9941 while ($row =
$ilDB->fetchAssoc($result)) {
9942 $obj_id = self::_getObjectIDFromTestID($row[
"test_fi"]);
9943 $all[$obj_id] = (bool) $row[
"pass"];
9959 $this->online = (bool) $a_online;
9977 return $this->
getScoreSettings()->getResultDetailsSettings()->getPrintBestSolutionWithResult();
9987 return $this->offeringQuestionHintsEnabled ?:
false;
9997 $this->offeringQuestionHintsEnabled = (bool) $offeringQuestionHintsEnabled;
10002 $this->activation_visibility = (bool) $a_value;
10017 $this->activation_limited = (bool) $a_value;
10023 return $this->
getScoreSettings()->getGamificationSettings()->getHighscoreEnabled();
10037 return $this->
getScoreSettings()->getGamificationSettings()->getHighscoreAnon();
10058 return $this->
getScoreSettings()->getGamificationSettings()->getHighscoreAchievedTS();
10066 return $this->
getScoreSettings()->getGamificationSettings()->getHighscoreScore();
10074 return $this->
getScoreSettings()->getGamificationSettings()->getHighscorePercentage();
10082 return $this->
getScoreSettings()->getGamificationSettings()->getHighscoreHints();
10090 return $this->
getScoreSettings()->getGamificationSettings()->getHighscoreWTime();
10098 return $this->
getScoreSettings()->getGamificationSettings()->getHighscoreOwnTable();
10106 return $this->
getScoreSettings()->getGamificationSettings()->getHighscoreTopTable();
10115 return $this->
getScoreSettings()->getGamificationSettings()->getHighscoreTopNum();
10120 return $this->
getScoreSettings()->getGamificationSettings()->getHighScoreMode();
10126 switch ($specific_answer_feedback) {
10128 $this->specific_answer_feedback = 1;
10131 $this->specific_answer_feedback = 0;
10138 switch ($this->specific_answer_feedback) {
10153 $this->obligationsEnabled = (bool) $obligationsEnabled;
10180 $obligationPossible = call_user_func(array($classConcreteQuestion,
'isObligationPossible'), $questionId);
10182 return $obligationPossible;
10194 $ilDB = $DIC[
'ilDB'];
10196 $rset =
$ilDB->queryF(
'SELECT obligatory FROM tst_test_question WHERE question_fi = %s', array(
'integer'), array($question_id));
10198 if ($row =
$ilDB->fetchAssoc($rset)) {
10199 return (
bool) $row[
'obligatory'];
10220 $ilDB = $DIC[
'ilDB'];
10222 $rset =
$ilDB->queryF(
10223 'SELECT obligations_answered FROM tst_pass_result WHERE active_fi = %s AND pass = %s',
10224 array(
'integer',
'integer'),
10225 array($active_id, $pass)
10228 if ($row =
$ilDB->fetchAssoc($rset)) {
10229 return (
bool) $row[
'obligations_answered'];
10232 return !self::hasObligations($test_id);
10246 $ilDB = $DIC[
'ilDB'];
10248 $rset =
$ilDB->queryF(
10249 'SELECT count(*) cnt FROM tst_test_question WHERE test_fi = %s AND obligatory = 1',
10254 $row =
$ilDB->fetchAssoc($rset);
10256 return (
bool) $row[
'cnt'] > 0;
10281 return $this->
getScoreSettings()->getResultSummarySettings()->getPassDeletionAllowed();
10284 #region Examview / PDF Examview 10347 return (strlen($this->activation_starting_time)) ? $this->activation_starting_time : null;
10352 return (strlen($this->activation_ending_time)) ? $this->activation_ending_time : null;
10364 $ilDB = $DIC[
'ilDB'];
10367 $result =
$ilDB->queryF(
10368 "SELECT tst_times.active_fi, tst_times.started FROM tst_times, tst_active WHERE tst_times.active_fi = tst_active.active_id AND tst_active.test_fi = %s ORDER BY tst_times.tstamp DESC",
10372 while ($row =
$ilDB->fetchAssoc($result)) {
10373 $times[$row[
'active_fi']] = $row[
'started'];
10381 $ilDB = $DIC[
'ilDB'];
10384 $result =
$ilDB->queryF(
10385 "SELECT tst_addtime.active_fi, tst_addtime.additionaltime FROM tst_addtime, tst_active WHERE tst_addtime.active_fi = tst_active.active_id AND tst_active.test_fi = %s",
10389 while ($row =
$ilDB->fetchAssoc($result)) {
10390 $times[$row[
'active_fi']] = $row[
'additionaltime'];
10398 $ilDB = $DIC[
'ilDB'];
10400 $result =
$ilDB->queryF(
10401 "SELECT additionaltime FROM tst_addtime WHERE active_fi = %s",
10405 if ($result->numRows() > 0) {
10406 $row =
$ilDB->fetchAssoc($result);
10407 return $row[
'additionaltime'];
10416 $participantData->setParticipantAccessFilter(
10421 $participantData->setActiveIdsFilter(array($active_id));
10424 $participantData->load($this->
getTestId());
10426 foreach ($participantData->getActiveIds() as $active_fi) {
10427 $result = $this->db->queryF(
10428 "SELECT active_fi FROM tst_addtime WHERE active_fi = %s",
10433 if ($result->numRows() > 0) {
10434 $this->db->manipulateF(
10435 "DELETE FROM tst_addtime WHERE active_fi = %s",
10441 $this->db->manipulateF(
10442 "UPDATE tst_active SET tries = %s, submitted = %s, submittimestamp = %s WHERE active_id = %s",
10443 array(
'integer',
'integer',
'timestamp',
'integer'),
10444 array(0, 0, null, $active_fi)
10447 $this->db->manipulateF(
10448 "INSERT INTO tst_addtime (active_fi, additionaltime, tstamp) VALUES (%s, %s, %s)",
10449 array(
'integer',
'integer',
'integer'),
10450 array($active_fi, $minutes, time())
10478 public function getMaxPassOfTest():
int 10484 $ilDB = $DIC[
'ilDB'];
10487 SELECT MAX(tst_pass_result.pass) + 1 max_res 10488 FROM tst_pass_result 10489 INNER JOIN tst_active ON tst_active.active_id = tst_pass_result.active_fi 10490 WHERE test_fi = ' .
$ilDB->quote($this->
getTestId(),
'integer') .
' 10494 return (
int)
$data[
'max_res'];
10500 $ilDB = $DIC[
'ilDB'];
10502 $exam_id_query =
'SELECT exam_id FROM tst_pass_result WHERE active_fi = %s AND pass = %s';
10503 $exam_id_result =
$ilDB->queryF($exam_id_query, array(
'integer',
'integer' ), array( $active_id, $pass ));
10504 if (
$ilDB->numRows($exam_id_result) == 1) {
10505 $exam_id_row =
$ilDB->fetchAssoc($exam_id_result);
10507 if ($exam_id_row[
'exam_id'] != null) {
10508 return $exam_id_row[
'exam_id'];
10515 public static function buildExamId($active_id, $pass, $test_obj_id = null): string
10520 $inst_id =
$ilSetting->get(
'inst_id', null);
10522 if ($test_obj_id === null) {
10523 $obj_id = self::_getObjectIDFromActiveID($active_id);
10525 $obj_id = $test_obj_id;
10528 $examId =
'I' . $inst_id .
'_T' . $obj_id .
'_A' . $active_id .
'_P' . $pass;
10548 return $this->
getScoreSettings()->getResultDetailsSettings()->getShowExamIdInTestResults();
10569 $this->char_selector_availability = (
int) $availability;
10585 $this->char_selector_definition = $definition;
10627 $ilDB = $DIC[
'ilDB'];
10629 $query =
"SELECT question_set_type FROM tst_tests WHERE obj_fi = %s";
10633 $questionSetType = null;
10635 while ($row =
$ilDB->fetchAssoc(
$res)) {
10636 $questionSetType = $row[
'question_set_type'];
10681 return self::lookupQuestionSetType($a_obj_id) == self::QUESTION_SET_TYPE_RANDOM;
10686 switch ($questionSetType) {
10688 return $lng->
txt(
'tst_question_set_type_fixed');
10691 return $lng->
txt(
'tst_question_set_type_random');
10694 throw new ilTestException(
'invalid question set type value given: ' . $questionSetType);
10709 $scoring->setPreserveManualScores($preserve_manscoring);
10710 $scoring->recalculateSolutions();
10717 $ilDB = $DIC[
'ilDB'];
10722 INNER JOIN tst_tests 10723 ON test_id = test_fi 10731 while ($row =
$ilDB->fetchAssoc(
$res)) {
10732 $objIds[] = (
int) $row[
'obj_fi'];
10751 return $this->
getScoreSettings()->getResultDetailsSettings()->getTaxonomyFilterIds();
10773 if (!self::isSkillManagementGloballyActivated()) {
10784 if (self::$isSkillManagementGloballyActivated === null) {
10787 self::$isSkillManagementGloballyActivated = $skmgSet->isActivated();
10790 return self::$isSkillManagementGloballyActivated;
10850 $ilDB = $DIC[
'ilDB'];
10851 $lng = $DIC[
'lng'];
10852 $refinery = $DIC[
'refinery'];
10853 $component_repository = $DIC[
'component.repository'];
10859 $activeId = $testOBJ->getActiveIdOfUser($userId);
10865 $testSession = $testSessionFactory->getSession($activeId);
10870 if ($a_force_new_run) {
10883 $ilDB = $DIC[
'ilDB'];
10884 $lng = $DIC[
'lng'];
10885 $refinery = $DIC[
'refinery'];
10886 $component_repository = $DIC[
'component.repository'];
10893 $activeId = $testOBJ->getActiveIdOfUser($userId);
10897 $testSessionFactory->reset();
10901 $testSession = $testSessionFactory->getSession($activeId);
10927 $ilDB = $DIC[
'ilDB'];
10930 SELECT COUNT(test_question_id) cnt 10931 FROM tst_test_question 10938 $row =
$ilDB->fetchAssoc($questRes);
10939 $questCount = $row[
'cnt'];
10944 FROM tst_active tac 10945 INNER JOIN tst_sequence tseq 10946 ON tseq.active_fi = tac.active_id 10947 WHERE tac.test_fi = %s 10950 $partRes =
$ilDB->queryF(
10956 while ($row =
$ilDB->fetchAssoc($partRes)) {
10957 $sequence = @unserialize($row[
'sequence']);
10960 $sequence = array();
10963 $sequence = array_filter($sequence,
function ($value) use ($questCount) {
10964 return $value <= $questCount;
10967 $num_seq = count($sequence);
10968 if ($questCount > $num_seq) {
10969 $diff = $questCount - $num_seq;
10970 for (
$i = 1;
$i <= $diff;
$i++) {
10971 $sequence[$num_seq +
$i - 1] = $num_seq +
$i;
10975 $new_sequence = serialize($sequence);
10977 $ilDB->update(
'tst_sequence', array(
10978 'sequence' => array(
'clob', $new_sequence)
10980 'active_fi' => array(
'integer', $row[
'active_fi']),
10981 'pass' => array(
'integer', $row[
'pass'])
10985 $new_sequence = serialize($questCount > 0 ? range(1, $questCount) : array());
10989 FROM tst_active tac 10990 INNER JOIN tst_sequence tseq 10991 ON tseq.active_fi = tac.active_id 10992 WHERE tac.test_fi = %s 10995 $part_rest =
$ilDB->queryF(
11001 while ($row =
$ilDB->fetchAssoc($part_rest)) {
11002 $ilDB->update(
'tst_sequence', array(
11003 'sequence' => array(
'clob', $new_sequence)
11005 'active_fi' => array(
'integer', $row[
'active_fi']),
11006 'pass' => array(
'integer', $row[
'pass'])
11022 if (!$this->score_settings) {
11031 if (!$this->score_settings_repo) {
static _replaceMediaObjectImageSrc(string $a_text, int $a_direction=0, string $nic='')
Replaces image source from mob image urls with the mob id or replaces mob id with the correct image s...
setAllowedUsers($a_allowed_users)
static _getUserIdFromActiveId($active_id)
isShowGradingMarkEnabled()
setAnswerFeedback($answer_feedback=0)
Sets the generic feedback for the test Use setGenericAnswerFeedback instead.
& getWorkedQuestions($active_id, $pass=null)
Gets the id's of all questions a user already worked through.
$ending_time_enabled
bool?
setSkillServiceEnabled($skillServiceEnabled)
getListOfQuestionsDescription()
Returns TRUE if the list of questions should be presented with the question descriptions.
setOldOnlineStatus($oldOnlineStatus)
raiseError(string $a_msg, int $a_err_obj)
wrapper for downward compability
static get(string $a_var)
buildStatisticsAccessFilteredParticipantList()
getCharSelectorDefinition()
getTimeExtensionsOfParticipants()
isHTML($a_text)
Checks if a given string contains HTML or not.
const SCORE_REPORTING_DISABLED
inviteRole($role_id)
Invites all users of a role to a test.
static _getWorkingTimeOfParticipantForPass($active_id, $pass)
Returns the complete working time in seconds for a test participant.
static _getAvailableQuestionpools($use_object_id=false, $equal_points=false, $could_be_offline=false, $showPath=false, $with_questioncount=false, $permission="read", $usr_id="")
Returns the available question pools for the active user.
setMailNotification($a_notification)
isDynamicTest()
Returns the fact wether this test is a dynamic question set test or not.
ilObjTestScoreSettings $score_settings
isBlockPassesAfterPassedEnabled()
setEnableExamview($enable_examview)
isTestFinished($active_id)
returns if the active for user_id has been submitted
setPassword($a_password=null)
Sets the password for test access.
& processCSVRow($row, $quoteAll=false, $separator=";")
Processes an array as a CSV row and converts the array values to correct CSV values.
getActivationVisibility()
getHighscoreOwnTable()
Gets if the own rankings table should be shown.
getHighscoreTopNum(int $a_retval=10)
Gets the number of entries which are to be shown in the top-rankings table.
$testSequence
contains the test sequence data
static _addLog( $user_id, $object_id, $logtext, $question_id=0, $original_id=0, $test_only=false, $test_ref_id=0)
Add an assessment log entry.
_getTitleOutput($active_id)
Returns the value of the title_output status.
exportFileItems($target_dir, &$expLog)
export files of file itmes
setOnline($a_online=true)
getFixedParticipants()
Returns the fixed participants status.
static _getObjectIDFromTestID($test_id)
Returns the ILIAS test object id for a given test id.
setShowExamIdInTestPassEnabled($show_exam_id_in_test_pass_enabled)
setIntroduction(string $introduction)
setForceInstantFeedbackEnabled($forceInstantFeedbackEnabled)
deliverPDFfromFO($fo, $title=null)
Delivers a PDF file from a XSL-FO string.
getReportingDate()
Gets the reporting date of the ilObjTest object.
float $ects_fx
Contains the percentage of maximum points a failed user needs to get the FX ECTS grade.
array $resultFilterTaxIds
evalTotalPersonsArray($name_sort_order="asc")
Returns all persons who started the test.
getResultsPresentation()
Returns the combined results presentation value.
const DEFAULT_PROCESSING_TIME_MINUTES
static allObligationsAnswered($test_id, $active_id, $pass)
checks wether all questions marked as obligatory were answered within the test pass with given testId...
setShowKioskModeTitle($a_title=false)
Set to true, if the full test title should be shown in kiosk mode.
logAction($logtext="", $question_id="")
Logs an action into the Test&Assessment log.
getProcessingTimeAsMinutes()
static _getPass($active_id)
Retrieves the actual pass of a given user for a given test.
evalTotalParticipantsArray($name_sort_order="asc")
Returns all participants who started the test.
static _getParticipantData($active_id)
Retrieves a participant name from active id.
setShowSolutionPrintview(int $a_printview=1)
Sets if the the solution printview should be presented to the user or not.
_buildName($is_anonymous, $user_id, $firstname, $lastname, $title)
Builds a user name for the output depending on test type and existence of the user.
removeTestResultsByUserIds($userIds)
setShowExamviewPdf($show_examview_pdf)
isShowExamIdInTestPassEnabled()
setQuestionOrderAndObligations($orders, $obligations)
setRedirectionMode($redirection_mode=0)
static _getQuestionType(int $question_id)
processPrintoutput2FO($print_output)
Convert a print output to XSL-FO.
setQuestionSetType($questionSetType)
setter for question set type
static deleteNewsOfContext(int $a_context_obj_id, string $a_context_obj_type, int $a_context_sub_obj_id=0, string $a_context_sub_obj_type="")
Delete all news of a context.
int $use_previous_answers
setECTSOutput($a_ects_output)
setActivationEndingTime($ending_time=null)
txtlng(string $a_module, string $a_topic, string $a_language)
gets the text for a given topic in a given language if the topic is not in the list, the topic itself with "-" will be returned
checkQuestionParent($questionId)
static _lookupTestObjIdForQuestionId($a_q_id)
Get test Object ID for question ID.
saveCompleteStatus(ilTestQuestionSetConfig $testQuestionSetConfig)
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...
$accessFilteredParticipantList
setReportingDate($reporting_date)
Sets the reporting date of the ilObjTest object when the score reporting is available.
withGamificationSettings(ilObjTestSettingsGamification $settings)
getQuestionTitle($title, $nr=null)
Returns the title of a test question and checks if the title output is allowed.
static _updateTestResultCache(int $active_id, ilAssQuestionProcessLocker $processLocker=null)
Move this to a proper place.
bool $instantFeedbackAnswerFixationEnabled
& getInvitedUsers($user_id="", $order="login, lastname, firstname")
Returns a list of all invited users in a test.
getEnableProcessingTime()
Returns the state of the processing time (enabled/disabled)
getProcessingTimeAsArray()
bool $show_exam_id_in_test_pass_enabled
const QUESTION_SET_TYPE_RANDOM
static _getSuggestedSolutionOutput(int $question_id)
getListOfQuestionsStart()
Returns if the list of questions should be presented as the first page of the test.
static _lookupRandomTest($a_obj_id)
Returns the fact wether the test with passed obj id is a random questions test or not...
& getParticipants()
Returns all persons who started the test.
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
getCompleteWorkingTimeOfParticipant($active_id)
Returns the complete working time in seconds for a test participant.
This class handles all operations on files (attachments) in directory ilias_data/mail.
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
loadFromDb()
loads the question set config for current test from the database
setShuffleQuestions($a_shuffle)
Sets the status of the shuffle_questions variable.
setFixedParticipants($a_value=1)
Sets the fixed participants status.
if(! $DIC->user() ->getId()||!ilLTIConsumerAccess::hasCustomProviderCreationAccess()) $params
Abstract basic class which is to be extended by the concrete assessment question type classes...
fromXML(ilQTIAssessment $assessment)
Receives parameters from a QTI parser and creates a valid ILIAS test object.
getPresentationMaterial()
getShowSolutionFeedback()
Returns if the feedback should be presented to the solution or not.
hasRandomQuestionsForPass(int $active_id, int $pass)
Checkes wheather a random test has already created questions for a given pass or not.
static _getPassScoring($active_id)
Gets the pass scoring type.
static lookupPassResultsUpdateTimestamp($active_id, $pass)
& getExistingQuestions($pass=null)
Get the id's of the questions which are already part of the test.
setInstantFeedbackOptionsByArray($options)
setCharSelectorDefinition($definition='')
bool $print_best_solution_with_result
getShowKioskModeParticipant()
Returns the status of the kiosk mode participant.
static $isSkillManagementGloballyActivated
const SCORE_REPORTING_AFTER_PASSED
static _getQuestionTitle(int $question_id)
insertQuestion(ilTestQuestionSetConfig $testQuestionSetConfig, $question_id, $linkOnly=false)
Insert a question in the list of questions.
getQuestionSetTypeTranslation(ilLanguage $lng, $questionSetType)
getHighscoreAchievedTS()
Returns if date and time of the scores achievement should be displayed.
getTestId()
Gets the database id of the additional test data.
static factory(string $a_package, int $a_timeout=0)
Creates an ilRpcClient instance to our ilServer.
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
getListOfQuestionsSettings()
Returns the settings for the list of questions options in the test properties This could contain one ...
getAvailableQuestionpools($use_object_id=false, $equal_points=false, $could_be_offline=false, $show_path=false, $with_questioncount=false, $permission="read")
Returns the available question pools for the active user.
createQuestionGUI($question_type, $question_id=-1)
Creates a question GUI instance of a given question type.
getShowInfo()
Gets whether the complete information page is shown or the required data only.
int $reset_processing_time
& getQuestionTitlesAndIndexes()
Returns the titles of the test questions in question sequence.
getMailNotificationType()
isNewRandomTest()
Checks wheather the test is a new random test (using tst_rnd_cpy) or an old one.
static formatDate(ilDateTime $date, bool $a_skip_day=false, bool $a_include_wd=false, bool $include_seconds=false)
logManualFeedback($active_id, $question_id, $feedback)
Creates a log for the manual feedback.
getJavaScriptOutput()
Returns if Javascript should be chosen for drag & drop actions for the active user.
setPassWaiting($pass_waiting)
const TIMINGS_DEACTIVATED
getECTSGrade($passed_array, $reached_points, $max_points)
{Returns the ECTS grade for a number of reached points.An array with the points of all users who pass...
getShowSolutionAnswersOnly()
Returns if the full solution (including ILIAS content) should be presented to the solution or not...
static _lookupName(int $a_user_id)
lookup user name
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
& createTestSequence($active_id, $pass, $shuffle)
static isManScoringDone($activeId)
reads the flag wether manscoring is done for the given test active or not from the global settings (s...
& _evalResultsOverview($test_id)
Creates an associated array with the results of all participants of a test.
& getQuestionsOfTest($active_id)
Retrieves all the assigned questions for all test passes of a test participant.
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
sendAdvancedNotification($active_id)
static _getOriginalId(int $question_id)
getXMLZip()
Get zipped xml file for test.
setResetProcessingTime($reset=0)
Sets wheather the processing time should be reset or not.
setCharSelectorAvailability($availability)
setShowMarker($a_value=1)
Sets the marker button status.
inviteUser($user_id, $client_ip="")
Invites a user to a test.
getAnonymity()
Returns the anonymity status of the test.
static _lookupOwner(int $obj_id)
Lookup owner user ID for object ID.
toXML()
Returns a QTI xml representation of the test.
loadLanguageModule(string $a_module)
Load language module.
setEndingTimeEnabled($ending_time_enabled)
getShowSolutionListOwnAnswers($user_id=null)
setActivationLimited($a_value)
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
setSpecificAnswerFeedback($specific_answer_feedback)
getShuffleQuestions()
Returns the status of the shuffle_questions variable.
setTestId($a_id)
Sets the test ID.
static _cleanupMediaObjectUsage(string $a_text, string $a_usage_type, int $a_usage_id)
Synchronises appearances of media objects in $a_text with media object usage table.
bool $showGradingMarkEnabled
isShowExamIdInTestResultsEnabled()
_getVisitTimeOfParticipant($test_id, $active_id)
Returns the first and last visit of a participant.
& getTestParticipants()
Returns a list of all participants in a test.
static deliverData(string $a_data, string $a_filename, string $mime="application/octet-stream")
getCompleteWorkingTime($user_id)
Returns the complete working time in seconds a user worked on the test.
getShowSolutionDetails()
Returns if the solution details should be presented to the user or not.
getImagePathWeb()
Returns the web image path for web accessable images of a test The image path is under the web access...
startingTimeReached()
Returns true if the starting time of a test is reached A starting time is not available for self asse...
questionMoveDown($question_id)
Moves a question down in order.
getHighscoreWTime()
Gets if the column with the workingtime should be shown.
static getStyleSheetLocation(string $mode="output", string $a_css_name="", string $a_css_location="")
get full style sheet file name (path inclusive) of current user
getActiveIdOfUser($user_id="", $anonymous_id="")
Gets the active id of a given user.
static _getObjectIDFromActiveID($active_id)
Returns the ILIAS test object id for a given active id.
setShowGradingStatusEnabled($showGradingStatusEnabled)
$participantDataExist
holds the fact wether participant data exists or not DO NOT USE TIS PROPERTY DRIRECTLY ALWAYS USE ilO...
getActiveParticipantList()
static _isPassed($user_id, $a_obj_id)
Returns TRUE if the user with the user id $user_id passed the test with the object id $a_obj_id...
setRedirectionUrl($redirection_url=null)
static _getBestPass($active_id)
Retrieves the best pass of a given user for a given test.
saveToDb(bool $properties_only=false)
static _lookupAnonymity($a_obj_id)
Returns the anonymity status of a test with a given object id.
setEndingTime($ending_time=null)
Sets the ending time in database timestamp format for the test.
getShowSolutionListComparison()
setQuestionSetSolved($value, $question_id, $user_id)
sets question solved state to value for given user_id
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
setListOfQuestionsStart($a_value=true)
Sets if the the list of questions as the start page of the test.
loadQuestions($active_id="", $pass=null)
Load the test question id's from the database.
getHighscoreTopTable()
Gets, if the top-rankings table should be shown.
setMailNotificationType($a_type)
startWorkingTime($active_id, $pass)
Write the initial entry for the tests working time to the database.
static removeTrailingPathSeparators(string $path)
isTestQuestion($questionId)
setObligationsEnabled($obligationsEnabled=true)
sets obligations enabled/disabled
setTitleOutput($title_output=0)
Sets the status of the title output.
disinviteUser($user_id)
Disinvites a user from a test.
int $instant_verification
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
setFinalStatement(string $a_statement)
$evaluation_data
Contains the evaluation data settings the tutor defines for the user.
areObligationsEnabled()
returns the fact wether obligations are enabled or not
& getQuestionTitles()
Returns the titles of the test questions in question sequence.
static _lookupObjId(int $ref_id)
& evalResultsOverview()
Creates an associated array with the results of all participants of a test.
getSequenceSettings()
SEQUENCE SETTING = POSTPONING ENABLED !!
static _instanciateQuestion($question_id)
Creates an instance of a question with a given question id.
& _getCompleteWorkingTimeOfParticipants($test_id)
Returns the complete working time in seconds for all test participants.
isRandomTest()
Returns the fact wether this test is a random questions test or not.
setTestFinalBroken($testFinalBroken)
static getASCIIFilename(string $a_filename)
getHighscorePercentage()
Gets if the percentage column should be shown.
isFixedTest()
Returns the fact wether this test is a fixed question set test or not.
checkMarks()
{boolean|string True or an error string which can be used for display purposes}
setShowKioskModeParticipant($a_participant=false)
Set to true, if the participant's name should be shown in kiosk mode.
static isQuestionObligatory($question_id)
checks wether the question with given id is marked as obligatory or not
saveManualFeedback(int $active_id, int $question_id, int $pass, ?string $feedback, bool $finalized=false, bool $is_single_feedback=false)
updateWorkingTime($times_id)
Update the working time of a test when a question is answered.
getFixedQuestionSetTotalPoints()
isExecutable($testSession, $user_id, $allowPassIncrease=false)
Checks if the test is executable by the given user.
setDescription(string $desc)
getHtmlQuestionContentPurifier()
setSignSubmission($sign_submission)
static completeMissingPluginName($questionTypeData)
getSpecificAnswerFeedback()
getImportMapping()
get array of (two) new created questions for import id
static _getMaxPass($active_id)
Retrieves the maximum pass of a given user for a given test in which the user answered at least one q...
setProcessingTimeByMinutes($minutes)
addDefaults($a_name)
Adds the defaults of this test to the test defaults.
getCountSystem()
Gets the count system for the calculation of points.
const SCORE_REPORTING_IMMIDIATLY
hasAnyTestResult(ilTestSession $testSession)
getMarkSchemaForeignId()
{int}
setNrOfTries($nr_of_tries=0)
Sets the nr of tries for the test.
static collectFileItems(ilPageObject $a_page, DOMDocument $a_domdoc)
Get all file items that are used within the page.
static instantiateQuestion(int $question_id)
$metadata
A reference to an IMS compatible matadata set.
removeTestResults(ilTestParticipantData $participantData)
setStartingTime($starting_time=null)
Sets the starting time in database timestamp format for the test.
Interface for html sanitizing functionality.
setAnswerFeedbackPoints($answer_feedback_points=0)
Sets the answer specific feedback of reached points for the test.
removeQuestions(array $removeQuestionIds)
evalStatistical($active_id)
Returns the statistical evaluation of the test for a specified user.
static getSingleManualFeedback(int $active_id, int $question_id, int $pass)
getHighscoreHints()
Gets, if the column with the number of requested hints should be shown.
static _enabledAssessmentLogging()
cloneMetaData(ilObject $target_obj)
Copy meta data.
getAccessFilteredParticipantList()
setShowCancel($a_value=1)
Sets the cancel test button status.
getQuestiontext($question_id)
Returns the question text for a given question.
getShowKioskModeTitle()
Returns the status of the kiosk mode title.
buildName($user_id, $firstname, $lastname, $title)
Builds a user name for the output depending on test type and existence of the user.
setAutosaveIval($autosave_ival)
setExportSettingsSingleChoiceShort($a_settings)
setCustomStyle($a_customStyle=null)
Set the custom style.
getVisitTimeOfParticipant($active_id)
Returns the first and last visit of a participant.
static _lookupClientIP(int $a_user_id)
getListOfQuestions()
Returns if the list of questions should be presented to the user or not.
QTIMaterialToString($a_material)
Reads an QTI material tag an creates a text string.
setProcessingTime($processing_time="00:00:00")
Sets the processing time for the test.
$forceInstantFeedbackEnabled
static _lookupTitle(int $obj_id)
getAllTestResults($participants, $prepareForCSV=true)
returns all test results for all participants
getResetProcessingTime()
Returns wheather the processing time should be reset or not.
getHighscoreAnon()
Gets if the highscores should be anonymized per setting.
$starting_time_enabled
bool?
getTestParticipantsForManualScoring($filter=null)
setExportSettings($a_settings)
static _getQuestionCountAndPointsForPassOfParticipant($active_id, $pass)
getInstantFeedbackOptionsAsArray()
static _isWorkedThrough(int $active_id, int $question_id, int $pass)
Returns true if the question was worked through in the given pass Worked through means that the user ...
int $answer_feedback_points
static _prepareCloneSelection(array $ref_ids, string $new_type, bool $show_path=true)
Prepare copy wizard object selection.
setActivationVisibility($a_value)
hasQuestionsWithoutQuestionpool()
evalTotalPersons()
Returns the number of persons who started the test.
setAuthor(string $author="")
Sets the authors name of the ilObjTest object.
hasSingleChoiceQuestions()
static _getScoreCutting($active_id)
Determines if the score of a question should be cut at 0 points or the score of the whole test...
getStartingTimeOfUser($active_id, $pass=null)
Returns the unix timestamp of the time a user started a test.
getShowMarker()
Returns wheather the marker button is shown or not.
sendSimpleNotification($active_id)
getShowSolutionPrintview()
Returns if the solution printview should be presented to the user or not.
getAnswerFeedback()
Returns 1 if generic answer feedback is activated.
hasNrOfTriesRestriction()
returns if the numbers of tries have to be checked
getTitleOutput()
Returns the value of the title_output status.
addExtraTime($active_id, $minutes)
getAuthor()
Gets the authors name of the ilObjTest object.
static _getResultPass($active_id)
Retrieves the pass number that should be counted for a given user.
getTestDefaults($test_defaults_id)
Returns the test defaults for a given id.
getUsePreviousAnswers()
Returns if the previous answers should be shown for a learner.
getShowPassDetails()
Returns if the pass details should be shown when a test is not finished.
static getManualFeedback($active_id, $question_id, $pass)
Retrieves the feedback comment for a question in a test if it is finalized.
removeQuestion(int $question_id)
isTestFinishedToViewResults($active_id, $currentpass)
Returns true if an active user completed a test pass and did not start a new pass.
getShowFinalStatement()
Returns whether the final statement should be shown or not.
static ensureParticipantsLastActivePassFinished($testObjId, $userId, $a_force_new_run=false)
getUserData($ids)
Returns a data of all users specified by id list.
setTemplate($template_id)
questionMoveUp($question_id)
Moves a question up in order.
static delDir(string $a_dir, bool $a_clean_only=false)
removes a dir and all its content (subdirs and files) recursively
const NEWS_NOTICE
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
setShowInfo($a_info=1)
Set whether the complete information page is shown or the required data only.
static getInstanceByRefId(int $ref_id, bool $stop_on_error=true)
get an instance of an Ilias object by reference id
getEvaluationAdditionalFields()
Gets additional user fields that should be shown in the user evaluation.
static _getSolutionMaxPass(int $question_id, int $active_id)
Returns the maximum pass a users question solution.
getShowSolutionSuggested()
& getAllQuestions($pass=null)
Returns all questions of a test in test order.
isSkillServiceToBeConsidered()
Returns whether this test must consider skills, usually by providing appropriate extensions in the us...
exportXMLMetaData(&$a_xml_writer)
export content objects meta data to xml (see ilias_co.dtd)
static _getCountSystem($active_id)
Gets the count system for the calculation of points.
setInstantFeedbackSolution($instant_feedback=0)
Sets the instant feedback for the solution.
setListOfQuestions($a_value=true)
Sets if the the list of questions should be presented to the user or not.
static _getSolvedQuestions($active_id, $question_fi=null)
get solved questions
setGenericAnswerFeedback(int $generic_answer_feedback=0)
static getAccessStatisticsUserFilter($refId)
buildIso8601PeriodFromUnixtimeForExportCompatibility($unix_timestamp)
setAllowedUsersTimeGap($a_allowed_users_time_gap)
applyDefaults($test_defaults)
Applies given test defaults to this test.
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
getProcessingTime()
Returns the processing time for the test.
setLimitUsersEnabled(bool $limitUsersEnabled)
isOfferingQuestionHintsEnabled()
returns the fact wether offering hints is enabled or not
removeTestActives($activeIds)
& getTestResult( $active_id, $pass=null, bool $ordered_sequence=false, bool $considerHiddenQuestions=true, bool $considerOptionalQuestions=true)
Calculates the results of a test for a given user and returns an array with all test results...
exportXMLMediaObjects(&$a_xml_writer, $a_inst, $a_target_dir, &$expLog)
export media objects to xml (see ilias_co.dtd)
header include for all ilias files.
getAnsweredQuestionCount($active_id, $pass=null)
Retrieves the number of answered questions for a given user in a given test.
isBestSolutionPrintedWithResult()
addQTIMaterial(&$a_xml_writer, $a_material='')
Creates a QTI material tag from a plain text or xhtml text.
static getInstanceByType(string $type)
$activation_starting_time
static isSkillManagementGloballyActivated()
getAnswerFeedbackPoints()
Returns 1 if answer specific feedback as reached points is activated.
createExportDirectory()
creates data directory for export files (data_dir/tst_data/tst_<id>/export, depending on data directo...
getStartTestLabel($active_id)
Returns the "Start the Test" label for the Info page.
setAccessFilteredParticipantList($accessFilteredParticipantList)
setECTSGrades(array $a_ects_grades)
removeTestResultsFromSoapLpAdministration($userIds)
getMarkSchema()
{ASS_MarkSchema}
getAggregatedResultsData()
Returns the aggregated test results.
static _lookupAuthor($obj_id)
Gets the authors name of the ilObjTest object.
static _getObjectsByOperations( $a_obj_type, string $a_operation, int $a_usr_id=0, int $limit=0)
Get all objects of a specific type and check access This function is not recursive, instead it parses the serialized rbac_pa entries.
getStartingTime()
Returns the starting time of the test.
getStartingTimeOfParticipants()
Note, this function should only be used if absolutely necessary, since it perform joins on tables tha...
setAnonymity($a_value=0)
Sets the anonymity status of the test.
setOfflineStatus(bool $status)
static getDataDir()
get data directory (outside webspace)
static lookupLastTestPassAccess($activeId, $passIndex)
getShowSolutionSignature()
Returns if the signature field should be shown in the test results.
getAllRTEContent()
Returns the content of all RTE enabled text areas in the test.
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
static isQuestionObligationPossible($questionId)
checks wether the obligation for question with given id is possible or not
static _lookupFinishedUserTests($a_user_id)
Gather all finished tests for user.
saveAuthorToMetadata(string $a_author="")
Saves an authors name into the lifecycle metadata if no lifecycle metadata exists This will only be c...
pcArrayShuffle($array)
Shuffles the values of a given array.
static _lookupDescription(int $obj_id)
getGamificationSettings()
static _getTestIDFromObjectID($object_id)
Returns the ILIAS test id for a given object id.
getInstantFeedbackSolution()
Returns 1 if the correct solution will be shown after answering a question.
setKiosk($kiosk=0)
Sets the kiosk mode for the test.
removeQuestionFromSequences($questionId, $activeIds, ilTestReindexedSequencePositionMap $reindexedSequencePositionMap)
isHighscoreAnon()
Gets if the highscores should be displayed anonymized.
inviteGroup($group_id)
Invites all users of a group to a test.
setUsePreviousAnswers($use_previous_answers=1)
Sets the status of the visibility of previous learner answers.
isAnyInstantFeedbackOptionEnabled()
const SCORE_REPORTING_FINISHED
isInstantFeedbackAnswerFixationEnabled()
prepareTextareaOutput($txt_output, $prepare_for_latex_output=false, $omitNl2BrWhenTextArea=false)
Prepares a string for a text area output in tests.
$char_selector_availability
static _createImportDirectory()
creates data directory for import files (data_dir/tst_data/tst_<id>/import, depending on data directo...
static _getECTSGrade($points_passed, $reached_points, $max_points, $a, $b, $c, $d, $e, $fx)
{Returns the ECTS grade for a number of reached points.The points reached in the test The maximum num...
const TEST_FIXED_SEQUENCE
Test constants.
getNrOfTries()
Returns the nr of tries for the test.
duplicateQuestionForTest($question_id)
Takes a question and creates a copy of the question for use in the test.
setForceJS($a_js=1)
Set whether JavaScript should be forced for tests.
setPostponingEnabled($postponingEnabled)
isScoreReportingEnabled()
static hasObligations($test_id)
returns the fact wether the test with given test id contains questions markes as obligatory or not ...
isForceInstantFeedbackEnabled()
setEnableProcessingTime($enable=0)
Sets the processing time enabled or disabled.
& getTotalPointsPassedArray()
Returns an array with the total points of all users who passed the test This array could be used for ...
getQuestionDataset($question_id)
Returns the dataset for a given question id.
_getLastAccess($active_id)
static ilTempnam(?string $a_temp_path=null)
Returns a unique and non existing Path for e temporary file or directory.
string $char_selector_definition
$mark_schema
Defines the mark schema ASS_MarkSchema ?
getResultsForActiveId($active_id)
setEnabledViewMode($mode)
getQuestionSetType()
getter for question set type
const SCORE_REPORTING_DATE
A news item can be created by different sources.
getGenericAnswerFeedback()
Returns 1 if generic answer feedback is to be shown.
static getItem(int $ref_id)
setEnableArchiving($enable_archiving)
getEstimatedWorkingTime()
Returns the estimated working time for the test calculated from the working time of the contained que...
isSingleChoiceTestWithoutShuffle()
isQuestionSetConfigured()
setBlockPassesAfterPassedEnabled($blockPassesAfterPassedEnabled)
__construct($a_id=0, bool $a_call_by_reference=true)
Constructor.
getEndingTime()
Returns the ending time of the test.
randomSelectQuestions(int $nr_of_questions, int $questionpool, $use_obj_id=0, $qpls="", $pass=null)
Returns a random selection of questions.
setPasswordEnabled($passwordEnabled)
setShowExamviewHtml($show_examview_html)
getActivationStartingTime()
getAvailableQuestions($arrFilter, $completeonly=0)
Calculates the available questions for a test.
getTextAnswer($active_id, $question_id, $pass=null)
Returns the text answer of a given user for a given question.
getScoreCutting()
Determines if the score of a question should be cut at 0 points or the score of the whole test...
bool $show_exam_id_in_test_results_enabled
getCharSelectorAvailability()
getResultDetailsSettings()
setKioskMode($a_kiosk=false)
Sets the kiosk mode for the test.
getTitleFilenameCompliant()
returns the object title prepared to be used as a filename
cleanupMediaobjectUsage()
Cleans up the media objects for all text fields in a test which are using an RTE field.
_lookupRandomTestFromActiveId($active_id)
Returns the random status of a test with a given object id.
setTmpCopyWizardCopyId(int $tmpCopyWizardCopyId)
static _getManualScoring()
Retrieve the manual scoring settings.
bool $blockPassesAfterPassedEnabled
static _getAvailableTests($use_object_id=false)
Returns the available tests for the active user.
setOfferingQuestionHintsEnabled($offeringQuestionHintsEnabled)
sets offering question hints enabled/disabled
checkMaximumAllowedUsers()
getInvitedParticipantList()
moveQuestions($move_questions, $target_index, $insert_mode)
Move questions to another position.
__construct(Container $dic, ilPlugin $plugin)
bool $offeringQuestionHintsEnabled
static getFirstNewsIdForContext(int $a_context_obj_id, string $a_context_obj_type, int $a_context_sub_obj_id=0, string $a_context_sub_obj_type="")
Get first new id of news set related to a certain context.
static getCompleteManualFeedback(int $question_id)
Retrieves the manual feedback for a question in a test.
exportPagesXML(&$a_xml_writer, $a_inst, $a_target_dir, &$expLog)
export pages of test to xml (see ilias_co.dtd)
recalculateScores($preserve_manscoring=false)
This class provides mathematical functions for statistics.
getKioskMode()
Returns the kiosk mode.
static getManageParticipantsUserFilter($refId)
getExportSettingsSingleChoiceShort()
ScoreSettingsRepository $score_settings_repo
deleteDefaults($test_default_id)
Deletes the defaults for a test.
endingTimeReached()
Returns true if the ending time of a test is reached An ending time is not available for self assessm...
getActivationEndingTime()
const QUESTION_SET_TYPE_FIXED
isActiveTestSubmitted($user_id=null)
returns if the active for user_id has been submitted
modifyExportIdentifier($a_tag, $a_param, $a_value)
Returns the installation id for a given identifier.
$testSession
contains the test session data
setFollowupQuestionAnswerFixationEnabled($followupQuestionAnswerFixationEnabled)
$a
thx to https://mlocati.github.io/php-cs-fixer-configurator for the examples
getQuestionType($question_id)
Returns the question type of a question with a given id.
static buildExamId($active_id, $pass, $test_obj_id=null)
static _includeClass(string $question_type, int $gui=0)
removeTestResultsByActiveIds($activeIds)
getSecondsUntilEndingTime()
Returns the seconds left from the actual time until the ending time.
& getCompleteWorkingTimeOfParticipants()
Returns the complete working time in seconds for all test participants.
& getCompleteEvaluationData($withStatistics=true, $filterby="", $filtertext="")
$_customStyle
Name of a custom style sheet for the test string?
getProcessingTimeInSeconds($active_id="")
Returns the processing time for the test in seconds.
getShowCancel()
Returns wheather the cancel test button is shown or not.
canShowTestResults(ilTestSession $testSession)
getNrOfResultsForPass($active_id, $pass)
Calculates the number of user results for a specific test pass.
bool $showGradingStatusEnabled
setClientIP($user_id, $client_ip)
static _getInstance(int $a_copy_id)
isShowGradingStatusEnabled()
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
canShowSolutionPrintview($user_id=null)
getQuestionCountWithoutReloading()
getHighscoreScore()
Gets if the score column should be shown.
setActivationStartingTime($starting_time=null)
static getTestObjIdsWithActiveForUserId($userId)
getListOfQuestionsEnd()
Returns if the list of questions should be presented as the last page of the test.
isPluginActive($a_pname)
Checks wheather or not a question plugin with a given name is active.
isFollowupQuestionAnswerFixationEnabled()
int $specific_answer_feedback
static isParticipantsLastPassActive($testRefId, $userId)
& evalResultsOverviewOfParticipant($active_id)
Creates an associated array with the results for a given participant of a test.
setShowGradingMarkEnabled($showGradingMarkEnabled)
getKiosk()
Returns the kiosk mode.
setInstantFeedbackAnswerFixationEnabled($instantFeedbackAnswerFixationEnabled)
moveQuestionAfter($question_to_move, $question_before)
getScoreSettingsRepository()
static insertInstIntoID(string $a_value)
inserts installation id into ILIAS id
setIntroductionEnabled($introductionEnabled)
static lookupQuestionSetType($objId)
lookup-er for question set type
bool $skillServiceEnabled
static lookupQuestionSetTypeByActiveId($active_id)
returns the question set type of test relating to passed active id
const QUESTION_SET_TYPE_DYNAMIC
deliverPDFfromHTML($content, $title=null)
Delivers a PDF file from XHTML.
getDetailedTestResults($participants)
returns all test results for all participants
static getInstance(int $obj_id)
bool $followupQuestionAnswerFixationEnabled
static clear(string $a_var)
isNrOfTriesReached($tries)
returns if number of tries are reached
exportXMLPageObjects(&$a_xml_writer, $a_inst, &$expLog)
export page objects to xml (see ilias_co.dtd)
& getQuestionsOfPass($active_id, $pass)
Retrieves all the assigned questions for a test participant in a given test pass. ...
setListOfQuestionsDescription($a_value=true)
Sets the show_summary attribute to TRUE if the list of questions should be presented with the questio...
getResultSummarySettings()
getForceJS()
Gets whether JavaScript should be forced for tests.
Class ilObjectActivation.
isComplete(ilTestQuestionSetConfig $testQuestionSetConfig)
setShowFinalStatement($show=0)
Sets whether the final statement should be shown or not.
static set(string $a_var, $a_val)
Set a value.
static deleteRequestsByActiveIds($activeIds)
Deletes all hint requests relating to a testactive included in given active ids.
setSequenceSettings($sequence_settings=0)
SEQUENCE SETTING = POSTPONING ENABLED !!
insertManualFeedback(int $active_id, int $question_id, int $pass, ?string $feedback, bool $finalized, array $feedback_old)
reindexFixedQuestionOrdering()
setListOfQuestionsSettings($a_value=0)
Sets the settings for the list of questions options in the test properties This could contain one of ...
setListOfQuestionsEnd($a_value=true)
Sets if the the list of questions as the end page of the test.
static _setImportDirectory($a_import_dir=null)
ILIAS Test InternalRequestService $testrequest
static _getTestDefaults($test_defaults_id)
for($i=6; $i< 13; $i++) for($i=1; $i< 13; $i++) $d
userLookupFullName($user_id, $overwrite_anonymity=false, $sorted_order=false, $suffix="")
Returns the full name of a test user according to the anonymity status.
static _getActiveIdOfUser($user_id="", $test_id="")
setStartingTimeEnabled($starting_time_enabled)
static makeDir(string $a_dir)
creates a new directory and inherits all filesystem permissions of the parent directory You may pass ...
isMaxProcessingTimeReached(int $starting_time, int $active_id)
Returns whether the maximum processing time for a test is reached or not.
static _getImportDirectory()
Get the import directory location of the test.
static _updateStatus(int $a_obj_id, int $a_usr_id, ?object $a_obj=null, bool $a_percentage=false, bool $a_force_raise=false)
isPreviousSolutionReuseEnabled($active_id)
bool $introductionEnabled
getImagePath()
Returns the image path for web accessable images of a test The image path is under the CLIENT_WEB_DIR...
static getFeedbackClassNameByQuestionType(string $questionType)
static lookupExamId($active_id, $pass)
evalTotalStartedAverageTime($activeIdsFilter=null)
Returns the average processing time for all started tests.
getPassScoring()
Gets the pass scoring type.