davidecesarano / embryo-cache
PSR-16 Simple Cache implementantion using PSR Stream.
Requires
- php: >=7.1
- davidecesarano/embryo-emitter: dev-master
- davidecesarano/embryo-http: dev-master
- psr/simple-cache: 1.0.1
Requires (Dev)
- phpstan/phpstan: ^0.12.54
This package is auto-updated.
Last update: 2025-03-09 00:52:06 UTC
README
A minimal PSR-16 cache implementation with file stream system.
Requirements
- PHP >= 7.1
- A PSR-7 http message implementation and PSR-17 http factory implementation (ex. Embryo-Http)
- A PSR response emitter (ex. Embryo-Emitter)
Installation
Using Composer:
$ composer require davidecesarano/embryo-cache
Usage
Set Response
and Emitter
objects. Later, set the Cache
object passing it the cache directory path.
use Embryo\Cache\Cache; use Embryo\Http\Emitter\Emitter; use Embryo\Http\Factory\ResponseFactory; $emitter = new Emitter; $response = (new ResponseFactory)->createResponse(200); $cachePath = __DIR__.DIRECTORY_SEPARATOR.'cache'; $cache = new Cache($cachePath); if (!$cache->has('test')) { $cache->set('test', 'Hello World!', 3600); } $body = $response->getBody(); $body->write($cache->get('test', 'Default value!')); $response = $response->withBody($body); $emitter->emit($response);
In this example we check if the item cache test
exists; if it not exists, we set test
item cache with value Hello World!
and the Time To Live (TTL) in 3600
seconds. Later, we get the test
item cache with default value if item cache not exists.
Example
You may quickly test this using the built-in PHP server going to http://localhost:8000.
$ cd example
$ php -S localhost:8000
Options
setDefaultTtl($ttl)
You can set the default expiration TTL time. $ttl
must be an integer or a DateInterval
object.
Collection
Retrieving data
You may retrieve an item from the cache and you may also pass a default value as the second argument to the get
method:
$cache->get('key', 'default');
Storing data
The set
method may be used to set a new value onto a cache with an optional expiration TTL time:
$cache->set('key', 'value', 3600);
Deleting data
The delete
method will remove a piece of data from the cache. If you would like the remove all data from the cache, you may use the clear
method:
$cache->delete('key'); $cache->clear();
Retrieving multiple data
You may retrieve multiple items from the cache and you may also pass a default value as the second argument to the getMultiple
method:
$cache->getMultiple(['key1', 'key2'], 'default');
Storing multiple data
The setMultiple
method may be used to set a multiple values onto a cache with an optional expiration TTL time:
$cache->setMultiple([ 'key1' => 'value', 'key2' => 'value' ], 3600);
Deleting multiple data
The deleteMultiple
method will remove items from the cache:
$cache->deleteMultiple(['key1', 'key2']);
Determining if an item exists in the cache
To determine if an item is present in the cache, you may use the has
method. The has method returns true
if the item is present and is not false
:
if ($cache->has('key')) { //... }