+function list_sort_members($members, $tri_promo = true)
+{
+ $m = list_extract_members($members);
+ return list_sort_owners($m, $tri_promo);
+}
+
+// }}}
+// {{{ 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_names($members)
+{
+ $res = array();
+ foreach ($members as $member) {
+ $res[] = list_fetch_name($member);
+ }
+ return $res;