52 $this->
user = $DIC->user();
54 $this->db = $DIC->database();
80 $md_gen = $md->getGeneral();
84 foreach ($md_gen->getDescriptionIds() as
$id) {
85 $md_des = $md_gen->getDescription($id);
94 $obj_lp->getCurrentMode(),
109 public static function _lookupNID(
int $a_lm_id,
int $a_lm_obj_id,
string $a_type): ?string
111 $md =
new ilMD($a_lm_id, $a_lm_obj_id, $a_type);
112 $md_gen = $md->getGeneral();
113 if (is_object($md_gen)) {
114 foreach ($md_gen->getIdentifierIds() as
$id) {
115 $md_id = $md_gen->getIdentifier($id);
116 if ($md_id->getCatalog() ==
"ILIAS_NID") {
117 return $md_id->getEntry();
134 $md_creator->setTitle($this->
getTitle());
135 $md_creator->setTitleLanguage(
$ilUser->getPref(
'language'));
137 $md_creator->setDescriptionLanguage(
$ilUser->getPref(
'language'));
138 $md_creator->setKeywordLanguage(
$ilUser->getPref(
'language'));
139 $md_creator->setLanguage(
$ilUser->getPref(
'language'));
140 $md_creator->create();
149 $md_gen = $md->getGeneral();
150 $md_gen->setTitle($this->
getTitle());
153 $md_des_ids = $md_gen->getDescriptionIds();
154 if (count($md_des_ids) > 0) {
155 $md_des = $md_gen->getDescription($md_des_ids[0]);
180 $this->data_record = $a_record;
187 if (!isset($this->data_record)) {
188 $query =
"SELECT * FROM lm_data WHERE obj_id = " .
189 $ilDB->quote($this->
id,
"integer");
191 $this->data_record =
$ilDB->fetchAssoc($obj_set);
194 $this->type = $this->data_record[
"type"];
195 $this->
setImportId((
string) $this->data_record[
"import_id"]);
196 $this->
setTitle((
string) $this->data_record[
"title"]);
197 $this->
setShortTitle((
string) $this->data_record[
"short_title"]);
198 $this->
setLayout((
string) $this->data_record[
"layout"]);
210 $ilDB = $DIC->database();
213 "SELECT * FROM lm_data " .
214 " WHERE lm_id = " .
$ilDB->quote($a_lm_id,
"integer")
216 while ($rec =
$ilDB->fetchAssoc($set)) {
217 self::$data_records[$rec[
"obj_id"]] = $rec;
219 return count(self::$data_records);
224 $this->title = $a_title;
234 $this->short_title = $a_title;
242 protected static function _lookup(
int $a_obj_id,
string $a_field): string
246 $ilDB = $DIC->database();
248 if (isset(self::$data_records[$a_obj_id])) {
249 return self::$data_records[$a_obj_id][$a_field] ??
"";
252 $query =
"SELECT " . $a_field .
" FROM lm_data WHERE obj_id = " .
253 $ilDB->quote($a_obj_id,
"integer");
255 $obj_rec =
$ilDB->fetchAssoc($obj_set);
257 return $obj_rec[$a_field] ??
"";
262 return self::_lookup($a_obj_id,
"title");
267 return self::_lookup($a_obj_id,
"short_title");
270 public static function _lookupType(
int $a_obj_id,
int $a_lm_id = 0): string
274 $ilDB = $DIC->database();
276 if (isset(self::$data_records[$a_obj_id])) {
277 if ($a_lm_id == 0 || self::$data_records[$a_obj_id][
"lm_id"] == $a_lm_id) {
278 return self::$data_records[$a_obj_id][
"type"];
284 $and =
' AND lm_id = ' .
$ilDB->quote($a_lm_id,
'integer');
287 $query =
"SELECT type FROM lm_data WHERE obj_id = " .
$ilDB->quote($a_obj_id,
"integer") . $and;
289 $obj_rec =
$ilDB->fetchAssoc($obj_set);
291 return $obj_rec[
"type"] ??
"";
295 public static function _writeTitle(
int $a_obj_id,
string $a_title): void
299 $ilDB = $DIC->database();
301 $query =
"UPDATE lm_data SET " .
302 " title = " .
$ilDB->quote($a_title,
"text") .
303 " WHERE obj_id = " .
$ilDB->quote($a_obj_id,
"integer");
310 $this->description = $a_description;
320 $this->type = $a_type;
330 $this->lm_id = $a_lm_id;
340 $this->content_object = $a_content_obj;
348 public function setId(
int $a_id): void
365 $this->import_id = $a_id;
370 $this->layout = $a_val;
382 $ilDB = $DIC->database();
384 $q =
"UPDATE lm_data " .
386 "import_id = " .
$ilDB->quote($a_import_id,
"text") .
"," .
387 "last_update = " .
$ilDB->now() .
" " .
388 "WHERE obj_id = " .
$ilDB->quote($a_id,
"integer");
390 $ilDB->manipulate($q);
393 public function create(
bool $a_upload =
false): void
399 $query =
"INSERT INTO lm_data (obj_id, title, type, layout, lm_id, import_id, short_title, create_date) " .
401 $ilDB->quote($this->
getId(),
"integer") .
"," .
408 ", " .
$ilDB->now() .
")";
409 $ilDB->manipulate($query);
416 $this->content_object->getType() .
":" . $this->
getType()
430 $query =
"UPDATE lm_data SET " .
431 " lm_id = " .
$ilDB->quote($this->
getLMId(),
"integer") .
435 " WHERE obj_id = " .
$ilDB->quote($this->
getId(),
"integer");
450 $ilDB = $DIC->database();
451 $ilLog = $DIC[
"ilLog"];
454 if (!is_array($a_pages)) {
458 if (empty($a_cont_obj_id)) {
459 $message =
'ilLMObject::_writePublicAccessStatus(): Invalid parameter! $a_cont_obj_id is empty';
460 $ilLog->write(
$message, $ilLog->WARNING);
466 $lm_tree =
new ilTree($a_cont_obj_id);
467 $lm_tree->setTableNames(
'lm_tree',
'lm_data');
468 $lm_tree->setTreeTablePK(
"lm_id");
469 $lm_tree->readRootId();
472 $q =
"SELECT obj_id FROM lm_data " .
473 "WHERE lm_id = " .
$ilDB->quote($a_cont_obj_id,
"integer") .
" " .
475 $r =
$ilDB->query($q);
478 while ($row =
$ilDB->fetchAssoc($r)) {
479 $childs = $lm_tree->getChilds($row[
"obj_id"]);
481 foreach ($childs as $page) {
482 if ($page[
"type"] ===
"pg" and in_array($page[
"obj_id"], $a_pages)) {
483 $a_pages[] = $row[
"obj_id"];
490 $q =
"UPDATE lm_data SET " .
491 "public_access = CASE " .
492 "WHEN " .
$ilDB->in(
"obj_id", $a_pages,
false,
"integer") .
" " .
493 "THEN " .
$ilDB->quote(
"y",
"text") .
494 "ELSE " .
$ilDB->quote(
"n",
"text") .
496 "WHERE lm_id = " .
$ilDB->quote($a_cont_obj_id,
"integer") .
" " .
497 "AND " .
$ilDB->in(
"type", array(
"pg",
"st"),
false,
"text");
498 $ilDB->manipulate($q);
503 bool $a_check_public_mode =
false 507 $ilDB = $DIC->database();
508 $ilLog = $DIC[
"ilLog"];
510 if (empty($a_node_id)) {
511 $message =
'ilLMObject::_isPagePublic(): Invalid parameter! $a_node_id is empty';
512 $ilLog->write(
$message, $ilLog->WARNING);
516 if ($a_check_public_mode ===
true) {
519 $q =
"SELECT public_access_mode FROM content_object WHERE id = " .
520 $ilDB->quote($lm_id,
"integer");
521 $r =
$ilDB->query($q);
522 $row =
$ilDB->fetchAssoc($r);
524 if ($row[
"public_access_mode"] ==
"complete") {
529 $q =
"SELECT public_access FROM lm_data WHERE obj_id=" .
530 $ilDB->quote($a_node_id,
"integer");
531 $r =
$ilDB->query($q);
532 $row =
$ilDB->fetchAssoc($r);
537 public function delete(
bool $a_delete_meta_data =
true):
void 541 $query =
"DELETE FROM lm_data WHERE obj_id = " .
559 $ilDB = $DIC->database();
561 $q =
"SELECT obj_id FROM lm_data WHERE import_id = " .
562 $ilDB->quote($a_import_id,
"text") .
" " .
563 " ORDER BY create_date DESC";
564 $obj_set =
$ilDB->query($q);
565 while ($obj_rec =
$ilDB->fetchAssoc($obj_set)) {
572 return $obj_rec[
"obj_id"];
590 $ilDB = $DIC->database();
592 $where = ($a_in_lm > 0)
593 ?
" AND lm_id = " .
$ilDB->quote($a_in_lm,
"integer") .
" " 596 $q =
"SELECT * FROM lm_data WHERE import_id = " .
597 $ilDB->quote($a_import_id,
"text") .
" " .
599 " ORDER BY create_date DESC";
600 $obj_set =
$ilDB->query($q);
603 while ($obj_rec =
$ilDB->fetchAssoc($obj_set)) {
616 public static function _exists(
int $a_id): bool
620 $ilDB = $DIC->database();
622 if (is_int(strpos($a_id,
"_"))) {
626 $q =
"SELECT * FROM lm_data WHERE obj_id = " .
627 $ilDB->quote($a_id,
"integer");
628 $obj_set =
$ilDB->query($q);
629 if ($obj_rec =
$ilDB->fetchAssoc($obj_set)) {
642 $ilDB = $DIC->database();
644 $type_str = ($type !=
"")
645 ?
"AND type = " .
$ilDB->quote($type,
"text") .
" " 648 $query =
"SELECT * FROM lm_data " .
649 "WHERE lm_id= " .
$ilDB->quote($lm_id,
"integer") .
" " .
654 while ($obj_rec =
$ilDB->fetchAssoc($obj_set)) {
655 $obj_list[] = array(
"obj_id" => $obj_rec[
"obj_id"],
656 "title" => $obj_rec[
"title"],
657 "import_id" => $obj_rec[
"import_id"],
658 "type" => $obj_rec[
"type"]);
672 $ilDB = $DIC->database();
674 $query =
"SELECT * FROM lm_data " .
675 "WHERE lm_id= " .
$ilDB->quote($a_cobj->
getId(),
"integer");
678 while ($obj_rec =
$ilDB->fetchAssoc($obj_set)) {
681 if (is_object($lm_obj)) {
682 $lm_obj->delete(
true);
694 $ilDB = $DIC->database();
696 if (isset(self::$data_records[$a_id])) {
697 return self::$data_records[$a_id][
"lm_id"];
700 $query =
"SELECT lm_id FROM lm_data WHERE obj_id = " .
701 $ilDB->quote($a_id,
"integer");
703 $obj_rec =
$ilDB->fetchAssoc($obj_set);
705 return (
int) ($obj_rec[
"lm_id"] ?? 0);
713 int $a_parent_id = 0,
714 int $a_target_node_id = 0
718 $ilLog = $DIC[
"ilLog"];
723 $parent_id = ($a_parent_id != 0)
728 if ($a_target_node_id != 0) {
729 $target = $a_target_node_id;
732 if ($a_obj->
getType() ==
"st") {
733 $s_types = array(
"st",
"pg");
734 $childs = $tree->getChildsByTypeFilter($parent_id, $s_types);
737 $childs = $tree->getChildsByType($parent_id, $s_types);
740 if (count($childs) == 0) {
743 $target = $childs[count($childs) - 1][
"obj_id"];
747 if ($tree->isInTree($parent_id) && !$tree->isInTree($a_obj->
getId())) {
748 $ilLog->write(
"LMObject::putInTree: insertNode, ID: " . $a_obj->
getId() .
749 "Parent ID: " . $parent_id .
", Target: " . $target);
751 $tree->insertNode($a_obj->
getId(), $parent_id, $target);
761 $tree =
new ilLMTree($a_cont_obj_id);
777 if (!is_array($a_ids)) {
781 foreach ($a_ids as $id) {
782 $path = $tree->getPathId($id);
784 foreach (
$path as $path_id) {
785 if ($path_id != $id && in_array($path_id, $a_ids)) {
800 foreach ($cut_ids as $id) {
801 $curnode = $tree->getNodeData($id);
802 if ($tree->isInTree($id)) {
803 $tree->deleteTree($curnode);
821 $ilUser->clipboardDeleteObjectsOfType(
"pg");
822 $ilUser->clipboardDeleteObjectsOfType(
"st");
825 $time = date(
"Y-m-d H:i:s", time());
827 foreach ($a_ids as $id) {
829 if ($tree->isInTree($id)) {
830 $curnode = $tree->getNodeData($id);
831 $subnodes = $tree->getSubTree($curnode);
832 foreach ($subnodes as $subnode) {
833 if ($subnode[
"child"] != $id) {
845 $order = (($curnode[
"lft"] ?? 0) > 0)
847 : (
int) ($order + 1);
850 self::_lookupType($id),
862 public static function pasteTree(
867 string $a_insert_time,
868 array &$a_copied_nodes,
869 bool $a_as_copy =
false,
876 $ilLog = $DIC[
"ilLog"];
882 if ($item_type ==
"st") {
884 } elseif ($item_type ==
"pg") {
888 $ilLog->write(
"Getting from clipboard type " . $item_type .
", " .
889 "Item ID: " . $a_item_id .
", of original LM: " . $item_lm_id);
891 if ($item_lm_id != $a_target_lm->
getId() && !$a_as_copy) {
895 $md =
new ilMD($item_lm_id, $item->getId(), $item->getType());
896 $new_md = $md->
cloneMD($a_target_lm->
getId(), $item->getId(), $item->getType());
899 $item->setLMId($a_target_lm->
getId());
900 $item->setContentObject($a_target_lm);
906 if ($item_type ==
"pg") {
907 $page = $item->getPageObject();
909 $page->setParentId($a_target_lm->
getId());
915 $target_item = $item->copy($a_target_lm);
916 $a_copied_nodes[$item->getId()] = $target_item->getId();
918 $target_item = $item;
921 $ilLog->write(
"Putting into tree type " . $target_item->getType() .
922 "Item ID: " . $target_item->getId() .
", Parent: " . $a_parent_id .
", " .
923 "Target: " . $a_target .
", Item LM:" . $target_item->getContentObject()->getId());
927 if ($a_source_lm == null) {
928 $childs =
$ilUser->getClipboardChilds($item->getId(), $a_insert_time);
930 $childs = $a_source_lm->lm_tree->getChilds($item->getId());
931 foreach ($childs as $k => $child) {
932 $childs[$k][
"id"] = $child[
"child"];
936 foreach ($childs as $child) {
937 ilLMObject::pasteTree(
940 $target_item->
getId(),
949 return $target_item->getId();
964 if (is_array($a_titles)) {
965 foreach ($a_titles as $id => $title) {
968 if ($a_lang ==
"-") {
970 if (is_object($lmobj)) {
974 if (is_object($md_gen)) {
975 $md_gen->setTitle($title);
983 $lmobjtrans->setTitle($title);
994 array $a_copied_nodes,
995 string $a_parent_type =
"lm" 997 $all_fixes = array();
998 foreach ($a_copied_nodes as $original_id => $copied_id) {
1002 if ($copied_type ==
"pg") {
1008 $tpg =
new ilLMPage($copied_id, 0, $l);
1010 $il = $tpg->getInternalLinks();
1012 foreach ($il as $l2) {
1018 foreach ($targets as $target) {
1019 if (($target[
"inst"] == 0 || $target[
"inst"] =
IL_INST_ID) &&
1020 ($target[
"type"] ==
"pg" || $target[
"type"] ==
"st")) {
1022 if (($a_copied_nodes[$target[
"id"]] ?? 0) > 0) {
1023 $fix[$target[
"id"]] = $a_copied_nodes[$target[
"id"]];
1029 if ($trg_lm != $copy_lm) {
1033 foreach ($lm_data as $item) {
1034 if (!$found && ($item[
"lm_id"] == $copy_lm)) {
1035 $fix[$target[
"id"]] = $item[
"obj_id"];
1045 if (count($fix) > 0) {
1049 if (isset($all_fixes[$t .
":" . $copied_id])) {
1050 $all_fixes[$t .
":" . $copied_id] += $fix;
1052 $all_fixes[$t .
":" . $copied_id] = $fix;
1058 if ($copied_type ==
"pg" ||
1059 $copied_type ==
"st") {
1071 if ($original_lm != $copy_lm) {
1085 "_" . $original_id);
1088 foreach (
$mobs as $mob) {
1097 foreach ($usages as $usage) {
1098 if ($usage[
"type"] ==
"lm:pg" | $usage[
"type"] ==
"lm:st") {
1099 $sources[] = $usage;
1104 foreach ($sources as
$source) {
1105 $stype = explode(
":", $source[
"type"]);
1106 $source_type = $stype[1] ??
"";
1108 if ($source_type ==
"pg" || $source_type ==
"st") {
1112 if ($src_lm == $original_lm) {
1116 "il__" . $source_type .
"_" . $source[
"id"],
1120 foreach ($lm_data as $item) {
1122 $fix[$item[
"obj_id"]][$original_id] = $copied_id;
1130 if (count($fix) > 0) {
1131 foreach ($fix as $page_id => $fix_array) {
1133 if (isset($all_fixes[$t .
":" . $page_id])) {
1134 $all_fixes[$t .
":" . $page_id] += $fix_array;
1136 $all_fixes[$t .
":" . $page_id] = $fix_array;
1144 foreach ($all_fixes as $pg => $fixes) {
1145 $pg = explode(
":", $pg);
1148 if ($page->moveIntLinks($fixes)) {
1149 $page->update(
true,
true);
1161 if (is_array($a_items)) {
1162 foreach ($a_items as $item) {
1168 if (count($types) > 1) {
1184 $ilDB = $DIC->database();
1189 $query =
"UPDATE lm_data SET " .
1190 " layout = " .
$ilDB->quote($a_layout,
"text") .
1191 " WHERE obj_id = " .
$ilDB->quote($a_obj_id,
"integer");
1193 } elseif ($t ==
"st" && is_object($a_lm)) {
1194 $node = $a_lm->getLMTree()->getNodeData($a_obj_id);
1195 $child_nodes = $a_lm->getLMTree()->getSubTree($node);
1196 if (is_array($child_nodes) && count($child_nodes) > 0) {
1197 foreach ($child_nodes as
$c) {
1198 if ($c[
"type"] ==
"pg") {
1199 $query =
"UPDATE lm_data SET " .
1200 " layout = " .
$ilDB->quote($a_layout,
"text") .
1201 " WHERE obj_id = " .
$ilDB->quote($c[
"child"],
"integer");
1216 $ilDB = $DIC->database();
1218 $query =
"SELECT layout FROM lm_data WHERE obj_id = " .
1219 $ilDB->quote($a_obj_id,
"integer");
1221 $obj_rec =
$ilDB->fetchAssoc($obj_set);
1223 return $obj_rec[
"layout"];
1234 $lm_tree =
new ilTree($a_lm_id);
1235 $lm_tree->setTableNames(
'lm_tree',
'lm_data');
1236 $lm_tree->setTreeTablePK(
"lm_id");
1237 $lm_tree->readRootId();
1239 $childs = $lm_tree->getChildsByType($a_chap_id,
"pg");
1253 $ilDB = $DIC->database();
1255 $and = ($a_type !=
"")
1256 ?
" AND type = " .
$ilDB->quote($a_type,
"text")
1259 $set =
$ilDB->query(
"SELECT obj_id FROM lm_data " .
1260 " WHERE lm_id = " .
$ilDB->quote($a_lm_id,
"integer") . $and);
1262 while ($rec =
$ilDB->fetchAssoc($set)) {
1263 $obj_ids[] = $rec[
"obj_id"];
1278 string $a_type =
"pg" 1285 if (trim($a_exp_id) ==
"") {
1288 foreach ($entries as $id =>
$e) {
1289 if (
$e[
"catalog"] ==
"ILIAS_NID") {
1291 $identifier->setMetaId($id);
1292 $identifier->delete();
1299 foreach ($entries as $id =>
$e) {
1300 if (
$e[
"catalog"] ==
"ILIAS_NID") {
1302 $identifier->setMetaId($id);
1303 $identifier->read();
1304 $identifier->setEntry($a_exp_id);
1305 $identifier->update();
1312 $md =
new ilMD($a_lm_id, $a_lmobj_id, $a_type);
1313 $md_gen = $md->getGeneral();
1314 $identifier = $md_gen->addIdentifier();
1315 $identifier->setEntry($a_exp_id);
1316 $identifier->setCatalog(
"ILIAS_NID");
1317 $identifier->save();
1325 string $a_type =
"pg" 1334 foreach ($entries as
$e) {
1335 if ($e[
"catalog"] ==
"ILIAS_NID") {
1348 string $a_type =
"pg" 1358 string $a_type =
"pg" 1362 foreach ($entries as
$e) {
1363 if ($e[
"catalog"] ==
"ILIAS_NID") {
1365 $res[trim($e[
"entry"])] = (
$res[trim($e[
"entry"])] ?? 0) + 1;
1375 string $a_type =
"pg" 1384 string $a_mode = self::PAGE_TITLE,
1385 bool $a_include_numbers =
false,
1386 bool $a_time_scheduled_activation =
false,
1387 bool $a_force_content =
false,
1389 string $a_lang =
"-" 1391 if ($a_lang ==
"") {
1395 if ($a_node[
"type"] ==
"st") {
1398 self::CHAPTER_TITLE,
1400 $a_time_scheduled_activation,
1410 $a_time_scheduled_activation,
1420 string $a_lang =
"-" 1424 $db = $DIC->database();
1426 $title_data = array();
1427 if ($a_lang ==
"-") {
1428 $set = $db->
query(
"SELECT t.child, d.obj_id, d.title, d.short_title FROM lm_data d LEFT JOIN lm_tree t ON (d.obj_id = t.child) WHERE d.lm_id = " .
1429 $db->
quote($a_lm_id,
"integer") .
" ORDER BY t.lft, d.title");
1431 $set = $db->
query(
"SELECT t.child, d.obj_id, tr.title, tr.short_title, d.title default_title, d.short_title default_short_title FROM lm_data d " .
1432 " LEFT JOIN lm_tree t ON (d.obj_id = t.child) " .
1433 " LEFT JOIN lm_data_transl tr ON (tr.id = d.obj_id AND tr.lang=" . $db->
quote($a_lang,
"text") .
") WHERE d.lm_id = " .
1434 $db->
quote($a_lm_id,
"integer") .
" ORDER BY t.lft, d.title");
1437 $title_data[] = $rec;
1444 string $a_short_title,
1445 string $a_lang =
"-" 1449 $db = $DIC->database();
1451 if ($a_lang !=
"-" && $a_lang !=
"") {
1453 $trans->setShortTitle($a_short_title);
1457 "UPDATE lm_data SET " .
1458 " short_title = " . $db->
quote($a_short_title,
"text") .
1459 " WHERE obj_id = " . $db->
quote($a_id,
"integer")
static updateInternalLinks(array $a_copied_nodes, string $a_parent_type="lm")
Update internal links, after multiple pages have been copied.
static _getPresentationTitle(int $a_st_id, string $a_mode=self::CHAPTER_TITLE, bool $a_include_numbers=false, bool $a_time_scheduled_activation=false, bool $a_force_content=false, int $a_lm_id=0, string $a_lang="-", bool $a_include_short=false)
static _isPagePublic(int $a_node_id, bool $a_check_public_mode=false)
static _getMobsForTarget(string $a_type, string $a_target)
Get areas for a certain target.
setDescription(string $a_description)
getExportIDInfo(int $a_lm_id, int $a_exp_id, string $a_type="pg")
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
static _lookupNID(int $a_lm_id, int $a_lm_obj_id, string $a_type)
lookup named identifier (ILIAS_NID)
static readIdData(int $a_rbac_id, string $a_obj_type, string $a_catalog, string $a_entry)
static _writePublicAccessStatus(array $a_pages, int $a_cont_obj_id)
update public access flags in lm_data for all pages of a content object
static _getSourcesOfTarget(string $a_target_type, int $a_target_id, int $a_target_inst)
get all sources of a link target
static getExportId(int $a_lm_id, int $a_lmobj_id, string $a_type="pg")
static _extractObjIdOfTarget(string $a_target)
Extract object id out of target.
static _createEntry(int $a_obj_id, string $a_action, array $a_info_params=[], string $a_obj_type="", string $a_user_comment="", bool $a_update_last=false)
Creates a new history entry for an object.
static _getAllObjectsForImportId(string $a_import_id, int $a_in_lm=0)
Get all items for an import ID.
static saveTitles(ilObjLearningModule $a_lm, array $a_titles, string $a_lang="-")
Save titles for lm objects.
fetchAssoc(ilDBStatement $statement)
static _getAllReferences(int $id)
get all reference ids for object ID
static _deleteAllObjectData(ilObjLearningModule $a_cobj)
delete all objects of content object (digi book / learning module)
static uniqueTypesCheck(array $a_items)
Check for unique types (all pages or all chapters)
static getInstance(ilObjLearningModule $a_content_obj, int $a_id=0, bool $a_halt=true)
MDUpdateListener(string $a_element)
Meta data update listener Important note: Do never call create() or update() method of ilObject here...
create(bool $a_upload=false)
static _hasUntrashedReference(int $obj_id)
checks whether an object has at least one reference that is not in trash
static _lookupShortTitle(int $a_obj_id)
static getObjectList(int $lm_id, string $type="")
const LP_MODE_COLLECTION_TLT
quote($value, string $type)
static preloadDataByLM(int $a_lm_id)
Preload data records by lm.
static clipboardCut(int $a_cont_obj_id, array $a_ids)
Copy a set of chapters/pages into the clipboard.
static subStr(string $a_str, int $a_start, ?int $a_length=null)
static existsIdInRbacObject(int $a_rbac_id, string $a_obj_type, string $a_catalog, string $a_entry)
static getTree(int $a_cont_obj_id)
Get learning module tree.
static lookupTranslations(string $a_parent_type, int $a_id)
Lookup translations.
static putInTree(ilLMObject $a_obj, int $a_parent_id=0, int $a_target_node_id=0)
put this object into content object tree
static _extractInstOfTarget(string $a_target)
Extract installation id out of target.
static writeShortTitle(int $a_id, string $a_short_title, string $a_lang="-")
static _lookupTitle(int $a_obj_id)
__construct(ilObjLearningModule $a_content_obj, int $a_id=0)
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
static writeLayout(int $a_obj_id, string $a_layout, ?ilObjLearningModule $a_lm=null)
Write layout setting.
static _getEntriesForObj(int $a_rbac_id, int $a_obj_id, string $a_obj_type)
static _getIdForImportId(string $a_import_id)
get current object id for import id (static)
static getPagesOfChapter(int $a_lm_id, int $a_chap_id)
Get pages of chapter.
static _refreshStatus(int $a_obj_id, ?array $a_users=null)
query(string $query)
Run a (read-only) Query on the database.
setTitle(string $a_title)
static isHelpLM(int $a_lm_id)
Check if LM is a help LM.
updateMetaData()
update meta data entry
setImportId(string $a_id)
static _getAllLMObjectsOfLM(int $a_lm_id, string $a_type="")
Get all objects of learning module.
existsExportID(int $a_lm_id, int $a_exp_id, string $a_type="pg")
Does export ID exist in lm?
static _writeImportId(int $a_id, string $a_import_id)
static _writeTitle(int $a_obj_id, string $a_title)
setShortTitle(string $a_title)
static getInstanceByObjId(?int $obj_id, bool $stop_on_error=true)
get an instance of an Ilias object by object id
static _exists(int $a_id)
checks wether a lm content object with specified id exists or not
static saveExportId(int $a_lm_id, int $a_lmobj_id, string $a_exp_id, string $a_type="pg")
static getShortTitles(int $a_lm_id, string $a_lang="-")
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
createMetaData()
create meta data entry
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
static _getPresentationTitle(int $a_pg_id, string $a_mode=self::CHAPTER_TITLE, bool $a_include_numbers=false, bool $a_time_scheduled_activation=false, bool $a_force_content=false, int $a_lm_id=0, string $a_lang="-", bool $a_include_short=false)
presentation title doesn't have to be page title, it may be chapter title + page title or chapter tit...
static getDuplicateExportIDs(int $a_lm_id, string $a_type="pg")
Get duplicate export IDs (count export ID usages)
static _lookupType(int $a_obj_id, int $a_lm_id=0)
static _lookupContObjID(int $a_id)
get learning module id for lm object
deleteMetaData()
delete meta data entry
static yn2tf(string $a_yn)
ilObjLearningModule $content_object
static _getEntriesForRbacObj(int $a_rbac_id, string $a_obj_type="")
static lookupLayout(int $a_obj_id)
Lookup type.
manipulate(string $query)
Run a (write) Query on the database.
static _lookupType(int $id, bool $reference=false)
setContentObject(ilObjLearningModule $a_content_obj)
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 getInstance(int $obj_id)
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
static getInstance(string $a_parent_type, int $a_id=0, int $a_old_nr=0, string $a_lang="-")
Get page object instance.
cloneMD(int $a_rbac_id, int $a_obj_id, string $a_obj_type)
static _extractTypeOfTarget(string $a_target)
Extract type out of target.
static _lookup(int $a_obj_id, string $a_field)
static clipboardCopy(int $a_cont_obj_id, array $a_ids)
Copy a set of chapters/pages into the clipboard.
setDataRecord(array $a_record)
this method should only be called by class ilLMObjectFactory
static _getNodePresentationTitle(array $a_node, string $a_mode=self::PAGE_TITLE, bool $a_include_numbers=false, bool $a_time_scheduled_activation=false, bool $a_force_content=false, int $a_lm_id=0, string $a_lang="-")