X-Git-Url: http://git.polytechnique.org/?a=blobdiff_plain;f=modules%2Fbanana.php;h=7a88b9ca5677b29bd486522b5162e499c940b0dd;hb=db9c38388c6d941c9aff798921a69317ff88ce8f;hp=2a32c71fa665e2e34957c5c3757de9343e294b61;hpb=f585e5a4347b0c0fd9502a47d09d54a78d462727;p=platal.git diff --git a/modules/banana.php b/modules/banana.php index 2a32c71..7a88b9c 100644 --- a/modules/banana.php +++ b/modules/banana.php @@ -24,28 +24,67 @@ class BananaModule extends PLModule function handlers() { return array( - 'banana' => $this->make_hook('banana', AUTH_COOKIE), - 'banana/profile' => $this->make_hook('profile', AUTH_MDP), - 'banana/xface' => $this->make_hook('xface', AUTH_PUBLIC), + 'banana' => $this->make_hook('banana', AUTH_COOKIE), + 'banana/profile' => $this->make_hook('profile', AUTH_MDP), + 'banana/subscription' => $this->make_hook('subscription', AUTH_COOKIE), + 'banana/xface' => $this->make_hook('xface', AUTH_COOKIE), ); } - function handler_banana(&$page) + function on_subscribe($forlife, $uid, $promo, $password) { - $page->changeTpl('banana/index.tpl'); - $page->addCssLink('css/banana/style.css'); - $page->assign('xorg_title','Polytechnique.org - Forums & PA'); + $cible = array('xorg.general', 'xorg.pa.divers', 'xorg.pa.logements'); + $p_for = "xorg.promo.x$promo"; - require_once 'banana.inc.php'; + // récupération de l'id du forum promo + $res = XDB::query("SELECT fid FROM forums.list WHERE nom={?}", $p_for); + if ($res->numRows()) { + $cible[] = $p_for; + } else { // pas de forum promo, il faut le créer + $res = XDB::query("SELECT SUM(perms IN ('admin','user') AND deces=0),COUNT(*) + FROM auth_user_md5 WHERE promo={?}", $promo); + list($effau, $effid) = $res->fetchOneRow(); + if (5*$effau>$effid) { // + de 20% d'inscrits + $mymail = new PlMailer('mails/forums.promo.tpl'); + $mymail->assign('promo', $promo); + $mymail->send(); + } + } - $res = PlatalBanana::run(); - $page->assign_by_ref('banana', $banana); - $page->assign('banana_res', $res); + while (list ($key, $val) = each ($cible)) { + XDB::execute("INSERT INTO forums.abos (fid,uid) + SELECT fid,{?} FROM forums.list WHERE nom={?}", $uid, $val); + } + } - return PL_OK; + function handler_banana(&$page, $group = null, $action = null, $artid = null) + { + $get = Array(); + if (!is_null($group)) { + $get['group'] = $group; + } + if (Post::has('updateall')) { + $get['updateall'] = Post::v('updateall'); + } + if (!is_null($action)) { + if ($action == 'new') { + $get['action'] = 'new'; + } elseif ($action == 'reply' && !is_null($artid)) { + $get['action'] = 'new'; + $get['artid'] = $artid; + } elseif ($action == 'cancel' && !is_null($artid)) { + $get['action'] = $action; + $get['artid'] = $artid; + } elseif ($action == 'from' && !is_null($artid)) { + $get['first'] = $artid; + } elseif ($action == 'read' && !is_null($artid)) { + $get['artid'] = $artid; + } + } + return BananaModule::run_banana($page, $get); } - function handler_profile(&$page) + function handler_profile(&$page, $action = null) { global $globals; @@ -53,17 +92,17 @@ class BananaModule extends PLModule if (!(Post::has('action') && Post::has('banananame') && Post::has('bananasig') && Post::has('bananadisplay') && Post::has('bananamail') - && Post::has('bananaupdate') && Post::get('action')=="OK" )) + && Post::has('bananaupdate') && Post::v('action')=="OK" )) { - $req = $globals->xdb->query(" + $req = XDB::query(" SELECT nom,mail,sig,if(FIND_IN_SET('threads',flags),'1','0'), IF(FIND_IN_SET('automaj',flags),'1','0') FROM forums.profils - WHERE uid = {?}", Session::getInt('uid')); + WHERE uid = {?}", S::v('uid')); if (!(list($nom,$mail,$sig,$disp,$maj) = $req->fetchOneRow())) { - $nom = Session::get('prenom').' '.Session::get('nom'); - $mail = Session::get('forlife').'@'.$globals->mail->domain; - $sig = $nom.' ('.Session::getInt('promo').')'; + $nom = S::v('prenom').' '.S::v('nom'); + $mail = S::v('forlife').'@'.$globals->mail->domain; + $sig = $nom.' ('.S::v('promo').')'; $disp = 0; $maj = 0; } @@ -73,23 +112,41 @@ class BananaModule extends PLModule $page->assign('disp', $disp); $page->assign('maj' , $maj); } else { - $globals->xdb->execute( + XDB::execute( 'REPLACE INTO forums.profils (uid,sig,mail,nom,flags) VALUES ({?},{?},{?},{?},{?})', - Session::getInt('uid'), Post::get('bananasig'), Post::get('bananamail'), Post::get('banananame'), - (Post::getBool('bananadisplay') ? 'threads,' : '') . (Post::getBool('bananaupdate') ? 'automaj' : '') + S::v('uid'), Post::v('bananasig'), + Post::v('bananamail'), Post::v('banananame'), + (Post::b('bananadisplay') ? 'threads,' : '') . + (Post::b('bananaupdate') ? 'automaj' : '') ); } + } + + function handler_subscription(&$page) + { + return $this->run_banana($page, Array('subscribe' => 1)); + } - return PL_OK; + function handler_xface(&$page, $face = null) + { + header('Content-Type: image/gif'); + passthru('echo ' . escapeshellarg(base64_decode(strtr($face, '.:', '+/'))) + . '| uncompface -X ' + . '| convert -transparent white xbm:- gif:-'); } - function handler_xface(&$page) + function run_banana(&$page, $params = null) { - header('Content-Type: image/jpeg'); - passthru('echo '.escapeshellarg(base64_decode($_REQUEST['face'])). - '|uncompface -X |convert xbm:- jpg:-'); - exit; + $page->changeTpl('banana/index.tpl'); + $page->addCssLink('banana.css'); + $page->assign('xorg_title','Polytechnique.org - Forums & PA'); + + require_once dirname(__FILE__).'/banana/banana.inc.php'; + + $res = PlatalBanana::run($params); + $page->assign_by_ref('banana', $banana); + $page->assign('banana_res', $res); } }