Skip to content
This repository has been archived by the owner on Sep 6, 2019. It is now read-only.
/ cacheable Public archive

[Abandoned] Automatically cache basic Eloquent models using the find methods

License

Notifications You must be signed in to change notification settings

pulkitjalan/cacheable

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

22 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Cacheable

Automatically cache basic Eloquent models using the find methods

License Latest Version Total Downloads

Requirements

  • PHP >= 5.5.9
  • Laravel >= 5.1

Installation

Install via composer - In the terminal

composer require pulkitjalan/cacheable

This package makes use of pulkitjalan\multicache which requires a service provider to be registered. So add the following to the providers array in your config/app.php

PulkitJalan\Cache\Providers\MultiCacheServiceProvider::class

Usage

Simply use the Cacheable trait in any model you want to be cache automatically.

<?php

namespace App;

use Illuminate\Database\Eloquent\Model;
use PulkitJalan\Cacheable\Cacheable;

class CachedModel extends Model
{
    use Cacheable;
}

Caching the model only works with using the find, findMany or findOrFail methods.

If you would like caching behavior like in Laravel 4 then consider using dwightwatson/rememberable which adds the remember function back into eloquent. Both packages can be used together also.

You can optinally set the expiry time in minutes for the model, by default it is set to 1440 minutes (24 hours).

<?php

namespace App;

use Illuminate\Database\Eloquent\Model;
use PulkitJalan\Cacheable\Cacheable;

class CachedModel extends Model
{
    use Cacheable;

    /**
     * Set the cache expiry time.
     *
     * @var int
     */
    public $cacheExpiry = 60;
}

Models are cached using the models table name as the cache tag and the id as the key. There are observers which get registered in the trait to also remove from cache when the saved or deleted.

Caching is only applied to basic models (ones without any conditions added).

// cached
CachedModel::find(1);

// not cached
CachedModel::where('some_field', 1)->find(1);

// not cached
CachedModel::with('relation')->find(1);

The cache can be manually cleared by calling the new refresh method on the cached model which can be found in the Cacheable trait.

// manually clear cache
CachedModel::find(1)->refresh();

About

[Abandoned] Automatically cache basic Eloquent models using the find methods

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages