aboutsummaryrefslogtreecommitdiffstats
path: root/includes/Settings/Config/ConfigBuilder.php
blob: 02f26de84080e2c08f2012c7aa999598ae05d268 (plain) (blame)
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
<?php

namespace MediaWiki\Settings\Config;

use MediaWiki\Config\Config;
use MediaWiki\Settings\SettingsBuilderException;

/**
 * Builder for Config objects.
 *
 * @unstable
 */
interface ConfigBuilder {

	/**
	 * Set the configuration $key to $value.
	 *
	 * @param string $key
	 * @param mixed $value
	 * @param MergeStrategy|null $mergeStrategy strategy for merging array config values.
	 * @return ConfigBuilder
	 */
	public function set( string $key, $value, ?MergeStrategy $mergeStrategy = null ): ConfigBuilder;

	/**
	 * Set all values in the array.
	 *
	 * @param array $values
	 * @param MergeStrategy[] $mergeStrategies The merge strategies indexed by config key
	 * @return ConfigBuilder
	 */
	public function setMulti( array $values, array $mergeStrategies = [] ): ConfigBuilder;

	/**
	 * Set the default for the configuration $key to $defaultValue.
	 *
	 * If the $key is already set, non-array $defaultValue will be ignored,
	 * for array $defaultValue the existing value will be merged into it as
	 * if the default was already there when the existing value was set.
	 *
	 * @param string $key
	 * @param mixed $defaultValue
	 * @param MergeStrategy|null $mergeStrategy strategy for merging array config values.
	 * @return ConfigBuilder
	 */
	public function setDefault( string $key, $defaultValue, ?MergeStrategy $mergeStrategy = null ): ConfigBuilder;

	/**
	 * Set defaults in a batch.
	 *
	 * @param array $defaults The default values
	 * @param MergeStrategy[] $mergeStrategies The merge strategies indexed by config key
	 * @return ConfigBuilder
	 * @throws SettingsBuilderException if a merge strategy is not provided and
	 *   the value is not an array.
	 */
	public function setMultiDefault( array $defaults, array $mergeStrategies ): ConfigBuilder;

	/**
	 * Get the current value for $key.
	 *
	 * @param string $key
	 * @return mixed
	 */
	public function get( string $key );

	/**
	 * Build the resulting Config object.
	 *
	 * @return Config
	 */
	public function build(): Config;
}