Differences Between: [Versions 310 and 400] [Versions 311 and 400] [Versions 39 and 400] [Versions 400 and 401] [Versions 400 and 402] [Versions 400 and 403]
Cache loaders This file is part of Moodle's cache API, affectionately called MUC. It contains the components that are required in order to use caching.
Copyright: | 2012 Sam Hemelryk |
License: | http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
File Size: | 2458 lines (104 kb) |
Included or required: | 0 times |
Referenced: | 1 time |
Includes or requires: | 0 files |
cache:: (50 methods):
make()
make_from_params()
__construct()
set_loader()
set_data_source()
set_is_sub_loader()
set_identifiers()
handle_invalidation_events()
get()
get_versioned()
check_version()
get_implementation()
get_many()
set()
set_versioned()
set_implementation()
unref()
requires_serialisation()
deep_clone()
set_many()
has()
has_all()
has_any()
delete()
delete_many()
purge()
parse_key()
has_a_ttl()
store_supports_native_ttl()
get_definition()
get_store()
get_loader()
get_datasource()
store_supports_key_awareness()
store_supports_native_locking()
is_using_persist_cache()
use_static_acceleration()
is_in_persist_cache()
static_acceleration_has()
get_from_persist_cache()
static_acceleration_get()
set_in_persist_cache()
static_acceleration_set()
delete_from_persist_cache()
static_acceleration_delete()
static_acceleration_purge()
now()
get_purge_token()
compare_purge_tokens()
purge_current_user()
cache_application:: (13 methods):
__construct()
get_identifier()
__clone()
acquire_lock()
check_lock_state()
release_lock()
ensure_cachelock_available()
set_implementation()
set_many()
get_implementation()
get_many()
delete()
delete_many()
cache_session:: (17 methods):
__construct()
set_session_id()
get_key_prefix()
parse_key()
check_tracked_user()
purge_current_user()
get_implementation()
set()
delete()
get_many()
delete_many()
set_many()
purge()
has()
has_all()
has_any()
use_static_acceleration()
cache_request:: (0 methods):
make($component, $area, array $identifiers = array() X-Ref |
Creates a new cache instance for a pre-defined definition. return: cache_application|cache_session|cache_store param: string $component The component for the definition param: string $area The area for the definition param: array $identifiers Any additional identifiers that should be provided to the definition. param: string $unused Used to be datasourceaggregate but that was removed and this is now unused. |
make_from_params($mode, $component, $area, array $identifiers = array() X-Ref |
Creates a new cache instance based upon the given params. return: cache_application|cache_session|cache_store param: int $mode One of cache_store::MODE_* param: string $component The component this cache relates to. param: string $area The area this cache relates to. param: array $identifiers Any additional identifiers that should be provided to the definition. param: array $options An array of options, available options are: |
__construct(cache_definition $definition, cache_store $store, $loader = null) X-Ref |
Constructs a new cache instance. You should not call this method from your code, instead you should use the cache::make methods. This method is public so that the cache_factory is able to instantiate cache instances. Ideally we would make this method protected and expose its construction to the factory method internally somehow. The factory class is responsible for this in order to centralise the storage of instances once created. This way if needed we can force a reset of the cache API (used during unit testing). param: cache_definition $definition The definition for the cache instance. param: cache_store $store The store that cache should use. param: cache_loader|cache_data_source $loader The next loader in the chain or the data source if there is one and there |
set_loader(cache_loader $loader) X-Ref |
Set the loader for this cache. param: cache_loader $loader |
set_data_source(cache_data_source $datasource) X-Ref |
Set the data source for this cache. param: cache_data_source $datasource |
set_is_sub_loader($setting = true) X-Ref |
Used to inform the loader of its state as a sub loader, or as the top of the chain. This is important as it ensures that we do not have more than one loader keeping static acceleration data. Subloaders need to be "pure" loaders in the sense that they are used to store and retrieve information from stores or the next loader/data source in the chain. Nothing fancy, nothing flash. param: bool $setting |
set_identifiers(array $identifiers) X-Ref |
Alters the identifiers that have been provided to the definition. This is an advanced method and should not be used unless really needed. It allows the developer to slightly alter the definition without having to re-establish the cache. It will cause more processing as the definition will need to clear and reprepare some of its properties. param: array $identifiers |
handle_invalidation_events() X-Ref |
Process any outstanding invalidation events for the cache we are registering, Identifiers and event invalidation are not compatible with each other at this time. As a result the cache does not need to consider identifiers when working out what to invalidate. |
get($key, $strictness = IGNORE_MISSING) X-Ref |
Retrieves the value for the given key from the cache. return: mixed|false The data from the cache or false if the key did not exist within the cache. param: string|int $key The key for the data being requested. param: int $strictness One of IGNORE_MISSING | MUST_EXIST |
get_versioned($key, int $requiredversion, int $strictness = IGNORE_MISSING, &$actualversion = null) X-Ref |
Retrieves the value and actual version for the given key, with at least the required version. If there is no value for the key, or there is a value but it doesn't have the required version, then this function will return null (or throw an exception if you set strictness to MUST_EXIST). This function can be used to make it easier to support localisable caches (where the cache could be stored on a local server as well as a shared cache). Specifying the version means that it will automatically retrieve the correct version if available, either from the local server or [if that has an older version] from the shared server. If the cached version is newer than specified version, it will be returned regardless. For example, if you request version 4, but the locally cached version is 5, it will be returned. If you request version 6, and the locally cached version is 5, then the system will look in higher-level caches (if any); if there still isn't a version 6 or greater, it will return null. You must use this function if you use set_versioned. return: mixed Data from the cache, or false if the key did not exist or was too old param: string|int $key The key for the data being requested. param: int $requiredversion Minimum required version of the data param: int $strictness One of IGNORE_MISSING or MUST_EXIST. param: mixed $actualversion If specified, will be set to the actual version number retrieved |
check_version($result, int $requiredversion) X-Ref |
Checks returned data to see if it matches the specified version number. For versioned data, this returns the version_wrapper object (or false). For other data, it returns the actual data (or false). return: bool True if version is current, false if not (or if result is false) param: mixed $result Result data param: int $requiredversion Required version number or VERSION_NONE if there must be no version |
get_implementation($key, int $requiredversion, int $strictness, &$actualversion = null) X-Ref |
Retrieves the value for the given key from the cache. return: mixed|false The data from the cache or false if the key did not exist within the cache. param: string|int $key The key for the data being requested. param: int $requiredversion Minimum required version of the data or cache::VERSION_NONE param: int $strictness One of IGNORE_MISSING | MUST_EXIST param: mixed $actualversion If specified, will be set to the actual version number retrieved |
get_many(array $keys, $strictness = IGNORE_MISSING) X-Ref |
Retrieves an array of values for an array of keys. Using this function comes with potential performance implications. Not all cache stores will support get_many/set_many operations and in order to replicate this functionality will call the equivalent singular method for each item provided. This should not deter you from using this function as there is a performance benefit in situations where the cache store does support it, but you should be aware of this fact. return: array An array of key value pairs for the items that could be retrieved from the cache. param: array $keys The keys of the data being requested. param: int $strictness One of IGNORE_MISSING or MUST_EXIST. |
set($key, $data) X-Ref |
Sends a key => value pair to the cache. <code> // This code will add four entries to the cache, one for each url. $cache->set('main', 'http://moodle.org'); $cache->set('docs', 'http://docs.moodle.org'); $cache->set('tracker', 'http://tracker.moodle.org'); $cache->set('qa', 'http://qa.moodle.net'); </code> return: bool True on success, false otherwise. param: string|int $key The key for the data being requested. param: mixed $data The data to set against the key. |
set_versioned($key, int $version, $data) X-Ref |
Sets the value for the given key with the given version. The cache does not store multiple versions - any existing version will be overwritten with this one. This function should only be used if there is a known 'current version' (e.g. stored in a database table). It only ensures that the cache does not return outdated data. This function can be used to help implement localisable caches (where the cache could be stored on a local server as well as a shared cache). The version will be recorded alongside the item and get_versioned will always return the correct version. The version number must be an integer that always increases. This could be based on the current time, or a stored value that increases by 1 each time it changes, etc. If you use this function you must use get_versioned to retrieve the data. return: bool True on success, false otherwise. param: string|int $key The key for the data being set. param: int $version Integer for the version of the data param: mixed $data The data to set against the key. |
set_implementation($key, int $version, $data, bool $setparents = true) X-Ref |
Sets the value for the given key, optionally with a version tag. return: bool True on success, false otherwise. param: string|int $key The key for the data being set. param: int $version Version number for the data or cache::VERSION_NONE if none param: mixed $data The data to set against the key. param: bool $setparents If true, sets all parent loaders, otherwise only this one |
unref($data) X-Ref |
Removes references where required. return: mixed What ever was put in but without any references. param: stdClass|array $data |
requires_serialisation($value, $depth = 1) X-Ref |
Checks to see if a var requires serialisation. return: bool Returns true if the value is going to require serialisation in order to ensure a reference free copy param: mixed $value The value to check. param: int $depth Used to ensure we don't enter an endless loop (think recursion). |
deep_clone($value) X-Ref |
Creates a reference free clone of the given value. return: mixed param: mixed $value |
set_many(array $keyvaluearray) X-Ref |
Sends several key => value pairs to the cache. Using this function comes with potential performance implications. Not all cache stores will support get_many/set_many operations and in order to replicate this functionality will call the equivalent singular method for each item provided. This should not deter you from using this function as there is a performance benefit in situations where the cache store does support it, but you should be aware of this fact. <code> // This code will add four entries to the cache, one for each url. $cache->set_many(array( 'main' => 'http://moodle.org', 'docs' => 'http://docs.moodle.org', 'tracker' => 'http://tracker.moodle.org', 'qa' => ''http://qa.moodle.net' )); </code> return: int The number of items successfully set. It is up to the developer to check this matches the number of items. param: array $keyvaluearray An array of key => value pairs to send to the cache. |
has($key, $tryloadifpossible = false) X-Ref |
Test is a cache has a key. The use of the has methods is strongly discouraged. In a high load environment the cache may well change between the test and any subsequent action (get, set, delete etc). Instead it is recommended to write your code in such a way they it performs the following steps: <ol> <li>Attempt to retrieve the information.</li> <li>Generate the information.</li> <li>Attempt to set the information</li> </ol> Its also worth mentioning that not all stores support key tests. For stores that don't support key tests this functionality is mimicked by using the equivalent get method. Just one more reason you should not use these methods unless you have a very good reason to do so. return: bool True if the cache has the requested key, false otherwise. param: string|int $key param: bool $tryloadifpossible If set to true, the cache doesn't contain the key, and there is another cache loader or |
has_all(array $keys) X-Ref |
Test is a cache has all of the given keys. It is strongly recommended to avoid the use of this function if not absolutely required. In a high load environment the cache may well change between the test and any subsequent action (get, set, delete etc). Its also worth mentioning that not all stores support key tests. For stores that don't support key tests this functionality is mimicked by using the equivalent get method. Just one more reason you should not use these methods unless you have a very good reason to do so. return: bool True if the cache has all of the given keys, false otherwise. param: array $keys |
has_any(array $keys) X-Ref |
Test if a cache has at least one of the given keys. It is strongly recommended to avoid the use of this function if not absolutely required. In a high load environment the cache may well change between the test and any subsequent action (get, set, delete etc). Its also worth mentioning that not all stores support key tests. For stores that don't support key tests this functionality is mimicked by using the equivalent get method. Just one more reason you should not use these methods unless you have a very good reason to do so. return: bool True if the cache has at least one of the given keys param: array $keys |
delete($key, $recurse = true) X-Ref |
Delete the given key from the cache. return: bool True of success, false otherwise. param: string|int $key The key to delete. param: bool $recurse When set to true the key will also be deleted from all stacked cache loaders and their stores. |
delete_many(array $keys, $recurse = true) X-Ref |
Delete all of the given keys from the cache. return: int The number of items successfully deleted. param: array $keys The key to delete. param: bool $recurse When set to true the key will also be deleted from all stacked cache loaders and their stores. |
purge() X-Ref |
Purges the cache store, and loader if there is one. return: bool True on success, false otherwise |
parse_key($key) X-Ref |
Parses the key turning it into a string (or array is required) suitable to be passed to the cache store. return: string|array String unless the store supports multi-identifiers in which case an array if returned. param: string|int $key As passed to get|set|delete etc. |
has_a_ttl() X-Ref |
Returns true if the cache is making use of a ttl. return: bool |
store_supports_native_ttl() X-Ref |
Returns true if the cache store supports native ttl. return: bool |
get_definition() X-Ref |
Returns the cache definition. return: cache_definition |
get_store() X-Ref |
Returns the cache store return: cache_store |
get_loader() X-Ref |
Returns the loader associated with this instance. return: cache|false |
get_datasource() X-Ref |
Returns the data source associated with this cache. return: cache_data_source|false |
store_supports_key_awareness() X-Ref |
Returns true if the store supports key awareness. return: bool |
store_supports_native_locking() X-Ref |
Returns true if the store natively supports locking. return: bool |
is_using_persist_cache() X-Ref |
use_static_acceleration() X-Ref |
Returns true if this cache is making use of the static acceleration array. return: bool |
is_in_persist_cache() X-Ref |
static_acceleration_has($key) X-Ref |
Returns true if the requested key exists within the static acceleration array. return: bool param: string $key The parsed key |
get_from_persist_cache() X-Ref |
static_acceleration_get($key) X-Ref |
Returns the item from the static acceleration array if it exists there. return: mixed|false Dereferenced data from the static acceleration array or false if it wasn't there. param: string $key The parsed key |
set_in_persist_cache() X-Ref |
static_acceleration_set($key, $data) X-Ref |
Sets a key value pair into the static acceleration array. return: bool param: string $key The parsed key param: mixed $data |
delete_from_persist_cache() X-Ref |
static_acceleration_delete($key) X-Ref |
Deletes an item from the static acceleration array. return: bool True on success, false otherwise. param: string|int $key As given to get|set|delete |
static_acceleration_purge() X-Ref |
Purge the static acceleration cache. |
now($float = false) X-Ref |
Returns the timestamp from the first request for the time from the cache API. This stamp needs to be used for all ttl and time based operations to ensure that we don't end up with timing issues. return: int|float param: bool $float Whether to use floating precision accuracy. |
get_purge_token($reset = false) X-Ref |
Get a 'purge' token used for cache invalidation handling. Note: This function is intended for use from within the Cache API only and not by plugins, or cache stores. return: string param: bool $reset Whether to reset the token and generate a new one. |
compare_purge_tokens($tokena, $tokenb) X-Ref |
Compare a pair of purge tokens. If the two tokens are identical, then the return value is 0. If the time component of token A is newer than token B, then a positive value is returned. If the time component of token B is newer than token A, then a negative value is returned. Note: This function is intended for use from within the Cache API only and not by plugins, or cache stores. return: int param: string $tokena param: string $tokenb |
purge_current_user() X-Ref |
Subclasses may support purging cache of all data belonging to the current user. |
Class: cache_application - X-Ref
An application cache.__construct(cache_definition $definition, cache_store $store, $loader = null) X-Ref |
Overrides the cache construct method. You should not call this method from your code, instead you should use the cache::make methods. param: cache_definition $definition param: cache_store $store param: cache_loader|cache_data_source $loader |
get_identifier() X-Ref |
Returns the identifier to use return: string |
__clone() X-Ref |
Fixes the instance up after a clone. |
acquire_lock($key) X-Ref |
Acquires a lock on the given key. This is done automatically if the definition requires it. It is recommended to use a definition if you want to have locking although it is possible to do locking without having it required by the definition. The problem with such an approach is that you cannot ensure that code will consistently use locking. You will need to rely on the integrators review skills. return: bool Returns true if the lock could be acquired, false otherwise. param: string|int $key The key as given to get|set|delete |
check_lock_state($key) X-Ref |
Checks if this cache has a lock on the given key. return: bool|null Returns true if there is a lock and this cache has it, null if no one has a lock on that key, false if param: string|int $key The key as given to get|set|delete |
release_lock($key) X-Ref |
Releases the lock this cache has on the given key return: bool True if the operation succeeded, false otherwise. param: string|int $key |
ensure_cachelock_available() X-Ref |
Ensure that the dedicated lock store is ready to go. This should only happen if the cache store doesn't natively support it. |
set_implementation($key, int $version, $data, bool $setparents = true) X-Ref |
Sends a key => value pair to the cache. <code> // This code will add four entries to the cache, one for each url. $cache->set('main', 'http://moodle.org'); $cache->set('docs', 'http://docs.moodle.org'); $cache->set('tracker', 'http://tracker.moodle.org'); $cache->set('qa', 'http://qa.moodle.net'); </code> return: bool True on success, false otherwise. param: string|int $key The key for the data being requested. param: int $version Version number param: mixed $data The data to set against the key. param: bool $setparents If true, sets all parent loaders, otherwise only this one |
set_many(array $keyvaluearray) X-Ref |
Sends several key => value pairs to the cache. Using this function comes with potential performance implications. Not all cache stores will support get_many/set_many operations and in order to replicate this functionality will call the equivalent singular method for each item provided. This should not deter you from using this function as there is a performance benefit in situations where the cache store does support it, but you should be aware of this fact. <code> // This code will add four entries to the cache, one for each url. $cache->set_many(array( 'main' => 'http://moodle.org', 'docs' => 'http://docs.moodle.org', 'tracker' => 'http://tracker.moodle.org', 'qa' => ''http://qa.moodle.net' )); </code> return: int The number of items successfully set. It is up to the developer to check this matches the number of items. param: array $keyvaluearray An array of key => value pairs to send to the cache. |
get_implementation($key, int $requiredversion, int $strictness, &$actualversion = null) X-Ref |
Retrieves the value for the given key from the cache. return: mixed|false The data from the cache or false if the key did not exist within the cache. param: string|int $key The key for the data being requested. param: int $requiredversion Minimum required version of the data or cache::VERSION_NONE param: int $strictness One of IGNORE_MISSING | MUST_EXIST param: mixed &$actualversion If specified, will be set to the actual version number retrieved |
get_many(array $keys, $strictness = IGNORE_MISSING) X-Ref |
Retrieves an array of values for an array of keys. Using this function comes with potential performance implications. Not all cache stores will support get_many/set_many operations and in order to replicate this functionality will call the equivalent singular method for each item provided. This should not deter you from using this function as there is a performance benefit in situations where the cache store does support it, but you should be aware of this fact. return: array An array of key value pairs for the items that could be retrieved from the cache. param: array $keys The keys of the data being requested. param: int $strictness One of IGNORE_MISSING or MUST_EXIST. |
delete($key, $recurse = true) X-Ref |
Delete the given key from the cache. return: bool True of success, false otherwise. param: string|int $key The key to delete. param: bool $recurse When set to true the key will also be deleted from all stacked cache loaders and their stores. |
delete_many(array $keys, $recurse = true) X-Ref |
Delete all of the given keys from the cache. return: int The number of items successfully deleted. param: array $keys The key to delete. param: bool $recurse When set to true the key will also be deleted from all stacked cache loaders and their stores. |
Class: cache_session - X-Ref
A session cache.__construct(cache_definition $definition, cache_store $store, $loader = null) X-Ref |
Override the cache::construct method. This function gets overriden so that we can process any invalidation events if need be. If the definition doesn't have any invalidation events then this occurs exactly as it would for the cache class. Otherwise we look at the last invalidation time and then check the invalidation data for events that have occured between then now. You should not call this method from your code, instead you should use the cache::make methods. param: cache_definition $definition param: cache_store $store param: cache_loader|cache_data_source $loader |
set_session_id() X-Ref |
Sets the session id for the loader. |
get_key_prefix() X-Ref |
Returns the prefix used for all keys. return: string |
parse_key($key) X-Ref |
Parses the key turning it into a string (or array is required) suitable to be passed to the cache store. This function is called for every operation that uses keys. For this reason we use this function to also check that the current user is the same as the user who last used this cache. On top of that if prepends the string 'sess_' to the start of all keys. The _ ensures things are easily identifiable. return: string|array String unless the store supports multi-identifiers in which case an array if returned. param: string|int $key As passed to get|set|delete etc. |
check_tracked_user() X-Ref |
Check that this cache instance is tracking the current user. |
purge_current_user() X-Ref |
Purges the session cache of all data belonging to the current user. |
get_implementation($key, int $requiredversion, int $strictness, &$actualversion = null) X-Ref |
Retrieves the value for the given key from the cache. return: mixed|false The data from the cache or false if the key did not exist within the cache. param: string|int $key The key for the data being requested. param: int $requiredversion Minimum required version of the data or cache::VERSION_NONE param: int $strictness One of IGNORE_MISSING | MUST_EXIST param: mixed &$actualversion If specified, will be set to the actual version number retrieved |
set($key, $data) X-Ref |
Sends a key => value pair to the cache. <code> // This code will add four entries to the cache, one for each url. $cache->set('main', 'http://moodle.org'); $cache->set('docs', 'http://docs.moodle.org'); $cache->set('tracker', 'http://tracker.moodle.org'); $cache->set('qa', 'http://qa.moodle.net'); </code> return: bool True on success, false otherwise. param: string|int $key The key for the data being requested. param: mixed $data The data to set against the key. |
delete($key, $recurse = true) X-Ref |
Delete the given key from the cache. return: bool True of success, false otherwise. param: string|int $key The key to delete. param: bool $recurse When set to true the key will also be deleted from all stacked cache loaders and their stores. |
get_many(array $keys, $strictness = IGNORE_MISSING) X-Ref |
Retrieves an array of values for an array of keys. Using this function comes with potential performance implications. Not all cache stores will support get_many/set_many operations and in order to replicate this functionality will call the equivalent singular method for each item provided. This should not deter you from using this function as there is a performance benefit in situations where the cache store does support it, but you should be aware of this fact. return: array An array of key value pairs for the items that could be retrieved from the cache. param: array $keys The keys of the data being requested. param: int $strictness One of IGNORE_MISSING or MUST_EXIST. |
delete_many(array $keys, $recurse = true) X-Ref |
Delete all of the given keys from the cache. return: int The number of items successfully deleted. param: array $keys The key to delete. param: bool $recurse When set to true the key will also be deleted from all stacked cache loaders and their stores. |
set_many(array $keyvaluearray) X-Ref |
Sends several key => value pairs to the cache. Using this function comes with potential performance implications. Not all cache stores will support get_many/set_many operations and in order to replicate this functionality will call the equivalent singular method for each item provided. This should not deter you from using this function as there is a performance benefit in situations where the cache store does support it, but you should be aware of this fact. <code> // This code will add four entries to the cache, one for each url. $cache->set_many(array( 'main' => 'http://moodle.org', 'docs' => 'http://docs.moodle.org', 'tracker' => 'http://tracker.moodle.org', 'qa' => ''http://qa.moodle.net' )); </code> return: int The number of items successfully set. It is up to the developer to check this matches the number of items. param: array $keyvaluearray An array of key => value pairs to send to the cache. |
purge() X-Ref |
Purges the cache store, and loader if there is one. return: bool True on success, false otherwise |
has($key, $tryloadifpossible = false) X-Ref |
Test is a cache has a key. The use of the has methods is strongly discouraged. In a high load environment the cache may well change between the test and any subsequent action (get, set, delete etc). Instead it is recommended to write your code in such a way they it performs the following steps: <ol> <li>Attempt to retrieve the information.</li> <li>Generate the information.</li> <li>Attempt to set the information</li> </ol> Its also worth mentioning that not all stores support key tests. For stores that don't support key tests this functionality is mimicked by using the equivalent get method. Just one more reason you should not use these methods unless you have a very good reason to do so. return: bool True if the cache has the requested key, false otherwise. param: string|int $key param: bool $tryloadifpossible If set to true, the cache doesn't contain the key, and there is another cache loader or |
has_all(array $keys) X-Ref |
Test is a cache has all of the given keys. It is strongly recommended to avoid the use of this function if not absolutely required. In a high load environment the cache may well change between the test and any subsequent action (get, set, delete etc). Its also worth mentioning that not all stores support key tests. For stores that don't support key tests this functionality is mimicked by using the equivalent get method. Just one more reason you should not use these methods unless you have a very good reason to do so. return: bool True if the cache has all of the given keys, false otherwise. param: array $keys |
has_any(array $keys) X-Ref |
Test if a cache has at least one of the given keys. It is strongly recommended to avoid the use of this function if not absolutely required. In a high load environment the cache may well change between the test and any subsequent action (get, set, delete etc). Its also worth mentioning that not all stores support key tests. For stores that don't support key tests this functionality is mimicked by using the equivalent get method. Just one more reason you should not use these methods unless you have a very good reason to do so. return: bool True if the cache has at least one of the given keys param: array $keys |
use_static_acceleration() X-Ref |
The session loader never uses static acceleration. Instead it stores things in the static $session variable. Shared between all session loaders. return: bool |
Class: cache_request - X-Ref
An request cache.