ILIAS  release_8 Revision v8.19
All Data Structures Namespaces Files Functions Variables Modules Pages
ilLuceneSearchResultFilter Class Reference

Validate Lucene search results Do access checks, create ref_ids from obj_ids... More...

+ Collaboration diagram for ilLuceneSearchResultFilter:

Public Member Functions

 addFilter (ilLuceneResultFilter $filter)
 
 setCandidates (ilLuceneSearchResult $a_ids)
 Set result ids. More...
 
 getCandidates ()
 get result ids More...
 
 getUserId ()
 Get user id. More...
 
 getRequiredPermission ()
 Get required permission. More...
 
 isLimitReached ()
 Check if search max hits is reached. More...
 
 getResultIds ()
 get filtered ids More...
 
 getResultObjIds ()
 get filtered ids More...
 
 getResults ()
 get results More...
 
 getMaxHits ()
 get max hits More...
 
 loadFromDb ()
 Load results from db. More...
 
 filter ()
 Filter search results. More...
 

Static Public Member Functions

static getInstance (int $a_user_id)
 

Protected Member Functions

 __construct (int $a_user_id)
 Singleton constructor. More...
 
 checkFilter (int $a_ref_id)
 check appended filter More...
 
 append (int $a_ref_id, int $a_obj_id)
 Append to filtered results. More...
 
 isOffsetReached (int $a_current_nr)
 Check if offset is reached. More...
 

Protected Attributes

int $user_id
 
ilLuceneSearchResult $result = null
 
array $checked = []
 
ilSearchSettings $settings
 
ilUserSearchCache $cache
 
string $required_permission = 'visible'
 
bool $limit_reached = false
 
int $offset = 0
 
array $filters = array()
 
ilAccess $access
 

Static Protected Attributes

static ilLuceneSearchResultFilter $instance = null
 

Detailed Description

Validate Lucene search results Do access checks, create ref_ids from obj_ids...

Author
Stefan Meyer meyer.nosp@m.@lei.nosp@m.fos.c.nosp@m.om

Definition at line 35 of file class.ilLuceneSearchResultFilter.php.

Constructor & Destructor Documentation

◆ __construct()

ilLuceneSearchResultFilter::__construct ( int  $a_user_id)
protected

Singleton constructor.

Definition at line 56 of file class.ilLuceneSearchResultFilter.php.

References $DIC, ilUserSearchCache\_getInstance(), ILIAS\Repository\access(), ilSearchSettings\getInstance(), getUserId(), and ILIAS\Repository\settings().

57  {
58  global $DIC;
59 
60  $this->access = $DIC->access();
61  $this->user_id = $a_user_id;
63  $this->cache = ilUserSearchCache::_getInstance($this->getUserId());
64  $this->offset = $this->settings->getMaxHits() * ($this->cache->getResultPageNumber() - 1);
65  }
static _getInstance(int $a_usr_id)
global $DIC
Definition: feed.php:28
+ Here is the call graph for this function:

Member Function Documentation

◆ addFilter()

ilLuceneSearchResultFilter::addFilter ( ilLuceneResultFilter  $filter)

Definition at line 75 of file class.ilLuceneSearchResultFilter.php.

75  : void
76  {
77  $this->filters[] = $filter;
78  }

◆ append()

ilLuceneSearchResultFilter::append ( int  $a_ref_id,
int  $a_obj_id 
)
protected

Append to filtered results.

Definition at line 244 of file class.ilLuceneSearchResultFilter.php.

Referenced by filter().

244  : void
245  {
246  $this->checked[$a_ref_id] = $a_obj_id;
247  }
+ Here is the caller graph for this function:

◆ checkFilter()

ilLuceneSearchResultFilter::checkFilter ( int  $a_ref_id)
protected

check appended filter

Definition at line 231 of file class.ilLuceneSearchResultFilter.php.

Referenced by filter().

231  : bool
232  {
233  foreach ($this->filters as $filter) {
234  if (!$filter->filter($a_ref_id)) {
235  return false;
236  }
237  }
238  return true;
239  }
+ Here is the caller graph for this function:

◆ filter()

ilLuceneSearchResultFilter::filter ( )

Filter search results.

Do RBAC checks.

Definition at line 172 of file class.ilLuceneSearchResultFilter.php.

References $ref_id, ilObject\_getAllReferences(), ILIAS\Repository\access(), append(), checkFilter(), getCandidates(), ilLoggerFactory\getLogger(), getRequiredPermission(), getResultIds(), isOffsetReached(), and ILIAS\Repository\settings().

172  : bool
173  {
174  // get ref_ids and check access
175  $counter = 0;
176  $offset_counter = 0;
177 
178  foreach ($this->getCandidates() as $obj_id) {
179  // Check referenced objects
180  foreach (ilObject::_getAllReferences($obj_id) as $ref_id) {
181  // Check filter
182  if (!$this->checkFilter($ref_id)) {
183  $this->cache->appendToFailed($ref_id);
184  continue;
185  }
186 
187  // Access failed by prior check
188  if ($this->cache->isFailed($ref_id)) {
189  continue;
190  }
191  // Offset check
192  if ($this->cache->isChecked($ref_id) and !$this->isOffsetReached($offset_counter)) {
193  ilLoggerFactory::getLogger('src')->debug('Result was checked');
194  $offset_counter++;
195  break;
196  }
197 
198  // RBAC check
199  if ($this->access->checkAccessOfUser(
200  $this->getUserId(),
201  $this->getRequiredPermission(),
202  '',
203  $ref_id,
204  '',
205  $obj_id
206  )) {
207  ++$counter;
208  $offset_counter++;
209  $this->append($ref_id, $obj_id);
210  $this->cache->appendToChecked($ref_id, $obj_id);
211  break;
212  } else {
213  $this->cache->appendToFailed($ref_id);
214  }
215  }
216  if ($counter >= $this->settings->getMaxHits()) {
217  $this->limit_reached = true;
218  $this->cache->setResults($this->getResultIds());
219  $this->cache->save();
220  return false;
221  }
222  }
223  $this->cache->setResults($this->getResultIds());
224  $this->cache->save();
225  return true;
226  }
static getLogger(string $a_component_id)
Get component logger.
checkFilter(int $a_ref_id)
check appended filter
static _getAllReferences(int $id)
get all reference ids for object ID
append(int $a_ref_id, int $a_obj_id)
Append to filtered results.
$ref_id
Definition: ltiauth.php:67
getRequiredPermission()
Get required permission.
isOffsetReached(int $a_current_nr)
Check if offset is reached.
+ Here is the call graph for this function:

◆ getCandidates()

ilLuceneSearchResultFilter::getCandidates ( )

get result ids

Definition at line 91 of file class.ilLuceneSearchResultFilter.php.

References $result.

Referenced by filter().

92  {
93  return $this->result;
94  }
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
+ Here is the caller graph for this function:

◆ getInstance()

static ilLuceneSearchResultFilter::getInstance ( int  $a_user_id)
static

Definition at line 67 of file class.ilLuceneSearchResultFilter.php.

Referenced by ilLuceneAdvancedSearchGUI\performSearch(), ilLuceneSearchGUI\performSearch(), ilSoapObjectAdministration\searchObjects(), ilLuceneAdvancedSearchGUI\showSavedResults(), and ilLuceneSearchGUI\showSavedResults().

68  {
69  if (self::$instance == null) {
70  return self::$instance = new ilLuceneSearchResultFilter($a_user_id);
71  }
72  return self::$instance;
73  }
Validate Lucene search results Do access checks, create ref_ids from obj_ids...
+ Here is the caller graph for this function:

◆ getMaxHits()

ilLuceneSearchResultFilter::getMaxHits ( )

get max hits

Definition at line 155 of file class.ilLuceneSearchResultFilter.php.

References ILIAS\Repository\settings().

155  : int
156  {
157  return $this->settings->getMaxHits();
158  }
+ Here is the call graph for this function:

◆ getRequiredPermission()

ilLuceneSearchResultFilter::getRequiredPermission ( )

Get required permission.

Definition at line 107 of file class.ilLuceneSearchResultFilter.php.

References $required_permission.

Referenced by filter().

107  : string
108  {
110  }
+ Here is the caller graph for this function:

◆ getResultIds()

ilLuceneSearchResultFilter::getResultIds ( )

get filtered ids

Returns
int[] array of filtered ref_ids

Definition at line 125 of file class.ilLuceneSearchResultFilter.php.

References $checked.

Referenced by filter().

125  : array
126  {
127  return $this->checked;
128  }
+ Here is the caller graph for this function:

◆ getResultObjIds()

ilLuceneSearchResultFilter::getResultObjIds ( )

get filtered ids

Returns
int[] array of filtered obj_ids

Definition at line 134 of file class.ilLuceneSearchResultFilter.php.

134  : array
135  {
136  $obj_ids = [];
137  foreach ($this->checked as $obj_id) {
138  $obj_ids[] = $obj_id;
139  }
140  return $obj_ids;
141  }

◆ getResults()

ilLuceneSearchResultFilter::getResults ( )

get results

Returns
int[] array of ids

Definition at line 147 of file class.ilLuceneSearchResultFilter.php.

References $checked.

◆ getUserId()

ilLuceneSearchResultFilter::getUserId ( )

Get user id.

Definition at line 99 of file class.ilLuceneSearchResultFilter.php.

References $user_id.

Referenced by __construct().

99  : int
100  {
101  return $this->user_id;
102  }
+ Here is the caller graph for this function:

◆ isLimitReached()

ilLuceneSearchResultFilter::isLimitReached ( )

Check if search max hits is reached.

Returns
bool max hits reached

Definition at line 116 of file class.ilLuceneSearchResultFilter.php.

References $limit_reached.

116  : bool
117  {
118  return $this->limit_reached;
119  }

◆ isOffsetReached()

ilLuceneSearchResultFilter::isOffsetReached ( int  $a_current_nr)
protected

Check if offset is reached.

Parameters
int$a_current_nrCurrent result number
Returns
bool

Definition at line 254 of file class.ilLuceneSearchResultFilter.php.

References $offset.

Referenced by filter().

254  : bool
255  {
256  return !($a_current_nr < $this->offset);
257  }
+ Here is the caller graph for this function:

◆ loadFromDb()

ilLuceneSearchResultFilter::loadFromDb ( )

Load results from db.

Definition at line 163 of file class.ilLuceneSearchResultFilter.php.

163  : void
164  {
165  $this->checked = $this->cache->getResults();
166  }

◆ setCandidates()

ilLuceneSearchResultFilter::setCandidates ( ilLuceneSearchResult  $a_ids)

Set result ids.

Definition at line 83 of file class.ilLuceneSearchResultFilter.php.

83  : void
84  {
85  $this->result = $a_ids;
86  }

Field Documentation

◆ $access

ilAccess ilLuceneSearchResultFilter::$access
protected

Definition at line 50 of file class.ilLuceneSearchResultFilter.php.

◆ $cache

ilUserSearchCache ilLuceneSearchResultFilter::$cache
protected

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

◆ $checked

array ilLuceneSearchResultFilter::$checked = []
protected

Definition at line 41 of file class.ilLuceneSearchResultFilter.php.

Referenced by getResultIds(), and getResults().

◆ $filters

array ilLuceneSearchResultFilter::$filters = array()
protected

Definition at line 48 of file class.ilLuceneSearchResultFilter.php.

◆ $instance

ilLuceneSearchResultFilter ilLuceneSearchResultFilter::$instance = null
staticprotected

Definition at line 37 of file class.ilLuceneSearchResultFilter.php.

◆ $limit_reached

bool ilLuceneSearchResultFilter::$limit_reached = false
protected

Definition at line 45 of file class.ilLuceneSearchResultFilter.php.

Referenced by isLimitReached().

◆ $offset

int ilLuceneSearchResultFilter::$offset = 0
protected

Definition at line 46 of file class.ilLuceneSearchResultFilter.php.

Referenced by isOffsetReached().

◆ $required_permission

string ilLuceneSearchResultFilter::$required_permission = 'visible'
protected

Definition at line 44 of file class.ilLuceneSearchResultFilter.php.

Referenced by getRequiredPermission().

◆ $result

ilLuceneSearchResult ilLuceneSearchResultFilter::$result = null
protected

Definition at line 40 of file class.ilLuceneSearchResultFilter.php.

Referenced by getCandidates().

◆ $settings

ilSearchSettings ilLuceneSearchResultFilter::$settings
protected

Definition at line 42 of file class.ilLuceneSearchResultFilter.php.

◆ $user_id

int ilLuceneSearchResultFilter::$user_id
protected

Definition at line 39 of file class.ilLuceneSearchResultFilter.php.

Referenced by getUserId().


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