X-Git-Url: http://git.polytechnique.org/?a=blobdiff_plain;ds=sidebyside;f=modules%2Femail.php;h=b78cfe7ff52b232e9ee8f68168c447fd98dd9c10;hb=8526cfe046865202710c548a3a58c7dbddeaee65;hp=772c1211eeb20290db7d995fe817438b4cb74d19;hpb=ca9cf2359f2f0e86a543aae34eb7bfee06938ef5;p=platal.git diff --git a/modules/email.php b/modules/email.php index 772c121..b78cfe7 100644 --- a/modules/email.php +++ b/modules/email.php @@ -1,6 +1,6 @@ $this->make_hook('duplicated', AUTH_PASSWD, 'admin'), 'admin/emails/watch' => $this->make_hook('duplicated', AUTH_PASSWD, 'admin'), 'admin/emails/lost' => $this->make_hook('lost', AUTH_PASSWD, 'admin'), - 'admin/emails/broken' => $this->make_hook('broken_addr', AUTH_PASSWD, 'admin'), + 'admin/emails/broken' => $this->make_hook('broken_addr', AUTH_PASSWD, 'admin,edit_directory'), ); } @@ -98,9 +98,23 @@ class EmailModule extends PLModule INNER JOIN email_virtual_domains AS m ON (s.domain = m.id) INNER JOIN email_virtual_domains AS d ON (d.aliasing = m.id) WHERE s.uid = {?} - ORDER BY !alias, s.email", + ORDER BY !alias, s.email, d.name", $user->id()); - $page->assign('aliases', $aliases); + $aliases_forlife = array(); + $aliases_hundred = array(); + $aliases_other = array(); + while ($a = $aliases->next()) { + if ($a['forlife']) { + $aliases_forlife[] = $a; + } elseif ($a['hundred_year']) { + $aliases_hundred[] = $a; + } else { + $aliases_other[] = $a; + } + } + $page->assign('aliases_forlife', $aliases_forlife); + $page->assign('aliases_hundred', $aliases_hundred); + $page->assign('aliases_other', $aliases_other); $alias = XDB::fetchOneCell('SELECT COUNT(email) FROM email_source_account @@ -853,6 +867,7 @@ class EmailModule extends PLModule sort($broken_list); foreach ($broken_list as $email) { + $email = trim($email); $userobj = null; if ($user = mark_broken_email($email, true)) { $userobj = User::getSilentWithUID($user['uid']); @@ -893,14 +908,23 @@ class EmailModule extends PLModule WHERE flags = \'active\' AND broken_level = 1 AND DATE_ADD(last, INTERVAL 1 YEAR) < CURDATE()'); + // Sort $broken_user_list with (promo, sortname, pid) + $sortable_array = array(); + foreach ($broken_user_list as $pid => $mails) { + $profile = $broken_user_profiles[$pid]; + $sortable_array[$pid] = array($profile->promo(), $profile->sortName(), $pid); + } + asort($sortable_array); + // Output the list of users with recently broken addresses, // along with the count of valid redirections. - pl_cached_content_headers('text/x-csv', 1); + pl_cached_content_headers('text/x-csv', null, 1, 'broken.csv'); $csv = fopen('php://output', 'w'); fputcsv($csv, array('nom', 'promo', 'bounces', 'nbmails', 'url', 'corps', 'job', 'networking'), ';'); $corpsList = DirEnum::getOptions(DirEnum::CURRENTCORPS); - foreach ($broken_user_list as $pid => $mails) { + foreach (array_keys($sortable_array) as $pid) { + $mails = $broken_user_list[$pid]; $profile = $broken_user_profiles[$pid]; $current_corps = $profile->getCorpsName(); $jobs = $profile->getJobs(); @@ -925,5 +949,5 @@ class EmailModule extends PLModule } } -// vim:set et sw=4 sts=4 sws=4 foldmethod=marker enc=utf-8: +// vim:set et sw=4 sts=4 sws=4 foldmethod=marker fenc=utf-8: ?>