You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
dimti c388e2c156 + support additional pieces for generate cache tags on clear cache general method 2 years ago
classes/observer + support additional pieces for generate cache tags on clear cache general method 2 years ago
updates Initial commit. 2 years ago
.gitignore Initial commit. 2 years ago
Plugin.php Initial commit. 2 years ago
README.md Initial commit. 2 years ago
composer.json Initial commit. 2 years ago

README.md

Observers

Observers maybe used for creating and clearing cache purposes

Example observer use

Create you own class with observer:

<?php namespace Dimti\Mirsporta\Classes\Observers;

use Dimti\Mirsporta\Models;
use Wpstudio\Helpers\Classes\Observer\BaseObserver;

class TagObserver extends BaseObserver
{
    public static function getClass(): string
    {
        return Models\Tag::class;
    }
}

Use in models:

<?php namespace Dimti\Mirsporta\Models;

use Dimti\Mirsporta\Classes\Observers;

class Tag extends Model
{
    //...

    public function afterSave()
    {
        Observers\TagObserver::clearCache();
    }
    
    //...
}

And in your code for caching data based on this model/observer:

use Dimti\Mirsporta\Classes\Observers;
//...

$cacheTags = Observers\TagObserver::getCacheTag();

$cacheKey = CacheManager::formatCacheKey([__CLASS__, __METHOD__, $siteId]);

\Cache::tags($cacheTags)->rememberForever($cacheKey, fn() =>
     Models\Tag::all()
));
  • CacheManager::formatCacheKey - that is simple helper for concatenate array elements to string

Clearing cache from admin dashboard widget

Template

<input
    type="button"
    class='btn btn-primary'
    value="Clear tag model cache"
    data-request="<?= $this->getEventHandler('onClearTagCache') ?>"
    data-request-success="$.oc.flashMsg({text: 'Cache of tag model is clearing', 'class': 'success', 'interval': 5}); return false;"
/>

Controller widget action

use Dimti\Mirsporta\Classes\Observers;

//...

public function onClearTagCache()
{
    Observers\TagObserver::clearCache();

    return ['status' => 1];
}

//...