Newer
Older
framework / app / Config / Cache.php
@MGatner MGatner on 6 Jun 2021 5 KB Release v4.1.3
<?php

namespace Config;

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.
	 *
	 * @var string
	 */
	public $handler = 'file';

	/**
	 * --------------------------------------------------------------------------
	 * 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.
	 *
	 * @var string
	 */
	public $backupHandler = 'dummy';

	/**
	 * --------------------------------------------------------------------------
	 * Cache Directory Path
	 * --------------------------------------------------------------------------
	 *
	 * The path to where cache files should be stored, if using a file-based
	 * system.
	 *
	 * @var string
	 *
	 * @deprecated Use the driver-specific variant under $file
	 */
	public $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.
	 *    array('q') = Enabled, but only take into account the specified list
	 *                 of query parameters.
	 *
	 * @var boolean|string[]
	 */
	public $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.
	 *
	 * @var string
	 */
	public $prefix = '';

	/**
	 * --------------------------------------------------------------------------
	 * 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.
	 *
	 * @var integer
	 */
	public $ttl = 60;

	/**
	 * --------------------------------------------------------------------------
	 * File settings
	 * --------------------------------------------------------------------------
	 * Your file storage preferences can be specified below, if you are using
	 * the File driver.
	 *
	 * @var array<string, string|int|null>
	 */
	public $file = [
		'storePath' => WRITEPATH . 'cache/',
		'mode'      => 0640,
	];

	/**
	 * -------------------------------------------------------------------------
	 * 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|boolean>
	 */
	public $memcached = [
		'host'   => '127.0.0.1',
		'port'   => 11211,
		'weight' => 1,
		'raw'    => false,
	];

	/**
	 * -------------------------------------------------------------------------
	 * Redis settings
	 * -------------------------------------------------------------------------
	 * Your Redis server can be specified below, if you are using
	 * the Redis or Predis drivers.
	 *
	 * @var array<string, string|int|null>
	 */
	public $redis = [
		'host'     => '127.0.0.1',
		'password' => null,
		'port'     => 6379,
		'timeout'  => 0,
		'database' => 0,
	];

	/**
	 * --------------------------------------------------------------------------
	 * 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>
	 */
	public $validHandlers = [
		'dummy'     => DummyHandler::class,
		'file'      => FileHandler::class,
		'memcached' => MemcachedHandler::class,
		'predis'    => PredisHandler::class,
		'redis'     => RedisHandler::class,
		'wincache'  => WincacheHandler::class,
	];
}