CakePHP
  • Documentation
    • Book
    • API
    • Videos
    • Reporting Security Issues
    • Privacy Policy
    • Logos & Trademarks
  • Business Solutions
  • Swag
  • Road Trip
  • Team
  • Community
    • Community
    • Get Involved
    • Issues (Github)
    • Bakery
    • Featured Resources
    • Training
    • Meetups
    • My CakePHP
    • CakeFest
    • Newsletter
    • Linkedin
    • YouTube
    • Facebook
    • Twitter
    • Mastodon
    • Help & Support
    • Forum
    • Stack Overflow
    • IRC
    • Slack
    • Paid Support
CakePHP

C CakePHP 4.4 Strawberry API

  • Project:
    • CakePHP
      • CakePHP
      • Authentication
      • Authorization
      • Chronos
      • Elastic Search
      • Queue
  • Version:
    • 4.4
      • 5.2
      • 5.1
      • 5.0
      • 4.6
      • 4.5
      • 4.4
      • 4.3
      • 4.2
      • 4.1
      • 4.0
      • 3.10
      • 3.9
      • 3.8
      • 3.7
      • 3.6
      • 3.5
      • 3.4
      • 3.3
      • 3.2
      • 3.1
      • 3.0
      • 2.10
      • 2.9
      • 2.8
      • 2.7
      • 2.6
      • 2.5
      • 2.4
      • 2.3
      • 2.2
      • 2.1
      • 2.0
      • 1.3
      • 1.2

Namespaces

  • Global
  • Cake
    • Auth
    • Cache
      • Engine
    • Collection
    • Command
    • Console
    • Controller
    • Core
    • Database
    • Datasource
    • Error
    • Event
    • Filesystem
    • Form
    • Http
    • I18n
    • Log
    • Mailer
    • Network
    • ORM
    • Routing
    • Shell
    • TestSuite
    • Utility
    • Validation
    • View

Class ArrayEngine

Array storage engine for cache.

Not actually a persistent cache engine. All data is only stored in memory for the duration of a single process. While not useful in production settings this engine can be useful in tests or console tools where you don't want the overhead of interacting with a cache servers, but want the work saving properties a cache provides.

Namespace: Cake\Cache\Engine

Constants

  • string
    CHECK_KEY ¶
    'key'
  • string
    CHECK_VALUE ¶
    'value'

Property Summary

  • $_config protected
    array<string, mixed>

    Runtime config

  • $_configInitialized protected
    bool

    Whether the config property has already been configured with defaults

  • $_defaultConfig protected
    array<string, mixed>

    The default cache configuration is overridden in most cache adapters. These are the keys that are common to all adapters. If overridden, this property is not used.

  • $_groupPrefix protected
    string

    Contains the compiled string with all group prefixes to be prepended to every key in this cache engine

  • $data protected
    array<string, array>

    Cached data.

Method Summary

  • _configDelete() protected

    Deletes a single config key.

  • _configRead() protected

    Reads a config key.

  • _configWrite() protected

    Writes a config key.

  • _key() protected

    Generates a key for cache backend usage.

  • add() public

    Add a key to the cache if it does not already exist.

  • clear() public

    Delete all keys from the cache. This will clear every cache config using APC.

  • clearGroup() public

    Increments the group value to simulate deletion of all keys under a group old values will remain in storage until they expire.

  • configShallow() public

    Merge provided config with existing config. Unlike config() which does a recursive merge for nested keys, this method does a simple merge.

  • decrement() public

    Decrements the value of an integer cached key

  • delete() public

    Delete a key from the cache

  • deleteMultiple() public

    Deletes multiple cache items as a list

  • duration() protected

    Convert the various expressions of a TTL value into duration in seconds

  • ensureValidKey() protected

    Ensure the validity of the given cache key.

  • ensureValidType() protected

    Ensure the validity of the argument type and cache keys.

  • get() public

    Read a key from the cache

  • getConfig() public

    Returns the config.

  • getConfigOrFail() public

    Returns the config for this specific key.

  • getMultiple() public

    Obtains multiple cache items by their unique keys.

  • groups() public

    Returns the group value for each of the configured groups If the group initial value was not found, then it initializes the group accordingly.

  • has() public

    Determines whether an item is present in the cache.

  • increment() public

    Increments the value of an integer cached key

  • init() public

    Initialize the cache engine

  • set() public

    Write data for key into cache

  • setConfig() public

    Sets the config.

  • setMultiple() public

    Persists a set of key => value pairs in the cache, with an optional TTL.

  • warning() protected

    Cache Engines may trigger warnings if they encounter failures during operation, if option warnOnWriteFailures is set to true.

Method Detail

_configDelete() ¶ protected

_configDelete(string $key): void

Deletes a single config key.

Parameters
string $key

Key to delete.

Returns
void
Throws
Cake\Core\Exception\CakeException
if attempting to clobber existing config

_configRead() ¶ protected

_configRead(string|null $key): mixed

Reads a config key.

Parameters
string|null $key

Key to read.

Returns
mixed

_configWrite() ¶ protected

_configWrite(array<string, mixed>|string $key, mixed $value, string|bool $merge = false): void

Writes a config key.

Parameters
array<string, mixed>|string $key

Key to write to.

mixed $value

Value to write.

string|bool $merge optional

True to merge recursively, 'shallow' for simple merge, false to overwrite, defaults to false.

Returns
void
Throws
Cake\Core\Exception\CakeException
if attempting to clobber existing config

_key() ¶ protected

_key(string $key): string

Generates a key for cache backend usage.

If the requested key is valid, the group prefix value and engine prefix are applied. Whitespace in keys will be replaced.

Parameters
string $key

the key passed over

Returns
string
Throws
Cake\Cache\InvalidArgumentException
If key's value is invalid.

add() ¶ public

add(string $key, mixed $value): bool

Add a key to the cache if it does not already exist.

Defaults to a non-atomic implementation. Subclasses should prefer atomic implementations.

Parameters
string $key

Identifier for the data.

mixed $value

Data to be cached.

Returns
bool

clear() ¶ public

clear(): bool

Delete all keys from the cache. This will clear every cache config using APC.

Returns
bool

clearGroup() ¶ public

clearGroup(string $group): bool

Increments the group value to simulate deletion of all keys under a group old values will remain in storage until they expire.

Each implementation needs to decide whether actually delete the keys or just augment a group generation value to achieve the same result.

Parameters
string $group

The group to clear.

Returns
bool

configShallow() ¶ public

configShallow(array<string, mixed>|string $key, mixed|null $value = null): $this

Merge provided config with existing config. Unlike config() which does a recursive merge for nested keys, this method does a simple merge.

Setting a specific value:

$this->configShallow('key', $value);

Setting a nested value:

$this->configShallow('some.nested.key', $value);

Updating multiple config settings at the same time:

$this->configShallow(['one' => 'value', 'another' => 'value']);
Parameters
array<string, mixed>|string $key

The key to set, or a complete array of configs.

mixed|null $value optional

The value to set.

Returns
$this

decrement() ¶ public

decrement(string $key, int $offset = 1): int|false

Decrements the value of an integer cached key

Parameters
string $key

Identifier for the data

int $offset optional

How much to subtract

Returns
int|false

delete() ¶ public

delete(string $key): bool

Delete a key from the cache

Parameters
string $key

Identifier for the data

Returns
bool

deleteMultiple() ¶ public

deleteMultiple(iterable $keys): bool

Deletes multiple cache items as a list

This is a best effort attempt. If deleting an item would create an error it will be ignored, and all items will be attempted.

Parameters
iterable $keys

A list of string-based keys to be deleted.

Returns
bool
Throws
Cake\Cache\InvalidArgumentException
If $keys is neither an array nor a Traversable, or if any of the $keys are not a legal value.

duration() ¶ protected

duration(DateInterval|int|null $ttl): int

Convert the various expressions of a TTL value into duration in seconds

Parameters
DateInterval|int|null $ttl

The TTL value of this item. If null is sent, the driver's default duration will be used.

Returns
int

ensureValidKey() ¶ protected

ensureValidKey(string $key): void

Ensure the validity of the given cache key.

Parameters
string $key

Key to check.

Returns
void
Throws
Cake\Cache\InvalidArgumentException
When the key is not valid.

ensureValidType() ¶ protected

ensureValidType(iterable $iterable, string $check = self::CHECK_VALUE): void

Ensure the validity of the argument type and cache keys.

Parameters
iterable $iterable

The iterable to check.

string $check optional

Whether to check keys or values.

Returns
void
Throws
Cake\Cache\InvalidArgumentException

get() ¶ public

get(string $key, mixed $default = null): mixed

Read a key from the cache

Parameters
string $key

Identifier for the data

mixed $default optional

Default value to return if the key does not exist.

Returns
mixed

getConfig() ¶ public

getConfig(string|null $key = null, mixed $default = null): mixed

Returns the config.

Usage

Reading the whole config:

$this->getConfig();

Reading a specific value:

$this->getConfig('key');

Reading a nested value:

$this->getConfig('some.nested.key');

Reading with default value:

$this->getConfig('some-key', 'default-value');
Parameters
string|null $key optional

The key to get or null for the whole config.

mixed $default optional

The return value when the key does not exist.

Returns
mixed

getConfigOrFail() ¶ public

getConfigOrFail(string $key): mixed

Returns the config for this specific key.

The config value for this key must exist, it can never be null.

Parameters
string $key

The key to get.

Returns
mixed
Throws
InvalidArgumentException

getMultiple() ¶ public

getMultiple(iterable $keys, mixed $default = null): iterable

Obtains multiple cache items by their unique keys.

Parameters
iterable $keys

A list of keys that can obtained in a single operation.

mixed $default optional

Default value to return for keys that do not exist.

Returns
iterable
Throws
Cake\Cache\InvalidArgumentException
If $keys is neither an array nor a Traversable, or if any of the $keys are not a legal value.

groups() ¶ public

groups(): array<string>

Returns the group value for each of the configured groups If the group initial value was not found, then it initializes the group accordingly.

Returns
array<string>

has() ¶ public

has(string $key): bool

Determines whether an item is present in the cache.

NOTE: It is recommended that has() is only to be used for cache warming type purposes and not to be used within your live applications operations for get/set, as this method is subject to a race condition where your has() will return true and immediately after, another script can remove it making the state of your app out of date.

Parameters
string $key

The cache item key.

Returns
bool
Throws
Cake\Cache\InvalidArgumentException
If the $key string is not a legal value.

increment() ¶ public

increment(string $key, int $offset = 1): int|false

Increments the value of an integer cached key

Parameters
string $key

Identifier for the data

int $offset optional

How much to increment

Returns
int|false

init() ¶ public

init(array<string, mixed> $config = []): bool

Initialize the cache engine

Called automatically by the cache frontend. Merge the runtime config with the defaults before use.

Parameters
array<string, mixed> $config optional

Associative array of parameters for the engine

Returns
bool

set() ¶ public

set(string $key, mixed $value, DateInterval|int|null $ttl = null): bool

Write data for key into cache

Parameters
string $key

Identifier for the data

mixed $value

Data to be cached

DateInterval|int|null $ttl optional

Optional. The TTL value of this item. If no value is sent and the driver supports TTL then the library may set a default value for it or let the driver take care of that.

Returns
bool

setConfig() ¶ public

setConfig(array<string, mixed>|string $key, mixed|null $value = null, bool $merge = true): $this

Sets the config.

Usage

Setting a specific value:

$this->setConfig('key', $value);

Setting a nested value:

$this->setConfig('some.nested.key', $value);

Updating multiple config settings at the same time:

$this->setConfig(['one' => 'value', 'another' => 'value']);
Parameters
array<string, mixed>|string $key

The key to set, or a complete array of configs.

mixed|null $value optional

The value to set.

bool $merge optional

Whether to recursively merge or overwrite existing config, defaults to true.

Returns
$this
Throws
Cake\Core\Exception\CakeException
When trying to set a key that is invalid.

setMultiple() ¶ public

setMultiple(iterable $values, DateInterval|int|null $ttl = null): bool

Persists a set of key => value pairs in the cache, with an optional TTL.

Parameters
iterable $values

A list of key => value pairs for a multiple-set operation.

DateInterval|int|null $ttl optional

Optional. The TTL value of this item. If no value is sent and the driver supports TTL then the library may set a default value for it or let the driver take care of that.

Returns
bool
Throws
Cake\Cache\InvalidArgumentException
If $values is neither an array nor a Traversable, or if any of the $values are not a legal value.

warning() ¶ protected

warning(string $message): void

Cache Engines may trigger warnings if they encounter failures during operation, if option warnOnWriteFailures is set to true.

Parameters
string $message

The warning message.

Returns
void

Property Detail

$_config ¶ protected

Runtime config

Type
array<string, mixed>

$_configInitialized ¶ protected

Whether the config property has already been configured with defaults

Type
bool

$_defaultConfig ¶ protected

The default cache configuration is overridden in most cache adapters. These are the keys that are common to all adapters. If overridden, this property is not used.

  • duration Specify how long items in this cache configuration last.
  • groups List of groups or 'tags' associated to every key stored in this config. handy for deleting a complete group from cache.
  • prefix Prefix appended to all entries. Good for when you need to share a keyspace with either another cache config or another application.
  • warnOnWriteFailures Some engines, such as ApcuEngine, may raise warnings on write failures.
Type
array<string, mixed>

$_groupPrefix ¶ protected

Contains the compiled string with all group prefixes to be prepended to every key in this cache engine

Type
string

$data ¶ protected

Cached data.

Structured as [key => [exp => expiration, val => value]]

Type
array<string, array>
OpenHub
Pingping
Linode
  • Business Solutions
  • Showcase
  • Documentation
  • Book
  • API
  • Videos
  • Reporting Security Issues
  • Privacy Policy
  • Logos & Trademarks
  • Community
  • Get Involved
  • Issues (Github)
  • Bakery
  • Featured Resources
  • Training
  • Meetups
  • My CakePHP
  • CakeFest
  • Newsletter
  • Linkedin
  • YouTube
  • Facebook
  • Twitter
  • Mastodon
  • Help & Support
  • Forum
  • Stack Overflow
  • IRC
  • Slack
  • Paid Support

Generated using CakePHP API Docs