diff options
author | Lukas Reschke <lukas@owncloud.com> | 2015-09-14 11:22:34 +0200 |
---|---|---|
committer | Lukas Reschke <lukas@owncloud.com> | 2015-09-14 11:22:34 +0200 |
commit | 3adbfbfd694d09b165be41df108480ea16bb4d29 (patch) | |
tree | f94cf4d4c42e21a861a90708ffc7cc5cb6d00886 /lib/private | |
parent | 211a2437840ec6897e377a5025f85aec27618263 (diff) | |
download | nextcloud-server-3adbfbfd694d09b165be41df108480ea16bb4d29.tar.gz nextcloud-server-3adbfbfd694d09b165be41df108480ea16bb4d29.zip |
Use / instead of an empty string as cookie path
When an empty string is used as cookie path PHP will assign the current directory as cookie path.
This means when an user had installed an ownCloud under "/", which is mapped to an empty string in \OC::$WEBROOT, and accessed it the cookie was set to values such as "/index.php/apps/files" since the web browser assumed this to be a directory. This means that multiple encryption cookies were set for the same domain resulting in potential havoc.
With this patch the path will be set to "/" in case an empty web root is installed which makes the cookie accessible to the whole domain.
To test this setup multiple ownCloud instances on the same domain under different ports and have both installed under "/", then try to login in both of it and previously this can in some cases lead to a lockout of the user.
Note that this affects the cookies that the browsers do sent and thus to test this you need to clear all cookies from your browser previously. I consider this an acceptable behaviour for now since this code is only in master.
Fixes https://github.com/owncloud/core/issues/18919
Diffstat (limited to 'lib/private')
-rw-r--r-- | lib/private/session/cryptowrapper.php | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/lib/private/session/cryptowrapper.php b/lib/private/session/cryptowrapper.php index 62bdcbfb719..261514d683e 100644 --- a/lib/private/session/cryptowrapper.php +++ b/lib/private/session/cryptowrapper.php @@ -77,7 +77,11 @@ class CryptoWrapper { $secureCookie = $request->getServerProtocol() === 'https'; // FIXME: Required for CI if (!defined('PHPUNIT_RUN')) { - setcookie(self::COOKIE_NAME, $this->passphrase, 0, \OC::$WEBROOT, '', $secureCookie, true); + $webRoot = \OC::$WEBROOT; + if($webRoot === '') { + $webRoot = '/'; + } + setcookie(self::COOKIE_NAME, $this->passphrase, 0, $webRoot, '', $secureCookie, true); } } } |