From 75b81c3e01f3a5dc97e78c8e82fd5f94a071daba Mon Sep 17 00:00:00 2001 From: Joas Schilling Date: Fri, 17 Mar 2017 13:34:23 +0100 Subject: Always suggest the overwrite.cli.url Signed-off-by: Joas Schilling --- lib/private/Server.php | 1 + lib/private/Settings/Admin/Server.php | 21 +++++++++++++++------ lib/private/Settings/Manager.php | 8 +++++++- 3 files changed, 23 insertions(+), 7 deletions(-) (limited to 'lib') diff --git a/lib/private/Server.php b/lib/private/Server.php index bcbe23b0181..969b65f9553 100644 --- a/lib/private/Server.php +++ b/lib/private/Server.php @@ -811,6 +811,7 @@ class Server extends ServerContainer implements IServerContainer { $c->getEncryptionManager(), $c->getUserManager(), $c->getLockingProvider(), + $c->getRequest(), new \OC\Settings\Mapper($c->getDatabaseConnection()), $c->getURLGenerator() ); diff --git a/lib/private/Settings/Admin/Server.php b/lib/private/Settings/Admin/Server.php index 8b1477a0257..5443336669f 100644 --- a/lib/private/Settings/Admin/Server.php +++ b/lib/private/Settings/Admin/Server.php @@ -32,12 +32,15 @@ use OCP\AppFramework\Http\TemplateResponse; use OCP\IConfig; use OCP\IDBConnection; use OCP\IL10N; +use OCP\IRequest; use OCP\Lock\ILockingProvider; use OCP\Settings\ISettings; class Server implements ISettings { /** @var IDBConnection|Connection */ private $db; + /** @var IRequest */ + private $request; /** @var IConfig */ private $config; /** @var ILockingProvider */ @@ -47,15 +50,18 @@ class Server implements ISettings { /** * @param IDBConnection $db + * @param IRequest $request * @param IConfig $config * @param ILockingProvider $lockingProvider * @param IL10N $l */ public function __construct(IDBConnection $db, + IRequest $request, IConfig $config, ILockingProvider $lockingProvider, IL10N $l) { $this->db = $db; + $this->request = $request; $this->config = $config; $this->lockingProvider = $lockingProvider; $this->l = $l; @@ -99,12 +105,15 @@ class Server implements ISettings { $fileLockingType = 'cache'; } - // If the current web root is non-empty but the web root from the config is, - // and system cron is used, the URL generator fails to build valid URLs. - $shouldSuggestOverwriteCliUrl = $this->config->getAppValue('core', 'backgroundjobs_mode', 'ajax') === 'cron' - && \OC::$WEBROOT && \OC::$WEBROOT !== '/' - && !$this->config->getSystemValue('overwrite.cli.url', ''); - $suggestedOverwriteCliUrl = ($shouldSuggestOverwriteCliUrl) ? \OC::$WEBROOT : ''; + $suggestedOverwriteCliUrl = ''; + if ($this->config->getSystemValue('overwrite.cli.url', '') === '') { + $suggestedOverwriteCliUrl = $this->request->getServerProtocol() . '://' . $this->request->getInsecureServerHost() . \OC::$WEBROOT; + if (!$this->config->getSystemValue('config_is_read_only', false)) { + // Set the overwrite URL when it was not set yet. + $this->config->setSystemValue('overwrite.cli.url', $suggestedOverwriteCliUrl); + $suggestedOverwriteCliUrl = ''; + } + } $parameters = [ // Diagnosis diff --git a/lib/private/Settings/Manager.php b/lib/private/Settings/Manager.php index 7a339b94199..94df00551d4 100644 --- a/lib/private/Settings/Manager.php +++ b/lib/private/Settings/Manager.php @@ -29,6 +29,7 @@ use OCP\IConfig; use OCP\IDBConnection; use OCP\IL10N; use OCP\ILogger; +use OCP\IRequest; use OCP\IURLGenerator; use OCP\IUserManager; use OCP\Lock\ILockingProvider; @@ -56,6 +57,8 @@ class Manager implements IManager { private $userManager; /** @var ILockingProvider */ private $lockingProvider; + /** @var IRequest */ + private $request; /** @var IURLGenerator */ private $url; @@ -67,6 +70,7 @@ class Manager implements IManager { * @param EncryptionManager $encryptionManager * @param IUserManager $userManager * @param ILockingProvider $lockingProvider + * @param IRequest $request * @param Mapper $mapper * @param IURLGenerator $url */ @@ -78,6 +82,7 @@ class Manager implements IManager { EncryptionManager $encryptionManager, IUserManager $userManager, ILockingProvider $lockingProvider, + IRequest $request, Mapper $mapper, IURLGenerator $url ) { @@ -89,6 +94,7 @@ class Manager implements IManager { $this->encryptionManager = $encryptionManager; $this->userManager = $userManager; $this->lockingProvider = $lockingProvider; + $this->request = $request; $this->url = $url; } @@ -299,7 +305,7 @@ class Manager implements IManager { try { if ($section === 'server') { /** @var ISettings $form */ - $form = new Admin\Server($this->dbc, $this->config, $this->lockingProvider, $this->l); + $form = new Admin\Server($this->dbc, $this->request, $this->config, $this->lockingProvider, $this->l); $forms[$form->getPriority()] = [$form]; $form = new Admin\ServerDevNotice(); $forms[$form->getPriority()] = [$form]; -- cgit v1.2.3