X-Git-Url: http://git.polytechnique.org/?a=blobdiff_plain;f=modules%2Fxnet.php;h=f46ec862614aa16fc3b1053223e2422af30acbe5;hb=9b5ef111c02be6325580afe696baa4492b3934a3;hp=e3ec083e686a06e2f65b69bd47ef3d4b360dbac2;hpb=10c0ebff150acd256f9e72e58ab8d56bb07e0a7d;p=platal.git diff --git a/modules/xnet.php b/modules/xnet.php index e3ec083..f46ec86 100644 --- a/modules/xnet.php +++ b/modules/xnet.php @@ -25,74 +25,77 @@ class XnetModule extends PLModule { return array( 'index' => $this->make_hook('index', AUTH_PUBLIC), + 'login' => $this->make_hook('login', AUTH_MDP), 'exit' => $this->make_hook('exit', AUTH_PUBLIC), - 'about' => $this->make_hook('about', AUTH_PUBLIC), - 'article12' => $this->make_hook('article12', AUTH_PUBLIC), - 'article16' => $this->make_hook('article16', AUTH_PUBLIC), - 'creategpx' => $this->make_hook('creategpx', AUTH_PUBLIC), - 'services' => $this->make_hook('services', AUTH_PUBLIC), - 'manuel' => $this->make_hook('manuel', AUTH_PUBLIC), - 'admin' => $this->make_hook('admin', AUTH_MDP, 'admin'), 'groups' => $this->make_hook('groups', AUTH_PUBLIC), 'groupes.php' => $this->make_hook('groups2', AUTH_PUBLIC), 'plan' => $this->make_hook('plan', AUTH_PUBLIC), + 'send_bug' => $this->make_hook('bug', AUTH_MDP), + 'photo' => $this->make_hook('photo', AUTH_MDP), ); } - function handler_index(&$page) - { - $page->changeTpl('xnet/index.tpl'); - } - - function handler_exit(&$page) + function handler_photo(&$page, $x = null) { - XnetSession::destroy(); - $page->changeTpl('xnet/deconnexion.tpl'); - $page->useMenu(); - } + if (is_null($x)) { + return PL_NOT_FOUND; + } - function handler_about(&$page) - { - $page->changeTpl('xnet/apropos.tpl'); - $page->useMenu(); - } + $res = XDB::query("SELECT attachmime, attach + FROM aliases + INNER JOIN photo ON(id = uid) + WHERE alias = {?}", $x); - function handler_article12(&$page) - { - $page->changeTpl('xnet/article12.tpl'); - $page->useMenu(); + if ((list($type, $data) = $res->fetchOneRow())) { + Header("Content-type: image/$type"); + echo $data; + } else { + Header('Content-type: image/png'); + echo file_get_contents(dirname(__FILE__).'/../htdocs/images/none.png'); + } + exit; } - function handler_article16(&$page) + function handler_bug(&$page) { - $page->changeTpl('xnet/article16.tpl'); - $page->useMenu(); + $page->changeTpl('bug.tpl',SIMPLE); + $page->addJsLink('close_on_esc.js'); + if (Env::has('send')) { + $page->assign('bug_sent',1); + $mymail = new PlMailer(); + $mymail->setFrom('"'.S::v('prenom').' '.S::v('nom').'" <'.S::v('bestalias').'@polytechnique.org>'); + $mymail->addTo('support+platal@polytechnique.org'); + $mymail->setSubject('Plat/al '.Env::v('task_type').' : '.Env::v('item_summary')); + $mymail->setTxtBody(Env::v('detailed_desc')); + $mymail->send(); + } } - - function handler_creategpx(&$page) + + function handler_index(&$page) { - $page->changeTpl('xnet/creation-groupex.tpl'); - $page->useMenu(); + $page->nomenu = true; + $page->changeTpl('xnet/index.tpl'); } - function handler_services(&$page) + function handler_login(&$page) { - $page->changeTpl('xnet/services.tpl'); - $page->useMenu(); + $allkeys = func_get_args(); + unset($allkeys[0]); + $url = join('/',$allkeys); + pl_redirect($url); } - function handler_manuel(&$page, $type = null) + function handler_exit(&$page) { - $page->changeTpl('xnet/manuel.tpl'); - $page->assign('type', $type); + XnetSession::destroy(); + $page->changeTpl('xnet/deconnexion.tpl'); } function handler_admin(&$page) { new_admin_page('xnet/admin.tpl'); - $page->useMenu(); if (Get::has('del')) { $res = XDB::query('SELECT id, nom, mail_domain @@ -111,11 +114,10 @@ class XnetModule extends PLModule WHERE alias LIKE {?}', '%@'.$domain); $page->trig('suppression des alias mails'); - require_once('lists.inc.php'); - $client =& lists_xmlrpc(S::v('uid'), S::v('password'), $domain); - if ($listes = $client->get_lists()) { + $mmlist = new MMList(S::v('uid'), S::v('password'), $domain); + if ($listes = $mmlist->get_lists()) { foreach ($listes as $l) { - $client->delete_list($l['list'], true); + $mmlist->delete_list($l['list'], true); } $page->trig('mail lists surpprimées'); } @@ -199,23 +201,23 @@ class XnetModule extends PLModule $page->assign('dom', $dom); $res = XDB::query("SELECT id,nom FROM groupex.dom - WHERE FIND_IN_SET({?}, cat) ORDER BY nom", $cat); + WHERE FIND_IN_SET({?}, cat) + ORDER BY nom", $cat); $doms = $res->fetchAllAssoc(); $page->assign('doms', $doms); if (empty($doms)) { - $res = XDB::iterator("SELECT diminutif, nom FROM groupex.asso - WHERE FIND_IN_SET({?}, cat) ORDER BY nom", $cat); + $res = XDB::query("SELECT diminutif, nom, site FROM groupex.asso + WHERE FIND_IN_SET({?}, cat) + ORDER BY nom", $cat); + $page->assign('gps', $res->fetchAllAssoc()); } elseif (!is_null($dom)) { - $res = XDB::iterator("SELECT diminutif, nom FROM groupex.asso - WHERE FIND_IN_SET({?}, cat) AND dom={?} - ORDER BY nom", $cat, $dom); - } else { - $res = null; + $res = XDB::query("SELECT diminutif, nom, site FROM groupex.asso + WHERE FIND_IN_SET({?}, cat) AND dom={?} + ORDER BY nom", $cat, $dom); + $page->assign('gps', $res->fetchAllAssoc()); } - $page->assign('gps', $res); - $page->useMenu(); $page->setType($cat); } }