<?php
/***************************************************************************
- * Copyright (C) 2003-2007 Polytechnique.org *
+ * Copyright (C) 2003-2008 Polytechnique.org *
* http://opensource.polytechnique.org/ *
* *
* This program is free software; you can redistribute it and/or modify *
'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),
);
}
}
exit;
}
-
+
function handler_index(&$page)
{
$page->nomenu = true;
function handler_admin(&$page)
{
- new_admin_page('xnet/admin.tpl');
+ $page->changeTpl('xnet/admin.tpl');
if (Get::has('del')) {
$res = XDB::query('SELECT id, nom, mail_domain
Get::v('del'));
list($id, $nom, $domain) = $res->fetchOneRow();
$page->assign('nom', $nom);
- if ($id && Post::has('del')) {
+ if ($id && Post::has('del') && S::has_xsrf_token()) {
XDB::query('DELETE FROM groupex.membres WHERE asso_id={?}', $id);
$page->trig('membres supprimés');
XDB::query('DELETE FROM groupex.asso WHERE id={?}', $id);
$page->trig("Groupe $nom supprimé");
Get::kill('del');
+ } else if ($id && Post::has('del')) {
+ $page->trig("La suppression du groupe X a échouée, merci de réssayer.");
}
if (!$id) {
Get::kill('del');
}
}
- if (Post::has('diminutif')) {
+ if (Post::has('diminutif') && S::has_xsrf_token()) {
XDB::query('INSERT INTO groupex.asso (id,diminutif)
VALUES(NULL,{?})', Post::v('diminutif'));
pl_redirect('../'.Post::v('diminutif').'/edit');
+ } else if (Post::has('diminutif')) {
+ $page->trig("L'ajout du groupe X a échoué, merci de réssayer.");
}
$res = XDB::query('SELECT nom,diminutif FROM groupex.asso ORDER by NOM');
$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: