Skip to content
Snippets Groups Projects
Cache.php 6.06 KiB
Newer Older
  • Learn to ignore specific revisions
  • use CodeIgniter\Cache\Handlers\DummyHandler;
    use CodeIgniter\Cache\Handlers\FileHandler;
    use CodeIgniter\Cache\Handlers\MemcachedHandler;
    use CodeIgniter\Cache\Handlers\PredisHandler;
    use CodeIgniter\Cache\Handlers\RedisHandler;
    use CodeIgniter\Cache\Handlers\WincacheHandler;
    
    use CodeIgniter\Config\BaseConfig;
    
    class Cache extends BaseConfig
    {
    
        /**
         * --------------------------------------------------------------------------
         * Primary Handler
         * --------------------------------------------------------------------------
         *
         * The name of the preferred handler that should be used. If for some reason
         * it is not available, the $backupHandler will be used in its place.
         */
    
        /**
         * --------------------------------------------------------------------------
         * Backup Handler
         * --------------------------------------------------------------------------
         *
         * The name of the handler that will be used in case the first one is
         * unreachable. Often, 'file' is used here since the filesystem is
         * always available, though that's not always practical for the app.
         */
    
        public string $backupHandler = 'dummy';
    
        /**
         * --------------------------------------------------------------------------
         * Cache Directory Path
         * --------------------------------------------------------------------------
         *
         * The path to where cache files should be stored, if using a file-based
         * system.
         *
         * @deprecated Use the driver-specific variant under $file
         */
    
        public string $storePath = WRITEPATH . 'cache/';
    
        /**
         * --------------------------------------------------------------------------
         * Cache Include Query String
         * --------------------------------------------------------------------------
         *
         * Whether to take the URL query string into consideration when generating
         * output cache files. Valid options are:
         *
    
         *    false = Disabled
         *    true  = Enabled, take all query parameters into account.
         *            Please be aware that this may result in numerous cache
         *            files generated for the same page over and over again.
         *    ['q'] = Enabled, but only take into account the specified list
    
         *                 of query parameters.
         *
         * @var boolean|string[]
         */
    
        public bool | array $cacheQueryString = false;
    
        /**
         * --------------------------------------------------------------------------
         * Key Prefix
         * --------------------------------------------------------------------------
         *
         * This string is added to all cache item names to help avoid collisions
         * if you run multiple applications with the same cache engine.
         */
    
        /**
         * --------------------------------------------------------------------------
         * Default TTL
         * --------------------------------------------------------------------------
         *
         * The default number of seconds to save items when none is specified.
         *
         * WARNING: This is not used by framework handlers where 60 seconds is
         * hard-coded, but may be useful to projects and modules. This will replace
         * the hard-coded value in a future release.
         */
        public int $ttl = 60;
    
    
        /**
         * --------------------------------------------------------------------------
         * Reserved Characters
         * --------------------------------------------------------------------------
         *
         * A string of reserved characters that will not be allowed in keys or tags.
         * Strings that violate this restriction will cause handlers to throw.
         * Default: {}()/\@:
    
         * Note: The default set is required for PSR-6 compliance.
         */
        public string $reservedCharacters = '{}()/\@:';
    
    
        /**
         * --------------------------------------------------------------------------
         * File settings
         * --------------------------------------------------------------------------
         * Your file storage preferences can be specified below, if you are using
         * the File driver.
         *
         * @var array<string, string|int|null>
         */
    
            'storePath' => WRITEPATH . 'cache/',
    
        ];
    
        /**
         * -------------------------------------------------------------------------
         * Memcached settings
         * -------------------------------------------------------------------------
         * Your Memcached servers can be specified below, if you are using
         * the Memcached drivers.
         *
         * @see https://codeigniter.com/user_guide/libraries/caching.html#memcached
         *
    
         * @var array<string, string|int|bool>
    
            'host'   => '127.0.0.1',
            'port'   => 11211,
    
        /**
         * -------------------------------------------------------------------------
         * Redis settings
         * -------------------------------------------------------------------------
         * Your Redis server can be specified below, if you are using
         * the Redis or Predis drivers.
         *
         * @var array<string, string|int|null>
         */
    
        /**
         * --------------------------------------------------------------------------
         * Available Cache Handlers
         * --------------------------------------------------------------------------
         *
         * This is an array of cache engine alias' and class names. Only engines
         * that are listed here are allowed to be used.
         *
         * @var array<string, string>
         */
    
            'dummy'     => DummyHandler::class,
            'file'      => FileHandler::class,
    
            'memcached' => MemcachedHandler::class,
    
            'predis'    => PredisHandler::class,
            'redis'     => RedisHandler::class,
            'wincache'  => WincacheHandler::class,