X-Git-Url: http://git.polytechnique.org/?a=blobdiff_plain;f=modules%2Fbanana.php;h=b0819c363e5d52704200ba18dee17549c5dfe917;hb=cce828e536471e7dce67d642d150e2ad1c31426b;hp=b853065cf2f9b724a123728a9d0d810085c4f78a;hpb=86136c76d3aa444fad543bc0e3b12704984d6579;p=platal.git diff --git a/modules/banana.php b/modules/banana.php index b853065..b0819c3 100644 --- a/modules/banana.php +++ b/modules/banana.php @@ -24,27 +24,35 @@ class BananaModule extends PLModule function handlers() { return array( - 'banana' => $this->make_hook('banana', AUTH_COOKIE), - 'banana/profile' => $this->make_hook('profile', AUTH_MDP), + 'banana' => $this->make_hook('banana', AUTH_COOKIE), + 'banana/profile' => $this->make_hook('profile', AUTH_MDP), + 'banana/subscription' => $this->make_hook('subscription', AUTH_COOKIE), + 'banana/updateall' => $this->make_hook('updateall', AUTH_COOKIE), ); } - function handler_banana(&$page) + function handler_banana(&$page, $group = null, $action = null, $artid = null) { - $page->changeTpl('banana/index.tpl'); - $page->addCssLink('css/banana.css'); - $page->assign('xorg_title','Polytechnique.org - Forums & PA'); - - require_once 'banana.inc.php'; - - $res = PlatalBanana::run(); - $page->assign_by_ref('banana', $banana); - $page->assign('banana_res', $res); - - return PL_OK; + $get = Array(); + if (!is_null($group)) { + $get['group'] = $group; + } + if (!is_null($action)) { + if ($action == 'new') { + $get['action'] = 'new'; + } elseif (($action == 'reply' || $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; @@ -75,13 +83,40 @@ class BananaModule extends PLModule $globals->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' : '') + Session::getInt('uid'), Post::get('bananasig'), + Post::get('bananamail'), Post::get('banananame'), + (Post::getBool('bananadisplay') ? 'threads,' : '') . + (Post::getBool('bananaupdate') ? 'automaj' : '') ); } return PL_OK; } + + function handler_updateall(&$page) + { + return BananaModule::run_banana($page, Array('banana' => 'updateall')); + } + + function handler_subscription(&$page) + { + return $this->run_banana($page, Array('subscribe' => 1)); + } + + function run_banana(&$page, $params = null) + { + $page->changeTpl('banana/index.tpl'); + $page->addCssLink('css/banana.css'); + $page->assign('xorg_title','Polytechnique.org - Forums & PA'); + + require_once('banana.inc.php'); + + $res = PlatalBanana::run($params); + $page->assign_by_ref('banana', $banana); + $page->assign('banana_res', $res); + + return PL_OK; + } } ?>