ILIAS  release_8 Revision v8.24
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.

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

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

+ 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.

244 : void
245 {
246 $this->checked[$a_ref_id] = $a_obj_id;
247 }

Referenced by filter().

+ 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.

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 }

Referenced by filter().

+ 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.

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
append(int $a_ref_id, int $a_obj_id)
Append to filtered results.
static _getAllReferences(int $id)
get all reference ids for object ID
$ref_id
Definition: ltiauth.php:67

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

+ Here is the call graph for this function:

◆ getCandidates()

ilLuceneSearchResultFilter::getCandidates ( )

get result ids

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

92 {
93 return $this->result;
94 }
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...

References $result.

Referenced by filter().

+ 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.

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...
static ilLuceneSearchResultFilter $instance

References $instance.

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

+ Here is the caller graph for this function:

◆ getMaxHits()

ilLuceneSearchResultFilter::getMaxHits ( )

get max hits

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

155 : int
156 {
157 return $this->settings->getMaxHits();
158 }

References ILIAS\Repository\settings().

+ Here is the call graph for this function:

◆ getRequiredPermission()

ilLuceneSearchResultFilter::getRequiredPermission ( )

Get required permission.

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

107 : string
108 {
110 }

References $required_permission.

◆ getResultIds()

ilLuceneSearchResultFilter::getResultIds ( )

get filtered ids

Returns
int[] array of filtered ref_ids

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

125 : array
126 {
127 return $this->checked;
128 }

References $checked.

Referenced by filter().

+ 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.

148 {
149 return $this->checked;
150 }

References $checked.

◆ getUserId()

ilLuceneSearchResultFilter::getUserId ( )

Get user id.

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

99 : int
100 {
101 return $this->user_id;
102 }

References $user_id.

Referenced by __construct().

+ 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.

116 : bool
117 {
119 }

References $limit_reached.

◆ 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.

254 : bool
255 {
256 return !($a_current_nr < $this->offset);
257 }

References $offset.

◆ 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.

Referenced by getInstance().

◆ $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: