intersvyaz / yii2-tag-dependency-helper
Helper for unifying cache tag names with invalidation support in yii2
Installs: 102
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 12
Forks: 16
Type:yii2-extension
Requires
- yiisoft/yii2: ~2.0.0
Requires (Dev)
- phpunit/phpunit: ~4.6.9
This package is auto-updated.
Last update: 2024-12-08 06:21:33 UTC
README
Helper for unifying cache tag names with invalidation support for Yii2.
Usage
In your model add behavior:
... use Intersvyaz\TagDependencyHelper\Traits\CachedFind; use Intersvyaz\TagDependencyHelper\InvalidateTagBehavior; ... class Configurable extends ActiveRecord { use CachedFind; /** * @inheritdoc */ public function behaviors() { return [ [ 'class' => InvalidateTagBehavior::class, 'cache' => 'cache', // optional option - application id of cache component ], ]; } }
This behavior automatically invalidates tags by model name and pair model-id.
If your cache entry should be flushed every time any row of model is edited - use getCommonTag
helper function:
use Intersvyaz\TagDependencyHelper\ActiveRecordCacheTags; ... $models = Configurable::getDb()->cache( function ($db) { return Configurable::find()->all($db); }, 86400, new TagDependency([ 'tags' => [ActiveRecordCacheTags::getCommonTag(Configurable::className())], ]) );
If your cache entry should be flushed only when exact row of model is edited - use getObjectTag
helper function:
use Intersvyaz\TagDependencyHelper\ActiveRecordCacheTags; ... $cacheKey = 'Product:' . $model_id; if (false === $product = Yii::$app->cache->get($cacheKey)) { if (null === $product = Product::findOne($model_id)) { throw new NotFoundHttpException; } Yii::$app->cache->set( $cacheKey, $product, 86400, new TagDependency( [ 'tags' => [ ActiveRecordCacheTags::getObjectTag(Product::class, $model_id), ] ] ) ); }
In the CachedFind trait implemented shortcut method cachedFindOne() and cachedFindAll() for cached find query.