aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--lib/unstable/Config/IUserConfig.php95
-rw-r--r--lib/unstable/Config/ValueType.php4
2 files changed, 97 insertions, 2 deletions
diff --git a/lib/unstable/Config/IUserConfig.php b/lib/unstable/Config/IUserConfig.php
index 21e5b6fb014..56ba797b9dd 100644
--- a/lib/unstable/Config/IUserConfig.php
+++ b/lib/unstable/Config/IUserConfig.php
@@ -31,9 +31,15 @@ use NCU\Config\Exceptions\UnknownKeyException;
* @since 31.0.0
*/
interface IUserConfig {
- /** @since 31.0.0 */
+ /**
+ * @experimental 31.0.0
+ * @since 31.0.0
+ */
public const FLAG_SENSITIVE = 1; // value is sensitive
- /** @since 31.0.0 */
+ /**
+ * @experimental 31.0.0
+ * @since 31.0.0
+ */
public const FLAG_INDEXED = 2; // value should be indexed
/**
@@ -45,6 +51,8 @@ interface IUserConfig {
* @param string $appId optional id of app
*
* @return list<string> list of userIds
+ *
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function getUserIds(string $appId = ''): array;
@@ -58,6 +66,8 @@ interface IUserConfig {
* @param string $userId id of the user
*
* @return list<string> list of app ids
+ *
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function getApps(string $userId): array;
@@ -72,6 +82,8 @@ interface IUserConfig {
* @param string $app id of the app
*
* @return list<string> list of stored config keys
+ *
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function getKeys(string $userId, string $app): array;
@@ -85,6 +97,8 @@ interface IUserConfig {
* @param bool $lazy search within lazy loaded config
*
* @return bool TRUE if key exists
+ *
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function hasKey(string $userId, string $app, string $key, ?bool $lazy = false): bool;
@@ -99,6 +113,8 @@ interface IUserConfig {
*
* @return bool TRUE if value is sensitive
* @throws UnknownKeyException if config key is not known
+ *
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function isSensitive(string $userId, string $app, string $key, ?bool $lazy = false): bool;
@@ -118,6 +134,8 @@ interface IUserConfig {
*
* @return bool TRUE if value is sensitive
* @throws UnknownKeyException if config key is not known
+ *
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function isIndexed(string $userId, string $app, string $key, ?bool $lazy = false): bool;
@@ -134,6 +152,8 @@ interface IUserConfig {
* @return bool TRUE if config is lazy loaded
* @throws UnknownKeyException if config key is not known
* @see IUserConfig for details about lazy loading
+ *
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function isLazy(string $userId, string $app, string $key): bool;
@@ -150,6 +170,8 @@ interface IUserConfig {
* @param bool $filtered filter sensitive config values
*
* @return array<string, string|int|float|bool|array> [key => value]
+ *
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function getValues(string $userId, string $app, string $prefix = '', bool $filtered = false): array;
@@ -164,6 +186,8 @@ interface IUserConfig {
* @param bool $filtered filter sensitive config values
*
* @return array<string, string|int|float|bool|array> [key => value]
+ *
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function getAllValues(string $userId, bool $filtered = false): array;
@@ -178,6 +202,8 @@ interface IUserConfig {
* @param ValueType|null $typedAs enforce type for the returned values
*
* @return array<string, string|int|float|bool|array> [appId => value]
+ *
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function getValuesByApps(string $userId, string $key, bool $lazy = false, ?ValueType $typedAs = null): array;
@@ -194,6 +220,8 @@ interface IUserConfig {
* @param array|null $userIds limit the search to a list of user ids
*
* @return array<string, string|int|float|bool|array> [userId => value]
+ *
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function getValuesByUsers(string $app, string $key, ?ValueType $typedAs = null, ?array $userIds = null): array;
@@ -210,6 +238,8 @@ interface IUserConfig {
* @param bool $caseInsensitive non-case-sensitive search, only works if $value is a string
*
* @return Generator<string>
+ *
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function searchUsersByValueString(string $app, string $key, string $value, bool $caseInsensitive = false): Generator;
@@ -225,6 +255,8 @@ interface IUserConfig {
* @param int $value config value
*
* @return Generator<string>
+ *
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function searchUsersByValueInt(string $app, string $key, int $value): Generator;
@@ -240,6 +272,8 @@ interface IUserConfig {
* @param array $values list of possible config values
*
* @return Generator<string>
+ *
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function searchUsersByValues(string $app, string $key, array $values): Generator;
@@ -255,6 +289,8 @@ interface IUserConfig {
* @param bool $value config value
*
* @return Generator<string>
+ *
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function searchUsersByValueBool(string $app, string $key, bool $value): Generator;
@@ -271,7 +307,10 @@ interface IUserConfig {
* @param bool $lazy search within lazy loaded config
*
* @return string stored config value or $default if not set in database
+ *
+ * @experimental 31.0.0
* @since 31.0.0
+ *
* @see IUserConfig for explanation about lazy loading
* @see getValueInt()
* @see getValueFloat()
@@ -292,7 +331,10 @@ interface IUserConfig {
* @param bool $lazy search within lazy loaded config
*
* @return int stored config value or $default if not set in database
+ *
+ * @experimental 31.0.0
* @since 31.0.0
+ *
* @see IUserConfig for explanation about lazy loading
* @see getValueString()
* @see getValueFloat()
@@ -313,7 +355,10 @@ interface IUserConfig {
* @param bool $lazy search within lazy loaded config
*
* @return float stored config value or $default if not set in database
+ *
+ * @experimental 31.0.0
* @since 31.0.0
+ *
* @see IUserConfig for explanation about lazy loading
* @see getValueString()
* @see getValueInt()
@@ -334,7 +379,10 @@ interface IUserConfig {
* @param bool $lazy search within lazy loaded config
*
* @return bool stored config value or $default if not set in database
+ *
+ * @experimental 31.0.0
* @since 31.0.0
+ *
* @see IUserPrefences for explanation about lazy loading
* @see getValueString()
* @see getValueInt()
@@ -355,7 +403,10 @@ interface IUserConfig {
* @param bool $lazy search within lazy loaded config
*
* @return array stored config value or $default if not set in database
+ *
+ * @experimental 31.0.0
* @since 31.0.0
+ *
* @see IUserConfig for explanation about lazy loading
* @see getValueString()
* @see getValueInt()
@@ -378,6 +429,8 @@ interface IUserConfig {
* @return ValueType type of the value
* @throws UnknownKeyException if config key is not known
* @throws IncorrectTypeException if config value type is not known
+ *
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function getValueType(string $userId, string $app, string $key, ?bool $lazy = null): ValueType;
@@ -396,6 +449,8 @@ interface IUserConfig {
* @return int a bitflag in relation to the config value
* @throws UnknownKeyException if config key is not known
* @throws IncorrectTypeException if config value type is not known
+ *
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function getValueFlags(string $userId, string $app, string $key, bool $lazy = false): int;
@@ -416,7 +471,10 @@ interface IUserConfig {
* @param bool $lazy set config as lazy loaded
*
* @return bool TRUE if value was different, therefor updated in database
+ *
+ * @experimental 31.0.0
* @since 31.0.0
+ *
* @see IUserConfig for explanation about lazy loading
* @see setValueInt()
* @see setValueFloat()
@@ -446,7 +504,10 @@ interface IUserConfig {
* @param bool $lazy set config as lazy loaded
*
* @return bool TRUE if value was different, therefor updated in database
+ *
+ * @experimental 31.0.0
* @since 31.0.0
+ *
* @see IUserConfig for explanation about lazy loading
* @see setValueString()
* @see setValueFloat()
@@ -471,7 +532,10 @@ interface IUserConfig {
* @param bool $lazy set config as lazy loaded
*
* @return bool TRUE if value was different, therefor updated in database
+ *
+ * @experimental 31.0.0
* @since 31.0.0
+ *
* @see IUserConfig for explanation about lazy loading
* @see setValueString()
* @see setValueInt()
@@ -495,7 +559,10 @@ interface IUserConfig {
* @param bool $lazy set config as lazy loaded
*
* @return bool TRUE if value was different, therefor updated in database
+ *
+ * @experimental 31.0.0
* @since 31.0.0
+ *
* @see IUserConfig for explanation about lazy loading
* @see setValueString()
* @see setValueInt()
@@ -520,7 +587,10 @@ interface IUserConfig {
* @param bool $lazy set config as lazy loaded
*
* @return bool TRUE if value was different, therefor updated in database
+ *
+ * @experimental 31.0.0
* @since 31.0.0
+ *
* @see IUserConfig for explanation about lazy loading
* @see setValueString()
* @see setValueInt()
@@ -540,6 +610,8 @@ interface IUserConfig {
* @param bool $sensitive TRUE to set as sensitive, FALSE to unset
*
* @return bool TRUE if database update were necessary
+ *
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function updateSensitive(string $userId, string $app, string $key, bool $sensitive): bool;
@@ -553,6 +625,7 @@ interface IUserConfig {
* @param string $key config key
* @param bool $sensitive TRUE to set as sensitive, FALSE to unset
*
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function updateGlobalSensitive(string $app, string $key, bool $sensitive): void;
@@ -569,6 +642,8 @@ interface IUserConfig {
* @param bool $indexed TRUE to set as indexed, FALSE to unset
*
* @return bool TRUE if database update were necessary
+ *
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function updateIndexed(string $userId, string $app, string $key, bool $indexed): bool;
@@ -581,6 +656,8 @@ interface IUserConfig {
* @param string $app id of the app
* @param string $key config key
* @param bool $indexed TRUE to set as indexed, FALSE to unset
+ *
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function updateGlobalIndexed(string $app, string $key, bool $indexed): void;
@@ -594,6 +671,8 @@ interface IUserConfig {
* @param bool $lazy TRUE to set as lazy loaded, FALSE to unset
*
* @return bool TRUE if database update was necessary
+ *
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function updateLazy(string $userId, string $app, string $key, bool $lazy): bool;
@@ -606,6 +685,8 @@ interface IUserConfig {
* @param string $app id of the app
* @param string $key config key
* @param bool $lazy TRUE to set as lazy loaded, FALSE to unset
+ *
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function updateGlobalLazy(string $app, string $key, bool $lazy): void;
@@ -631,6 +712,8 @@ interface IUserConfig {
*
* @return array
* @throws UnknownKeyException if config key is not known in database
+ *
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function getDetails(string $userId, string $app, string $key): array;
@@ -642,6 +725,7 @@ interface IUserConfig {
* @param string $app id of the app
* @param string $key config key
*
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function deleteUserConfig(string $userId, string $app, string $key): void;
@@ -652,6 +736,7 @@ interface IUserConfig {
* @param string $app id of the app
* @param string $key config key
*
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function deleteKey(string $app, string $key): void;
@@ -660,6 +745,8 @@ interface IUserConfig {
* delete all config keys linked to an app
*
* @param string $app id of the app
+ *
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function deleteApp(string $app): void;
@@ -668,6 +755,8 @@ interface IUserConfig {
* delete all config keys linked to a user
*
* @param string $userId id of the user
+ *
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function deleteAllUserConfig(string $userId): void;
@@ -680,6 +769,7 @@ interface IUserConfig {
* @param string $userId id of the user
* @param bool $reload set to TRUE to refill cache instantly after clearing it
*
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function clearCache(string $userId, bool $reload = false): void;
@@ -688,6 +778,7 @@ interface IUserConfig {
* Clear the cache for all users.
* The cache will be rebuilt only the next time a user config is requested.
*
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function clearCacheAll(): void;
diff --git a/lib/unstable/Config/ValueType.php b/lib/unstable/Config/ValueType.php
index 3e1e47e9d7c..9f49f7241f8 100644
--- a/lib/unstable/Config/ValueType.php
+++ b/lib/unstable/Config/ValueType.php
@@ -38,6 +38,8 @@ enum ValueType: int {
*
* @return self
* @throws IncorrectTypeException
+ *
+ * @experimental 31.0.0
* @since 31.0.0
*/
public static function fromStringDefinition(string $definition): self {
@@ -60,6 +62,8 @@ enum ValueType: int {
*
* @return string
* @throws IncorrectTypeException
+ *
+ * @experimental 31.0.0
* @since 31.0.0
*/
public function getDefinition(): string {