1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
|
<?php
declare(strict_types=1);
/**
* SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors
* SPDX-License-Identifier: AGPL-3.0-or-later
*/
namespace NCU\Config;
use NCU\Config\Exceptions\IncorrectTypeException;
use OCP\IAppConfig;
use UnhandledMatchError;
/**
* Listing of available value type for typed config value
*
* @experimental 31.0.0
* @deprecated 32.0.0 use \OCP\Config\ValueType
* @see \OCP\Config\ValueType
*/
enum ValueType: int {
/**
* @experimental 31.0.0
* @deprecated 32.0.0 use \OCP\Config\ValueType
* @see \OCP\Config\ValueType
*/
case MIXED = 0;
/**
* @experimental 31.0.0
* @deprecated 32.0.0 use \OCP\Config\ValueType
* @see \OCP\Config\ValueType
*/
case STRING = 1;
/**
* @experimental 31.0.0
* @deprecated 32.0.0 use \OCP\Config\ValueType
* @see \OCP\Config\ValueType
*/
case INT = 2;
/**
* @experimental 31.0.0
* @deprecated 32.0.0 use \OCP\Config\ValueType
* @see \OCP\Config\ValueType
*/
case FLOAT = 3;
/**
* @experimental 31.0.0
* @deprecated 32.0.0 use \OCP\Config\ValueType
* @see \OCP\Config\ValueType
*/
case BOOL = 4;
/**
* @experimental 31.0.0
* @deprecated 32.0.0 use \OCP\Config\ValueType
* @see \OCP\Config\ValueType
*/
case ARRAY = 5;
/**
* get ValueType from string
*
* @param string $definition
*
* @return self
* @throws IncorrectTypeException
*
* @experimental 31.0.0
* @deprecated 32.0.0 use \OCP\Config\ValueType
* @see \OCP\Config\ValueType
* @psalm-suppress DeprecatedConstant
* @psalm-suppress DeprecatedClass
*/
public static function fromStringDefinition(string $definition): self {
try {
return match ($definition) {
'mixed' => self::MIXED,
'string' => self::STRING,
'int' => self::INT,
'float' => self::FLOAT,
'bool' => self::BOOL,
'array' => self::ARRAY
};
} catch (\UnhandledMatchError) {
throw new IncorrectTypeException('unknown string definition');
}
}
/**
* get string definition for current enum value
*
* @return string
* @throws IncorrectTypeException
*
* @experimental 31.0.0
* @deprecated 32.0.0 use \OCP\Config\ValueType
* @see \OCP\Config\ValueType
* @psalm-suppress DeprecatedConstant
* @psalm-suppress DeprecatedClass
*/
public function getDefinition(): string {
try {
return match ($this) {
self::MIXED => 'mixed',
self::STRING => 'string',
self::INT => 'int',
self::FLOAT => 'float',
self::BOOL => 'bool',
self::ARRAY => 'array',
};
} catch (UnhandledMatchError) {
throw new IncorrectTypeException('unknown type definition ' . $this->value);
}
}
/**
* get corresponding AppConfig flag value
*
* @return int
* @throws IncorrectTypeException
*
* @experimental 31.0.0
* @deprecated 32.0.0 use \OCP\Config\ValueType
* @see \OCP\Config\ValueType
* @psalm-suppress DeprecatedConstant
* @psalm-suppress DeprecatedClass
*/
public function toAppConfigFlag(): int {
try {
return match ($this) {
self::MIXED => IAppConfig::VALUE_MIXED,
self::STRING => IAppConfig::VALUE_STRING,
self::INT => IAppConfig::VALUE_INT,
self::FLOAT => IAppConfig::VALUE_FLOAT,
self::BOOL => IAppConfig::VALUE_BOOL,
self::ARRAY => IAppConfig::VALUE_ARRAY,
};
} catch (UnhandledMatchError) {
throw new IncorrectTypeException('unknown type definition ' . $this->value);
}
}
}
|