You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
184 lines
4.2 KiB
184 lines
4.2 KiB
<?php
|
|
|
|
/*
|
|
* This file is part of the overtrue/socialite.
|
|
*
|
|
* (c) overtrue <i@overtrue.me>
|
|
*
|
|
* This source file is subject to the MIT license that is bundled
|
|
* with this source code in the file LICENSE.
|
|
*/
|
|
|
|
namespace Overtrue\Socialite;
|
|
|
|
use ArrayAccess;
|
|
use InvalidArgumentException;
|
|
|
|
/**
|
|
* Class Config.
|
|
*/
|
|
class Config implements ArrayAccess
|
|
{
|
|
/**
|
|
* @var array
|
|
*/
|
|
protected $config;
|
|
|
|
/**
|
|
* Config constructor.
|
|
*
|
|
* @param array $config
|
|
*/
|
|
public function __construct(array $config)
|
|
{
|
|
$this->config = $config;
|
|
}
|
|
|
|
/**
|
|
* Get an item from an array using "dot" notation.
|
|
*
|
|
* @param string $key
|
|
* @param mixed $default
|
|
*
|
|
* @return mixed
|
|
*/
|
|
public function get($key, $default = null)
|
|
{
|
|
$config = $this->config;
|
|
|
|
if (is_null($key)) {
|
|
return $config;
|
|
}
|
|
if (isset($config[$key])) {
|
|
return $config[$key];
|
|
}
|
|
foreach (explode('.', $key) as $segment) {
|
|
if (!is_array($config) || !array_key_exists($segment, $config)) {
|
|
return $default;
|
|
}
|
|
$config = $config[$segment];
|
|
}
|
|
|
|
return $config;
|
|
}
|
|
|
|
/**
|
|
* Set an array item to a given value using "dot" notation.
|
|
*
|
|
* @param string $key
|
|
* @param mixed $value
|
|
*
|
|
* @return array
|
|
*/
|
|
public function set($key, $value)
|
|
{
|
|
if (is_null($key)) {
|
|
throw new InvalidArgumentException('Invalid config key.');
|
|
}
|
|
|
|
$keys = explode('.', $key);
|
|
$config = &$this->config;
|
|
|
|
while (count($keys) > 1) {
|
|
$key = array_shift($keys);
|
|
if (!isset($config[$key]) || !is_array($config[$key])) {
|
|
$config[$key] = [];
|
|
}
|
|
$config = &$config[$key];
|
|
}
|
|
|
|
$config[array_shift($keys)] = $value;
|
|
|
|
return $config;
|
|
}
|
|
|
|
/**
|
|
* Determine if the given configuration value exists.
|
|
*
|
|
* @param string $key
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function has($key)
|
|
{
|
|
return (bool) $this->get($key);
|
|
}
|
|
|
|
/**
|
|
* Whether a offset exists.
|
|
*
|
|
* @see http://php.net/manual/en/arrayaccess.offsetexists.php
|
|
*
|
|
* @param mixed $offset <p>
|
|
* An offset to check for.
|
|
* </p>
|
|
*
|
|
* @return bool true on success or false on failure.
|
|
* </p>
|
|
* <p>
|
|
* The return value will be casted to boolean if non-boolean was returned
|
|
*
|
|
* @since 5.0.0
|
|
*/
|
|
#[\ReturnTypeWillChange]
|
|
public function offsetExists($offset)
|
|
{
|
|
return array_key_exists($offset, $this->config);
|
|
}
|
|
|
|
/**
|
|
* Offset to retrieve.
|
|
*
|
|
* @see http://php.net/manual/en/arrayaccess.offsetget.php
|
|
*
|
|
* @param mixed $offset <p>
|
|
* The offset to retrieve.
|
|
* </p>
|
|
*
|
|
* @return mixed Can return all value types
|
|
*
|
|
* @since 5.0.0
|
|
*/
|
|
#[\ReturnTypeWillChange]
|
|
public function offsetGet($offset)
|
|
{
|
|
return $this->get($offset);
|
|
}
|
|
|
|
/**
|
|
* Offset to set.
|
|
*
|
|
* @see http://php.net/manual/en/arrayaccess.offsetset.php
|
|
*
|
|
* @param mixed $offset <p>
|
|
* The offset to assign the value to.
|
|
* </p>
|
|
* @param mixed $value <p>
|
|
* The value to set.
|
|
* </p>
|
|
*
|
|
* @since 5.0.0
|
|
*/
|
|
#[\ReturnTypeWillChange]
|
|
public function offsetSet($offset, $value)
|
|
{
|
|
$this->set($offset, $value);
|
|
}
|
|
|
|
/**
|
|
* Offset to unset.
|
|
*
|
|
* @see http://php.net/manual/en/arrayaccess.offsetunset.php
|
|
*
|
|
* @param mixed $offset <p>
|
|
* The offset to unset.
|
|
* </p>
|
|
*
|
|
* @since 5.0.0
|
|
*/
|
|
#[\ReturnTypeWillChange]
|
|
public function offsetUnset($offset)
|
|
{
|
|
$this->set($offset, null);
|
|
}
|
|
}
|
|
|