various fixes for php5.
[platal.git] / classes / session.php
CommitLineData
cab08090 1<?php
2/***************************************************************************
3 * Copyright (C) 2003-2006 Polytechnique.org *
4 * http://opensource.polytechnique.org/ *
5 * *
6 * This program is free software; you can redistribute it and/or modify *
7 * it under the terms of the GNU General Public License as published by *
8 * the Free Software Foundation; either version 2 of the License, or *
9 * (at your option) any later version. *
10 * *
11 * This program is distributed in the hope that it will be useful, *
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
14 * GNU General Public License for more details. *
15 * *
16 * You should have received a copy of the GNU General Public License *
17 * along with this program; if not, write to the Free Software *
18 * Foundation, Inc., *
19 * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA *
20 ***************************************************************************/
21
b76f0797 22require_once 'diogenes/diogenes.misc.inc.php';
b76f0797 23
cab08090 24class Session
25{
26 function init()
27 {
28 @session_start();
29 if (empty($_SESSION['challenge'])) {
30 $_SESSION['challenge'] = sha1(uniqid(rand(), true));
31 }
32 }
33
34 function destroy()
35 {
36 @session_destroy();
37 unset($_SESSION);
38 }
39
40
41
42 function has($key)
43 {
44 return isset($_SESSION[$key]);
45 }
46
47 function kill($key)
48 {
49 unset($_SESSION[$key]);
50 }
51
52 function v($key, $default = null)
53 {
54 return isset($_SESSION[$key]) ? $_SESSION[$key] : $default;
55 }
56
6b590724 57 function i($key, $default = 0)
58 {
59 $i = Session::v($key, $default);
60 return is_numeric($i) ? intval($i) : $default;
61 }
cab08090 62
63 function has_perms()
64 {
65 return Session::logged() && Session::v('perms') == PERMS_ADMIN;
66 }
67
68 function logged()
69 {
70 return Session::v('auth', AUTH_PUBLIC) >= AUTH_COOKIE;
71 }
72
73 function identified()
74 {
75 return Session::v('auth', AUTH_PUBLIC) >= AUTH_MDP;
76 }
77}
78
b76f0797 79// {{{ function check_perms()
80
81/** verifie si un utilisateur a les droits pour voir une page
82 ** si ce n'est pas le cas, on affiche une erreur
83 * @return void
84 */
85function check_perms()
86{
87 global $page;
88 if (!S::has_perms()) {
89 if ($_SESSION['log']) {
90 $_SESSION['log']->log("noperms",$_SERVER['PHP_SELF']);
91 }
b406e354 92 $page->kill("Tu n'as pas les permissions nécessaires pour accéder à cette page.");
b76f0797 93 }
94}
95
96// }}}
97
cab08090 98?>