19 declare(strict_types=1);
40 public function setMode(
string $a_mode): void
42 $this->mode = $a_mode;
64 case 'typical_age_range':
70 case 'classification':
97 case 'title_description':
135 $where = $this->__createObjectPropertiesWhereCondition(...$fields);
138 $query =
"SELECT obj_id,type " .
140 "FROM object_data " .
141 $where .
" " . $and .
' ' .
142 "ORDER BY obj_id DESC";
144 $res = $this->db->query($query);
146 $this->search_result->addEntry(
149 $this->__prepareFound($row)
160 $ilDB = $DIC->database();
162 $coverage_query = $general_query =
'';
163 if ($this->options[
'lom_coverage'] ??
null) {
165 $and = $this->__createCoverageAndCondition();
167 $coverage_query =
"SELECT rbac_id,obj_type,obj_id " .
169 "FROM il_meta_coverage " .
173 if ($this->options[
'lom_structure'] ?? null) {
175 $general_query =
"SELECT rbac_id,obj_type,obj_id " .
176 "FROM il_meta_general " .
186 $res = $this->db->query($query);
188 if ($this->options[
'lom_coverage'] ?? null) {
190 if (!in_array(0, $found)) {
191 $this->search_result->addEntry(
193 (
string) $row->obj_type,
199 $this->search_result->addEntry(
201 (
string) $row->obj_type,
213 if (!($this->options[
'lom_language'] ??
null)) {
217 $query =
"SELECT rbac_id,obj_id,obj_type FROM il_meta_language " .
218 "WHERE language = " . $this->db->quote($this->options[
'lom_language'],
'text') .
" " .
220 "AND parent_type = 'meta_general'";
222 $res = $this->db->query($query);
223 #var_dump("<pre>",$query,"<pre>"); 225 $this->search_result->addEntry(
227 (
string) $row->obj_type,
237 if (!($this->options[
'lom_role'] ??
null)) {
241 $query =
"SELECT rbac_id,obj_id,obj_type FROM il_meta_contribute " .
242 "WHERE role = " . $this->db->quote($this->options[
'lom_role'],
'text') .
" " .
245 $res = $this->db->query($query);
246 #var_dump("<pre>",$query,"<pre>"); 248 $this->search_result->addEntry(
250 (
string) $row->obj_type,
263 $where = $this->__createEntityWhereCondition();
266 $query =
"SELECT rbac_id,obj_id,obj_type " .
268 "FROM il_meta_entity " .
269 $where .
" " . $and .
' ';
271 $res = $this->db->query($query);
274 if (!in_array(0, $found)) {
275 $this->search_result->addEntry(
277 (
string) $row->obj_type,
291 $query =
"SELECT rbac_id,obj_id,obj_type FROM il_meta_or_composite " .
294 $os_query = $browser_query =
'';
295 if ($this->options[
'lom_operating_system'] ??
null) {
296 $os_query = $query .
" AND type = 'operating system' AND " .
299 if ($this->options[
'lom_browser'] ?? null) {
300 $browser_query = $query .
" AND type = 'browser' AND " .
309 $res = $this->db->query($query);
310 #var_dump("<pre>",$query,"<pre>"); 312 $this->search_result->addEntry(
314 (
string) $row->obj_type,
324 $query_start =
"SELECT rbac_id,obj_id,obj_type ";
327 $ed_query = $lr_type_query = $end_user_query = $context_query =
'';
329 $ed_query = $query_start .
'FROM il_meta_educational ' . $where . $and;
331 if ($this->options[
'lom_resource'] ??
null) {
332 $where =
" WHERE learning_resource_type = " . $this->db->quote($this->options[
'lom_resource'],
'text');
333 $lr_type_query = $query_start .
'FROM il_meta_lr_type ' . $where . $and;
335 if ($this->options[
'lom_user_role'] ?? null) {
336 $where =
" WHERE intended_end_user_role = " . $this->db->quote($this->options[
'lom_user_role'],
'text');
337 $end_user_query = $query_start .
'FROM il_meta_end_usr_role ' . $where . $and;
339 if ($this->options[
'lom_context'] ?? null) {
340 $where =
" WHERE context = " . $this->db->quote($this->options[
'lom_context'],
'text');
341 $context_query = $query_start .
'FROM il_meta_context ' . $where . $and;
354 $res = $this->db->query($query);
356 $this->search_result->addEntry(
358 (
string) $row->obj_type,
369 !($this->options[
'typ_age_1'] ??
null) or
370 !($this->options[
'typ_age_2'] ?? null)
375 $query =
"SELECT rbac_id,obj_id,obj_type FROM il_meta_typical_age_range " .
376 "WHERE typical_age_range_min >= '" . (
int) $this->options[
'typ_age_1'] .
"' " .
377 "AND typical_age_range_max <= '" . (
int) $this->options[
'typ_age_2'] .
"'";
380 $res = $this->db->query($query);
381 #var_dump("<pre>",$query,"<pre>"); 383 $this->search_result->addEntry(
385 (
string) $row->obj_type,
395 $query =
"SELECT rbac_id,obj_id,obj_type FROM il_meta_rights ";
401 $query = $query . $where . $and;
402 $res = $this->db->query($query);
403 #var_dump("<pre>",$query,"<pre>"); 405 $this->search_result->addEntry(
407 (
string) $row->obj_type,
417 $query =
"SELECT rbac_id,obj_id,obj_type FROM il_meta_classification ";
423 $query = $query . $where . $and;
424 $res = $this->db->query($query);
425 #var_dump("<pre>",$query,"<pre>"); 427 $this->search_result->addEntry(
429 (
string) $row->obj_type,
442 $where = $this->__createTaxonWhereCondition();
445 $query =
"SELECT rbac_id,obj_id,obj_type " .
447 "FROM il_meta_taxon " .
448 $where .
" " . $and .
' ';
450 $res = $this->db->query($query);
453 if (!in_array(0, $found)) {
454 $this->search_result->addEntry(
456 (
string) $row->obj_type,
471 if ($a_in_classification) {
472 $and .=
" AND parent_type = 'meta_classification' ";
474 $where = $this->__createKeywordWhereCondition();
477 $query =
"SELECT rbac_id,obj_id,obj_type " .
479 "FROM il_meta_keyword " .
480 $where .
" " . $and .
' ';
482 $res = $this->db->query($query);
485 if (!in_array(0, $found) or !$a_in_classification) {
486 $this->search_result->addEntry(
488 (
string) $row->obj_type,
502 if ($this->options[
'lom_version'] ??
null) {
503 $where = $this->__createLifecycleWhereCondition();
506 $where =
"WHERE 1 = 1 ";
510 if ($this->options[
'lom_status'] ?? null) {
511 $and .= (
" AND lifecycle_status = " . $this->db->quote($this->options[
'lom_status'],
'text') .
"");
514 $query =
"SELECT rbac_id,obj_id,obj_type " .
516 "FROM il_meta_lifecycle " .
517 $where .
" " . $and .
' ';
519 $res = $this->db->query($query);
522 if (!in_array(0, $found)) {
523 $this->search_result->addEntry(
525 (
string) $row->obj_type,
537 if (!($this->options[
'lom_format'] ??
null)) {
541 $query =
"SELECT rbac_id,obj_id,obj_type FROM il_meta_format " .
542 "WHERE format LIKE(" . $this->db->quote($this->options[
'lom_format'],
ilDBConstants::T_TEXT) .
") " .
545 $res = $this->db->query($query);
546 #var_dump("<pre>",$query,"<pre>"); 548 $this->search_result->addEntry(
550 (
string) $row->obj_type,
565 if ($this->options[
'lom_costs'] ??
null) {
566 $and = $counter++ ?
'AND ' :
' ';
567 $where .= ($and .
"costs = " . $this->db->quote($this->options[
'lom_costs'],
'text') .
" ");
569 if ($this->options[
'lom_copyright'] ?? null) {
570 $and = $counter++ ?
'AND ' :
' ';
571 $where .= ($and .
"cpr_and_or = " . $this->db->quote($this->options[
'lom_copyright'],
'text') .
" ");
573 return $counter ? $where :
'';
581 if ($this->options[
'lom_purpose'] ??
null) {
582 $and = $counter++ ?
'AND ' :
' ';
583 $where .= ($and .
"purpose = " . $this->db->quote($this->options[
'lom_purpose'],
ilDBConstants::T_TEXT) .
" ");
585 return $counter ? $where :
'';
593 if ($this->options[
'lom_interactivity'] ??
null) {
594 $and = $counter++ ?
'AND ' :
' ';
595 $where .= ($and .
"interactivity_type = " . $this->db->quote($this->options[
'lom_interactivity'],
'text') .
" ");
598 ($this->options[
'lom_level_start'] ?? null) or
599 ($this->options[
'lom_level_end'] ?? null)) {
600 $and = $counter++ ?
'AND ' :
' ';
603 (
int) $this->options[
'lom_level_start'],
604 (
int) $this->options[
'lom_level_end'],
605 array(
'VeryLow',
'Low',
'Medium',
'High',
'VeryHigh')
611 ($this->options[
'lom_density_start'] ?? null) or
612 ($this->options[
'lom_density_end'] ?? null)
614 $and = $counter++ ?
'AND ' :
' ';
617 (
int) $this->options[
'lom_density_start'],
618 (
int) $this->options[
'lom_density_end'],
619 array(
'VeryLow',
'Low',
'Medium',
'High',
'VeryHigh')
625 ($this->options[
'lom_difficulty_start'] ?? null) or
626 ($this->options[
'lom_difficulty_end'] ?? null)
628 $and = $counter++ ?
'AND ' :
' ';
631 (
int) $this->options[
'lom_difficulty_start'],
632 (
int) $this->options[
'lom_difficulty_end'],
633 array(
'VeryEasy',
'Easy',
'Medium',
'Difficult',
'VeryDifficult')
639 return $counter ? $where :
'';
647 $a_val2 = $a_val2 ?: count($options);
649 if ($a_val1 > $a_val2) {
655 foreach ($options as $option) {
656 if ($a_val1 > ++$counter) {
659 if ($a_val2 < $counter) {
673 $in .= implode(
"','", $a_fields);
681 $non_empty_queries = [];
682 foreach ($individual_queries as $query) {
684 $non_empty_queries[] = $query;
688 if (count($non_empty_queries) < 2) {
689 return $non_empty_queries[0] ??
'';
693 foreach ($non_empty_queries as $query) {
694 if ($total_query ===
'') {
695 $total_query = $query;
698 $total_query =
"SELECT t1.rbac_id, t1.obj_type, t1.obj_id " .
699 "FROM (" . $total_query .
") AS t1 JOIN (" . $query .
700 ") AS t2 ON t1.rbac_id = t2.rbac_id AND t1.obj_type = t2.obj_type AND t1.obj_id = t2.obj_id";
__getInStatement(array $a_fields)
setOptions(array &$options)
__prepareFound(object $row)
joinOnRessourceIDs(string ... $individual_queries)
setFields(array $a_fields)
& __searchTitleDescription()
while($session_entry=$r->fetchRow(ilDBConstants::FETCHMODE_ASSOC)) return null
__getDifference(int $a_val1, int $a_val2, array $options)
__searchKeyword(bool $a_in_classification=false)
__createEducationalWhere()
searchObjectProperties(string ... $fields)
__createClassificationWhere()
ilSearchResult $search_result
__searchTypicalAgeRange()