if (empty($_SESSION['challenge'])) {
$_SESSION['challenge'] = sha1(uniqid(rand(), true));
}
+ if (empty($_SESSION['xsrf_token'])) {
+ require_once 'xorg.misc.inc.php';
+ $_SESSION['xsrf_token'] = rand_url_id();
+ }
if (!isset($_SESSION['perms']) || !($_SESSION['perms'] instanceof FlagSet)) {
$_SESSION['perms'] = new FlagSet();
}
{
return Session::v('auth', AUTH_PUBLIC) >= AUTH_MDP;
}
+
+ // Anti-XSRF protections.
+ public static function has_xsrf_token()
+ {
+ return Session::has('xsrf_token') && Session::v('xsrf_token') == Env::v('token');
+ }
+
+ public static function assert_xsrf_token()
+ {
+ if (!Session::has_xsrf_token()) {
+ global $page;
+ if ($page instanceof PlatalPage) {
+ $page->kill("L'opération n'a pas pu aboutir, merci de réessayer.");
+ }
+ }
+ }
+
+ public static function rssActivated()
+ {
+ return Session::has('core_rss_hash') && Session::v('core_rss_hash');
+ }
}
// {{{ function check_perms()
if ($_SESSION['log']) {
$_SESSION['log']->log("noperms",$_SERVER['PHP_SELF']);
}
- $page->kill("Tu n'as pas les permissions nécessaires pour accéder à cette page.");
+ $page->kill("Tu n'as pas les permissions nécessaires pour accéder à cette page.");
}
}