Skip to content

abr4xas/cache-version-laravel

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

1 Commit
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Laravel Logo

Cache Versioned for Laravel

abr4xas/cache-version-laravel is a lightweight helper around Laravel's cache system that automatically versions cache keys behind a human-friendly prefix. That lets you invalidate entire groups of cached data without touching individual keys or writing custom eviction logic—perfect for paginated feeds, dashboards, and expensive queries.

Requirements

  • PHP 8.4 or later
  • Laravel Framework 12.37 or later

Installation

Install via Composer:

composer require abr4xas/cache-version-laravel

The package registers its service provider automatically thanks to Laravel Package Discovery, so no additional setup is required.

How It Works

Every cache entry is stored using the following pattern:

<prefix>:v<version>:<key>
  • Prefix — A logical namespace for a group of cached values.
  • Version — An auto-incremented integer stored in cache to invalidate the entire prefix.
  • Key — Whatever identifier you need underneath the prefix.

When you call flush('prefix'), the version increments and all previously stored entries become unreachable without needing to manually delete any keys.

Usage Examples

use Abr4xas\CacheVersionedLaravel\Facade\CacheVersioned as VersionedCache;
use App\Models\Post;
use App\Models\Setting;

// 1️⃣ Basic usage with TTL (seconds or DateInterval)
$posts = VersionedCache::remember(
    'angel_cruz_cache_blog_page',
    'posts:page:1',
    3600,
    fn () => Post::latest()->paginate(10)
);

// 2️⃣ Cache forever without a TTL
$settings = VersionedCache::rememberForever(
    'site_settings',
    'home_page',
    fn () => Setting::all()->pluck('value', 'key')
);

// 3️⃣ Invalidate an entire prefix instantly
VersionedCache::flush('angel_cruz_cache_blog_page');

// 4️⃣ Use a specific cache store for an operation
$pageNine = VersionedCache::remember(
    'angel_cruz_cache_blog_page',
    'posts:page:9',
    3600,
    fn () => Post::latest()->paginate(10),
    store: 'array_secondary' // or 'file', 'redis', 'database', etc.
);

Service Container Access

If you prefer dependency injection, resolve the service from the container:

use Abr4xas\CacheVersionedLaravel\CacheVersioned;

class DashboardController
{
    public function __construct(
        private CacheVersioned $cache
    ) {}

    public function __invoke()
    {
        return $this->cache->remember('dashboard', 'stats', 600, function () {
            // Heavy aggregation work...
        });
    }
}

Available Methods

  • put(string $prefix, string $key, mixed $value, DateInterval|DateTimeInterface|int|null $ttl = null, ?string $store = null): bool
  • get(string $prefix, string $key, mixed $default = null, ?string $store = null): mixed
  • forget(string $prefix, string $key, ?string $store = null): bool
  • flush(string $prefix, ?string $store = null): int
  • remember(string $prefix, string $key, DateInterval|DateTimeInterface|int|null $ttl, callable $callback, ?string $store = null): mixed
  • rememberForever(string $prefix, string $key, callable $callback, ?string $store = null): mixed
  • version(string $prefix, ?string $store = null): int
  • setVersion(string $prefix, int $version, ?string $store = null): bool
  • reset(string $prefix, ?string $store = null): bool

All methods accept an optional $store argument, allowing you to switch cache drivers per call without touching your business logic.

Testing

The repository includes a Pest test suite that exercises the full API surface, façade integration, and per-store isolation:

composer test

The test suite uses Orchestra Testbench with in-memory cache drivers, so it runs without external services.

Tips & Best Practices

  • Prefix consistently — Use descriptive prefixes (e.g., blog_posts, user_profile:{$userId}) to control invalidation boundaries precisely.
  • Flush selectively — Prefer flush() over manual key removal to keep your code succinct and less error-prone.
  • Custom stores — Use per-call stores for long-lived caches (e.g., Redis) while keeping defaults on faster transient drivers.
  • Observe versionsversion() is handy for debugging and for exposing cache state in observability dashboards.

Contributing

  1. Fork the repository.
  2. Install dependencies with composer install.
  3. Run composer test to ensure the suite passes.
  4. Open a pull request describing your change.

Please feel free to submit issues or enhancements. Contributions are welcome!

License

The MIT License (MIT). Refer to the LICENSE file for more information.

About

just a POC

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages