X-Git-Url: http://git.polytechnique.org/?a=blobdiff_plain;f=modules%2Flists%2Flists.inc.php;h=5f8c2f4918b5a8d2ade455bf6181f63f54c79bec;hb=164566891eef6e4027b2dfccda0040d37f10605b;hp=2e60c61ef7423b0bd22ad707d47de2570550e519;hpb=a16cf1c2e56cc6e4c6cda1e984d2659c4cf0450c;p=platal.git diff --git a/modules/lists/lists.inc.php b/modules/lists/lists.inc.php index 2e60c61..5f8c2f4 100644 --- a/modules/lists/lists.inc.php +++ b/modules/lists/lists.inc.php @@ -1,6 +1,6 @@ $key => $listMember + $membres = array(); - foreach($members as $mem) { - list($m, $dom) = explode('@', $mem); - $info = list_fetch_name($mem); - if (!isset($info['uid']) || is_null($info['uid'])) { - $membres[0][] = array('l' => $mem, 'p' => (!$tri_promo ? 'inconnue' : null)); + foreach($members as $member) { + $user = User::getSilent($member); + if (!$user) { + $membres[0][$member] = array('name' => null, 'email' => $member, 'category' => null, 'uid' => null, 'lost' => null, 'hasProfile' => null); } else { - $uid = $info['uid']; - $nom = $info['nom']; - $prenom = $info['prenom']; - $promo = $info['promo']; - $broken = $info['lost']; - $key = $tri_promo ? ($promo != 'non-X' ? $promo : 0) : strtoupper(@$nom{0}); - if ($tri_promo) { - $promo = null; + $hasProfile = $user->hasProfile(); + $uid = $user->id(); + $name = $user->directoryName(); + $category = $user->category(); + $key = $tri_promo ? ($category ? $category : 'AAAAA') : strtoupper($name{0}); + if (!$category) { + $category = 'extérieurs'; } - $membres[$key][$nom.$m] = Array('n' => "$prenom $nom", 'l' => $m, 'p' => $promo, 'x' => $uid, 'b' => $broken); + $membres[$key][$name . $member] = array('name' => $name, 'email' => $member, 'category' => $category, + 'uid' => $uid, 'lost' => $user->lost, 'hasProfile' => $hasProfile); } } ksort($membres); - foreach($membres as $key=>$val) ksort($membres[$key]); + foreach($membres as $membre) { + ksort($membre); + } return $membres; } @@ -73,44 +76,18 @@ function list_sort_members($members, $tri_promo = true) } // }}} -// {{{ function list_fetch_names - -function list_fetch_name($member) -{ - global $globals; - list($m, $dom) = explode('@', $member); - if ($dom == $globals->mail->domain || $dom == $globals->mail->domain2) { - $res = XDB::query('SELECT u.user_id AS uid, prenom AS prenom, IF(nom_usage="", nom, nom_usage) AS nom, - promo AS promo, - (e.uid IS NULL AND FIND_IN_SET("googleapps", u.mail_storage) = 0) AS lost - FROM auth_user_md5 AS u - INNER JOIN aliases AS a ON u.user_id = a.id - LEFT JOIN emails AS e ON (e.flags = "active" AND e.uid = u.user_id) - WHERE a.alias = {?} - GROUP BY u.user_id', $m); - } else { - $res = XDB::query('SELECT m2.uid AS uid, - IF(m2.origine="X", u.prenom, m1.prenom) AS prenom, - IF(m2.origine="X", u.nom, m1.nom) AS nom, - IF(m2.origine="X", u.promo, "non-X") AS promo, - 0 AS lost - FROM groupex.membres AS m1 - LEFT JOIN groupex.membres AS m2 ON(m1.email=m2.email AND m2.asso_id={?}) - LEFT JOIN auth_user_md5 AS u ON(m2.origine = "X" AND m2.uid = u.user_id) - WHERE m1.email={?}', $globals->asso('id'), $member); - } - if ($res->numRows() == 0) { - return array('email' => $member); - } else { - return array_merge(array('email' => $member), $res->fetchOneAssoc()); - } -} +// {{{ function list_fetch_basic_info -function list_fetch_names($members) +function list_fetch_basic_info($members) { $res = array(); foreach ($members as $member) { - $res[] = list_fetch_name($member); + $user = User::getSilent($member); + if (!$user) { + $res[] = $member . ',,'; + } else { + $res[] = $user->forlifeEmail() . ',' . $user->directoryName() . ',' . $user->promo(); + } } return $res; }