remove smarty {version} function, we have {#globals.version#} for it !!!
[platal.git] / modules / marketing.php
index b26040e..1046574 100644 (file)
@@ -37,15 +37,13 @@ class MarketingModule extends PLModule
 
     function handler_marketing(&$page)
     {
-        global $globals;
-
         $page->changeTpl('marketing/index.tpl');
 
         $page->assign('xorg_title','Polytechnique.org - Marketing');
 
         // Quelques statistiques
 
-        $res   = $globals->xdb->query(
+        $res   = XDB::query(
                   "SELECT COUNT(*) AS vivants,
                           COUNT(NULLIF(perms='admin' OR perms='user', 0)) AS inscrits,
                           100*COUNT(NULLIF(perms='admin' OR perms='user', 0))/COUNT(*) AS ins_rate,
@@ -62,34 +60,33 @@ class MarketingModule extends PLModule
         $stats = $res->fetchOneAssoc();
         $page->assign('stats', $stats);
 
-        $res   = $globals->xdb->query("SELECT count(*) FROM auth_user_md5 WHERE date_ins > ".
+        $res   = XDB::query("SELECT count(*) FROM auth_user_md5 WHERE date_ins > ".
                                       date('Ymd000000', strtotime('1 week ago')));
         $page->assign('nbInsSem', $res->fetchOneCell());
 
-        $res = $globals->xdb->query("SELECT count(*) FROM register_pending WHERE hash != 'INSCRIT'");
+        $res = XDB::query("SELECT count(*) FROM register_pending WHERE hash != 'INSCRIT'");
         $page->assign('nbInsEnCours', $res->fetchOneCell());
 
-        $res = $globals->xdb->query("SELECT count(*) FROM register_marketing");
+        $res = XDB::query("SELECT count(*) FROM register_marketing");
         $page->assign('nbInsMarket', $res->fetchOneCell());
 
-        $res = $globals->xdb->query("SELECT count(*) FROM register_mstats
+        $res = XDB::query("SELECT count(*) FROM register_mstats
                                       WHERE TO_DAYS(NOW()) - TO_DAYS(success) <= 7");
         $page->assign('nbInsMarkOK', $res->fetchOneCell());
-
-        return PL_OK;
     }
 
-    function handler_private(&$page, $uid = null)
+    function handler_private(&$page, $uid = null,
+                             $action = null, $value = null)
     {
-        global $globals;
-
         $page->changeTpl('marketing/private.tpl');
 
         if (is_null($uid)) {
             return PL_NOT_FOUND;
         }
 
-        $res = $globals->xdb->query("SELECT nom, prenom, promo, matricule
+        $page->assign('path', 'marketing/private/'.$uid);
+
+        $res = XDB::query("SELECT nom, prenom, promo, matricule
                                        FROM auth_user_md5
                                       WHERE user_id={?} AND perms='pending'", $uid);
 
@@ -105,47 +102,47 @@ class MarketingModule extends PLModule
             $page->kill('uid invalide');
         }
 
-        if (Env::has('del')) {
-            $globals->xdb->execute('DELETE FROM register_marketing WHERE uid={?} AND email={?}',
-                                   $uid, Env::get('del'));
+        if ($action == 'del') {
+            XDB::execute('DELETE FROM register_marketing WHERE uid={?} AND email={?}',
+                                   $uid, $value);
         }
 
-        if (Env::has('rel') && !Env::has('valider')) {
+        if ($action == 'rel') {
             require_once('marketing.inc.php');
-            list($to, $title, $text) = mark_text_mail($uid, Env::get('rel'));
-            $from = mark_from_mail($uid, Env::get('rel'));
+            list($to, $title, $text) = mark_text_mail($uid, $value);
+            $from = mark_from_mail($uid, $value);
             $page->assign('rel_from_user', $from);
             $page->assign('rel_from_staff',
                           "\"Equipe Polytechnique.org\" <register@polytechnique.org>");
             $page->assign('rel_to', $to);
             $page->assign('rel_title', $title);
             $page->assign('rel_text', $text);
+            $page->assign('rel_email', $value);
         }
 
-        if (Env::get('valider') == 'Envoyer') {
+        if ($action == 'relforce') {
             require_once('marketing.inc.php');
-            mark_send_mail($uid, Env::get('rel'), Env::get('from'),
-                           Env::get('to'), Env::get('title'),
-                           Env::get('message'));
+            mark_send_mail($uid, $value, Post::get('from'), Post::get('to'),
+                           Post::get('title'), Post::get('message'));
             $page->trig("Mail envoyé");
         }
 
-        if (Env::has('relance')) {
-            require_once('marketing.inc.php');
+        if ($action == 'insrel') {
+            require_once 'marketing.inc.php';
             if (relance($uid)) {
                 $page->trig('relance faite');
             }
         }
 
-        if (Env::get('action') == 'ajouter') {
-            $globals->xdb->execute(
+        if ($action == 'add' && Post::has('email') && Post::has('type')) {
+            XDB::execute(
                 "INSERT INTO register_marketing
                          SET uid = {?}, sender = {?}, email = {?},
                              date = NOW(), type = {?}",
-                $uid, Session::get('uid'), Env::get('email'), Env::get('type')); 
+                $uid, Session::get('uid'), Post::get('email'), Post::get('type')); 
         }
 
-        $res = $globals->xdb->iterator(
+        $res = XDB::iterator(
                 "SELECT  r.*, a.alias
                    FROM  register_marketing AS r
              INNER JOIN  aliases            AS a ON (r.sender=a.id AND a.type = 'a_vie')
@@ -153,20 +150,16 @@ class MarketingModule extends PLModule
                ORDER BY  date", $uid);
         $page->assign('addr', $res);
 
-        $res = $globals->xdb->query("SELECT date, relance FROM register_pending
+        $res = XDB::query("SELECT date, relance FROM register_pending
                                       WHERE uid = {?}", $uid);
         if (list($pending, $relance) = $res->fetchOneCell()) {
             $page->assign('pending', $pending);
             $page->assign('relance', $relance);
         }
-
-        return PL_OK;
     }
 
     function handler_promo(&$page, $promo = null)
     {
-        global $globals;
-
         $page->changeTpl('marketing/promo.tpl');
 
         if (is_null($promo)) {
@@ -182,22 +175,18 @@ class MarketingModule extends PLModule
                  WHERE  u.promo = {?} AND u.deces = 0 AND u.perms='pending'
               GROUP BY  u.user_id
               ORDER BY  nom, prenom";
-        $page->assign('nonins', $globals->xdb->iterator($sql, $promo));
-
-        return PL_OK;
+        $page->assign('nonins', XDB::iterator($sql, $promo));
     }
 
     function handler_public(&$page, $uid = null)
     {
-        global $globals;
-
         $page->changeTpl('marketing/public.tpl');
 
         if (is_null($uid)) {
             return PL_NOT_FOUND;
         }
 
-        $res = $globals->xdb->query("SELECT nom, prenom, promo FROM auth_user_md5
+        $res = XDB::query("SELECT nom, prenom, promo FROM auth_user_md5
                                       WHERE user_id={?} AND perms='pending'", $uid);
 
         if (list($nom, $prenom, $promo) = $res->fetchOneRow()) {
@@ -205,11 +194,11 @@ class MarketingModule extends PLModule
             $page->assign('nom', $nom);
             $page->assign('promo', $promo);
 
-            if (Env::has('valide')) {
+            if (Post::has('valide')) {
                 require_once('xorg.misc.inc.php');
 
-                $email = trim(Env::get('mail'));
-                $res   = $globals->xdb->query('SELECT COUNT(*) FROM register_marketing
+                $email = trim(Post::get('mail'));
+                $res   = XDB::query('SELECT COUNT(*) FROM register_marketing
                                                 WHERE uid={?} AND email={?}', $uid, $email);
 
                 if (!isvalid_email_redirection($email)) {
@@ -218,46 +207,38 @@ class MarketingModule extends PLModule
                     $page->assign('already', true);
                 } else {
                     $page->assign('ok', true);
-                    $globals->xdb->execute(
+                    XDB::execute(
                             "INSERT INTO  register_marketing (uid,sender,email,date,last,nb,type,hash)
                                   VALUES  ({?}, {?}, {?}, NOW(), 0, 0, {?}, '')",
-                            $uid, Session::getInt('uid'), $email, Env::get('origine'));
+                            $uid, Session::getInt('uid'), $email, Post::get('origine'));
                     require_once('validations.inc.php');
                     $req = new MarkReq(Session::getInt('uid'), $uid, $email,
-                                       Env::get('origine')=='user');
+                                       Post::get('origine')=='user');
                     $req->submit();
                 }
             }
         }
-
-        return PL_OK;
     }
 
-    function handler_week(&$page)
+    function handler_week(&$page, $sorting = 'per_promo')
     {
-        global $globals;
-
         $page->changeTpl('marketing/this_week.tpl');
 
-        $sort = Get::get('sort') == 'promo' ? 'promo' : 'date_ins';
+        $sort = $sorting == 'per_promo' ? 'promo' : 'date_ins';
 
         $sql = "SELECT  a.alias AS forlife, u.date_ins, u.promo, u.nom, u.prenom
                   FROM  auth_user_md5  AS u
             INNER JOIN  aliases        AS a ON (u.user_id = a.id AND a.type='a_vie')
                  WHERE  u.date_ins > ".date("Ymd000000", strtotime ('1 week ago'))."
               ORDER BY  u.$sort DESC";
-        $page->assign('ins', $globals->xdb->iterator($sql));
-
-        return PL_OK;
+        $page->assign('ins', XDB::iterator($sql));
     }
 
-    function handler_volontaire(&$page)
+    function handler_volontaire(&$page, $promo = null)
     {
-        global $globals;
-
         $page->changeTpl('marketing/volontaire.tpl');
 
-        $res = $globals->xdb->query(
+        $res = XDB::query(
                 "SELECT
                DISTINCT  a.promo
                    FROM  register_marketing AS m
@@ -266,27 +247,25 @@ class MarketingModule extends PLModule
         $page->assign('promos', $res->fetchColumn());
 
 
-        if (Env::has('promo')) {
+        if (!is_null($promo)) {
             $sql = "SELECT  a.nom, a.prenom, a.user_id,
                             m.email, sa.alias AS forlife
                       FROM  register_marketing AS m
                 INNER JOIN  auth_user_md5      AS a  ON a.user_id = m.uid AND a.promo = {?}
                 INNER JOIN  aliases            AS sa ON (m.sender = sa.id AND sa.type='a_vie')
                   ORDER BY  a.nom";
-            $page->assign('addr', $globals->xdb->iterator($sql, Env::get('promo')));
+            $page->assign('addr', XDB::iterator($sql, $promo));
         }
-
-        return PL_OK;
     }
 
     function handler_relance(&$page)
     {
-        global $globals;
-
         $page->changeTpl('marketing/relance.tpl');
 
         if (Post::has('relancer')) {
-            $res   = $globals->xdb->query("SELECT COUNT(*) FROM auth_user_md5 WHERE deces=0");
+            require_once 'marketing.inc.php';
+
+            $res   = XDB::query("SELECT COUNT(*) FROM auth_user_md5 WHERE deces=0");
             $nbdix = $res->fetchOneCell();
 
             $sent  = Array();
@@ -303,9 +282,7 @@ class MarketingModule extends PLModule
             INNER JOIN  auth_user_md5    AS u ON r. uid = u.user_id
                  WHERE  hash!='INSCRIT'
               ORDER BY  date DESC";
-        $page->assign('relance', $globals->xdb->iterator($sql));
-
-        return PL_OK;
+        $page->assign('relance', XDB::iterator($sql));
     }
 }