CakePHP Caching Behaviour
, (*1)
Caching Behaviour for CakePHP 2.1+, (*2)
Use it if you want to wrap model methods with cache.
For example you can use this for heavy model methods,
that can't change output value for some time, but you need to invoke them very often., (*3)
Installation
cd my_cake_app/app
git clone git://github.com/imsamurai/cakephp-caching-behavior.git Plugin/Caching
or if you use git add as submodule:, (*4)
cd my_cake_app
git submodule add "git://github.com/imsamurai/cakephp-caching-behavior.git" "app/Plugin/Caching"
then add plugin loading in Config/bootstrap.php, (*5)
CakePlugin::load('Caching');
Configuration
Attach behaviour to model:, (*6)
public $actsAs = array(
'Caching.Caching' => array(
'cache' => <valid cache config or name>, // optional
'cachedObject' => <name of object class> // optional
)
);
If cache is not specified in config and method cache()
used 'default' cache config.
By default for 'cachedObject' used 'Caching.CachedObject' that stored in Lib folder. You can use your own class, that
must be in Lib folder of app or plugin. But remember that your class must have same interface., (*7)
Usage
After attaching behavior to your model you can do (assuming your model has methods something()
and somethingElse()
):, (*8)
$Model->cached()->something(/*args*/);
or, (*9)
$Model->cached(/*cache name*/)->something(/*args*/);
or, (*10)
$CachedModel = $Model->cached(/*cache name or empty*/);
$CachedModel->something(/*args*/);
$CachedModel->somethingElse(/*args*/);
$Model->cached()
returns object-wrapper that use magick methods and caching. So if expire date is ok,
and you invoke same cached methods with same arguments and same cache config then model method calls
only once., (*11)