aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorMaxence Lange <maxence@artificial-owl.com>2024-01-15 13:50:44 -0100
committerMaxence Lange <maxence@artificial-owl.com>2024-01-15 15:45:13 -0100
commit6daea857ab286aae98120bf7d1e1034aeaa44bca (patch)
treee7edb14f82b87d04a032a287ab0339d0d29390d6 /lib
parentf7d0c74b1003af6c47dd6ec74f4ef904a2681d62 (diff)
downloadnextcloud-server-6daea857ab286aae98120bf7d1e1034aeaa44bca.tar.gz
nextcloud-server-6daea857ab286aae98120bf7d1e1034aeaa44bca.zip
fixes
Signed-off-by: Maxence Lange <maxence@artificial-owl.com> d Signed-off-by: Maxence Lange <maxence@artificial-owl.com>
Diffstat (limited to 'lib')
-rw-r--r--lib/private/AppConfig.php195
-rw-r--r--lib/public/IAppConfig.php101
2 files changed, 69 insertions, 227 deletions
diff --git a/lib/private/AppConfig.php b/lib/private/AppConfig.php
index 071f7d79542..94a8fae3081 100644
--- a/lib/private/AppConfig.php
+++ b/lib/private/AppConfig.php
@@ -46,30 +46,26 @@ use OCP\Exceptions\AppConfigUnknownKeyException;
use OCP\IAppConfig;
use OCP\IConfig;
use OCP\IDBConnection;
-use OCP\Util;
use Psr\Log\LoggerInterface;
/**
* This class provides an easy way for apps to store config values in the
* database.
*
- * **Note:** since 29.0.0, it supports **lazy grouping**
+ * **Note:** since 29.0.0, it supports **lazy loading**
*
- * ### What is lazy grouping ?
- * In order to avoid loading useless config values in memory for each request on
- * the cloud, it has been made possible to group your config keys.
- * Each group, called _lazy group_, is only loaded in memory when one its config
- * keys is retrieved.
+ * ### What is lazy loading ?
+ * In order to avoid loading useless config values into memory for each request,
+ * only non-lazy values are now loaded.
*
- * It is advised to only use the default lazy group, named '' (empty string), for
- * config keys used in the registered part of your code that is called even when
- * your app is not boot (as in event listeners, ...)
+ * Once a value that is lazy is requested, all lazy values will be loaded.
*
- * **WARNING:** some methods from this class are marked with a warning about ignoring
- * lazy grouping, use them wisely and only on part of code called during
- * specific request/action
+ * Similarly, some methods from this class are marked with a warning about ignoring
+ * lazy loading. Use them wisely and only on parts of the code that are called
+ * during specific requests or actions to avoid loading the lazy values all the time.
*
* @since 7.0.0
+ * @since 29.0.0 - Supporting types and lazy loading
*/
class AppConfig implements IAppConfig {
private const APP_MAX_LENGTH = 32;
@@ -149,12 +145,10 @@ class AppConfig implements IAppConfig {
}
if ($lazy) {
- $cache = &$this->lazyCache;
- } else {
- $cache = &$this->fastCache;
+ return isset($this->lazyCache[$app][$key]);
}
- return isset($cache[$app][$key]);
+ return isset($this->fastCache[$app][$key]);
}
/**
@@ -254,9 +248,9 @@ class AppConfig implements IAppConfig {
/** @var array<array-key, array<array-key, mixed>> $cache */
if ($lazy) {
- $cache = &$this->lazyCache;
+ $cache = $this->lazyCache;
} else {
- $cache = &$this->fastCache;
+ $cache = $this->fastCache;
}
foreach (array_keys($cache) as $app) {
@@ -270,12 +264,12 @@ class AppConfig implements IAppConfig {
/**
- * Get any config value, will be returned as string.
- * If value does not exist, will return $default
+ * Get the config value as string.
+ * If the value does not exist the given default will be returned.
*
- * $lazy can be NULL to ignore lazy loading
+ * Set lazy to `null` to ignore it and get the value from either source.
*
- * **WARNING:** Method is internal and **MUST** not be used as it is best to set a real value type
+ * **WARNING:** Method is internal and **SHOULD** not be used, as it is better to get the value with a type.
*
* @param string $app id of the app
* @param string $key config key
@@ -285,13 +279,12 @@ class AppConfig implements IAppConfig {
* @return string the value or $default
* @internal
* @since 29.0.0
- * @see IAppConfig for explanation about lazy grouping
+ * @see IAppConfig for explanation about lazy loading
* @see getValueString()
* @see getValueInt()
- * @see getValueBigInt()
* @see getValueFloat()
* @see getValueBool()
- * @see setValueArray()
+ * @see getValueArray()
*/
public function getValueMixed(
string $app,
@@ -321,11 +314,6 @@ class AppConfig implements IAppConfig {
* @throws AppConfigTypeConflictException in case of conflict with the value type set in database
* @since 29.0.0
* @see IAppConfig for explanation about lazy loading
- * @see getValueInt()
- * @see getValueBigInt()
- * @see getValueFloat()
- * @see getValueBool()
- * @see getValueArray()
*/
public function getValueString(
string $app,
@@ -349,11 +337,6 @@ class AppConfig implements IAppConfig {
* @throws AppConfigTypeConflictException in case of conflict with the value type set in database
* @since 29.0.0
* @see IAppConfig for explanation about lazy loading
- * @see getValueString()
- * @see getValueBigInt()
- * @see getValueFloat()
- * @see getValueBool()
- * @see getValueArray()
*/
public function getValueInt(
string $app,
@@ -369,34 +352,6 @@ class AppConfig implements IAppConfig {
*
* @param string $app id of the app
* @param string $key config key
- * @param int|float $default default value
- * @param bool $lazy search within lazy loaded config
- *
- * @return int|float stored config value or $default if not set in database
- * @throws InvalidArgumentException if one of the argument format is invalid
- * @throws AppConfigTypeConflictException in case of conflict with the value type set in database
- * @since 29.0.0
- * @see IAppConfig for explanation about lazy loading
- * @see getValueString()
- * @see getValueInt()
- * @see getValueFloat()
- * @see getValueBool()
- * @see getValueArray()
- */
- public function getValueBigInt(
- string $app,
- string $key,
- int|float $default = 0,
- bool $lazy = false
- ): int|float {
- return Util::numericToNumber($this->getTypedValue($app, $key, (string)$default, $lazy, self::VALUE_INT));
- }
-
- /**
- * @inheritDoc
- *
- * @param string $app id of the app
- * @param string $key config key
* @param float $default default value
* @param bool $lazy search within lazy loaded config
*
@@ -405,11 +360,6 @@ class AppConfig implements IAppConfig {
* @throws AppConfigTypeConflictException in case of conflict with the value type set in database
* @since 29.0.0
* @see IAppConfig for explanation about lazy loading
- * @see getValueString()
- * @see getValueInt()
- * @see getValueBigInt()
- * @see getValueBool()
- * @see getValueArray()
*/
public function getValueFloat(string $app, string $key, float $default = 0, bool $lazy = false): float {
return (float)$this->getTypedValue($app, $key, (string)$default, $lazy, self::VALUE_FLOAT);
@@ -428,11 +378,6 @@ class AppConfig implements IAppConfig {
* @throws AppConfigTypeConflictException in case of conflict with the value type set in database
* @since 29.0.0
* @see IAppConfig for explanation about lazy loading
- * @see getValueString()
- * @see getValueInt()
- * @see getValueBigInt()
- * @see getValueFloat()
- * @see getValueArray()
*/
public function getValueBool(string $app, string $key, bool $default = false, bool $lazy = false): bool {
$b = strtolower($this->getTypedValue($app, $key, $default ? 'true' : 'false', $lazy, self::VALUE_BOOL));
@@ -452,11 +397,6 @@ class AppConfig implements IAppConfig {
* @throws AppConfigTypeConflictException in case of conflict with the value type set in database
* @since 29.0.0
* @see IAppConfig for explanation about lazy loading
- * @see getValueString()
- * @see getValueInt()
- * @see getValueBigInt()
- * @see getValueFloat()
- * @see getValueBool()
*/
public function getValueArray(
string $app,
@@ -510,12 +450,10 @@ class AppConfig implements IAppConfig {
}
if ($lazy) {
- $cache = &$this->lazyCache;
- } else {
- $cache = &$this->fastCache;
+ return $this->lazyCache[$app][$key] ?? $default;
}
- return $cache[$app][$key] ?? $default;
+ return $this->fastCache[$app][$key] ?? $default;
}
/**
@@ -537,7 +475,11 @@ class AppConfig implements IAppConfig {
$this->assertParams($app, $key);
$this->loadConfigAll();
- $type = $this->valueTypes[$app][$key] ?? throw new AppConfigUnknownKeyException('unknown config key');
+ if (!isset($this->valueTypes[$app][$key])) {
+ throw new AppConfigUnknownKeyException('unknown config key');
+ }
+
+ $type = $this->valueTypes[$app][$key];
$type &= ~self::VALUE_SENSITIVE;
return $type;
}
@@ -558,10 +500,9 @@ class AppConfig implements IAppConfig {
* @throws AppConfigTypeConflictException if type from database is not VALUE_MIXED
* @internal
* @since 29.0.0
- * @see IAppConfig for explanation about lazy grouping
+ * @see IAppConfig for explanation about lazy loading
* @see setValueString()
* @see setValueInt()
- * @see setValueBigInt()
* @see setValueFloat()
* @see setValueBool()
* @see setValueArray()
@@ -596,11 +537,6 @@ class AppConfig implements IAppConfig {
* @throws AppConfigTypeConflictException if type from database is not VALUE_MIXED and different from the requested one
* @since 29.0.0
* @see IAppConfig for explanation about lazy loading
- * @see setValueInt()
- * @see setValueBigInt()
- * @see setValueFloat()
- * @see setValueBool()
- * @see setValueArray()
*/
public function setValueString(
string $app,
@@ -631,11 +567,6 @@ class AppConfig implements IAppConfig {
* @throws AppConfigTypeConflictException if type from database is not VALUE_MIXED and different from the requested one
* @since 29.0.0
* @see IAppConfig for explanation about lazy loading
- * @see setValueString()
- * @see setValueBigInt()
- * @see setValueFloat()
- * @see setValueBool()
- * @see setValueArray()
*/
public function setValueInt(
string $app,
@@ -644,42 +575,10 @@ class AppConfig implements IAppConfig {
bool $lazy = false,
bool $sensitive = false
): bool {
- return $this->setTypedValue(
- $app,
- $key,
- (string)$value,
- $lazy,
- self::VALUE_INT | ($sensitive ? self::VALUE_SENSITIVE : 0)
- );
- }
-
+ if ($value > 2147400000) {
+ $this->logger->debug('You are trying to store an integer value around/above 2,147,483,647. This is a reminder that reaching this theoretical limit on 32 bits system will result to an exception.');
+ }
- /**
- * @inheritDoc
- *
- * @param string $app id of the app
- * @param string $key config key
- * @param int|float $value config value
- * @param bool $lazy set config as lazy loaded
- * @param bool $sensitive if TRUE value will be hidden when listing config values.
- *
- * @return bool TRUE if value was different, therefor updated in database
- * @throws AppConfigTypeConflictException if type from database is not VALUE_MIXED and different from the requested one
- * @since 29.0.0
- * @see IAppConfig for explanation about lazy loading
- * @see setValueString()
- * @see setValueInt()
- * @see setValueFloat()
- * @see setValueBool()
- * @see setValueArray()
- */
- public function setValueBigInt(
- string $app,
- string $key,
- int|float $value,
- bool $lazy = false,
- bool $sensitive = false
- ): bool {
return $this->setTypedValue(
$app,
$key,
@@ -689,7 +588,6 @@ class AppConfig implements IAppConfig {
);
}
-
/**
* @inheritDoc
*
@@ -703,11 +601,6 @@ class AppConfig implements IAppConfig {
* @throws AppConfigTypeConflictException if type from database is not VALUE_MIXED and different from the requested one
* @since 29.0.0
* @see IAppConfig for explanation about lazy loading
- * @see setValueString()
- * @see setValueInt()
- * @see setValueBigInt()
- * @see setValueBool()
- * @see setValueArray()
*/
public function setValueFloat(
string $app,
@@ -737,11 +630,6 @@ class AppConfig implements IAppConfig {
* @throws AppConfigTypeConflictException if type from database is not VALUE_MIXED and different from the requested one
* @since 29.0.0
* @see IAppConfig for explanation about lazy loading
- * @see setValueString()
- * @see setValueInt()
- * @see setValueBigInt()
- * @see setValueFloat()
- * @see setValueArray()
*/
public function setValueBool(
string $app,
@@ -772,11 +660,6 @@ class AppConfig implements IAppConfig {
* @throws JsonException
* @since 29.0.0
* @see IAppConfig for explanation about lazy loading
- * @see setValueString()
- * @see setValueInt()
- * @see setValueBigInt()
- * @see setValueFloat()
- * @see setValueBool()
*/
public function setValueArray(
string $app,
@@ -860,6 +743,15 @@ class AppConfig implements IAppConfig {
}
/**
+ * This should only happen during the upgrade process from 28 to 29.
+ * We only log a warning and set it to VALUE_MIXED.
+ */
+ if ($currType === 0) {
+ $this->logger->warning('Value type is set to zero (0) in database. This is fine only during the upgrade process from 28 to 29.', ['app' => $app, 'key' => $key]);
+ $currType = self::VALUE_MIXED;
+ }
+
+ /**
* we only accept a different type from the one stored in database
* if the one stored in database is not-defined (VALUE_MIXED)
*/
@@ -869,6 +761,7 @@ class AppConfig implements IAppConfig {
$currType = $this->convertTypeToString($currType);
$type = $this->convertTypeToString($type);
} catch (AppConfigIncorrectTypeException) {
+ // can be ignored, this was just needed for a better exception message.
}
throw new AppConfigTypeConflictException('conflict between new type (' . $type . ') and old type (' . $currType . ')');
}
@@ -1049,9 +942,9 @@ class AppConfig implements IAppConfig {
$lazy = $this->isLazy($app, $key);
if ($lazy) {
- $cache = &$this->lazyCache;
+ $cache = $this->lazyCache;
} else {
- $cache = &$this->fastCache;
+ $cache = $this->fastCache;
}
$type = $this->getValueType($app, $key);
@@ -1066,8 +959,8 @@ class AppConfig implements IAppConfig {
'app' => $app,
'key' => $key,
'value' => $cache[$app][$key] ?? throw new AppConfigUnknownKeyException('unknown config key'),
- 'lazy' => $lazy,
'type' => $type,
+ 'lazy' => $lazy,
'typeString' => $typeString,
'sensitive' => $this->isSensitive($app, $key, null)
];
@@ -1197,7 +1090,7 @@ class AppConfig implements IAppConfig {
}
/**
- * Confirm the string set for app, key and lazyGroup fit the database description
+ * Confirm the string set for app and key fit the database description
*
* @param string $app assert $app fit in database
* @param string $configKey assert config key fit in database
diff --git a/lib/public/IAppConfig.php b/lib/public/IAppConfig.php
index b5d6d26a4b5..9bdeb14b295 100644
--- a/lib/public/IAppConfig.php
+++ b/lib/public/IAppConfig.php
@@ -38,31 +38,32 @@ use OCP\Exceptions\AppConfigUnknownKeyException;
* **Note:** since 29.0.0, it supports **lazy loading**
*
* ### What is lazy loading ?
+ * In order to avoid loading useless config values into memory for each request,
+ * only non-lazy values are now loaded.
*
- * By default, app config values are all loaded in memory; but in order to avoid
- * loading useless config values in memory on each request on the cloud, it has
- * been made possible to set your config keys as lazy.
- * When set as lazy, the values will only be loaded in memory when needed.
- * In fact, the cloud will load all config set as lazy loaded when a first one
- * is requested.
+ * Once a value that is lazy is requested, all lazy values will be loaded.
*
- * It is advised to set a config key as lazy when its value is only needed during
- * really specific request, in part of code that is not called frequently.
+ * Similarly, some methods from this class are marked with a warning about ignoring
+ * lazy loading. Use them wisely and only on parts of the code that are called
+ * during specific requests or actions to avoid loading the lazy values all the time.
*
- * **Note:** some methods from this class are marked with a warning about ignoring
- * lazy filtering, meaning it will load in memory all apps config values. use them
- * wisely and only in part of code called during specific request/action.
- *
- * @since 29.0.0 supports lazy loading
* @since 7.0.0
+ * @since 29.0.0 - Supporting types and lazy loading
*/
interface IAppConfig {
+ /** @since 29.0.0 */
public const VALUE_SENSITIVE = 1;
+ /** @since 29.0.0 */
public const VALUE_MIXED = 2;
+ /** @since 29.0.0 */
public const VALUE_STRING = 4;
+ /** @since 29.0.0 */
public const VALUE_INT = 8;
+ /** @since 29.0.0 */
public const VALUE_FLOAT = 16;
+ /** @since 29.0.0 */
public const VALUE_BOOL = 32;
+ /** @since 29.0.0 */
public const VALUE_ARRAY = 64;
/**
@@ -170,7 +171,6 @@ interface IAppConfig {
* @since 29.0.0
* @see IAppConfig for explanation about lazy loading
* @see getValueInt()
- * @see getValueBigInt()
* @see getValueFloat()
* @see getValueBool()
* @see getValueArray()
@@ -191,7 +191,6 @@ interface IAppConfig {
* @since 29.0.0
* @see IAppConfig for explanation about lazy loading
* @see getValueString()
- * @see getValueBigInt()
* @see getValueFloat()
* @see getValueBool()
* @see getValueArray()
@@ -205,27 +204,6 @@ interface IAppConfig {
*
* @param string $app id of the app
* @param string $key config key
- * @param int|float $default default value
- * @param bool $lazy search within lazy loaded config
- *
- * @return int|float stored config value or $default if not set in database
- * @since 29.0.0
- * @see IAppConfig for explanation about lazy loading
- * @see getValueString()
- * @see getValueInt()
- * @see getValueFloat()
- * @see getValueBool()
- * @see getValueArray()
- */
- public function getValueBigInt(string $app, string $key, int|float $default = 0, bool $lazy = false): int|float;
-
- /**
- * Get config value assigned to a config key.
- * If config key is not found in database, default value is returned.
- * If config key is set as lazy loaded, the $lazy argument needs to be set to TRUE.
- *
- * @param string $app id of the app
- * @param string $key config key
* @param float $default default value
* @param bool $lazy search within lazy loaded config
*
@@ -234,7 +212,6 @@ interface IAppConfig {
* @see IAppConfig for explanation about lazy loading
* @see getValueString()
* @see getValueInt()
- * @see getValueBigInt()
* @see getValueBool()
* @see getValueArray()
*/
@@ -255,7 +232,6 @@ interface IAppConfig {
* @see IAppConfig for explanation about lazy loading
* @see getValueString()
* @see getValueInt()
- * @see getValueBigInt()
* @see getValueFloat()
* @see getValueArray()
*/
@@ -276,7 +252,6 @@ interface IAppConfig {
* @see IAppConfig for explanation about lazy loading
* @see getValueString()
* @see getValueInt()
- * @see getValueBigInt()
* @see getValueFloat()
* @see getValueBool()
*/
@@ -317,9 +292,8 @@ interface IAppConfig {
*
* @return bool TRUE if value was different, therefor updated in database
* @since 29.0.0
- * @see IAppConfig for explanation about lazy grouping
+ * @see IAppConfig for explanation about lazy loading
* @see setValueInt()
- * @see setValueBigInt()
* @see setValueFloat()
* @see setValueBool()
* @see setValueArray()
@@ -329,31 +303,10 @@ interface IAppConfig {
/**
* Store a config key and its value in database
*
- * If config key is already known with the exact same config value, the database is not updated.
- * If config key is not supposed to be read during the boot of the cloud, it is advised to set it as lazy loaded.
+ * When handling huge value around and/or above 2,147,483,647, a debug log will be generated
+ * on 64bits system, as php int type reach its limit (and throw an exception) on 32bits when using huge numbers.
*
- * If config value was previously stored as sensitive or lazy loaded, status cannot be altered without using {@see deleteKey()} first
- *
- * @param string $app id of the app
- * @param string $key config key
- * @param int $value config value
- * @param bool $sensitive if TRUE value will be hidden when listing config values.
- * @param bool $lazy set config as lazy loaded
- *
- * @return bool TRUE if value was different, therefor updated in database
- * @since 29.0.0
- * @see IAppConfig for explanation about lazy grouping
- * @see setValueString()
- * @see setValueBigInt()
- * @see setValueFloat()
- * @see setValueBool()
- * @see setValueArray()
- */
- public function setValueInt(string $app, string $key, int $value, bool $lazy = false, bool $sensitive = false): bool;
-
-
- /**
- * Store a config key and its value in database
+ * When using huge numbers, it is advised to use {@see \OCP\Util::numericToNumber()} and {@see setValueString()}
*
* If config key is already known with the exact same config value, the database is not updated.
* If config key is not supposed to be read during the boot of the cloud, it is advised to set it as lazy loaded.
@@ -362,23 +315,22 @@ interface IAppConfig {
*
* @param string $app id of the app
* @param string $key config key
- * @param int|float $value config value
+ * @param int $value config value
* @param bool $sensitive if TRUE value will be hidden when listing config values.
* @param bool $lazy set config as lazy loaded
*
* @return bool TRUE if value was different, therefor updated in database
* @since 29.0.0
- * @see IAppConfig for explanation about lazy grouping
+ * @see IAppConfig for explanation about lazy loading
* @see setValueString()
- * @see setValueBigInt()
* @see setValueFloat()
* @see setValueBool()
* @see setValueArray()
*/
- public function setValueBigInt(string $app, string $key, int|float $value, bool $lazy = false, bool $sensitive = false): bool;
+ public function setValueInt(string $app, string $key, int $value, bool $lazy = false, bool $sensitive = false): bool;
/**
- * Store a config key and its value in database
+ * Store a config key and its value in database.
*
* If config key is already known with the exact same config value, the database is not updated.
* If config key is not supposed to be read during the boot of the cloud, it is advised to set it as lazy loaded.
@@ -393,10 +345,9 @@ interface IAppConfig {
*
* @return bool TRUE if value was different, therefor updated in database
* @since 29.0.0
- * @see IAppConfig for explanation about lazy grouping
+ * @see IAppConfig for explanation about lazy loading
* @see setValueString()
* @see setValueInt()
- * @see setValueBigInt()
* @see setValueBool()
* @see setValueArray()
*/
@@ -417,10 +368,9 @@ interface IAppConfig {
*
* @return bool TRUE if value was different, therefor updated in database
* @since 29.0.0
- * @see IAppConfig for explanation about lazy grouping
+ * @see IAppConfig for explanation about lazy loading
* @see setValueString()
* @see setValueInt()
- * @see setValueBigInt()
* @see setValueFloat()
* @see setValueArray()
*/
@@ -442,10 +392,9 @@ interface IAppConfig {
*
* @return bool TRUE if value was different, therefor updated in database
* @since 29.0.0
- * @see IAppConfig for explanation about lazy grouping
+ * @see IAppConfig for explanation about lazy loading
* @see setValueString()
* @see setValueInt()
- * @see setValueBigInt()
* @see setValueFloat()
* @see setValueBool()
*/