X-Git-Url: http://git.polytechnique.org/?a=blobdiff_plain;f=modules%2Fxnet.php;h=dbaa8a3605a9d285bd031cc1a2772f5d7c5ba1b5;hb=38984ab07f8c2d2e1dbb401be05cfcc57f71b27c;hp=84bb0d230ed19948e2d9d364e4093ee81336ceac;hpb=fd8f77de8bc10d40395990e3f8e96e0b4a186b46;p=platal.git diff --git a/modules/xnet.php b/modules/xnet.php index 84bb0d2..dbaa8a3 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), + 'index' => $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), - 'plan' => $this->make_hook('plan', AUTH_PUBLIC), + 'Xnet' => $this->make_wiki_hook(), ); } - 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(); - } + if (!$x || !($profile = Profile::get($x))) { + return PL_NOT_FOUND; + } - function handler_article12(&$page) - { - $page->changeTpl('xnet/article12.tpl'); - $page->useMenu(); - } + // Retrieve the photo and its mime type. + $photo = $profile->getPhoto(true, true); - function handler_article16(&$page) - { - $page->changeTpl('xnet/article16.tpl'); - $page->useMenu(); + // Display the photo, or a default one when not available. + $photo->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_exit(&$page) { - $page->changeTpl('xnet/services.tpl'); - $page->useMenu(); + Platal::session()->stopSUID(); + Platal::session()->destroy(); + $page->changeTpl('xnet/deconnexion.tpl'); } - function handler_manuel(&$page) + function handler_admin(&$page) { - $page->changeTpl('xnet/manuel.tpl'); - $page->useMenu(); + $page->changeTpl('xnet/admin.tpl'); + + if (Get::has('del')) { + $res = XDB::query('SELECT id, nom, mail_domain + FROM groups WHERE diminutif={?}', + Get::v('del')); + list($id, $nom, $domain) = $res->fetchOneRow(); + $page->assign('nom', $nom); + if ($id && Post::has('del')) { + S::assert_xsrf_token(); + + XDB::query('DELETE FROM group_members WHERE asso_id={?}', $id); + $page->trigSuccess('membres supprimés'); + + if ($domain) { + 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->trigSuccess('suppression des alias mails'); + + $mmlist = new MMList(S::v('uid'), S::v('password'), $domain); + if ($listes = $mmlist->get_lists()) { + foreach ($listes as $l) { + $mmlist->delete_list($l['list'], true); + } + $page->trigSuccess('mail lists surpprimées'); + } + } + + XDB::query('DELETE FROM groups WHERE id={?}', $id); + $page->trigSuccess("Groupe $nom supprimé"); + Get::kill('del'); + } + if (!$id) { + Get::kill('del'); + } + } + + if (Post::has('diminutif') && Post::v('diminutif') != "") { + S::assert_xsrf_token(); + + $res = XDB::query('SELECT COUNT(*) + FROM groups + WHERE diminutif = {?}', + Post::v('diminutif')); + + if ($res->fetchOneCell() == 0) { + XDB::execute('INSERT INTO groups (id, diminutif) + VALUES (NULL, {?})', + Post::v('diminutif')); + pl_redirect(Post::v('diminutif') . '/edit'); + } else { + $page->trigError('Le diminutif demandé est déjà pris.'); + } + } + + $res = XDB::query('SELECT nom, diminutif + FROM groups + 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( - 'SELECT dom.id, dom.nom as domnom, asso.diminutif, asso.nom - FROM groupex.dom - INNER JOIN groupex.asso ON dom.id = asso.dom - WHERE FIND_IN_SET("GroupesX", dom.cat) AND FIND_IN_SET("GroupesX", asso.cat) - ORDER BY dom.nom, asso.nom'); + $res = XDB::iterator( + 'SELECT dom.id, dom.nom as domnom, groups.diminutif, groups.nom + FROM group_dom AS dom + INNER JOIN groups ON dom.id = groups.dom + WHERE FIND_IN_SET("GroupesX", dom.cat) AND FIND_IN_SET("GroupesX", groups.cat) + ORDER BY dom.nom, groups.nom'); $groupesx = array(); while ($tmp = $res->next()) { $groupesx[$tmp['id']][] = $tmp; } $page->assign('groupesx', $groupesx); - $res = $globals->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 - WHERE FIND_IN_SET("Binets", dom.cat) AND FIND_IN_SET("Binets", asso.cat) - ORDER BY dom.nom, asso.nom'); + $res = XDB::iterator( + 'SELECT dom.id, dom.nom as domnom, groups.diminutif, groups.nom + FROM group_dom AS dom + INNER JOIN groups ON dom.id = groups.dom + WHERE FIND_IN_SET("Binets", dom.cat) AND FIND_IN_SET("Binets", groups.cat) + ORDER BY dom.nom, groups.nom'); $binets = array(); while ($tmp = $res->next()) { $binets[$tmp['id']][] = $tmp; } $page->assign('binets', $binets); - $res = $globals->xdb->iterator( - 'SELECT asso.diminutif, asso.nom - FROM groupex.asso + $res = XDB::iterator( + 'SELECT diminutif, nom + FROM groups WHERE cat LIKE "%Promotions%" ORDER BY diminutif'); $page->assign('promos', $res); - $res = $globals->xdb->iterator( - 'SELECT asso.diminutif, asso.nom - FROM groupex.asso + $res = XDB::iterator( + 'SELECT diminutif, nom + FROM groups WHERE FIND_IN_SET("Institutions", cat) ORDER BY diminutif'); $page->assign('inst', $res); } + + function handler_groups2(&$page) + { + $this->handler_groups(&$page, Get::v('cat'), Get::v('dom')); + } + + function handler_groups(&$page, $cat = null, $dom = null) + { + if (!$cat) { + $this->handler_index(&$page); + } + + $cat = mb_strtolower($cat); + + $page->changeTpl('xnet/groupes.tpl'); + $page->assign('cat', $cat); + $page->assign('dom', $dom); + + $res = XDB::query("SELECT id,nom + FROM group_dom + WHERE FIND_IN_SET({?}, cat) + ORDER BY nom", $cat); + $doms = $res->fetchAllAssoc(); + $page->assign('doms', $doms); + + if (empty($doms)) { + $res = XDB::query("SELECT diminutif, nom, site + FROM groups + WHERE FIND_IN_SET({?}, cat) + ORDER BY nom", $cat); + $page->assign('gps', $res->fetchAllAssoc()); + } elseif (!is_null($dom)) { + $res = XDB::query("SELECT diminutif, nom, site + FROM groups + WHERE FIND_IN_SET({?}, cat) AND dom={?} + ORDER BY nom", $cat, $dom); + $page->assign('gps', $res->fetchAllAssoc()); + } + + $page->setType($cat); + } + + function handler_autologin(&$page) + { + $allkeys = func_get_args(); + unset($allkeys[0]); + $url = join('/',$allkeys); + pl_content_headers("text/javascript"); + 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: ?>