summaryrefslogtreecommitdiffstats
path: root/lib/private/session/internal.php
diff options
context:
space:
mode:
authorcetra3 <peter@parashift.com.au>2014-08-30 08:48:13 +0000
committercetra3 <peter@parashift.com.au>2014-08-30 08:48:13 +0000
commit6b24aa522409f17742ad43e2ad0fc4343479b232 (patch)
tree269a309eba873fd84341f00f78da7ec64ce6f134 /lib/private/session/internal.php
parent53f3b7ab52a938b525c40436512e545af38706d2 (diff)
downloadnextcloud-server-6b24aa522409f17742ad43e2ad0fc4343479b232.tar.gz
nextcloud-server-6b24aa522409f17742ad43e2ad0fc4343479b232.zip
Refactor internal session to write directly to $_SESSION
Diffstat (limited to 'lib/private/session/internal.php')
-rw-r--r--lib/private/session/internal.php44
1 files changed, 37 insertions, 7 deletions
diff --git a/lib/private/session/internal.php b/lib/private/session/internal.php
index 42ec9606dc9..8fda6b3b3ee 100644
--- a/lib/private/session/internal.php
+++ b/lib/private/session/internal.php
@@ -15,14 +15,13 @@ namespace OC\Session;
*
* @package OC\Session
*/
-class Internal extends Memory {
+class Internal extends Session {
public function __construct($name) {
session_name($name);
session_start();
if (!isset($_SESSION)) {
throw new \Exception('Failed to start session');
}
- $this->data = $_SESSION;
}
public function __destruct() {
@@ -31,30 +30,61 @@ class Internal extends Memory {
/**
* @param string $key
+ * @param integer $value
+ */
+ public function set($key, $value) {
+ $this->validateSession();
+ $_SESSION[$key] = $value;
+ }
+
+ /**
+ * @param string $key
+ * @return mixed
+ */
+ public function get($key) {
+ if (!$this->exists($key)) {
+ return null;
+ }
+ return $_SESSION[$key];
+ }
+
+ /**
+ * @param string $key
+ * @return bool
+ */
+ public function exists($key) {
+ return isset($_SESSION[$key]);
+ }
+
+ /**
+ * @param string $key
*/
public function remove($key) {
- // also remove it from $_SESSION to prevent re-setting the old value during the merge
if (isset($_SESSION[$key])) {
unset($_SESSION[$key]);
}
- parent::remove($key);
}
+
public function clear() {
session_unset();
@session_regenerate_id(true);
@session_start();
- $this->data = $_SESSION = array();
+ $_SESSION = array();
}
public function close() {
- $_SESSION = array_merge($_SESSION, $this->data);
session_write_close();
-
parent::close();
}
public function reopen() {
throw new \Exception('The session cannot be reopened - reopen() is ony to be used in unit testing.');
}
+
+ private function validateSession() {
+ if ($this->sessionClosed) {
+ throw new \Exception('Session has been closed - no further changes to the session as allowed');
+ }
+ }
}