ILIAS  release_9 Revision v9.13-25-g2c18ec4c24f
ilCronFinishUnfinishedTestPasses Class Reference

Class ilCronFinishUnfinishedTestPasses. More...

+ Inheritance diagram for ilCronFinishUnfinishedTestPasses:
+ Collaboration diagram for ilCronFinishUnfinishedTestPasses:

Public Member Functions

 getId ()
 
 getTitle ()
 
 getDescription ()
 
 getDefaultScheduleType ()
 
 getDefaultScheduleValue ()
 
 hasAutoActivation ()
 
 hasFlexibleSchedule ()
 
 hasCustomSettings ()
 
 run ()
 
- Public Member Functions inherited from ilCronJob
 setDateTimeProvider (?Closure $date_time_provider)
 
 isDue (?DateTimeImmutable $last_run, ?CronJobScheduleType $schedule_type, ?int $schedule_value, bool $is_manually_executed=false)
 
 getScheduleType ()
 Get current schedule type (if flexible) More...
 
 getScheduleValue ()
 Get current schedule value (if flexible) More...
 
 setSchedule (?CronJobScheduleType $a_type, ?int $a_value)
 Update current schedule (if flexible) More...
 
 getAllScheduleTypes ()
 Get all available schedule types. More...
 
 getScheduleTypesWithValues ()
 
 getValidScheduleTypes ()
 Returns a collection of all valid schedule types for a specific job. More...
 
 isManuallyExecutable ()
 
 hasCustomSettings ()
 
 addCustomSettingsToForm (ilPropertyFormGUI $a_form)
 
 saveCustomSettings (ilPropertyFormGUI $a_form)
 
 addToExternalSettingsForm (int $a_form_id, array &$a_fields, bool $a_is_active)
 
 activationWasToggled (ilDBInterface $db, ilSetting $setting, bool $a_currently_active)
 Important: This method is (also) called from the setup process, where the constructor of an ilCronJob ist NOT executed. More...
 
 getId ()
 
 getTitle ()
 
 getDescription ()
 
 hasAutoActivation ()
 Is to be activated on "installation", does only work for ILIAS core cron jobs. More...
 
 hasFlexibleSchedule ()
 
 getDefaultScheduleType ()
 
 getDefaultScheduleValue ()
 
 run ()
 

Protected Member Functions

 gatherUsersWithUnfinishedPasses ()
 
 getTestsFinishAndProcessingTime ()
 
 processPasses ()
 
 finishPassForUser ($active_id, $obj_id)
 

Protected Attributes

 $log
 
ilLanguage $lng
 
ilDBInterface $db
 
ilObjUser $user
 
ilObjectDataCache $obj_data_cache
 
int $now
 
array $unfinished_passes
 
array $test_ids
 
array $test_ending_times
 
ilTestProcessLockerFactory $processLockerFactory
 
- Protected Attributes inherited from ilCronJob
CronJobScheduleType $schedule_type = null
 
int $schedule_value = null
 
Closure $date_time_provider = null
 

Detailed Description

Member Function Documentation

◆ finishPassForUser()

ilCronFinishUnfinishedTestPasses::finishPassForUser (   $active_id,
  $obj_id 
)
protected

Definition at line 213 of file class.ilCronFinishUnfinishedTestPasses.php.

References ilObject\_exists(), and ILIAS\Repository\user().

Referenced by processPasses().

213  : void
214  {
215  $processLocker = $this->processLockerFactory->withContextId((int) $active_id)->getLocker();
216 
217  $test_session = new ilTestSession($this->db, $this->user);
218  $test_session->loadFromDb($active_id);
219 
220  if (ilObject::_exists($obj_id)) {
221  $test = new ilObjTest($obj_id, false);
222 
223  $test->updateTestPassResults(
224  $active_id,
225  $test_session->getPass(),
226  $test->areObligationsEnabled(),
227  null,
228  $obj_id
229  );
230 
231  (new ilTestPassFinishTasks($test_session, $test))->performFinishTasks($processLocker);
232 
233  $this->log->info('Test session with active id (' . $active_id . ') and obj_id (' . $obj_id . ') is now finished.');
234  } else {
235  $this->log->info('Test object with id (' . $obj_id . ') does not exist.');
236  }
237  }
Class ilTestPassFinishTasks.
static _exists(int $id, bool $reference=false, ?string $type=null)
checks if an object exists in object_data
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ gatherUsersWithUnfinishedPasses()

ilCronFinishUnfinishedTestPasses::gatherUsersWithUnfinishedPasses ( )
protected

Definition at line 128 of file class.ilCronFinishUnfinishedTestPasses.php.

Referenced by run().

128  : void
129  {
130  $query = '
131  SELECT tst_active.active_id,
132  tst_active.tries,
133  tst_active.user_fi usr_id,
134  tst_active.test_fi test_fi,
135  usr_data.login,
136  usr_data.lastname,
137  usr_data.firstname,
138  tst_active.submitted test_finished,
139  usr_data.matriculation,
140  usr_data.active,
141  tst_active.lastindex,
142  tst_active.last_started_pass last_started
143  FROM tst_active
144  LEFT JOIN usr_data
145  ON tst_active.user_fi = usr_data.usr_id
146  WHERE IFNULL(tst_active.last_finished_pass, -1) <> tst_active.last_started_pass
147  ';
148  $result = $this->db->query($query);
149  while ($row = $this->db->fetchAssoc($result)) {
150  $this->unfinished_passes[] = $row;
151  $this->test_ids[] = $row['test_fi'];
152  }
153  }
+ Here is the caller graph for this function:

◆ getDefaultScheduleType()

ilCronFinishUnfinishedTestPasses::getDefaultScheduleType ( )

Definition at line 81 of file class.ilCronFinishUnfinishedTestPasses.php.

82  {
83  return CronJobScheduleType::SCHEDULE_TYPE_DAILY;
84  }
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...

◆ getDefaultScheduleValue()

ilCronFinishUnfinishedTestPasses::getDefaultScheduleValue ( )

Definition at line 86 of file class.ilCronFinishUnfinishedTestPasses.php.

86  : int
87  {
88  return 1;
89  }

◆ getDescription()

ilCronFinishUnfinishedTestPasses::getDescription ( )

Definition at line 76 of file class.ilCronFinishUnfinishedTestPasses.php.

References ILIAS\Repository\lng().

Referenced by ilCronFinishUnfinishedTestPassesTest\testGetDescription().

76  : string
77  {
78  return $this->lng->txt('finish_unfinished_passes_desc');
79  }
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ getId()

ilCronFinishUnfinishedTestPasses::getId ( )

Definition at line 66 of file class.ilCronFinishUnfinishedTestPasses.php.

66  : string
67  {
68  return 'finish_unfinished_passes';
69  }

◆ getTestsFinishAndProcessingTime()

ilCronFinishUnfinishedTestPasses::getTestsFinishAndProcessingTime ( )
protected

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

Referenced by run().

155  : void
156  {
157  $query = 'SELECT test_id, obj_fi, ending_time, ending_time_enabled, processing_time, enable_processing_time FROM tst_tests WHERE ' .
158  $this->db->in('test_id', $this->test_ids, false, 'integer');
159  $result = $this->db->query($query);
160  while ($row = $this->db->fetchAssoc($result)) {
161  $this->test_ending_times[$row['test_id']] = $row;
162  }
163  $this->log->info('Gathered data for ' . count($this->test_ids) . ' test id(s) => (' . implode(',', $this->test_ids) . ')');
164  }
+ Here is the caller graph for this function:

◆ getTitle()

ilCronFinishUnfinishedTestPasses::getTitle ( )

Definition at line 71 of file class.ilCronFinishUnfinishedTestPasses.php.

References ILIAS\Repository\lng().

Referenced by ilCronFinishUnfinishedTestPassesTest\testGetTitle().

71  : string
72  {
73  return $this->lng->txt('finish_unfinished_passes');
74  }
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ hasAutoActivation()

ilCronFinishUnfinishedTestPasses::hasAutoActivation ( )

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

91  : bool
92  {
93  return false;
94  }

◆ hasCustomSettings()

ilCronFinishUnfinishedTestPasses::hasCustomSettings ( )

Definition at line 101 of file class.ilCronFinishUnfinishedTestPasses.php.

101  : bool
102  {
103  return true;
104  }

◆ hasFlexibleSchedule()

ilCronFinishUnfinishedTestPasses::hasFlexibleSchedule ( )

Definition at line 96 of file class.ilCronFinishUnfinishedTestPasses.php.

96  : bool
97  {
98  return true;
99  }

◆ processPasses()

ilCronFinishUnfinishedTestPasses::processPasses ( )
protected

Definition at line 166 of file class.ilCronFinishUnfinishedTestPasses.php.

References $data, ILIAS\LTI\ToolProvider\$key, ilObject\_exists(), and finishPassForUser().

Referenced by run().

166  : void
167  {
168  $now = time();
169  foreach ($this->unfinished_passes as $key => $data) {
170  $test_id = $data['test_fi'];
171  $can_not_be_finished = true;
172  if (array_key_exists($test_id, $this->test_ending_times)) {
173  if ($this->test_ending_times[$test_id]['ending_time_enabled'] == 1) {
174  $this->log->info('Test (' . $test_id . ') has ending time (' . $this->test_ending_times[$test_id]['ending_time'] . ')');
175  $ending_time = $this->test_ending_times[$test_id]['ending_time'];
176  if ($ending_time < $now) {
177  $this->finishPassForUser($data['active_id'], $this->test_ending_times[$test_id]['obj_fi']);
178  $can_not_be_finished = false;
179  } else {
180  $this->log->info('Test (' . $test_id . ') ending time (' . $this->test_ending_times[$test_id]['ending_time'] . ') > now (' . $now . ') is not reached.');
181  }
182  } else {
183  $this->log->info('Test (' . $test_id . ') has no ending time.');
184  }
185  if ($this->test_ending_times[$test_id]['enable_processing_time'] == 1) {
186  $this->log->info('Test (' . $test_id . ') has processing time (' . $this->test_ending_times[$test_id]['processing_time'] . ')');
187  $obj_id = $this->test_ending_times[$test_id]['obj_fi'];
188  if (ilObject::_exists($obj_id)) {
189  $test_obj = new ilObjTest($obj_id, false);
190  $startingTime = $test_obj->getStartingTimeOfUser($data['active_id']);
191  $max_processing_time = $test_obj->isMaxProcessingTimeReached($startingTime, $data['active_id']);
192  if ($max_processing_time) {
193  $this->log->info('Max Processing time reached for user id (' . $data['usr_id'] . ') so test with active id (' . $data['active_id'] . ') will be finished.');
194  $this->finishPassForUser($data['active_id'], $this->test_ending_times[$test_id]['obj_fi']);
195  $can_not_be_finished = false;
196  } else {
197  $this->log->info('Max Processing time not reached for user id (' . $data['usr_id'] . ') in test with active id (' . $data['active_id'] . '). Starting time: ' . $startingTime . ' Processing time: ' . $test_obj->getProcessingTime() . ' / ' . $test_obj->getProcessingTimeInSeconds() . 's');
198  }
199  } else {
200  $this->log->info('Test object with id (' . $obj_id . ') does not exist.');
201  }
202  } else {
203  $this->log->info('Test (' . $test_id . ') has no processing time.');
204  }
205 
206  if ($can_not_be_finished) {
207  $this->log->info('Test session with active id (' . $data['active_id'] . ') can not be finished by this cron job.');
208  }
209  }
210  }
211  }
static _exists(int $id, bool $reference=false, ?string $type=null)
checks if an object exists in object_data
string $key
Consumer key/client ID value.
Definition: System.php:193
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ run()

ilCronFinishUnfinishedTestPasses::run ( )

Definition at line 106 of file class.ilCronFinishUnfinishedTestPasses.php.

References gatherUsersWithUnfinishedPasses(), getTestsFinishAndProcessingTime(), processPasses(), and ilCronJobResult\STATUS_OK.

107  {
108  $this->log->info('start inf cronjob...');
109 
110  $result = new ilCronJobResult();
111 
113  if (count($this->unfinished_passes) > 0) {
114  $this->log->info('found ' . count($this->unfinished_passes) . ' unfinished passes starting analyses.');
116  $this->processPasses();
117  } else {
118  $this->log->info('No unfinished passes found.');
119  }
120 
121  $result->setStatus(ilCronJobResult::STATUS_OK);
122 
123  $this->log->info(' ...finishing cronjob.');
124 
125  return $result;
126  }
+ Here is the call graph for this function:

Field Documentation

◆ $db

ilDBInterface ilCronFinishUnfinishedTestPasses::$db
protected

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

◆ $lng

ilLanguage ilCronFinishUnfinishedTestPasses::$lng
protected

Definition at line 34 of file class.ilCronFinishUnfinishedTestPasses.php.

◆ $log

ilCronFinishUnfinishedTestPasses::$log
protected

Definition at line 32 of file class.ilCronFinishUnfinishedTestPasses.php.

◆ $now

int ilCronFinishUnfinishedTestPasses::$now
protected

Definition at line 38 of file class.ilCronFinishUnfinishedTestPasses.php.

◆ $obj_data_cache

ilObjectDataCache ilCronFinishUnfinishedTestPasses::$obj_data_cache
protected

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

◆ $processLockerFactory

ilTestProcessLockerFactory ilCronFinishUnfinishedTestPasses::$processLockerFactory
protected

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

◆ $test_ending_times

array ilCronFinishUnfinishedTestPasses::$test_ending_times
protected

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

◆ $test_ids

array ilCronFinishUnfinishedTestPasses::$test_ids
protected

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

◆ $unfinished_passes

array ilCronFinishUnfinishedTestPasses::$unfinished_passes
protected

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

◆ $user

ilObjUser ilCronFinishUnfinishedTestPasses::$user
protected

Definition at line 36 of file class.ilCronFinishUnfinishedTestPasses.php.


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