+ function handler_subscribe(&$page, $u = null)
+ {
+ global $globals;
+
+ $page->changeTpl('xnet/groupe/inscrire.tpl');
+
+ $page->useMenu();
+ $page->setType($globals->asso('cat'));
+ $page->assign('asso', $globals->asso());
+ $page->assign('admin', may_update());
+
+ if (!$globals->asso('inscriptible'))
+ $page->kill("Il n'est pas possible de s'inscire en ligne à ce "
+ ."groupe. Essaie de joindre le contact indiqué "
+ ."sur la page de présentation.");
+
+ if (!is_null($u) && may_update()) {
+ $page->assign('u', $u);
+ $res = XDB::query("SELECT nom, prenom, promo, user_id
+ FROM auth_user_md5 AS u
+ INNER JOIN aliases AS al ON (al.id = u.user_id
+ AND al.type != 'liste')
+ WHERE al.alias = {?}", $u);
+
+ if (list($nom, $prenom, $promo, $uid) = $res->fetchOneRow()) {
+ $res = XDB::query("SELECT COUNT(*)
+ FROM groupex.membres AS m
+ INNER JOIN aliases AS a ON (m.uid = a.id
+ AND a.type != 'homonyme')
+ WHERE a.alias = {?} AND m.asso_id = {?}",
+ $u, $globals->asso('id'));
+ $n = $res->fetchOneCell();
+ if ($n) {
+ $page->trig_run("$prenom $nom est déjà membre du groupe !");
+ }
+ elseif (Env::has('accept'))
+ {
+ XDB::execute("INSERT INTO groupex.membres
+ VALUES ({?}, {?}, 'membre', 'X', NULL, NULL, NULL, NULL)",
+ $globals->asso('id'), $uid);
+ require_once 'diogenes/diogenes.hermes.inc.php';
+ $mailer = new HermesMailer();
+ $mailer->addTo("$u@polytechnique.org");
+ $mailer->setFrom('"'.S::v('prenom').' '.S::v('nom')
+ .'" <'.S::v('forlife').'@polytechnique.org>');
+ $mailer->setSubject('['.$globals->asso('nom').'] Demande d\'inscription');
+ $message = "Cher Camarade,\n"
+ . "\n"
+ . " Suite à ta demande d'adhésion à ".$globals->asso('nom').",\n"
+ . "j'ai le plaisir de t'annoncer que ton inscription a été validée !\n"
+ . "\n"
+ . "Bien cordialement,\n"
+ . "{$_SESSION["prenom"]} {$_SESSION["nom"]}.";
+ $mailer->setTxtBody($message);
+ $mailer->send();
+ $page->kill("$prenom $nom a bien été inscrit");
+ }
+ elseif (Env::has('refuse'))
+ {
+ require_once 'diogenes/diogenes.hermes.inc.php';
+ $mailer = new HermesMailer();
+ $mailer->addTo("$u@polytechnique.org");
+ $mailer->setFrom('"'.S::v('prenom').' '.S::v('nom')
+ .'" <'.S::v('forlife').'@polytechnique.org>');
+ $mailer->setSubject('['.$globals->asso('nom').'] Demande d\'inscription annulée');
+ $mailer->setTxtBody(Env::get('motif'));
+ $mailer->send();
+ $page->kill("la demande $prenom $nom a bien été refusée");
+ } else {
+ $page->assign('show_form', true);
+ $page->assign('prenom', $prenom);
+ $page->assign('nom', $nom);
+ $page->assign('promo', $promo);
+ $page->assign('uid', $uid);
+ }
+ return;
+ }
+ return PL_NOT_FOUND;
+ }
+
+ if (is_member()) {
+ $page->kill("tu es déjà membre !");
+ return;
+ }
+
+ if (Post::has('inscrire')) {
+ $res = XDB::query('SELECT IF(m.email IS NULL,
+ CONCAT(al.alias,"@polytechnique.org"),
+ m.email)
+ FROM groupex.membres AS m
+ INNER JOIN aliases AS al ON (al.type = "a_vie"
+ AND al.id = m.uid)
+ WHERE perms="admin" AND m.asso_id = {?}',
+ $globals->asso('id'));
+ $emails = $res->fetchColumn();
+ $to = implode(',', $emails);
+
+ $append = "\n"
+ . "-- \n"
+ . "Ce message a été envoyé suite à la demande d'inscription de\n"
+ . S::v('prenom').' '.S::v('nom').' (X'.S::v('promo').")\n"
+ . "Via le site www.polytechnique.net. Tu peux choisir de valider ou\n"
+ . "de refuser sa demande d'inscription depuis la page :\n"
+ .
+ "http://www.polytechnique.net/".$globals->asso("diminutif")."/subscribe/"
+ .S::v('forlife')."\n"
+ . "\n"
+ . "En cas de problème, contacter l'équipe de Polytechnique.org\n"
+ . "à l'adresse : support@polytechnique.org\n";
+
+ if (!$to) {
+ $to = $globals->asso("mail").", support@polytechnique.org";
+ $append = "\n-- \nLe groupe ".$globals->asso("nom")
+ ." n'a pas d'administrateur, l'équipe de"
+ ." Polytechnique.org a été prévenue et va rapidement"
+ ." résoudre ce problème.\n";
+ }
+
+ require_once 'diogenes/diogenes.hermes.inc.php';
+ $mailer = new HermesMailer();
+ $mailer->addTo($to);
+ $mailer->setFrom('"'.S::v('prenom').' '.S::v('nom')
+ .'" <'.S::v('forlife').'@polytechnique.org>');
+ $mailer->setSubject('['.$globals->asso('nom').'] Demande d\'inscription');
+ $mailer->setTxtBody(Post::get('message').$append);
+ $mailer->send();
+ }
+ }
+
+ function handler_paiement(&$page)
+ {
+ global $globals;
+
+ new_group_page('xnet/groupe/telepaiement.tpl');
+
+ $res = XDB::query(
+ "SELECT id, text
+ FROM {$globals->money->mpay_tprefix}paiements
+ WHERE asso_id = {?} AND NOT FIND_IN_SET(flags, 'old')
+ ORDER BY id DESC", $globals->asso('id'));
+ $tit = $res->fetchAllAssoc();
+ $page->assign('titres', $tit);
+
+ $order = Env::get('order', 'timestamp');
+ $orders = array('timestamp', 'nom', 'promo', 'montant');
+ if (!in_array($order, $orders)) {
+ $order = 'timestamp';
+ }
+ $inv_order = Env::get('order_inv', 0);
+ $page->assign('order', $order);
+ $page->assign('order_inv', !$inv_order);
+
+ if ($order == 'timestamp') {
+ $inv_order = !$inv_order;
+ }
+
+ if ($inv_order) {
+ $inv_order = ' DESC';
+ } else {
+ $inv_order = '';
+ }
+ if ($order == 'montant') {
+ $order = 'LENGTH(montant) '.$inv_order.', montant';
+ }
+
+ $orderby = 'ORDER BY '.$order.$inv_order;
+ if ($order != 'nom') {
+ $orderby .= ', nom'; $inv_order = '';
+ }
+ $orderby .= ', prenom'.$inv_order;
+ if ($order != 'timestamp') {
+ $orderby .= ', timestamp DESC';
+ }
+
+ if (may_update()) {
+ $trans = array();
+ foreach($tit as $foo) {
+ $pid = $foo['id'];
+ $res = XDB::query(
+ "SELECT IF(u.nom_usage<>'', u.nom_usage, u.nom) AS nom,
+ u.prenom, u.promo, a.alias, timestamp AS `date`, montant
+ FROM {$globals->money->mpay_tprefix}transactions AS t
+ INNER JOIN auth_user_md5 AS u ON ( t.uid = u.user_id )
+ INNER JOIN aliases AS a ON ( t.uid = a.id AND a.type='a_vie' )
+ WHERE ref = {?} ".$orderby, $pid);
+ $trans[$pid] = $res->fetchAllAssoc();
+ $sum = 0;
+ foreach ($trans[$pid] as $i => $t) {
+ $sum += strtr(substr($t['montant'], 0, strpos($t['montant'], 'EUR')), ',', '.');
+ }
+ $trans[$pid][] = array('nom' => 'somme totale',
+ 'montant' => strtr($sum, '.', ',').' EUR');
+ }
+ $page->assign('trans', $trans);
+ }
+ }
+