Moodle APIs
3.8
Moodle 3.8.6 (Build: 20201109)
|
The static store class. More...
Public Member Functions | |
__construct ($name, array $configuration=array()) | |
Constructs the store instance. More... | |
cleanup () | |
create_clone (array $details=array()) | |
Creates a clone of this store instance ready to be initialised. More... | |
delete ($key) | |
Deletes an item from the cache store. More... | |
delete_many (array $keys) | |
Deletes several keys from the cache in a single action. More... | |
find_all () | |
Finds all of the keys being stored in the cache store instance. More... | |
find_by_prefix ($prefix) | |
Finds all of the keys whose keys start with the given prefix. More... | |
get ($key) | |
Retrieves an item from the cache store given its key. More... | |
get_many ($keys) | |
Retrieves several items from the cache store in a single transaction. More... | |
get_warnings () | |
Can be overridden to return any warnings this store instance should make to the admin. More... | |
has ($key) | |
Checks if the store has a record for the given key and returns true if so. More... | |
has_all (array $keys) | |
Returns true if the store contains records for all of the given keys. More... | |
has_any (array $keys) | |
Returns true if the store contains records for any of the given keys. More... | |
initialise (cache_definition $definition) | |
Initialises the cache. More... | |
instance_created () | |
Performs any necessary operation when the store instance has been created. More... | |
instance_deleted () | |
Performs any necessary clean up when the store instance is being deleted. | |
is_initialised () | |
Returns true once this instance has been initialised. More... | |
is_ready () | |
Returns true if this cache store instance is ready to use. More... | |
is_searchable () | |
Returns true if the store instance is searchable. More... | |
my_name () | |
Returns the name of this instance. More... | |
purge () | |
Purges the cache deleting all items within it. More... | |
set ($key, $data) | |
Sets an item in the cache given its key and data value. More... | |
set ($key, $data, $testmaxsize=true) | |
Sets an item in the cache given its key and data value. More... | |
set_many (array $keyvaluearray) | |
Sets many items in the cache in a single transaction. More... | |
supports_data_guarantee () | |
Returns true if the store instance guarantees data. More... | |
supports_dereferencing_objects () | |
Returns true if the store automatically dereferences objects. More... | |
supports_multiple_identifiers () | |
Returns true as this store does support multiple identifiers. More... | |
supports_native_ttl () | |
Returns true if the store instance supports native ttl. More... | |
Static Public Member Functions | |
static | are_requirements_met () |
Returns true if the store requirements are met. More... | |
static | can_add_instance () |
Returns true if the user can add an instance of the store plugin. More... | |
static | get_supported_features (array $configuration=array()) |
Returns the supported features as a combined int. More... | |
static | get_supported_modes (array $configuration=array()) |
Returns the supported modes as a combined int. More... | |
static | initialise_test_instance (cache_definition $definition) |
Generates an instance of the cache store that can be used for testing. More... | |
static | is_supported_mode ($mode) |
Returns true if the given mode is supported by this store. More... | |
static | ready_to_be_used_for_testing () |
Returns true if this cache store instance is both suitable for testing, and ready for testing. More... | |
static | unit_test_configuration () |
Generates the appropriate configuration required for unit testing. More... | |
Public Attributes | |
const | DEREFERENCES_OBJECTS = 16 |
The cache store dereferences objects. More... | |
const | IS_SEARCHABLE = 8 |
The cache is searchable by key. | |
const | MODE_APPLICATION = 1 |
Application caches. More... | |
const | MODE_REQUEST = 4 |
Request caches. More... | |
const | MODE_SESSION = 2 |
Session caches. More... | |
const | SUPPORTS_DATA_GUARANTEE = 2 |
Ensures data remains in the cache once set. | |
const | SUPPORTS_MULTIPLE_IDENTIFIERS = 1 |
Supports multi-part keys. | |
const | SUPPORTS_NATIVE_TTL = 4 |
Supports a native ttl system. | |
Protected Member Functions | |
reduce_for_maxsize () | |
Reduces the size of the array if maxsize has been hit. More... | |
serialize ($data) | |
Uses igbinary serializer if igbinary extension is loaded. More... | |
unserialize ($str) | |
Uses igbinary unserializer if igbinary extension is loaded. More... | |
Static Protected Member Functions | |
static | flush_store () |
Flushes all of the values from all stores. More... | |
static | flush_store_by_id ($id) |
Flushes the store of all values for belonging to the store with the given id. More... | |
static & | register_store_id ($id) |
Returns a static store by reference... More... | |
Protected Attributes | |
bool | $igbinaryfound = false |
igbinary extension available. | |
bool | $maxsize = false |
The maximum size for the store, or false if there isn't one. | |
store | $name |
The name of the store. | |
bool | $simpledata = false |
Where this cache uses simpledata and we don't need to serialize it. | |
array | $store |
The store we use for data. | |
int | $storecount = 0 |
The number of items currently being stored. | |
string | $storeid |
The store id (should be unique) | |
The static store class.
cachestore_static::__construct | ( | $name, | |
array | $configuration = array() |
||
) |
Constructs the store instance.
Noting that this function is not an initialisation. It is used to prepare the store for use. The store will be initialised when required and will be provided with a cache_definition at that time.
string | $name | |
array | $configuration |
Reimplemented from cache_store.
|
static |
Returns true if the store requirements are met.
bool |
Implements cache_store_interface.
|
static |
Returns true if the user can add an instance of the store plugin.
bool |
Reimplemented from cache_store.
|
inherited |
|
inherited |
Creates a clone of this store instance ready to be initialised.
This method is used so that a cache store needs only be constructed once. Future requests for an instance of the store will be given a cloned instance.
If you are writing a cache store that isn't compatible with the clone operation you can override this method to handle any situations you want before cloning.
array | $details | An array containing the details of the store from the cache config. |
cache_store |
cachestore_static::delete | ( | $key | ) |
Deletes an item from the cache store.
string | $key | The key to delete. |
bool | Returns true if the operation was a success, false otherwise. |
Reimplemented from cache_store.
cachestore_static::delete_many | ( | array | $keys | ) |
Deletes several keys from the cache in a single action.
array | $keys | The keys to delete |
int | The number of items successfully deleted. |
Reimplemented from cache_store.
cachestore_static::find_all | ( | ) |
Finds all of the keys being stored in the cache store instance.
array |
Implements cache_is_searchable.
cachestore_static::find_by_prefix | ( | $prefix | ) |
Finds all of the keys whose keys start with the given prefix.
string | $prefix |
Implements cache_is_searchable.
|
staticprotectedinherited |
Flushes all of the values from all stores.
|
staticprotectedinherited |
Flushes the store of all values for belonging to the store with the given id.
string | $id |
cachestore_static::get | ( | $key | ) |
Retrieves an item from the cache store given its key.
string | $key | The key to retrieve |
mixed | The data that was associated with the key, or false if the key did not exist. |
Reimplemented from cache_store.
cachestore_static::get_many | ( | $keys | ) |
Retrieves several items from the cache store in a single transaction.
If not all of the items are available in the cache then the data value for those that are missing will be set to false.
array | $keys | The array of keys to retrieve |
array | An array of items from the cache. There will be an item for each key, those that were not in the store will be set to false. |
Reimplemented from cache_store.
|
static |
Returns the supported features as a combined int.
array | $configuration |
int |
Implements cache_store_interface.
|
static |
Returns the supported modes as a combined int.
array | $configuration |
int |
Implements cache_store_interface.
|
inherited |
Can be overridden to return any warnings this store instance should make to the admin.
This should be used to notify things like configuration conflicts etc. The warnings returned here will be displayed on the cache configuration screen.
string[] | An array of warning strings from the store instance. |
Reimplemented in cachestore_memcached.
cachestore_static::has | ( | $key | ) |
Checks if the store has a record for the given key and returns true if so.
string | $key |
bool |
Implements cache_is_key_aware.
cachestore_static::has_all | ( | array | $keys | ) |
Returns true if the store contains records for all of the given keys.
array | $keys |
bool |
Implements cache_is_key_aware.
cachestore_static::has_any | ( | array | $keys | ) |
Returns true if the store contains records for any of the given keys.
array | $keys |
bool |
Implements cache_is_key_aware.
cachestore_static::initialise | ( | cache_definition | $definition | ) |
Initialises the cache.
Once this has been done the cache is all set to be used.
cache_definition | $definition |
Reimplemented from cache_store.
|
static |
Generates an instance of the cache store that can be used for testing.
cache_definition | $definition |
cachestore_static |
Implements cache_store_interface.
|
inherited |
Performs any necessary operation when the store instance has been created.
Reimplemented in cachestore_file.
cachestore_static::is_initialised | ( | ) |
Returns true once this instance has been initialised.
bool |
Reimplemented from cache_store.
|
inherited |
Returns true if this cache store instance is ready to use.
bool |
Reimplemented in cachestore_redis, cachestore_mongodb, cachestore_memcached, and cachestore_file.
|
inherited |
Returns true if the store instance is searchable.
bool |
|
static |
Returns true if the given mode is supported by this store.
int | $mode | One of cache_store::MODE_* |
bool |
Implements cache_store_interface.
cachestore_static::my_name | ( | ) |
cachestore_static::purge | ( | ) |
Purges the cache deleting all items within it.
boolean | True on success. False otherwise. |
Reimplemented from cache_store.
|
staticinherited |
Returns true if this cache store instance is both suitable for testing, and ready for testing.
Cache stores that support being used as the default store for unit and acceptance testing should override this function and return true if there requirements have been met.
bool |
Reimplemented in cachestore_redis, cachestore_mongodb, cachestore_memcached, and cachestore_apcu.
|
protected |
Reduces the size of the array if maxsize has been hit.
This function reduces the size of the store reducing it by 10% of its maxsize. It removes the oldest items in the store when doing this. The reason it does this an doesn't use a least recently used system is purely the overhead such a system requires. The current approach is focused on speed, MUC already adds enough overhead to static/session caches and avoiding more is of benefit.
int |
|
staticprotectedinherited |
Returns a static store by reference...
REFERENCE SUPER IMPORTANT.
string | $id |
array |
|
protected |
Uses igbinary serializer if igbinary extension is loaded.
Fallback to PHP serializer.
mixed | $data | The value to be serialized. |
string | a string containing a byte-stream representation of value that can be stored anywhere. |
|
abstractinherited |
Sets an item in the cache given its key and data value.
string | $key | The key to use. |
mixed | $data | The data to set. |
bool | True if the operation was a success false otherwise. |
Reimplemented in cachestore_redis, cachestore_mongodb, cachestore_memcached, cachestore_file, cachestore_apcu, and cachestore_dummy.
cachestore_static::set | ( | $key, | |
$data, | |||
$testmaxsize = true |
|||
) |
Sets an item in the cache given its key and data value.
string | $key | The key to use. |
mixed | $data | The data to set. |
bool | $testmaxsize | If set to true then we test the maxsize arg and reduce if required. |
bool | True if the operation was a success false otherwise. |
cachestore_static::set_many | ( | array | $keyvaluearray | ) |
Sets many items in the cache in a single transaction.
array | $keyvaluearray | An array of key value pairs. Each item in the array will be an associative array with two keys, 'key' and 'value'. |
int | The number of items successfully set. It is up to the developer to check this matches the number of items sent ... if they care that is. |
Reimplemented from cache_store.
|
inherited |
Returns true if the store instance guarantees data.
bool |
|
inherited |
Returns true if the store automatically dereferences objects.
bool |
cachestore_static::supports_multiple_identifiers | ( | ) |
Returns true as this store does support multiple identifiers.
(This optional function is a performance optimisation; it must be consistent with the value from get_supported_features.)
bool | true |
Reimplemented from cache_store.
|
inherited |
Returns true if the store instance supports native ttl.
bool |
|
static |
Generates the appropriate configuration required for unit testing.
array | Array of unit test configuration data to be used by initialise(). |
Implements cache_store_interface.
|
protected |
Uses igbinary unserializer if igbinary extension is loaded.
Fallback to PHP unserializer.
string | $str | The serialized string. |
mixed | The converted value is returned, and can be a boolean, integer, float, string, array or object. |
|
inherited |
The cache store dereferences objects.
When set, loaders will assume that all data coming from this store has already had all references resolved. So even for complex object structures it will not try to remove references again.
|
inherited |
Application caches.
These are shared caches.
|
inherited |
Request caches.
Static caches really.
|
inherited |
Session caches.
Just access to the PHP session.