ILIAS  release_4-4 Revision
ilCronDeleteInactivatedUserAccounts Class Reference
+ Inheritance diagram for ilCronDeleteInactivatedUserAccounts:
+ Collaboration diagram for ilCronDeleteInactivatedUserAccounts:

Public Member Functions

 __construct ()
 
 getId ()
 
 getTitle ()
 
 getDescription ()
 
 getDefaultScheduleType ()
 
 getDefaultScheduleValue ()
 
 hasAutoActivation ()
 
 hasFlexibleSchedule ()
 
 hasCustomSettings ()
 
 run ()
 
 addCustomSettingsToForm (ilPropertyFormGUI $a_form)
 
 saveCustomSettings (ilPropertyFormGUI $a_form)
 
- 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...
 
 getValidScheduleTypes ()
 Get all available schedule types. 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
 
- 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
 

Private Attributes

 $period = null
 
 $include_roles = null
 

Additional Inherited Members

- Protected Member Functions inherited from ilCronJob
 checkSchedule ($a_ts_last_run, $a_schedule_type, $a_schedule_value)
 

Detailed Description

Constructor & Destructor Documentation

◆ __construct()

ilCronDeleteInactivatedUserAccounts::__construct ( )

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

References $ilSetting.

23  {
24  global $ilSetting;
25 
26  if(is_object($ilSetting))
27  {
28  $this->include_roles = $ilSetting->get(
29  'cron_inactivated_user_delete_include_roles', null
30  );
31  if($this->include_roles === null) $this->include_roles = array();
32  else $this->include_roles = explode(',', $this->include_roles);
33 
34  $this->period = $ilSetting->get(
35  'cron_inactivated_user_delete_period',
36  self::DEFAULT_INACTIVITY_PERIOD
37  );
38  }
39  }
global $ilSetting
Definition: privfeed.php:40

Member Function Documentation

◆ addCustomSettingsToForm()

ilCronDeleteInactivatedUserAccounts::addCustomSettingsToForm ( ilPropertyFormGUI  $a_form)

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

References $ilSetting, $lng, ilPropertyFormGUI\addItem(), and ilFormPropertyGUI\setInfo().

126  {
127  global $lng, $rbacreview, $ilObjDataCache, $ilSetting;
128 
129  include_once('Services/Form/classes/class.ilMultiSelectInputGUI.php');
130  $sub_mlist = new ilMultiSelectInputGUI(
131  $lng->txt('delete_inactivated_user_accounts_include_roles'),
132  'cron_inactivated_user_delete_include_roles'
133  );
134  $sub_mlist->setInfo($lng->txt('delete_inactivated_user_accounts_include_roles_desc'));
135  $roles = array();
136  foreach($rbacreview->getGlobalRoles() as $role_id)
137  {
138  if( $role_id != ANONYMOUS_ROLE_ID )
139  $roles[$role_id] = $ilObjDataCache->lookupTitle($role_id);
140  }
141  $sub_mlist->setOptions($roles);
142  $setting = $ilSetting->get('cron_inactivated_user_delete_include_roles', null);
143  if($setting === null) $setting = array();
144  else $setting = explode(',', $setting);
145  $sub_mlist->setValue($setting);
146  $sub_mlist->setWidth(300);
147  #$sub_mlist->setHeight(100);
148  $a_form->addItem($sub_mlist);
149 
150  $default_setting = self::DEFAULT_INACTIVITY_PERIOD;
151  $sub_text = new ilNumberInputGUI(
152  $lng->txt('delete_inactivated_user_accounts_period'),
153  'cron_inactivated_user_delete_period'
154  );
155  $sub_text->setInfo($lng->txt('delete_inactivated_user_accounts_period_desc'));
156  $sub_text->setValue($ilSetting->get("cron_inactivated_user_delete_period", $default_setting));
157  $sub_text->setSize(4);
158  $sub_text->setMaxLength(4);
159  $sub_text->setRequired(true);
160  $a_form->addItem($sub_text);
161 
162  /*
163  $default_setting = ilCronDeleteInactiveUserAccounts::DEFAULT_SETTING_INCLUDE_ADMINS;
164  $sub_cb = new ilCheckboxInputGUI($lng->txt('delete_inactivated_user_accounts_include_admins'),'cron_inactivated_user_delete_include_admins');
165  $sub_cb->setChecked($ilSetting->get("cron_inactivated_user_delete_include_admins", $default_setting) ? 1 : 0 );
166  //$sub_cb->setOptionTitle($lng->txt('delete_inactivated_user_accounts_include_admins'));
167  $sub_cb->setInfo($lng->txt('delete_inactivated_user_accounts_include_admins_desc'));
168  $a_form->addItem($sub_cb);
169  */
170  }
addItem($a_item)
Add Item (Property, SectionHeader).
setInfo($a_info)
Set Information Text.
This class represents a multi selection list property in a property form.
This class represents a number property in a property form.
global $ilSetting
Definition: privfeed.php:40
global $lng
Definition: privfeed.php:40
+ Here is the call graph for this function:

◆ getDefaultScheduleType()

ilCronDeleteInactivatedUserAccounts::getDefaultScheduleType ( )

Definition at line 60 of file class.ilCronDeleteInactivatedUserAccounts.php.

61  {
62  return self::SCHEDULE_TYPE_DAILY;
63  }

◆ getDefaultScheduleValue()

ilCronDeleteInactivatedUserAccounts::getDefaultScheduleValue ( )

Definition at line 65 of file class.ilCronDeleteInactivatedUserAccounts.php.

66  {
67  return;
68  }

◆ getDescription()

ilCronDeleteInactivatedUserAccounts::getDescription ( )

Definition at line 53 of file class.ilCronDeleteInactivatedUserAccounts.php.

References $lng.

54  {
55  global $lng;
56 
57  return $lng->txt("delete_inactivated_user_accounts_desc");
58  }
global $lng
Definition: privfeed.php:40

◆ getId()

ilCronDeleteInactivatedUserAccounts::getId ( )

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

42  {
43  return "user_inactivated";
44  }

◆ getTitle()

ilCronDeleteInactivatedUserAccounts::getTitle ( )

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

References $lng.

47  {
48  global $lng;
49 
50  return $lng->txt("delete_inactivated_user_accounts");
51  }
global $lng
Definition: privfeed.php:40

◆ hasAutoActivation()

ilCronDeleteInactivatedUserAccounts::hasAutoActivation ( )

Definition at line 70 of file class.ilCronDeleteInactivatedUserAccounts.php.

71  {
72  return false;
73  }

◆ hasCustomSettings()

ilCronDeleteInactivatedUserAccounts::hasCustomSettings ( )

Definition at line 80 of file class.ilCronDeleteInactivatedUserAccounts.php.

81  {
82  return true;
83  }

◆ hasFlexibleSchedule()

ilCronDeleteInactivatedUserAccounts::hasFlexibleSchedule ( )

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

76  {
77  return true;
78  }

◆ run()

ilCronDeleteInactivatedUserAccounts::run ( )

Definition at line 85 of file class.ilCronDeleteInactivatedUserAccounts.php.

References $result, $usr_id, ilObjUser\_getUserIdsByInactivationPeriod(), ilObjectFactory\getInstanceByObjId(), ilCronJobResult\STATUS_NO_ACTION, and ilCronJobResult\STATUS_OK.

86  {
87  global $rbacreview;
88 
90 
91  $usr_ids = ilObjUser::_getUserIdsByInactivationPeriod($this->period);
92 
93  $counter = 0;
94  foreach($usr_ids as $usr_id)
95  {
96  if($usr_id == ANONYMOUS_USER_ID || $usr_id == SYSTEM_USER_ID) continue;
97 
98  $continue = true;
99  foreach($this->include_roles as $role_id)
100  {
101  if( $rbacreview->isAssigned($usr_id, $role_id) )
102  {
103  $continue = false;
104  break;
105  }
106  }
107  if($continue) continue;
108 
109  $user = ilObjectFactory::getInstanceByObjId($usr_id);
110 
111  $user->delete();
112 
113  $counter++;
114  }
115 
116  if($counter)
117  {
118  $status = ilCronJobResult::STATUS_OK;
119  }
120  $result = new ilCronJobResult();
121  $result->setStatus($status);
122  return $result;
123  }
static _getUserIdsByInactivationPeriod($period)
get ids of all users that have been inactivated since at least the given period
$result
getInstanceByObjId($a_obj_id, $stop_on_error=true)
get an instance of an Ilias object by object id
Cron job result data container.
+ Here is the call graph for this function:

◆ saveCustomSettings()

ilCronDeleteInactivatedUserAccounts::saveCustomSettings ( ilPropertyFormGUI  $a_form)

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

References $_POST, and $ilSetting.

173  {
174  global $ilSetting;
175 
176  $setting = implode(',', $_POST['cron_inactivated_user_delete_include_roles']);
177  if( !strlen($setting) ) $setting = null;
178  $ilSetting->set('cron_inactivated_user_delete_include_roles', $setting);
179  $ilSetting->set('cron_inactivated_user_delete_period', $_POST['cron_inactivated_user_delete_period']);
180 
181  return true;
182  }
$_POST['username']
Definition: cron.php:12
global $ilSetting
Definition: privfeed.php:40

Field Documentation

◆ $include_roles

ilCronDeleteInactivatedUserAccounts::$include_roles = null
private

◆ $period

ilCronDeleteInactivatedUserAccounts::$period = null
private

◆ DEFAULT_INACTIVITY_PERIOD

const ilCronDeleteInactivatedUserAccounts::DEFAULT_INACTIVITY_PERIOD = 365

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