sci / cacheable
Transparent caching library
1.0.1
2016-02-21 18:40 UTC
Requires
- php: >=5.4.0
- psr/cache: 1.0.0
- psr/cache-implementation: 1.0.0
Requires (Dev)
- ext-redis: *
- cache/array-adapter: ^0.3.0
- cache/chain-adapter: ^0.2.0
- cache/doctrine-adapter: dev-master
- cache/redis-adapter: dev-master
- phpunit/phpunit: ^4.7
This package is auto-updated.
Last update: 2024-11-09 00:35:22 UTC
README
Installation
Using composer:
composer require sci/cacheable
Usage
Lets say, you have a class Foo
, implementing a method Foo::bar()
with quite high time/resource consumption:
class Foo { public function bar($a, $b) { // make some hard things with $a and $b ... return ...; // some result } } $foo = new Foo(); $bar = $foo->bar(1, 2); // takes some amount of time // and later, again... $bar = $foo->bar(1, 2); // takes the same amount of time, again
If there are no side-effects, the result of Foo::bar()
is determined only by its arguments $a
and $b
.
So you could use some cache, if eventuelly the method is called again.
To avoid messing around with cache keys, you can use sci\cacheable
:
use Sci\Cacheable; use Sci\CacheTrait; class Foo implements Cacheable { use CacheTrait; public function bar($a, $b) { // make some hard things with $a and $b ... return ...; // some result } } $foo = new Foo(); $foo->setCache(/* any PSR-6 cache pool interface */) $bar = $foo->cache()->bar(1, 2); // 1st call takes some time, but now, the result is stored into cache // and later, again... $bar = $foo->cache()->bar(1, 2); // 2nd call's result comes directly from cache
en détail
- A class to be cached (
Foo
in example above) implements the interfaceSci\Cacheable
(which demands a methodcache()
). - This can be done using
Sci\CacheTrait
(which additially provides a methodsetCache()
). - The method
setCache
gets as first argument a service, implementingPsr\Cache\CacheItemPoolInterface
.- This cache pool is the actual cache backend.
- An optional second argument to
setCache
is the default TTL (time to live) for all cached values.
- To use the cache, method calls are proxied through the method
cache()
, e.g. instead of$foo->bar(1, 2)
, now we use$foo->cache()->bar(1, 2)
.- Method
cache()
returns$this
, i.e. it acts in a transparent way (fluent interface). - An optional argument for
cache()
allows to specify a TTL, different from the default one.
- Method
Implementation
License
All contents of this package are licensed under the MIT license.