summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorMorris Jobke <hey@morrisjobke.de>2017-06-15 10:11:56 -0500
committerGitHub <noreply@github.com>2017-06-15 10:11:56 -0500
commit5bf447649d6b5c18d1d500df3ff52a2484cc67b5 (patch)
tree04930600815518b0c679c059754f48bac41d7671 /lib
parent8ccc2e27586d4c77dd68f8e5fcf696d39af012a2 (diff)
parentd1a8269de31ffa85ff7908c31f3c270b76be361c (diff)
downloadnextcloud-server-5bf447649d6b5c18d1d500df3ff52a2484cc67b5.tar.gz
nextcloud-server-5bf447649d6b5c18d1d500df3ff52a2484cc67b5.zip
Merge pull request #5421 from nextcloud/5190-master
[master] Treat PHP Errors on User session regenerate
Diffstat (limited to 'lib')
-rw-r--r--lib/private/Session/Internal.php41
1 files changed, 32 insertions, 9 deletions
diff --git a/lib/private/Session/Internal.php b/lib/private/Session/Internal.php
index 72af5727a54..09b33f79d29 100644
--- a/lib/private/Session/Internal.php
+++ b/lib/private/Session/Internal.php
@@ -43,12 +43,12 @@ class Internal extends Session {
* @throws \Exception
*/
public function __construct($name) {
- session_name($name);
set_error_handler(array($this, 'trapError'));
+ $this->invoke('session_name', [$name]);
try {
- session_start();
+ $this->invoke('session_start');
} catch (\Exception $e) {
- setcookie(session_name(), null, -1, \OC::$WEBROOT ? : '/');
+ setcookie($this->invoke('session_name'), null, -1, \OC::$WEBROOT ?: '/');
}
restore_error_handler();
if (!isset($_SESSION)) {
@@ -94,14 +94,14 @@ class Internal extends Session {
}
public function clear() {
- session_unset();
+ $this->invoke('session_unset');
$this->regenerateId();
- @session_start();
- $_SESSION = array();
+ $this->invoke('session_start', [], true);
+ $_SESSION = [];
}
public function close() {
- session_write_close();
+ $this->invoke('session_write_close');
parent::close();
}
@@ -112,7 +112,11 @@ class Internal extends Session {
* @return void
*/
public function regenerateId($deleteOldSession = true) {
- @session_regenerate_id($deleteOldSession);
+ try {
+ @session_regenerate_id($deleteOldSession);
+ } catch (\Error $e) {
+ $this->trapError($e->getCode(), $e->getMessage());
+ }
}
/**
@@ -123,7 +127,7 @@ class Internal extends Session {
* @since 9.1.0
*/
public function getId() {
- $id = @session_id();
+ $id = $this->invoke('session_id', [], true);
if ($id === '') {
throw new SessionNotAvailableException();
}
@@ -154,4 +158,23 @@ class Internal extends Session {
throw new SessionNotAvailableException('Session has been closed - no further changes to the session are allowed');
}
}
+
+ /**
+ * @param string $functionName the full session_* function name
+ * @param array $parameters
+ * @param bool $silence whether to suppress warnings
+ * @throws \ErrorException via trapError
+ * @return mixed
+ */
+ private function invoke($functionName, array $parameters = [], $silence = false) {
+ try {
+ if($silence) {
+ return @call_user_func_array($functionName, $parameters);
+ } else {
+ return call_user_func_array($functionName, $parameters);
+ }
+ } catch(\Error $e) {
+ $this->trapError($e->getCode(), $e->getMessage());
+ }
+ }
}