/usr/share/php/Predis/Option/ClientOptions.php is in libphp-predis 0.8.3-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
| 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 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 | <?php
/*
 * This file is part of the Predis package.
 *
 * (c) Daniele Alessandri <suppakilla@gmail.com>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */
namespace Predis\Option;
/**
 * Class that manages client options with filtering and conversion.
 *
 * @author Daniele Alessandri <suppakilla@gmail.com>
 */
class ClientOptions implements ClientOptionsInterface
{
    private $handlers;
    private $defined;
    private $options = array();
    /**
     * @param array $options Array of client options.
     */
    public function __construct(Array $options = array())
    {
        $this->handlers = $this->initialize($options);
        $this->defined = array_fill_keys(array_keys($options), true);
    }
    /**
     * Ensures that the default options are initialized.
     *
     * @return array
     */
    protected function getDefaultOptions()
    {
        return array(
            'profile' => new ClientProfile(),
            'connections' => new ClientConnectionFactory(),
            'cluster' => new ClientCluster(),
            'replication' => new ClientReplication(),
            'prefix' => new ClientPrefix(),
            'exceptions' => new ClientExceptions(),
        );
    }
    /**
     * Initializes client options handlers.
     *
     * @param array $options List of client options values.
     * @return array
     */
    protected function initialize(Array $options)
    {
        $handlers = $this->getDefaultOptions();
        foreach ($options as $option => $value) {
            if (isset($handlers[$option])) {
                $handler = $handlers[$option];
                $handlers[$option] = function ($options) use ($handler, $value) {
                    return $handler->filter($options, $value);
                };
            } else {
                $this->options[$option] = $value;
            }
        }
        return $handlers;
    }
    /**
     * Checks if the specified option is set.
     *
     * @param string $option Name of the option.
     * @return Boolean
     */
    public function __isset($option)
    {
        return isset($this->defined[$option]);
    }
    /**
     * Returns the value of the specified option.
     *
     * @param string $option Name of the option.
     * @return mixed
     */
    public function __get($option)
    {
        if (isset($this->options[$option])) {
            return $this->options[$option];
        }
        if (isset($this->handlers[$option])) {
            $handler = $this->handlers[$option];
            $value = $handler instanceof OptionInterface ? $handler->getDefault($this) : $handler($this);
            $this->options[$option] = $value;
            return $value;
        }
    }
    /**
     * Returns the default value for the specified option.
     *
     * @param string|OptionInterface $option Name or instance of the option.
     * @return mixed
     */
    public function getDefault($option)
    {
        if ($option instanceof OptionInterface) {
            return $option->getDefault($this);
        }
        $options = $this->getDefaultOptions();
        if (isset($options[$option])) {
            return $options[$option]->getDefault($this);
        }
    }
}
 |