123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179 |
- <?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);
- while (count($keys) > 1) {
- $key = array_shift($keys);
- if (!isset($this->config[$key]) || !is_array($this->config[$key])) {
- $this->config[$key] = [];
- }
- $this->config = &$this->config[$key];
- }
- $this->config[array_shift($keys)] = $value;
- return $this->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
- */
- 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
- */
- 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
- */
- 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
- */
- public function offsetUnset($offset)
- {
- $this->set($offset, null);
- }
- }
|