ILIAS  trunk Revision v11.0_alpha-1702-gfd3ecb7f852
All Data Structures Namespaces Files Functions Variables Enumerations Enumerator Modules Pages
ilLPCollectionOfRepositoryObjects Class Reference

LP collection of repository objects. More...

+ Inheritance diagram for ilLPCollectionOfRepositoryObjects:
+ Collaboration diagram for ilLPCollectionOfRepositoryObjects:

Public Member Functions

 __construct (int $a_obj_id, int $a_mode)
 
 getPossibleItems (int $a_ref_id, bool $a_full_data=false)
 
 cloneCollection (int $a_target_id, int $a_copy_id)
 
 deactivateEntries (array $a_item_ids)
 
 activateEntries (array $a_item_ids)
 
 createNewGrouping (array $a_item_ids, int $a_num_obligatory=1)
 
 releaseGrouping (array $a_item_ids)
 
 saveObligatoryMaterials (array $a_obl)
 
 getTableGUIData (int $a_parent_ref_id)
 
 getGroupedItemsForLPStatus ()
 
- Public Member Functions inherited from ilLPCollection
 __construct (int $a_obj_id, int $a_mode)
 
 hasSelectableItems ()
 
 cloneCollection (int $a_target_id, int $a_copy_id)
 
 getItems ()
 
 delete ()
 
 isAssignedEntry (int $a_item_id)
 
 deactivateEntries (array $a_item_ids)
 
 activateEntries (array $a_item_ids)
 

Static Public Member Functions

static hasGroupedItems (int $a_obj_id)
 
- Static Public Member Functions inherited from ilLPCollection
static getInstanceByMode (int $a_obj_id, int $a_mode)
 
static getCollectionModes ()
 

Protected Member Functions

 validateEntry (int $a_item_id)
 
 read (int $a_obj_id)
 
 addEntry (int $a_item_id)
 
 deleteEntry (int $a_item_id)
 
 getNonGroupedItems (array $a_item_ids)
 
 getGroupingIds (array $a_item_ids)
 
 parseTableGUIItem (int $a_id, array $a_item)
 
 getTableGUItemGroup (int $item_id)
 
- Protected Member Functions inherited from ilLPCollection
 read (int $a_obj_id)
 
 validateEntry (int $a_item_id)
 
 addEntry (int $a_item_id)
 
 deleteEntry (int $a_item_id)
 

Protected Attributes

ilTree $tree
 
ilObjectDefinition $objDefinition
 
- Protected Attributes inherited from ilLPCollection
int $obj_id
 
int $mode
 
array $items = []
 
ilDBInterface $db
 
ilLogger $logger
 

Static Protected Attributes

static array $possible_items = array()
 

Detailed Description

LP collection of repository objects.

Author
Jörg Lützenkirchen luetz.nosp@m.enki.nosp@m.rchen.nosp@m.@lei.nosp@m.fos.c.nosp@m.om

Definition at line 26 of file class.ilLPCollectionOfRepositoryObjects.php.

Constructor & Destructor Documentation

◆ __construct()

ilLPCollectionOfRepositoryObjects::__construct ( int  $a_obj_id,
int  $a_mode 
)

Definition at line 33 of file class.ilLPCollectionOfRepositoryObjects.php.

References $DIC, and ILIAS\GlobalScreen\Provider\__construct().

34  {
35  global $DIC;
36 
37  $this->tree = $DIC->repositoryTree();
38  $this->objDefinition = $DIC['objDefinition'];
39 
40  parent::__construct($a_obj_id, $a_mode);
41  }
global $DIC
Definition: shib_login.php:22
__construct(Container $dic, ilPlugin $plugin)
+ Here is the call graph for this function:

Member Function Documentation

◆ activateEntries()

ilLPCollectionOfRepositoryObjects::activateEntries ( array  $a_item_ids)

Definition at line 324 of file class.ilLPCollectionOfRepositoryObjects.php.

References getGroupingIds(), and getNonGroupedItems().

Referenced by createNewGrouping().

324  : void
325  {
326  // 44683: only activate non-grouped items via parent
327  $non_grouped_ids = $this->getNonGroupedItems($a_item_ids);
328  parent::activateEntries($non_grouped_ids);
329 
330  $grouping_ids = $this->getGroupingIds($a_item_ids);
331  if ($grouping_ids) {
332  $query = "UPDATE ut_lp_collections" .
333  " SET active = " . $this->db->quote(1, "integer") .
334  " WHERE " . $this->db->in(
335  "grouping_id",
336  $grouping_ids,
337  false,
338  "integer"
339  ) .
340  " AND obj_id = " . $this->db->quote($this->obj_id, "integer");
341  $this->db->manipulate($query);
342  }
343  }
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ addEntry()

ilLPCollectionOfRepositoryObjects::addEntry ( int  $a_item_id)
protected

Definition at line 229 of file class.ilLPCollectionOfRepositoryObjects.php.

References deleteEntry(), and ilLPCollection\isAssignedEntry().

Referenced by cloneCollection().

229  : bool
230  {
231  // only active entries are assigned!
232  if (!$this->isAssignedEntry($a_item_id)) {
233  // #13278 - because of grouping inactive items may exist
234  $this->deleteEntry($a_item_id);
235 
236  $query = "INSERT INTO ut_lp_collections" .
237  " (obj_id, lpmode, item_id, grouping_id, num_obligatory, active)" .
238  " VALUES (" . $this->db->quote($this->obj_id, "integer") .
239  ", " . $this->db->quote($this->mode, "integer") .
240  ", " . $this->db->quote($a_item_id, "integer") .
241  ", " . $this->db->quote(0, "integer") .
242  ", " . $this->db->quote(0, "integer") .
243  ", " . $this->db->quote(1, "integer") .
244  ")";
245  $this->db->manipulate($query);
246  $this->items[] = $a_item_id;
247  }
248  return true;
249  }
isAssignedEntry(int $a_item_id)
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ cloneCollection()

ilLPCollectionOfRepositoryObjects::cloneCollection ( int  $a_target_id,
int  $a_copy_id 
)

Definition at line 157 of file class.ilLPCollectionOfRepositoryObjects.php.

References ilLPCollection\$mode, ilCopyWizardOptions\_getInstance(), ilObject\_lookupObjId(), addEntry(), and getGroupedItemsForLPStatus().

157  : void
158  {
159  parent::cloneCollection($a_target_id, $a_copy_id);
160 
161  $cwo = ilCopyWizardOptions::_getInstance($a_copy_id);
162  $mappings = $cwo->getMappings();
163 
164  $target_obj_id = ilObject::_lookupObjId($a_target_id);
165  $target_collection = new static($target_obj_id, $this->mode);
166 
167  // clone (active) groupings
168  foreach ($this->getGroupedItemsForLPStatus(
169  ) as $grouping_id => $group) {
170  $target_item_ids = array();
171  foreach ($group["items"] as $item) {
172  if (!isset($mappings[$item]) or !$mappings[$item]) {
173  continue;
174  }
175 
176  $target_item_ids[] = $mappings[$item];
177  }
178 
179  // grouping - if not only single item left after copy?
180  if ($grouping_id && sizeof($target_item_ids) > 1) {
181  // should not be larger than group
182  $num_obligatory = min(
183  sizeof($target_item_ids),
184  $group["num_obligatory"]
185  );
186 
187  $target_collection->createNewGrouping(
188  $target_item_ids,
189  $num_obligatory
190  );
191  } else {
192  // #15487 - single items
193  foreach ($target_item_ids as $item_id) {
194  $this->addEntry($item_id);
195  }
196  }
197  }
198  }
static _lookupObjId(int $ref_id)
static _getInstance(int $a_copy_id)
+ Here is the call graph for this function:

◆ createNewGrouping()

ilLPCollectionOfRepositoryObjects::createNewGrouping ( array  $a_item_ids,
int  $a_num_obligatory = 1 
)

Definition at line 345 of file class.ilLPCollectionOfRepositoryObjects.php.

References $res, activateEntries(), ilDBConstants\FETCHMODE_OBJECT, getGroupingIds(), and releaseGrouping().

348  : void {
349  $this->activateEntries($a_item_ids);
350 
351  $all_item_ids = array();
352  $grouping_ids = $this->getGroupingIds($a_item_ids);
353  $query = "SELECT item_id FROM ut_lp_collections" .
354  " WHERE obj_id = " . $this->db->quote($this->obj_id, "integer") .
355  " AND " . $this->db->in(
356  "grouping_id",
357  $grouping_ids,
358  false,
359  "integer"
360  );
361  $res = $this->db->query($query);
362  while ($row = $res->fetchRow(ilDBConstants::FETCHMODE_OBJECT)) {
363  $all_item_ids[] = $row->item_id;
364  }
365 
366  $all_item_ids = array_unique(array_merge($all_item_ids, $a_item_ids));
367 
368  $this->releaseGrouping($a_item_ids);
369 
370  // Create new grouping
371  $query = "SELECT MAX(grouping_id) grp FROM ut_lp_collections" .
372  " WHERE obj_id = " . $this->db->quote($this->obj_id, "integer") .
373  " GROUP BY obj_id";
374  $res = $this->db->query($query);
375  $row = $res->fetchRow(ilDBConstants::FETCHMODE_OBJECT);
376  $grp_id = $row->grp;
377  ++$grp_id;
378 
379  $query = "UPDATE ut_lp_collections SET" .
380  " grouping_id = " . $this->db->quote($grp_id, "integer") .
381  ", num_obligatory = " . $this->db->quote(
382  $a_num_obligatory,
383  "integer"
384  ) .
385  ", active = " . $this->db->quote(1, "integer") .
386  " WHERE obj_id = " . $this->db->quote($this->obj_id, "integer") .
387  " AND " . $this->db->in("item_id", $all_item_ids, false, "integer");
388  $this->db->manipulate($query);
389  }
$res
Definition: ltiservices.php:66
+ Here is the call graph for this function:

◆ deactivateEntries()

ilLPCollectionOfRepositoryObjects::deactivateEntries ( array  $a_item_ids)

Definition at line 305 of file class.ilLPCollectionOfRepositoryObjects.php.

References getGroupingIds().

305  : void
306  {
307  parent::deactivateEntries($a_item_ids);
308 
309  $grouping_ids = $this->getGroupingIds($a_item_ids);
310  if ($grouping_ids) {
311  $query = "UPDATE ut_lp_collections" .
312  " SET active = " . $this->db->quote(0, "integer") .
313  " WHERE " . $this->db->in(
314  "grouping_id",
315  $grouping_ids,
316  false,
317  "integer"
318  ) .
319  " AND obj_id = " . $this->db->quote($this->obj_id, "integer");
320  $this->db->manipulate($query);
321  }
322  }
+ Here is the call graph for this function:

◆ deleteEntry()

ilLPCollectionOfRepositoryObjects::deleteEntry ( int  $a_item_id)
protected

Definition at line 251 of file class.ilLPCollectionOfRepositoryObjects.php.

Referenced by addEntry(), and read().

251  : bool
252  {
253  $query = "DELETE FROM ut_lp_collections " .
254  " WHERE obj_id = " . $this->db->quote($this->obj_id, "integer") .
255  " AND item_id = " . $this->db->quote($a_item_id, "integer") .
256  " AND grouping_id = " . $this->db->quote(0, "integer");
257  $this->db->manipulate($query);
258  return true;
259  }
+ Here is the caller graph for this function:

◆ getGroupedItemsForLPStatus()

ilLPCollectionOfRepositoryObjects::getGroupedItemsForLPStatus ( )

Definition at line 526 of file class.ilLPCollectionOfRepositoryObjects.php.

References ilLPCollection\$items, $res, ilDBConstants\FETCHMODE_OBJECT, ilLPCollection\getItems(), and ILIAS\Repository\int().

Referenced by cloneCollection().

526  : array
527  {
528  $items = $this->getItems();
529  $query = " SELECT * FROM ut_lp_collections" .
530  " WHERE obj_id = " . $this->db->quote($this->obj_id, "integer") .
531  " AND active = " . $this->db->quote(1, "integer");
532  $res = $this->db->query($query);
533 
534  $grouped = array();
535  while ($row = $res->fetchRow(ilDBConstants::FETCHMODE_OBJECT)) {
536  if (in_array($row->item_id, $items)) {
537  $grouped[$row->grouping_id]['items'][] = (int) $row->item_id;
538  $grouped[$row->grouping_id]['num_obligatory'] = (int) $row->num_obligatory;
539  }
540  }
541  return $grouped;
542  }
$res
Definition: ltiservices.php:66
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ getGroupingIds()

ilLPCollectionOfRepositoryObjects::getGroupingIds ( array  $a_item_ids)
protected

Definition at line 289 of file class.ilLPCollectionOfRepositoryObjects.php.

References $res, and ilDBConstants\T_INTEGER.

Referenced by activateEntries(), createNewGrouping(), deactivateEntries(), and releaseGrouping().

289  : array
290  {
291  $grouping_ids = [];
292 
293  $query = "SELECT grouping_id FROM ut_lp_collections" .
294  " WHERE obj_id = " . $this->db->quote($this->obj_id, ilDBConstants::T_INTEGER) .
295  " AND " . $this->db->in("item_id", $a_item_ids, false, ilDBConstants::T_INTEGER) .
296  " AND grouping_id > " . $this->db->quote(0, ilDBConstants::T_INTEGER);
297  $res = $this->db->query($query);
298  while ($row = $res->fetchObject()) {
299  $grouping_ids[] = $row->grouping_id;
300  }
301 
302  return $grouping_ids;
303  }
$res
Definition: ltiservices.php:66
+ Here is the caller graph for this function:

◆ getNonGroupedItems()

ilLPCollectionOfRepositoryObjects::getNonGroupedItems ( array  $a_item_ids)
protected

Definition at line 273 of file class.ilLPCollectionOfRepositoryObjects.php.

References $res, and ilDBConstants\T_INTEGER.

Referenced by activateEntries().

273  : array
274  {
275  $grouped_item_ids = [];
276 
277  $query = "SELECT item_id FROM ut_lp_collections" .
278  " WHERE obj_id = " . $this->db->quote($this->obj_id, ilDBConstants::T_INTEGER) .
279  " AND " . $this->db->in("item_id", $a_item_ids, false, ilDBConstants::T_INTEGER) .
280  " AND grouping_id > " . $this->db->quote(0, ilDBConstants::T_INTEGER);
281  $res = $this->db->query($query);
282  while ($row = $res->fetchObject()) {
283  $grouped_item_ids[] = $row->item_id;
284  }
285 
286  return array_diff($a_item_ids, $grouped_item_ids);
287  }
$res
Definition: ltiservices.php:66
+ Here is the caller graph for this function:

◆ getPossibleItems()

ilLPCollectionOfRepositoryObjects::getPossibleItems ( int  $a_ref_id,
bool  $a_full_data = false 
)

Definition at line 43 of file class.ilLPCollectionOfRepositoryObjects.php.

References $data, $DIC, ILIAS\Repository\int(), ilLPCollection\isAssignedEntry(), ilRepositoryObjectPluginSlot\isTypePluginWithLP(), and validateEntry().

Referenced by getTableGUIData(), and read().

46  : array {
47  global $DIC;
48 
49  $cache_idx = $a_ref_id . "__" . $a_full_data;
50  if (!isset(self::$possible_items[$cache_idx])) {
51  $all_possible = array();
52 
53  if (!$this->tree->isDeleted($a_ref_id)) {
54  if (!$a_full_data) {
55  $data = $this->tree->getRbacSubtreeInfo($a_ref_id);
56  } else {
57  $node = $this->tree->getNodeData($a_ref_id);
58  $data = $this->tree->getSubTree($node);
59  }
60  foreach ($data as $node) {
61  if (!$a_full_data) {
62  $item_ref_id = (int) $node['child'];
63  } else {
64  $item_ref_id = (int) $node['ref_id'];
65  }
66 
67  // avoid recursion
68  if ($item_ref_id == $a_ref_id || !$this->validateEntry(
69  $item_ref_id
70  )) {
71  continue;
72  }
73 
74  switch ($node['type']) {
75  case 'sess':
76  case 'exc':
77  case 'fold':
78  case 'grp':
79  case 'sahs':
80  case 'lm':
81  case 'tst':
82  case 'file':
83  case 'mcst':
84  case 'htlm':
85  case 'svy':
86  case "prg":
87  case 'iass':
88  case 'copa':
89  case 'frm':
90  case 'cmix':
91  case 'lti':
92  case 'lso':
93  case 'crsr':
94  if (!$a_full_data) {
95  $all_possible[] = $item_ref_id;
96  } else {
97  $all_possible[$item_ref_id] = array(
98  'ref_id' => (int) $item_ref_id,
99  'obj_id' => (int) $node['obj_id'],
100  'title' => (string) $node['title'],
101  'description' => (string) $node['description'],
102  'type' => (string) $node['type']
103  );
104  }
105  break;
106 
107  // repository plugin object?
108  case $this->objDefinition->isPluginTypeName(
109  $node['type']
110  ):
111  $only_active = false;
112  if (!$this->isAssignedEntry($item_ref_id)) {
113  $only_active = true;
114  }
116  $node['type'],
117  $only_active
118  )) {
119  if (!$a_full_data) {
120  $all_possible[] = $item_ref_id;
121  } else {
122  $all_possible[$item_ref_id] = array(
123  'ref_id' => (int) $item_ref_id,
124  'obj_id' => (int) $node['obj_id'],
125  'title' => (string) $node['title'],
126  'description' => (string) $node['description'],
127  'type' => (string) $node['type']
128  );
129  }
130  }
131  break;
132  }
133  }
134  }
135 
136  self::$possible_items[$cache_idx] = $all_possible;
137  }
138 
139  return self::$possible_items[$cache_idx];
140  }
isAssignedEntry(int $a_item_id)
global $DIC
Definition: shib_login.php:22
static isTypePluginWithLP(string $a_type, bool $a_active_status=true)
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ getTableGUIData()

ilLPCollectionOfRepositoryObjects::getTableGUIData ( int  $a_parent_ref_id)

Definition at line 443 of file class.ilLPCollectionOfRepositoryObjects.php.

References $data, ilLPCollection\$items, getPossibleItems(), getTableGUItemGroup(), and parseTableGUIItem().

443  : array
444  {
445  $items = $this->getPossibleItems($a_parent_ref_id, true);
446 
447  $data = array();
448  $done = array();
449  foreach ($items as $item_id => $item) {
450  if (in_array($item_id, $done)) {
451  continue;
452  }
453 
454  $table_item = $this->parseTableGUIItem($item_id, $item);
455 
456  // grouping
457  $table_item['grouped'] = array();
458  $grouped_items = $this->getTableGUItemGroup($item_id);
459  if (count((array) ($grouped_items['items'] ?? [])) > 1) {
460  foreach ($grouped_items['items'] as $grouped_item_id) {
461  if ($grouped_item_id == $item_id ||
462  !is_array($items[$grouped_item_id] ?? false)) { // #15498
463  continue;
464  }
465 
466  $table_item['grouped'][] = $this->parseTableGUIItem(
467  $grouped_item_id,
468  $items[$grouped_item_id]
469  );
470  $table_item['num_obligatory'] = $grouped_items['num_obligatory'];
471  $table_item['grouping_id'] = $grouped_items['grouping_id'];
472 
473  $done[] = $grouped_item_id;
474  }
475  }
476  $data[] = $table_item;
477  }
478  return $data;
479  }
getPossibleItems(int $a_ref_id, bool $a_full_data=false)
+ Here is the call graph for this function:

◆ getTableGUItemGroup()

ilLPCollectionOfRepositoryObjects::getTableGUItemGroup ( int  $item_id)
protected

Definition at line 495 of file class.ilLPCollectionOfRepositoryObjects.php.

References ilLPCollection\$items, $res, ilDBConstants\FETCHMODE_OBJECT, and ILIAS\Repository\int().

Referenced by getTableGUIData().

495  : array
496  {
497  $items = array();
498  $query = "SELECT grouping_id FROM ut_lp_collections" .
499  " WHERE obj_id = " . $this->db->quote($this->obj_id, "integer") .
500  " AND item_id = " . $this->db->quote($item_id, "integer");
501  $res = $this->db->query($query);
502  $grouping_id = 0;
503  while ($row = $res->fetchRow(ilDBConstants::FETCHMODE_OBJECT)) {
504  $grouping_id = (int) $row->grouping_id;
505  }
506  if ($grouping_id > 0) {
507  $query = "SELECT item_id, num_obligatory FROM ut_lp_collections" .
508  " WHERE obj_id = " . $this->db->quote(
509  $this->obj_id,
510  "integer"
511  ) .
512  " AND grouping_id = " . $this->db->quote(
513  $grouping_id,
514  "integer"
515  );
516  $res = $this->db->query($query);
517  while ($row = $res->fetchRow(ilDBConstants::FETCHMODE_OBJECT)) {
518  $items['items'][] = (int) $row->item_id;
519  $items['num_obligatory'] = (int) $row->num_obligatory;
520  $items['grouping_id'] = (int) $grouping_id;
521  }
522  }
523  return $items;
524  }
$res
Definition: ltiservices.php:66
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ hasGroupedItems()

static ilLPCollectionOfRepositoryObjects::hasGroupedItems ( int  $a_obj_id)
static

Definition at line 261 of file class.ilLPCollectionOfRepositoryObjects.php.

References $DIC, $ilDB, and $res.

Referenced by ilLPCollectionSettingsTableGUI\parse().

261  : bool
262  {
263  global $DIC;
264 
265  $ilDB = $DIC['ilDB'];
266  $query = "SELECT item_id FROM ut_lp_collections" .
267  " WHERE obj_id = " . $ilDB->quote($a_obj_id, "integer") .
268  " AND grouping_id > " . $ilDB->quote(0, "integer");
269  $res = $ilDB->query($query);
270  return $res->numRows() ? true : false;
271  }
$res
Definition: ltiservices.php:66
global $DIC
Definition: shib_login.php:22
+ Here is the caller graph for this function:

◆ parseTableGUIItem()

ilLPCollectionOfRepositoryObjects::parseTableGUIItem ( int  $a_id,
array  $a_item 
)
protected

Definition at line 481 of file class.ilLPCollectionOfRepositoryObjects.php.

References ilObjectLP\getInstance(), and ilLPCollection\isAssignedEntry().

Referenced by getTableGUIData().

481  : array
482  {
483  $table_item = $a_item;
484  $table_item['id'] = $a_id;
485  $table_item['status'] = $this->isAssignedEntry($a_id);
486 
487  $olp = ilObjectLP::getInstance($a_item['obj_id']);
488  $table_item['mode_id'] = $olp->getCurrentMode();
489  $table_item['mode'] = $olp->getModeText($table_item['mode_id']);
490  $table_item['anonymized'] = $olp->isAnonymized();
491 
492  return $table_item;
493  }
isAssignedEntry(int $a_item_id)
static getInstance(int $obj_id)
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ read()

ilLPCollectionOfRepositoryObjects::read ( int  $a_obj_id)
protected

Definition at line 200 of file class.ilLPCollectionOfRepositoryObjects.php.

References ilLPCollection\$items, $ref_id, $res, ilObject\_getAllReferences(), deleteEntry(), ilDBConstants\FETCHMODE_OBJECT, getPossibleItems(), and validateEntry().

200  : void
201  {
202  $items = array();
203 
204  $ref_ids = ilObject::_getAllReferences($a_obj_id);
205  $ref_id = end($ref_ids);
206  $possible = $this->getPossibleItems($ref_id);
207 
208  $res = $this->db->query(
209  "SELECT utc.item_id, obd.type" .
210  " FROM ut_lp_collections utc" .
211  " JOIN object_reference obr ON item_id = ref_id" .
212  " JOIN object_data obd ON obr.obj_id = obd.obj_id" .
213  " WHERE utc.obj_id = " . $this->db->quote($a_obj_id, "integer") .
214  " AND active = " . $this->db->quote(1, "integer") .
215  " ORDER BY title"
216  );
217  while ($row = $res->fetchRow(ilDBConstants::FETCHMODE_OBJECT)) {
218  if (in_array($row->item_id, $possible) &&
219  $this->validateEntry((int) $row->item_id)) {
220  $items[] = $row->item_id;
221  } else {
222  $this->deleteEntry((int) $row->item_id);
223  }
224  }
225 
226  $this->items = $items;
227  }
$res
Definition: ltiservices.php:66
static _getAllReferences(int $id)
get all reference ids for object ID
$ref_id
Definition: ltiauth.php:65
getPossibleItems(int $a_ref_id, bool $a_full_data=false)
+ Here is the call graph for this function:

◆ releaseGrouping()

ilLPCollectionOfRepositoryObjects::releaseGrouping ( array  $a_item_ids)

Definition at line 391 of file class.ilLPCollectionOfRepositoryObjects.php.

References getGroupingIds().

Referenced by createNewGrouping().

391  : void
392  {
393  $grouping_ids = $this->getGroupingIds($a_item_ids);
394 
395  $query = "UPDATE ut_lp_collections" .
396  " SET grouping_id = " . $this->db->quote(0, "integer") .
397  ", num_obligatory = " . $this->db->quote(0, "integer") .
398  " WHERE obj_id = " . $this->db->quote($this->obj_id, "integer") .
399  " AND " . $this->db->in(
400  "grouping_id",
401  $grouping_ids,
402  false,
403  "integer"
404  );
405  $this->db->manipulate($query);
406  }
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ saveObligatoryMaterials()

ilLPCollectionOfRepositoryObjects::saveObligatoryMaterials ( array  $a_obl)

Definition at line 408 of file class.ilLPCollectionOfRepositoryObjects.php.

References $res, and ilDBConstants\FETCHMODE_OBJECT.

408  : void
409  {
410  foreach ($a_obl as $grouping_id => $num) {
411  $query = "SELECT count(obj_id) num FROM ut_lp_collections" .
412  " WHERE obj_id = " . $this->db->quote(
413  $this->obj_id,
414  "integer"
415  ) .
416  " AND grouping_id = " . $this->db->quote(
417  $grouping_id,
418  'integer'
419  ) .
420  " GROUP BY obj_id";
421  $res = $this->db->query($query);
422  while ($row = $res->fetchRow(ilDBConstants::FETCHMODE_OBJECT)) {
423  if ($num <= 0 || $num >= $row->num) {
424  throw new UnexpectedValueException();
425  }
426  }
427  }
428  foreach ($a_obl as $grouping_id => $num) {
429  $query = "UPDATE ut_lp_collections" .
430  " SET num_obligatory = " . $this->db->quote($num, "integer") .
431  " WHERE obj_id = " . $this->db->quote(
432  $this->obj_id,
433  "integer"
434  ) .
435  " AND grouping_id = " . $this->db->quote(
436  $grouping_id,
437  "integer"
438  );
439  $this->db->manipulate($query);
440  }
441  }
$res
Definition: ltiservices.php:66

◆ validateEntry()

ilLPCollectionOfRepositoryObjects::validateEntry ( int  $a_item_id)
protected

Definition at line 142 of file class.ilLPCollectionOfRepositoryObjects.php.

References ilObject\_lookupObjId(), ilObject\_lookupType(), and ilObjectLP\getInstance().

Referenced by getPossibleItems(), and read().

142  : bool
143  {
144  $a_item_type = ilObject::_lookupType($a_item_id, true);
145  // this is hardcoded so we do not need to call all ObjectLP types
146  if ($a_item_type == 'tst') {
147  // Check anonymized
148  $item_obj_id = ilObject::_lookupObjId($a_item_id);
149  $olp = ilObjectLP::getInstance($item_obj_id);
150  if ($olp->isAnonymized()) {
151  return false;
152  }
153  }
154  return true;
155  }
static _lookupObjId(int $ref_id)
static _lookupType(int $id, bool $reference=false)
static getInstance(int $obj_id)
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

Field Documentation

◆ $objDefinition

ilObjectDefinition ilLPCollectionOfRepositoryObjects::$objDefinition
protected

Definition at line 31 of file class.ilLPCollectionOfRepositoryObjects.php.

◆ $possible_items

array ilLPCollectionOfRepositoryObjects::$possible_items = array()
staticprotected

Definition at line 28 of file class.ilLPCollectionOfRepositoryObjects.php.

◆ $tree

ilTree ilLPCollectionOfRepositoryObjects::$tree
protected

Definition at line 30 of file class.ilLPCollectionOfRepositoryObjects.php.


The documentation for this class was generated from the following file: