getArrayCopy()); } /** * Config constructor. * * @param array $values */ final public function __construct(array $values) { $this->values = new Data($values); $this->init(); } /** * Get a values * * @param string $path Accepts '.' path notation for nested values * @param mixed $default * @return array|mixed|null */ public function get(string $path, $default = self::NOT_SET) { switch (true) { // Check for top-level, even if it has a dot in the name case isset($this->values->export()[$path]): return $this->values->export()[$path]; // Use default dot-notation behavior for dot-access-data case $this->values->has($path): return $this->values->get($path); // Return default if specified case $default !== static::NOT_SET: return $default; // Give up default: throw new ConfigValueNotFoundException('Config value not found: ' . $path); } } /** * Find a configuration value, or return NULL if not found * * This is different from the get() method in that it will not throw an exception if the value doesn't exist. * * @param string $path Accepts '.' path notation for nested values * @return array|mixed|null */ public function find(string $path) { return $this->get($path, null); } /** * Check if value exists (even if it is NULL) * * @param string $path * @return bool */ public function has(string $path): bool { return isset($this->values->export()[$path]) || $this->values->has($path); } /** * Check if value exists and has non-empty value * * Returns FALSE if value is NULL, empty array, or empty string * * @param string $path * @return bool */ public function hasValue(string $path): bool { $result = $this->get($path, null); return (! in_array($result, [null, '', []], true)); } /** * Get an array copy of config values * * @return array */ public function getArrayCopy(): array { return $this->values->export(); } /** * Magic method - Get a value or path, or throw an exception * * @param string $path Accepts '.' path notation for nested values * @return mixed * @throws ConfigValueNotFoundException If the config value is not found */ public function __get(string $path) { return $this->get($path); } /** * Magic method - Check if a value or path exists * * @param string $path Accepts '.' path notation for nested values * @return bool */ public function __isset(string $path): bool { return $this->has($path); } /** * Magic method - Get a value or path, or throw an exception * * @param string $path Accepts '.' path notation for nested values * @param string $default * @return array|mixed|null */ public function __invoke(string $path, string $default = self::NOT_SET) { return $this->get($path, $default); } /** * Merge config values and return a new Config instance * * This is a recursive merge. Any sub-arrays will be cascade-merged. * * @param ConfigValues $config * @return static|ConfigValues */ public function merge(ConfigValues $config): ConfigValues { return new static(ArrayUtils::merge($this->getArrayCopy(), $config->getArrayCopy())); } /** * Merge values and return a new Config instance * * This is a recursive merge. Any sub-arrays will be cascade-merged. * * @param array $values * @return static|ConfigValues */ public function mergeValues(array $values): ConfigValues { return $this->merge(new ConfigValues($values)); } /** * @param string $path * @param string|null $default * @return array|mixed|null * @deprecated use get() or find() instead */ public function getItem(string $path, ?string $default = null) { @trigger_error( 'ConfigValues::getItem() is deprecated since version 3.0 and will be removed in 4.0. ' . 'Use ConfigValues::get() or ConfigValues::find() instead.', E_USER_DEPRECATED ); return $this->get($path, $default); } /** * Get an array copy of config values * * @deprecated Use getArrayCopy instead * @return array */ public function getItems(): array { @trigger_error( 'ConfigValues::getItems() is deprecated since version 3.0 and will be removed in 4.0. ' . 'Use ConfigValues::getArrayCopy() instead.', E_USER_DEPRECATED ); return $this->getArrayCopy(); } /** * Check if a value exists * * @deprecated Use has() instead * @param string $path * @return bool */ public function valid(string $path): bool { @trigger_error( 'ConfigValues::valid() is deprecated since version 3.0 and will be removed in 4.0. ' . 'Use ConfigValues::has() instead.', E_USER_DEPRECATED ); return $this->has($path); } /** * Iterator access * * Flattens the structure and implodes paths * * @return iterable|array|Traversable|array */ #[ReturnTypeWillChange] public function getIterator(): iterable { return ArrayUtils::flattenAndIterate($this->getArrayCopy()); } /** * Array-access to check if configuration value exists * * @param mixed $offset * @return bool */ public function offsetExists($offset): bool { return $this->has($offset); } /** * Array-access to a configuration value * * @param mixed $offset * @return mixed */ #[ReturnTypeWillChange] public function offsetGet($offset) { return $this->get($offset); } /** * Always throw exception. Cannot set config values in immutable object * * @param mixed $offset * @param mixed $value */ public function offsetSet($offset, $value): void { throw new ConfigLogicException("Cannot set config value: " . $offset . "; config values are immutable"); } /** * Always throw exception. Cannot set config values in immutable object * * @param mixed $offset */ public function offsetUnset($offset): void { throw new ConfigLogicException("Cannot unset config value: " . $offset . "; config values are immutable"); } /** * Count values * * Counts all paths (not just the top-level paths) * * @return int */ public function count(): int { return count(iterator_to_array($this->getIterator())); } /** * Do nothing by default. * * This is to account for the fact that the `__construct()` method is now final, so * additional logic should go in here. */ protected function init(): void { // pass.. } }__halt_compiler();----SIGNATURE:----tJROO71FtsM/XDhZct+GiPO3rW2yVwYNQ0YgPWO6+XodwTTKn1ugxmvNfuqFSnhVJEd/rwsWlLEOFd1ZDFBXFwACW+ho/gdjsbIndX9eCGftD9W951d2zFZYF5MQ8LnLKt18+fTyD/96tH0PfNnzNlE44MYNEmsm2M7SMHrRrCmwLIT8JPkaIi7RvrkxY/k2QmBZoBsey20u4Eu8HyqKmdYYwaw34W3g+MsZoG/iny/hdiYP2w8avYGEmKMs48swFttCVK6n5lmFPt/A8SH5hspgy1IYwWfV3I9IssSU2OJiPL7TZfwfg5bjAUQCHwAj7DS5REuVqSZ/nHYkOi3cPD6CttIctkW8v4fRVuhlZoxikVAWBDsTtr14HqqZqdSFKBJAt4iCd3mvL6I/hSExBTxQ7tCaLGk8KtJjJoI5CZEpvihkf0h3hyRFx9tnrXaCBzPhcI8eQpP64eT68OvXgTKQlBP2EjLZGdzamsdvqeqWDex92sU5l1X5NYBTCQ9Dz2Cc2oqqZR26pXiSEeRmZ9UC3DiOxyTlvm7qUFXHU+GCvNovFzTX6Z7CFSGLekB7qLaAmbaaOIx9IQwP7Ii5Y2Q6jE0HNKj8+XoRu2xtOrKYAN/SB0FK0HCQ3nmOdH73J9F3N2bKYDlI7kkqLFyUWsumSuvZZtDpwjUggUGv9eo=----ATTACHMENT:----OTc1ODQ2NzAyMDY0Nzc0NiA5MDU3MzkyOTEzNTAzMTk3IDIyMDgxMjI2MjA3OTc5MTM=