ILIAS  release_7 Revision v7.30-3-g800a261c036
ilCronDeleteInactiveUserAccounts Class Reference
+ Inheritance diagram for ilCronDeleteInactiveUserAccounts:
+ Collaboration diagram for ilCronDeleteInactiveUserAccounts:

Public Member Functions

 __construct ()
 
 getId ()
 Get id. More...
 
 getTitle ()
 Get title. More...
 
 getDescription ()
 Get description. More...
 
 getDefaultScheduleType ()
 Get schedule type. More...
 
 getDefaultScheduleValue ()
 Get schedule value. More...
 
 hasAutoActivation ()
 Is to be activated on "installation". More...
 
 hasFlexibleSchedule ()
 Can the schedule be configured? More...
 
 hasCustomSettings ()
 Has cron job any custom setting which can be edited? More...
 
 addCustomSettingsToForm (ilPropertyFormGUI $a_form)
 Add custom settings to form. More...
 
 saveCustomSettings (ilPropertyFormGUI $a_form)
 Save custom settings. More...
 
- Public Member Functions inherited from ilCronJob
 isActive ($a_ts_last_run, $a_schedule_type, $a_schedule_value, $a_manual=false)
 Is job currently active? More...
 
 getScheduleType ()
 Get current schedule type (if flexible) More...
 
 getScheduleValue ()
 Get current schedule value (if flexible) More...
 
 setSchedule ($a_type, $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...
 
 getTitle ()
 Get title. More...
 
 getDescription ()
 Get description. More...
 
 isManuallyExecutable ()
 Defines whether or not a cron job can be started manually. More...
 
 hasCustomSettings ()
 Has cron job any custom setting which can be edited? More...
 
 addCustomSettingsToForm (ilPropertyFormGUI $a_form)
 Add custom settings to form. More...
 
 saveCustomSettings (ilPropertyFormGUI $a_form)
 Save custom settings. More...
 
 addToExternalSettingsForm ($a_form_id, array &$a_fields, $a_is_active)
 Add external settings to form. More...
 
 activationWasToggled ($a_currently_active)
 Cron job status was changed. More...
 
 getId ()
 Get id. More...
 
 hasAutoActivation ()
 Is to be activated on "installation". More...
 
 hasFlexibleSchedule ()
 Can the schedule be configured? More...
 
 getDefaultScheduleType ()
 Get schedule type. More...
 
 getDefaultScheduleValue ()
 Get schedule value. More...
 
 run ()
 Run job. More...
 

Data Fields

const DEFAULT_INACTIVITY_PERIOD = 365
 
const DEFAULT_REMINDER_PERIOD = 0
 
- Data Fields inherited from ilCronJob
const SCHEDULE_TYPE_DAILY = 1
 
const SCHEDULE_TYPE_IN_MINUTES = 2
 
const SCHEDULE_TYPE_IN_HOURS = 3
 
const SCHEDULE_TYPE_IN_DAYS = 4
 
const SCHEDULE_TYPE_WEEKLY = 5
 
const SCHEDULE_TYPE_MONTHLY = 6
 
const SCHEDULE_TYPE_QUARTERLY = 7
 
const SCHEDULE_TYPE_YEARLY = 8
 

Protected Member Functions

 getTimeDifferenceBySchedule ($schedule_time, $multiplier)
 
 calculateDeletionData ($date_for_deletion)
 
 isDecimal ($number)
 
- Protected Member Functions inherited from ilCronJob
 checkSchedule ($a_ts_last_run, $a_schedule_type, $a_schedule_value)
 

Private Attributes

 $period = null
 
 $reminderTimer = null
 
 $include_roles = null
 

Detailed Description

Definition at line 17 of file class.ilCronDeleteInactiveUserAccounts.php.

Constructor & Destructor Documentation

◆ __construct()

ilCronDeleteInactiveUserAccounts::__construct ( )

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

27 {
28 global $DIC;
29
30 $ilSetting = $DIC['ilSetting'];
31
32 if (is_object($ilSetting)) {
33 $this->include_roles = $ilSetting->get(
34 'cron_inactive_user_delete_include_roles',
35 null
36 );
37 if ($this->include_roles === null) {
38 $this->include_roles = array();
39 } else {
40 $this->include_roles = explode(',', $this->include_roles);
41 }
42
43 $this->period = $ilSetting->get(
44 'cron_inactive_user_delete_period',
45 self::DEFAULT_INACTIVITY_PERIOD
46 );
47 $this->reminderTimer = $ilSetting->get(
48 'cron_inactive_user_reminder_period',
49 self::DEFAULT_REMINDER_PERIOD
50 );
51 }
52 }
global $DIC
Definition: goto.php:24
global $ilSetting
Definition: privfeed.php:17

References $DIC, and $ilSetting.

Member Function Documentation

◆ addCustomSettingsToForm()

ilCronDeleteInactiveUserAccounts::addCustomSettingsToForm ( ilPropertyFormGUI  $a_form)

Add custom settings to form.

Parameters
ilPropertyFormGUI$a_form

Reimplemented from ilCronJob.

Definition at line 219 of file class.ilCronDeleteInactiveUserAccounts.php.

220 {
221 global $DIC;
222
223 $lng = $DIC['lng'];
224 $rbacreview = $DIC['rbacreview'];
225 $ilObjDataCache = $DIC['ilObjDataCache'];
226 $ilSetting = $DIC['ilSetting'];
227 $lng->loadLanguageModule("user");
228
229 $schedule = $a_form->getItemByPostVar('type');
230 $schedule->setTitle($lng->txt('delete_inactive_user_accounts_frequency'));
231 $schedule->setInfo($lng->txt('delete_inactive_user_accounts_frequency_desc'));
232
233 include_once('Services/Form/classes/class.ilMultiSelectInputGUI.php');
234 $sub_mlist = new ilMultiSelectInputGUI(
235 $lng->txt('delete_inactive_user_accounts_include_roles'),
236 'cron_inactive_user_delete_include_roles'
237 );
238 $sub_mlist->setInfo($lng->txt('delete_inactive_user_accounts_include_roles_desc'));
239 $roles = array();
240 foreach ($rbacreview->getGlobalRoles() as $role_id) {
241 if ($role_id != ANONYMOUS_ROLE_ID) {
242 $roles[$role_id] = $ilObjDataCache->lookupTitle($role_id);
243 }
244 }
245 $sub_mlist->setOptions($roles);
246 $setting = $ilSetting->get('cron_inactive_user_delete_include_roles', null);
247 if ($setting === null) {
248 $setting = array();
249 } else {
250 $setting = explode(',', $setting);
251 }
252 $sub_mlist->setValue($setting);
253 $sub_mlist->setWidth(300);
254 $a_form->addItem($sub_mlist);
255
256 $default_setting = self::DEFAULT_INACTIVITY_PERIOD;
257 $sub_text = new ilNumberInputGUI(
258 $lng->txt('delete_inactive_user_accounts_period'),
259 'cron_inactive_user_delete_period'
260 );
261 $sub_text->setInfo($lng->txt('delete_inactive_user_accounts_period_desc'));
262 $sub_text->setValue($ilSetting->get("cron_inactive_user_delete_period", $default_setting));
263 $sub_text->setSize(4);
264 $sub_text->setMaxLength(4);
265 $sub_text->setRequired(true);
266 $a_form->addItem($sub_text);
267
268 $sub_period = new ilNumberInputGUI(
269 $lng->txt('send_mail_to_inactive_users'),
270 'cron_inactive_user_reminder_period'
271 );
272 $sub_period->setInfo($lng->txt("send_mail_to_inactive_users_desc"));
273 $sub_period->setValue($ilSetting->get("cron_inactive_user_reminder_period", $default_setting));
274 $sub_period->setSuffix($lng->txt("send_mail_to_inactive_users_suffix"));
275 $sub_period->setSize(4);
276 $sub_period->setMaxLength(4);
277 $sub_period->setRequired(false);
278 $sub_period->setMinValue(0);
279 $a_form->addItem($sub_period);
280 }
This class represents a multi selection list property in a property form.
This class represents a number property in a property form.
addItem($a_item)
Add Item (Property, SectionHeader).
getItemByPostVar($a_post_var)
Get Item by POST variable.
const ANONYMOUS_ROLE_ID
Definition: constants.php:26
$lng

References $DIC, $ilSetting, $lng, ilPropertyFormGUI\addItem(), ANONYMOUS_ROLE_ID, DEFAULT_INACTIVITY_PERIOD, and ilPropertyFormGUI\getItemByPostVar().

+ Here is the call graph for this function:

◆ calculateDeletionData()

ilCronDeleteInactiveUserAccounts::calculateDeletionData (   $date_for_deletion)
protected

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

201 {
202 $cron_timing = ilCronManager::getCronJobData($this->getId());
203 $time_difference = 0;
204 $multiplier = 1;
205
206 if (!is_array($cron_timing) || !is_array($cron_timing[0])) {
207 return time() + $date_for_deletion + $time_difference;
208 }
209
210 if (array_key_exists('schedule_type', $cron_timing[0])) {
211 if ($cron_timing[0]['schedule_value'] != null) {
212 $multiplier = $cron_timing[0]['schedule_value'];
213 }
214 $time_difference = $this->getTimeDifferenceBySchedule($cron_timing[0]['schedule_type'], $multiplier);
215 }
216 return time() + $date_for_deletion + $time_difference;
217 }
static getCronJobData($a_id=null, $a_include_inactive=true)
Get cron job configuration/execution data.

References ilCronManager\getCronJobData(), getId(), and getTimeDifferenceBySchedule().

+ Here is the call graph for this function:

◆ getDefaultScheduleType()

ilCronDeleteInactiveUserAccounts::getDefaultScheduleType ( )

Get schedule type.

Returns
int

Reimplemented from ilCronJob.

Definition at line 114 of file class.ilCronDeleteInactiveUserAccounts.php.

115 {
117 }
const SCHEDULE_TYPE_DAILY

References ilCronJob\SCHEDULE_TYPE_DAILY.

◆ getDefaultScheduleValue()

ilCronDeleteInactiveUserAccounts::getDefaultScheduleValue ( )

Get schedule value.

Returns
int|array

Reimplemented from ilCronJob.

Definition at line 119 of file class.ilCronDeleteInactiveUserAccounts.php.

120 {
121 return;
122 }

◆ getDescription()

ilCronDeleteInactiveUserAccounts::getDescription ( )

Get description.

Returns
string

Reimplemented from ilCronJob.

Definition at line 105 of file class.ilCronDeleteInactiveUserAccounts.php.

106 {
107 global $DIC;
108
109 $lng = $DIC['lng'];
110
111 return $lng->txt("delete_inactive_user_accounts_desc");
112 }

References $DIC, and $lng.

◆ getId()

ilCronDeleteInactiveUserAccounts::getId ( )

Get id.

Returns
string

Reimplemented from ilCronJob.

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

92 {
93 return "user_inactive";
94 }

Referenced by calculateDeletionData().

+ Here is the caller graph for this function:

◆ getTimeDifferenceBySchedule()

ilCronDeleteInactiveUserAccounts::getTimeDifferenceBySchedule (   $schedule_time,
  $multiplier 
)
protected
Parameters
$schedule_time
$multiplier
Returns
int

Definition at line 59 of file class.ilCronDeleteInactiveUserAccounts.php.

60 {
61 $time_difference = 0;
62 switch ($schedule_time) {
64 $time_difference = 86400;
65 break;
67 $time_difference = 60 * $multiplier;
68 break;
70 $time_difference = 3600 * $multiplier;
71 break;
73 $time_difference = 86400 * $multiplier;
74 break;
76 $time_difference = 604800;
77 break;
79 $time_difference = 2629743;
80 break;
82 $time_difference = 7889229;
83 break;
85 $time_difference = 31556926;
86 break;
87 }
88 return $time_difference;
89 }
const SCHEDULE_TYPE_IN_DAYS
const SCHEDULE_TYPE_IN_HOURS
const SCHEDULE_TYPE_IN_MINUTES
const SCHEDULE_TYPE_WEEKLY
const SCHEDULE_TYPE_YEARLY
const SCHEDULE_TYPE_QUARTERLY
const SCHEDULE_TYPE_MONTHLY

References ilCronJob\SCHEDULE_TYPE_DAILY, ilCronJob\SCHEDULE_TYPE_IN_DAYS, ilCronJob\SCHEDULE_TYPE_IN_HOURS, ilCronJob\SCHEDULE_TYPE_IN_MINUTES, ilCronJob\SCHEDULE_TYPE_MONTHLY, ilCronJob\SCHEDULE_TYPE_QUARTERLY, ilCronJob\SCHEDULE_TYPE_WEEKLY, and ilCronJob\SCHEDULE_TYPE_YEARLY.

Referenced by calculateDeletionData().

+ Here is the caller graph for this function:

◆ getTitle()

ilCronDeleteInactiveUserAccounts::getTitle ( )

Get title.

Returns
string

Reimplemented from ilCronJob.

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

97 {
98 global $DIC;
99
100 $lng = $DIC['lng'];
101
102 return $lng->txt("delete_inactive_user_accounts");
103 }

References $DIC, and $lng.

◆ hasAutoActivation()

ilCronDeleteInactiveUserAccounts::hasAutoActivation ( )

Is to be activated on "installation".

Returns
boolean

Reimplemented from ilCronJob.

Definition at line 124 of file class.ilCronDeleteInactiveUserAccounts.php.

125 {
126 return false;
127 }

◆ hasCustomSettings()

ilCronDeleteInactiveUserAccounts::hasCustomSettings ( )

Has cron job any custom setting which can be edited?

Returns
boolean

Reimplemented from ilCronJob.

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

135 {
136 return true;
137 }

◆ hasFlexibleSchedule()

ilCronDeleteInactiveUserAccounts::hasFlexibleSchedule ( )

Can the schedule be configured?

Returns
boolean

Reimplemented from ilCronJob.

Definition at line 129 of file class.ilCronDeleteInactiveUserAccounts.php.

130 {
131 return true;
132 }

◆ isDecimal()

ilCronDeleteInactiveUserAccounts::isDecimal (   $number)
protected

Definition at line 358 of file class.ilCronDeleteInactiveUserAccounts.php.

359 {
360 if (strpos($number, ',') || strpos($number, '.')) {
361 return true;
362 }
363 return false;
364 }

Referenced by saveCustomSettings().

+ Here is the caller graph for this function:

◆ saveCustomSettings()

ilCronDeleteInactiveUserAccounts::saveCustomSettings ( ilPropertyFormGUI  $a_form)

Save custom settings.

Parameters
ilPropertyFormGUI$a_form
Returns
boolean

Reimplemented from ilCronJob.

Definition at line 282 of file class.ilCronDeleteInactiveUserAccounts.php.

283 {
284 global $DIC;
285
286 $ilSetting = $DIC['ilSetting'];
287 $lng = $DIC['lng'];
288 $lng->loadLanguageModule("user");
289 $setting = implode(',', $_POST['cron_inactive_user_delete_include_roles']);
290 if (!strlen($setting)) {
291 $setting = null;
292 }
293
294 $valid = true;
295 $delete_period = ilUtil::stripSlashes($_POST['cron_inactive_user_delete_period']);
296 $reminder_period = ilUtil::stripSlashes($_POST['cron_inactive_user_reminder_period']);
297 $cron_period = (int) ilUtil::stripSlashes($_POST['type']);
298 $cron_period_custom = (int) ilUtil::stripSlashes($_POST['sdyi']);
299
300 if ($this->isDecimal($delete_period)) {
301 $valid = false;
302 $a_form->getItemByPostVar('cron_inactive_user_delete_period')->setAlert($lng->txt('send_mail_to_inactive_users_numbers_only'));
303 }
304 if ($this->isDecimal($reminder_period)) {
305 $valid = false;
306 $a_form->getItemByPostVar('cron_inactive_user_reminder_period')->setAlert($lng->txt('send_mail_to_inactive_users_numbers_only'));
307 }
308 if ($reminder_period >= $delete_period) {
309 $valid = false;
310 $a_form->getItemByPostVar('cron_inactive_user_reminder_period')->setAlert($lng->txt('send_mail_to_inactive_users_must_be_smaller_than'));
311 }
312 if ($cron_period >= ilCronJob::SCHEDULE_TYPE_IN_DAYS && $cron_period <= ilCronJob::SCHEDULE_TYPE_YEARLY && $reminder_period > 0) {
313 $logic = true;
314 $check_window_logic = $delete_period - $reminder_period;
315 if ($cron_period == ilCronJob::SCHEDULE_TYPE_IN_DAYS) {
316 if ($check_window_logic < $cron_period_custom) {
317 $logic = false;
318 }
319 } elseif ($cron_period == ilCronJob::SCHEDULE_TYPE_WEEKLY) {
320 if ($check_window_logic <= 7) {
321 $logic = false;
322 }
323 } elseif ($cron_period == ilCronJob::SCHEDULE_TYPE_MONTHLY) {
324 if ($check_window_logic <= 31) {
325 $logic = false;
326 }
327 } elseif ($cron_period == ilCronJob::SCHEDULE_TYPE_QUARTERLY) {
328 if ($check_window_logic <= 92) {
329 $logic = false;
330 }
331 } elseif ($cron_period == ilCronJob::SCHEDULE_TYPE_YEARLY) {
332 if ($check_window_logic <= 366) {
333 $logic = false;
334 }
335 }
336 if (!$logic) {
337 $valid = false;
338 $a_form->getItemByPostVar('cron_inactive_user_reminder_period')->setAlert($lng->txt('send_mail_reminder_window_too_small'));
339 }
340 }
341 if ($_POST['cron_inactive_user_delete_period']) {
342 $ilSetting->set('cron_inactive_user_delete_include_roles', $setting);
343 $ilSetting->set('cron_inactive_user_delete_period', $_POST['cron_inactive_user_delete_period']);
344 }
345 if ($this->reminderTimer > $reminder_period) {
347 }
348 $ilSetting->set('cron_inactive_user_reminder_period', $reminder_period);
349
350 if (!$valid) {
351 ilUtil::sendFailure($lng->txt("form_input_not_valid"));
352 return false;
353 }
354
355 return true;
356 }
$_POST["username"]
static sendFailure($a_info="", $a_keep=false)
Send Failure Message to Screen.
static stripSlashes($a_str, $a_strip_html=true, $a_allow="")
strip slashes if magic qoutes is enabled
$valid

References $_POST, $DIC, $ilSetting, $lng, $valid, ilCronDeleteInactiveUserReminderMail\flushDataTable(), ilPropertyFormGUI\getItemByPostVar(), isDecimal(), ilCronJob\SCHEDULE_TYPE_IN_DAYS, ilCronJob\SCHEDULE_TYPE_MONTHLY, ilCronJob\SCHEDULE_TYPE_QUARTERLY, ilCronJob\SCHEDULE_TYPE_WEEKLY, ilCronJob\SCHEDULE_TYPE_YEARLY, ilUtil\sendFailure(), and ilUtil\stripSlashes().

+ Here is the call graph for this function:

Field Documentation

◆ $include_roles

ilCronDeleteInactiveUserAccounts::$include_roles = null
private

Definition at line 24 of file class.ilCronDeleteInactiveUserAccounts.php.

◆ $period

ilCronDeleteInactiveUserAccounts::$period = null
private

Definition at line 22 of file class.ilCronDeleteInactiveUserAccounts.php.

◆ $reminderTimer

ilCronDeleteInactiveUserAccounts::$reminderTimer = null
private

Definition at line 23 of file class.ilCronDeleteInactiveUserAccounts.php.

◆ DEFAULT_INACTIVITY_PERIOD

const ilCronDeleteInactiveUserAccounts::DEFAULT_INACTIVITY_PERIOD = 365

Definition at line 19 of file class.ilCronDeleteInactiveUserAccounts.php.

Referenced by addCustomSettingsToForm().

◆ DEFAULT_REMINDER_PERIOD

const ilCronDeleteInactiveUserAccounts::DEFAULT_REMINDER_PERIOD = 0

Definition at line 20 of file class.ilCronDeleteInactiveUserAccounts.php.


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