summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorChristoph Wurst <ChristophWurst@users.noreply.github.com>2021-12-17 14:39:40 +0100
committerGitHub <noreply@github.com>2021-12-17 14:39:40 +0100
commit4b36f9d92f886609e34f5a180f38e6034aacbd79 (patch)
tree22f9f9b3a233b41044c99f36f814e71f5a793cd8 /lib
parente23133887644a2a024d0458c849b857cb85bd7f4 (diff)
parent241dfef7fb07cb5908ef6bed0f584ebeb277f653 (diff)
downloadnextcloud-server-4b36f9d92f886609e34f5a180f38e6034aacbd79.tar.gz
nextcloud-server-4b36f9d92f886609e34f5a180f38e6034aacbd79.zip
Merge pull request #30130 from nextcloud/fix/config_is_read_only
Don't write to config file if `config_is_read_only` is set
Diffstat (limited to 'lib')
-rw-r--r--lib/private/Config.php26
-rw-r--r--lib/public/IConfig.php2
2 files changed, 28 insertions, 0 deletions
diff --git a/lib/private/Config.php b/lib/private/Config.php
index 2a83d2300dc..b044d0731a3 100644
--- a/lib/private/Config.php
+++ b/lib/private/Config.php
@@ -57,6 +57,8 @@ class Config {
protected $configFilePath;
/** @var string */
protected $configFileName;
+ /** @var bool */
+ protected $isReadOnly;
/**
* @param string $configDir Path to the config dir, needs to end with '/'
@@ -67,6 +69,7 @@ class Config {
$this->configFilePath = $this->configDir.$fileName;
$this->configFileName = $fileName;
$this->readData();
+ $this->isReadOnly = $this->getValue('config_is_read_only', false);
}
/**
@@ -109,6 +112,7 @@ class Config {
*
* @param array $configs Associative array with `key => value` pairs
* If value is null, the config key will be deleted
+ * @throws HintException
*/
public function setValues(array $configs) {
$needsUpdate = false;
@@ -131,6 +135,7 @@ class Config {
*
* @param string $key key
* @param mixed $value value
+ * @throws HintException
*/
public function setValue($key, $value) {
if ($this->set($key, $value)) {
@@ -145,8 +150,11 @@ class Config {
* @param string $key key
* @param mixed $value value
* @return bool True if the file needs to be updated, false otherwise
+ * @throws HintException
*/
protected function set($key, $value) {
+ $this->checkReadOnly();
+
if (!isset($this->cache[$key]) || $this->cache[$key] !== $value) {
// Add change
$this->cache[$key] = $value;
@@ -158,7 +166,9 @@ class Config {
/**
* Removes a key from the config and removes it from config.php if required
+ *
* @param string $key
+ * @throws HintException
*/
public function deleteKey($key) {
if ($this->delete($key)) {
@@ -172,8 +182,11 @@ class Config {
*
* @param string $key
* @return bool True if the file needs to be updated, false otherwise
+ * @throws HintException
*/
protected function delete($key) {
+ $this->checkReadOnly();
+
if (isset($this->cache[$key])) {
// Delete key from cache
unset($this->cache[$key]);
@@ -239,6 +252,8 @@ class Config {
* @throws \Exception If no file lock can be acquired
*/
private function writeData() {
+ $this->checkReadOnly();
+
// Create a php file ...
$content = "<?php\n";
$content .= '$CONFIG = ';
@@ -274,4 +289,15 @@ class Config {
@opcache_invalidate($this->configFilePath, true);
}
}
+
+ /**
+ * @throws HintException
+ */
+ private function checkReadOnly(): void {
+ if ($this->isReadOnly) {
+ throw new HintException(
+ 'Config is set to be read-only via option "config_is_read_only".',
+ 'Unset "config_is_read_only" to allow changes to the config file.');
+ }
+ }
}
diff --git a/lib/public/IConfig.php b/lib/public/IConfig.php
index 6b396624556..33b9c97971a 100644
--- a/lib/public/IConfig.php
+++ b/lib/public/IConfig.php
@@ -47,6 +47,7 @@ interface IConfig {
*
* @param array $configs Associative array with `key => value` pairs
* If value is null, the config key will be deleted
+ * @throws HintException if config file is read-only
* @since 8.0.0
*/
public function setSystemValues(array $configs);
@@ -56,6 +57,7 @@ interface IConfig {
*
* @param string $key the key of the value, under which will be saved
* @param mixed $value the value that should be stored
+ * @throws HintException if config file is read-only
* @since 8.0.0
*/
public function setSystemValue($key, $value);