summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorRobin Appelman <icewind@owncloud.com>2013-11-25 15:08:24 +0100
committerRobin Appelman <icewind@owncloud.com>2013-11-25 15:08:24 +0100
commit71c1327691225a0a517aa3929a48743f95b177d0 (patch)
treea97d2765d35ff518fad9581fec8da4ed3ccdac87 /lib
parentde2b4440301badf48e638ede84f64692f2a2db41 (diff)
downloadnextcloud-server-71c1327691225a0a517aa3929a48743f95b177d0.tar.gz
nextcloud-server-71c1327691225a0a517aa3929a48743f95b177d0.zip
Add "single user mode" which restricts access to users in the admin group
This can be enabled by setting 'singleuser' to true in config.php
Diffstat (limited to 'lib')
-rw-r--r--lib/base.php19
1 files changed, 18 insertions, 1 deletions
diff --git a/lib/base.php b/lib/base.php
index 865d174d212..b361ac3c71a 100644
--- a/lib/base.php
+++ b/lib/base.php
@@ -230,6 +230,22 @@ class OC {
}
}
+ public static function checkSingleUserMode() {
+ $user = OC_User::getUserSession()->getUser();
+ $group = OC_Group::getManager()->get('admin');
+ if ($user && OC_Config::getValue('singleuser', false) && !$group->inGroup($user)) {
+ // send http status 503
+ header('HTTP/1.1 503 Service Temporarily Unavailable');
+ header('Status: 503 Service Temporarily Unavailable');
+ header('Retry-After: 120');
+
+ // render error page
+ $tmpl = new OC_Template('', 'singleuser.user', 'guest');
+ $tmpl->printPage();
+ die();
+ }
+ }
+
public static function checkUpgrade($showTemplate = true) {
if (OC_Config::getValue('installed', false)) {
$installedVersion = OC_Config::getValue('version', '0.0.0');
@@ -652,11 +668,12 @@ class OC {
// Test it the user is already authenticated using Apaches AuthType Basic... very usable in combination with LDAP
OC::tryBasicAuthLogin();
- if (!self::$CLI) {
+ if (!self::$CLI and (!isset($_GET["logout"]) or ($_GET["logout"] !== 'true'))) {
try {
if (!OC_Config::getValue('maintenance', false)) {
OC_App::loadApps();
}
+ self::checkSingleUserMode();
OC::getRouter()->match(OC_Request::getRawPathInfo());
return;
} catch (Symfony\Component\Routing\Exception\ResourceNotFoundException $e) {