| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180 | 
							- <?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
 
-      */
 
-     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);
 
-     }
 
- }
 
 
  |