X-Git-Url: http://git.polytechnique.org/?a=blobdiff_plain;f=modules%2Fxnet.php;h=b0d01518a270d3b734ae2eb29d11fd8c42f6b835;hb=a7d35093a40837b3a17d7fbac0259995f084812c;hp=7b7c0a95bda0a67cfc43aa776647dce888eb11c1;hpb=2e94d2b81ecadfd32bea9e45a8f6cf938c877f7f;p=platal.git diff --git a/modules/xnet.php b/modules/xnet.php index 7b7c0a9..b0d0151 100644 --- a/modules/xnet.php +++ b/modules/xnet.php @@ -1,6 +1,6 @@ $this->make_hook('index', AUTH_PUBLIC), '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), + 'photo' => $this->make_hook('photo', AUTH_MDP), + 'autologin' => $this->make_hook('autologin', AUTH_MDP), ); } - function handler_index(&$page) - { - $page->changeTpl('xnet/index.tpl'); - } - - function handler_exit(&$page) - { - XnetSession::destroy(); - $page->changeTpl('xnet/deconnexion.tpl'); - $page->useMenu(); - } - - function handler_about(&$page) + function handler_photo(&$page, $x = null) { - $page->changeTpl('xnet/apropos.tpl'); - $page->useMenu(); - } - - function handler_article12(&$page) - { - $page->changeTpl('xnet/article12.tpl'); - $page->useMenu(); - } + if (is_null($x)) { + return PL_NOT_FOUND; + } - function handler_article16(&$page) - { - $page->changeTpl('xnet/article16.tpl'); - $page->useMenu(); - } + $res = XDB::query("SELECT attachmime, attach + FROM aliases + INNER JOIN photo ON(id = uid) + WHERE alias = {?}", $x); - function handler_creategpx(&$page) - { - $page->changeTpl('xnet/creation-groupex.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_services(&$page) + function handler_index(&$page) { - $page->changeTpl('xnet/services.tpl'); - $page->useMenu(); + $page->nomenu = true; + $page->changeTpl('xnet/index.tpl'); } - function handler_manuel(&$page) + function handler_exit(&$page) { - $page->changeTpl('xnet/manuel.tpl'); - $page->useMenu(); + XnetSession::killSuid(); + XnetSession::destroy(); + $page->changeTpl('xnet/deconnexion.tpl'); } function handler_admin(&$page) { - global $globals; - - new_admin_page('xnet/admin.tpl'); - $page->useMenu(); + $page->changeTpl('xnet/admin.tpl'); if (Get::has('del')) { - $res = $globals->xdb->query('SELECT id, nom, mail_domain + $res = XDB::query('SELECT id, nom, mail_domain FROM groupex.asso WHERE diminutif={?}', - Get::get('del')); + Get::v('del')); list($id, $nom, $domain) = $res->fetchOneRow(); $page->assign('nom', $nom); if ($id && Post::has('del')) { - $globals->xdb->query('DELETE FROM groupex.membres WHERE asso_id={?}', $id); - $page->trig('membres supprimés'); + S::assert_xsrf_token(); + + XDB::query('DELETE FROM groupex.membres WHERE asso_id={?}', $id); + $page->trigSuccess('membres supprimés'); if ($domain) { - $globals->xdb->query('DELETE FROM virtual_domains WHERE domain={?}', $domain); - $globals->xdb->query('DELETE FROM virtual, virtual_redirect + XDB::query('DELETE FROM virtual_domains WHERE domain={?}', $domain); + XDB::query('DELETE FROM virtual, virtual_redirect USING virtual INNER JOIN virtual_redirect USING (vid) WHERE alias LIKE {?}', '%@'.$domain); - $page->trig('suppression des alias mails'); + $page->trigSuccess('suppression des alias mails'); - require_once('lists.inc.php'); - $client =& lists_xmlrpc(Session::getInt('uid'), Session::get('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'); + $page->trigSuccess('mail lists surpprimées'); } } - $globals->xdb->query('DELETE FROM groupex.asso WHERE id={?}', $id); - $page->trig("Groupe $nom supprimé"); + XDB::query('DELETE FROM groupex.asso WHERE id={?}', $id); + $page->trigSuccess("Groupe $nom supprimé"); Get::kill('del'); } if (!$id) { @@ -133,24 +112,24 @@ class XnetModule extends PLModule } if (Post::has('diminutif')) { - $globals->xdb->query('INSERT INTO groupex.asso (id,diminutif) - VALUES(NULL,{?})', Post::get('diminutif')); - redirect(Post::get('diminutif').'/edit'); + S::assert_xsrf_token(); + + XDB::query('INSERT INTO groupex.asso (id,diminutif) + VALUES(NULL,{?})', Post::v('diminutif')); + pl_redirect('../'.Post::v('diminutif').'/edit'); } - $res = $globals->xdb->query('SELECT nom,diminutif FROM groupex.asso ORDER by NOM'); + $res = XDB::query('SELECT nom,diminutif FROM groupex.asso ORDER by NOM'); $page->assign('assos', $res->fetchAllAssoc()); } function handler_plan(&$page) { - global $globals; - $page->changeTpl('xnet/plan.tpl'); $page->setType('plan'); - $res = $globals->xdb->iterator( + $res = XDB::iterator( 'SELECT dom.id, dom.nom as domnom, asso.diminutif, asso.nom FROM groupex.dom INNER JOIN groupex.asso ON dom.id = asso.dom @@ -160,7 +139,7 @@ class XnetModule extends PLModule while ($tmp = $res->next()) { $groupesx[$tmp['id']][] = $tmp; } $page->assign('groupesx', $groupesx); - $res = $globals->xdb->iterator( + $res = XDB::iterator( 'SELECT dom.id, dom.nom as domnom, asso.diminutif, asso.nom FROM groupex.dom INNER JOIN groupex.asso ON dom.id = asso.dom @@ -170,14 +149,14 @@ class XnetModule extends PLModule while ($tmp = $res->next()) { $binets[$tmp['id']][] = $tmp; } $page->assign('binets', $binets); - $res = $globals->xdb->iterator( + $res = XDB::iterator( 'SELECT asso.diminutif, asso.nom FROM groupex.asso WHERE cat LIKE "%Promotions%" ORDER BY diminutif'); $page->assign('promos', $res); - $res = $globals->xdb->iterator( + $res = XDB::iterator( 'SELECT asso.diminutif, asso.nom FROM groupex.asso WHERE FIND_IN_SET("Institutions", cat) @@ -187,13 +166,11 @@ class XnetModule extends PLModule function handler_groups2(&$page) { - $this->handler_groups(&$page, Get::get('cat'), Get::get('dom')); + $this->handler_groups(&$page, Get::v('cat'), Get::v('dom')); } function handler_groups(&$page, $cat = null, $dom = null) { - global $globals; - if (!$cat) { $this->handler_index(&$page); } @@ -204,26 +181,37 @@ class XnetModule extends PLModule $page->assign('cat', $cat); $page->assign('dom', $dom); - $res = $globals->xdb->query("SELECT id,nom FROM groupex.dom - WHERE FIND_IN_SET({?}, cat) ORDER BY nom", $cat); + $res = XDB::query("SELECT id,nom FROM groupex.dom + WHERE FIND_IN_SET({?}, cat) + ORDER BY nom", $cat); $doms = $res->fetchAllAssoc(); $page->assign('doms', $doms); if (empty($doms)) { - $res = $globals->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 = $globals->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); } + + function handler_autologin(&$page) + { + $allkeys = func_get_args(); + unset($allkeys[0]); + $url = join('/',$allkeys); + header("Content-type: text/javascript; charset=utf-8"); + echo '$.ajax({ url: "'.$url.'?forceXml=1", dataType: "xml", success: function(xml) { $("body",xml).insertBefore("body"); $("body:eq(1)").remove(); }});'; + exit; + } } +// vim:set et sw=4 sts=4 sws=4 foldmethod=marker enc=utf-8: ?>