'lists/create' => $this->make_hook('create', AUTH_MDP),
'lists/members' => $this->make_hook('members', AUTH_COOKIE),
+ 'lists/csv' => $this->make_hook('csv', AUTH_COOKIE),
'lists/annu' => $this->make_hook('annu', AUTH_COOKIE),
'lists/archives' => $this->make_hook('archives', AUTH_COOKIE),
'lists/archives/rss' => $this->make_hook('rss', AUTH_PUBLIC, 'user', NO_HTTPS),
}
}
+ function handler_csv(PlPage &$page, $liste = null)
+ {
+ if (is_null($liste)) {
+ return PL_NOT_FOUND;
+ }
+ $this->prepare_client($page);
+ $members = $this->client->get_members($liste);
+ $list = list_fetch_names(list_extract_members($members[1]));
+ header('Content-Type: text/x-csv; charset=utf-8;');
+ header('Pragma: ');
+ header('Cache-Control: ');
+
+ echo "email,nom,prenom,promo\n";
+ foreach ($list as $member) {
+ echo @$member['email'] . ',' . @$member['nom'] . ',' . @$member['prenom'] . ',' . @$member['promo'] . "\n";
+ }
+ exit;
+ }
+
function handler_annu(&$page, $liste = null, $action = null, $subaction = null)
{
if (is_null($liste)) {
$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,
- (e.uid IS NULL AND FIND_IN_SET("googleapps", u.mail_storage) = 0)
- 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);
- if(list($prenom, $nom, $promo, $broken) = $res->fetchOneRow()) {
- $key = $tri_promo ? $promo : strtoupper($nom{0});
- $membres[$key][$nom.$m] = Array('n' => "$prenom $nom", 'l' => $m, 'p' => (!$tri_promo ? $promo : null), 'b' => $broken);
- } else {
- $membres[0][] = Array('l' => $mem, 'b' => $broken);
- }
+ list($m, $dom) = explode('@', $mem);
+ $info = list_fetch_name($mem);
+ if (is_null($info['uid'])) {
+ $membres[0][] = array('l' => $mem, 'p' => (!$tri_promo ? 'inconnue' : null));
} 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,
- 0
- 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));
+ $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;
}
+ $membres[$key][$nom.$m] = Array('n' => "$prenom $nom", 'l' => $m, 'p' => $promo, 'x' => $uid, 'b' => $broken);
}
}
}
// }}}
+// {{{ list_extract_member
+
+function _list_extract_member($member)
+{
+ return $member[1];
+}
+
+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)
+{
+ return list_sort_owners(list_extract_members($members), $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;
}
// }}}