4 include_once
'Services/Mail/classes/class.ilMailNotification.php';
5 include_once
'Services/WebDAV/classes/class.ilDiskQuotaChecker.php';
25 $rcpt = $dqs->get(
'summary_rcpt');
26 $rcpt = explode(
',', $rcpt);
27 $loginnames = array();
28 foreach($rcpt as $loginname)
30 $loginname = trim($loginname);
33 $loginnames[] = $loginname;
57 "SELECT u.usr_id,u.gender,u.firstname,u.lastname,u.login,u.email,u.last_login,u.active,".
58 "u.time_limit_unlimited, ".$ilDB->fromUnixtime(
"u.time_limit_from").
", ".$ilDB->fromUnixtime(
"u.time_limit_until").
",".
64 "CASE WHEN u.active = 0 THEN '0001-01-01' ELSE CASE WHEN u.time_limit_unlimited=1 THEN '9999-12-31' ELSE ".$ilDB->fromUnixtime(
"u.time_limit_until").
" END END access_until,".
66 " CASE WHEN ".$ilDB->unixTimestamp().
" BETWEEN u.time_limit_from AND u.time_limit_until THEN 0 ELSE 1 END expired,".
67 "rq.role_disk_quota, system_role.rol_id role_id, ".
68 "p1.value+0 user_disk_quota,".
69 "p2.value+0 disk_usage, ".
70 "p3.value last_update, ".
71 "p5.value language, ".
75 "CASE WHEN rq.role_disk_quota>p1.value+0 OR p1.value IS NULL THEN rq.role_disk_quota ELSE p1.value+0 END disk_quota ".
79 "JOIN (SELECT u.usr_id usr_id,MAX(rd.disk_quota) role_disk_quota ".
81 "JOIN rbac_ua ua ON ua.usr_id=u.usr_id ".
82 "JOIN rbac_fa fa ON fa.rol_id=ua.rol_id AND fa.parent=%s ".
83 "JOIN role_data rd ON rd.role_id=ua.rol_id WHERE u.usr_id=ua.usr_id GROUP BY u.usr_id) rq ON rq.usr_id=u.usr_id ".
86 "LEFT JOIN rbac_ua system_role ON system_role.usr_id=u.usr_id AND system_role.rol_id = %s ".
89 "LEFT JOIN usr_pref p1 ON p1.usr_id=u.usr_id AND p1.keyword = 'disk_quota' ".
92 "LEFT JOIN usr_pref p2 ON p2.usr_id=u.usr_id AND p2.keyword = 'disk_usage' ".
95 "LEFT JOIN usr_pref p3 ON p3.usr_id=u.usr_id AND p3.keyword = 'disk_usage.last_update' ".
98 "LEFT JOIN usr_pref p5 ON p5.usr_id=u.usr_id AND p5.keyword = 'language' ".
103 'WHERE (((p1.value+0 > rq.role_disk_quota OR rq.role_disk_quota IS NULL) AND p2.value+0 > p1.value+0) OR
104 ((rq.role_disk_quota > p1.value+0 OR p1.value IS NULL) AND p2.value+0 > rq.role_disk_quota)) '.
105 'AND (u.active=1 AND (u.time_limit_unlimited = 1 OR '.$ilDB->unixTimestamp().
' BETWEEN u.time_limit_from AND u.time_limit_until)) '
107 array(
'integer',
'integer'),
108 array(ROLE_FOLDER_ID, SYSTEM_ROLE_ID)
114 while(
$row = $ilDB->fetchAssoc(
$res) )
118 $users[$counter][
'disk_quota'] =
$row[
'disk_quota'];
119 $users[$counter][
'disk_usage'] = $details[
'disk_usage'];
120 $users[$counter][
'email'] =
$row[
'email'];
121 $users[$counter][
'firstname'] =
$row[
'firstname'];
122 $users[$counter][
'lastname'] =
$row[
'lastname'];
144 $numUsers = count($users);
145 foreach($users as $user)
149 $this->
appendBody(
"\n---------------------------------------------------\n\n");
154 $user[
'lastname'].
', '.$user[
'firstname']
165 $this->
getLanguage()->txt(
'currently_used_disk_space').
': '.
170 $this->
getLanguage()->txt(
'usrf_profile_link').
': '.
174 if($counter < $numUsers - 1)
183 $this->
getMail()->appendInstallationSignature(
true);
185 $this->
sendMail(array($rcp), array(
'system'),
false);