123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130 |
- <?php
- namespace System;
- /**
- * Session Management
- *
- * @see ChamiloSession
- *
- * @license see /license.txt
- * @author Laurent Opprecht <laurent@opprecht.info> for the Univesity of Geneva
- */
- class Session implements \ArrayAccess
- {
- static function read($variable, $default = null)
- {
- return isset($_SESSION[$variable]) ? $_SESSION[$variable] : $default;
- }
- static function write($variable, $value)
- {
- $_SESSION[$variable] = $value;
- }
- static function erase($variable)
- {
- $variable = (string) $variable;
- if (isset($GLOBALS[$variable])) {
- unset($GLOBALS[$variable]);
- }
- if (isset($_SESSION[$variable])) {
- unset($_SESSION[$variable]);
- }
- }
- /**
- * Returns true if session has variable set up, false otherwise.
- *
- * @param string $variable
- */
- static function has($variable)
- {
- return isset($_SESSION[$variable]);
- }
- static function clear()
- {
- session_regenerate_id();
- session_unset();
- $_SESSION = array();
- }
- static function destroy()
- {
- session_unset();
- $_SESSION = array();
- session_destroy();
- }
- /*
- * ArrayAccess
- */
- public function offsetExists($offset)
- {
- return isset($_SESSION[$offset]);
- }
- /**
- * It it exists returns the value stored at the specified offset.
- * If offset does not exists returns null. Do not trigger a warning.
- *
- * @param string $offset
- * @return any
- */
- public function offsetGet($offset)
- {
- return self::read($offset);
- }
- public function offsetSet($offset, $value)
- {
- self::write($offset, $value);
- }
- public function offsetUnset($offset)
- {
- unset($_SESSION[$offset]);
- }
- /**
- * Magical methods
- *
- */
- public function __unset($name)
- {
- unset($_SESSION[$name]);
- }
- public function __isset($name)
- {
- return self::has($name);
- }
- /**
- * It it exists returns the value stored at the specified offset.
- * If offset does not exists returns null. Do not trigger a warning.
- *
- * @param string $name
- * @return any
- *
- */
- function __get($name)
- {
- return self::read($name);
- }
- /**
- *
- * @param string $name
- * @param any $value
- */
- function __set($name, $value)
- {
- self::write($name, $value);
- }
- }
|