<?php
/***************************************************************************
- * Copyright (C) 2003-2007 Polytechnique.org *
+ * Copyright (C) 2003-2014 Polytechnique.org *
* http://opensource.polytechnique.org/ *
* *
* This program is free software; you can redistribute it and/or modify *
// {{{ function list_sort_owners
-function list_sort_owners(&$members, $tri_promo = true) {
+function list_sort_owners($emails, $tri_promo = true)
+{
global $globals;
- $membres = Array();
-
- foreach($members as $mem) {
- list($m, $dom) = explode('@',$mem);
- if ($dom == $globals->mail->domain || $dom == $globals->mail->domain2) {
- $res = XDB::query('SELECT prenom,IF(nom_usage="", nom, nom_usage), promo
- FROM auth_user_md5 AS u
- INNER JOIN aliases AS a ON u.user_id = a.id
- WHERE a.alias = {?}', $m);
- if(list($prenom, $nom, $promo) = $res->fetchOneRow()) {
- $key = $tri_promo ? $promo : strtoupper($nom{0});
- $membres[$key][$nom.$m] = Array('n' => "$prenom $nom", 'l' => $m, 'p' => (!$tri_promo ? $promo : null));
- } else {
- $membres[0][] = Array('l' => $mem);
- }
+ // $membres' structure is the following: $sortKey => $key => $listMember
+ $membres = array();
+ $seen = array();
+
+ $members = array();
+
+ $uf = new UserFilter(new UFC_Email($emails));
+ $it = $uf->iterUsers();
+ while ($u = $it->next()) {
+ $members[$u->uid] = array(
+ 'user' => $u,
+ 'profile' => null,
+ 'email' => $u->forlifeEmail());
+ $seen[] = $u->forlifeEmail();
+ }
+
+ $pf = new ProfileFilter(new UFC_Email($emails));
+ $it = $pf->iterProfiles();
+ if ($it) {
+ while ($p = $it->next()) {
+ $members[$p->owner_id]['user']->setPrefetchedProfile($p);
+ $members[$p->owner_id]['profile'] = $p;
+ }
+ }
+
+ foreach ($emails as $email) {
+ if (!in_array($email, $seen)) {
+ $seen[] = $email;
+ $members[$email] = array('user' => null, 'profile' => null,
+ 'email' => $email);
+ }
+ }
+
+ // $members is now an array of uid => {'user': User or null, 'email': $email}
+
+ // $sorted_members is an array of $sortKey1 => $sortKey2 => {User, email}
+ $sorted_members = array();
+
+ foreach($members as $member) {
+ if (is_null($member['user'])) {
+ $category = 'AAAAA';
+ $name = $member['email'];
} else {
- $res = XDB::query('SELECT m2.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
- 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'), $mem);
- if (list($uid, $prenom, $nom, $promo) = $res->fetchOneRow()) {
- $key = $tri_promo ? ($promo != 'non-X' ? $promo : 0) : strtoupper($nom{0});
- if ($tri_promo) {
- $promo = null;
- }
- $membres[$key][$nom.$m] = Array('n' => "$prenom $nom", 'l' => $mem, 'x' => $uid, 'p' => $promo);
- } else {
- $membres[0][] = Array('l' => $mem, 'p' => (!$tri_promo ? 'non-X' : null));
- }
+ $category = $member['user']->category();
+ $name = $member['user']->directoryName();
+ }
+ if (empty($category)) {
+ $category = "AAAAA";
+ }
+
+ $main_sort_key = $tri_promo ? $category : strtoupper($name{0});
+ $alt_sort_key = $name;
+
+ if (!array_key_exists($main_sort_key, $sorted_members)) {
+ $sorted_members[$main_sort_key] = array();
}
+
+ $sorted_members[$main_sort_key][$alt_sort_key] = $member;
+ }
+
+ uksort($sorted_members, 'strcasecmp');
+ foreach($sorted_members as &$subsorted_members) {
+ uksort($subsorted_members, 'strcasecmp');
}
+ return $sorted_members;
+}
+
+// }}}
+// {{{ list_extract_member
+
+function _list_extract_member($member)
+{
+ return $member[1];
+}
- ksort($membres);
- foreach($membres as $key=>$val) ksort($membres[$key]);
- return $membres;
+function list_extract_members($members)
+{
+ return array_map('_list_extract_member', $members);
}
// }}}
// {{{ function list_sort_members
-function list_sort_members(&$members, $tri_promo = true) {
- $member_list = array_map(create_function('$arr', 'return $arr[1];'), $members);
- return list_sort_owners($member_list, $tri_promo);
+function list_sort_members($members, $tri_promo = true)
+{
+ $m = list_extract_members($members);
+ return list_sort_owners($m, $tri_promo);
+}
+
+// }}}
+// {{{ function list_fetch_basic_info
+
+function list_fetch_basic_info($members)
+{
+ $res = array();
+ foreach ($members as $member) {
+ $user = User::getSilent($member);
+ if (!$user) {
+ $res[] = $member . ';;';
+ } else {
+ $res[] = $user->lastName() . ';' . $user->firstName() . ';' . $user->promo();
+ }
+ }
+ return $res;
}
// }}}
}
function list_header_decode($value) {
+ if (!$value) {
+ return "[pas de sujet]";
+ }
$val = preg_replace('/(=\?[^?]*\?[BQbq]\?[^?]*\?=) (=\?[^?]*\?[BQbq]\?[^?]*\?=)/', '\1\2', $value);
return preg_replace('/=\?([^?]*)\?([BQbq])\?([^?]*)\?=/e', '_list_header_decode("\1", "\2", "\3")', $val);
}
// }}}
-// 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:
?>