fxcjahid / laravel-eloquent-cache-magic
A powerful Laravel package for automatic Eloquent query caching with zero-code auto-cache, Redis/Memcached tag support, automatic invalidation, and advanced monitoring
Requires
- php: ^8.0|^8.1|^8.2|^8.3|^8.4
- illuminate/cache: ^10.0|^11.0|^12.0
- illuminate/database: ^10.0|^11.0|^12.0
- illuminate/support: ^10.0|^11.0|^12.0
- predis/predis: ^2.0
Requires (Dev)
- mockery/mockery: ^1.5
- orchestra/testbench: ^7.0|^8.0|^9.0
- pestphp/pest: ^2.0
- pestphp/pest-plugin-laravel: ^2.0
- phpunit/phpunit: ^9.5|^10.0|^11.0
Suggests
- ext-memcached: Required for Memcached cache driver with tag support
- predis/predis: Required for Redis cache driver with tag support (^2.0)
This package is auto-updated.
Last update: 2025-09-16 08:39:20 UTC
README
A powerful Laravel package that adds automatic and intelligent caching to your Eloquent queries with zero effort. Features include automatic cache invalidation, Redis/Memcached tag support, cache statistics, and much more!
๐ Read Complete Documentation - Everything you need to know in one place
โจ Features
- ๐ Zero Configuration - Works out of the box with sensible defaults
- ๐ Automatic Query Caching - All queries are automatically cached without any code changes!
- ๐ท๏ธ Cache Tags Support - Full support for Redis and Memcached tagged caching
- ๐ Automatic Cache Invalidation - Cache automatically clears on model create, update, delete
- ๐ Built-in Statistics - Monitor cache hit rates and performance
- ๐ฏ Adaptive TTL - Automatically adjusts cache duration based on access patterns
- ๐ง Flexible API - Multiple ways to configure caching per query
- ๐ Multi-Driver Support - Works with Redis, Memcached, File, Database drivers
- ๐งช Fully Tested - Comprehensive test coverage with PHPUnit and Pest
- ๐ Performance Monitoring - Track and optimize cache performance
- โก Async Cache Refresh - Refresh cache in background jobs
- ๐ค Auto User/Guest Tags - Automatic user-specific cache isolation
- ๐ซ doNotCache() Method - Disable caching for specific queries (DataTables compatible)
๐ Requirements
- PHP 8.0 - 8.4
- Laravel 10.0 - 12.0
- Redis or Memcached (optional, for tag support)
๐ฆ Installation
composer require fxcjahid/laravel-eloquent-cache-magic
Optional: Publish Configuration
php artisan vendor:publish --tag=cache-magic-config
Recommended: Setup Redis for Tag Support
composer require predis/predis
CACHE_DRIVER=predis REDIS_HOST=127.0.0.1 REDIS_PASSWORD=null REDIS_PORT=6379
Also update config\database.php
'redis' => [ 'client' => env('REDIS_CLIENT', 'predis'), ]
๐ Quick Start
๐ NEW: Automatic Query Caching (v0.2+)
With auto-cache enabled, ALL your queries are automatically cached without any code changes:
use App\Models\User; use App\Models\Product; // These queries are AUTOMATICALLY cached (no ->cache() needed!) $users = User::all(); // Auto-cached! $product = Product::find(1); // Auto-cached! $count = User::where('active', true)->count(); // Auto-cached! // Bypass auto-cache when you need fresh data $freshUsers = User::withoutCache()->get(); // Skip cache $freshProduct = Product::fresh()->find(1); // Skip cache // Disable auto-cache for specific models class Order extends Model { use CacheableTrait; protected $autoCache = false; // Disable auto-cache for this model }
Manual Caching (Traditional Method)
You can still manually control caching with the ->cache()
method:
// Manually cache the query $users = User::where('active', true)->cache()->get(); // Cache for specific duration (in seconds) $users = User::where('active', true)->cache(3600)->get(); // 1 hour // Cache with tags (Redis/Memcached only) $users = User::where('active', true) ->cache() ->tags(['users', 'active']) ->get(); // Clear cache by tags Cache::tags(['users'])->flush(); // Only clears 'users' tagged cache
Model Integration
use Illuminate\Database\Eloquent\Model; use Fxcjahid\LaravelEloquentCacheMagic\Traits\CacheableTrait; class Product extends Model { use CacheableTrait; protected $cacheExpiry = 7200; // 2 hours protected $cacheTags = ['products']; }
๐ฏ Key Features Explained
๐ Automatic Query Caching (NEW!)
Enable automatic caching for ALL queries without changing your code:
// In config/cache-magic.php 'auto_cache' => [ 'enabled' => true, // Enable auto-caching 'ttl' => 3600, // Default 1 hour 'aggregate_ttl' => 300, // 5 min for count/sum/avg 'find_ttl' => 7200, // 2 hours for find() ],
Once enabled, all your existing queries are automatically cached:
// These are ALL automatically cached now! User::all(); // Cached for 1 hour Product::find($id); // Cached for 2 hours Order::count(); // Cached for 5 minutes Invoice::where('paid', true)->get(); // Cached for 1 hour // Need fresh data? Bypass cache: User::withoutCache()->all(); // Direct from database Product::fresh()->find($id); // Direct from database
Cache Tags - Smart Invalidation
// Cache with tags for smart invalidation $products = Product::where('category', 'electronics') ->cache() ->tags(['products', 'electronics']) ->get(); // Clear all electronics products Cache::tags(['electronics'])->flush(); // Clear all products Cache::tags(['products'])->flush();
Automatic Cache Invalidation
class Product extends Model { use CacheableTrait; // Cache automatically clears when model is updated/deleted protected $cacheTags = ['products']; // Dynamic tags based on attributes public function dynamicCacheTags(): array { return [ 'category:' . $this->category_id, 'brand:' . $this->brand_id, ]; } }
Performance Monitoring
use Fxcjahid\LaravelEloquentCacheMagic\Facades\CacheMagic; // Get cache statistics $stats = CacheMagic::statistics()->getGlobalStats(); // Returns: ['hit_rate' => '92.5%', 'hits' => 15420, ...] // Check cache health $health = CacheMagic::health()->check(); // Returns: ['status' => 'healthy', 'checks' => [...]]
๐ Console Commands
# Clear cache php artisan cache-magic:clear --tags=products # View statistics php artisan cache-magic:stats # Warm cache php artisan cache-magic:warm --model=Product
๐ Complete Documentation
Read the complete documentation for comprehensive details on:
- โ All query methods and parameters
- โ Cache tags explained with examples
- โ Model integration guide
- โ Console commands usage
- โ API middleware setup
- โ Performance monitoring
- โ Helper functions
- โ Advanced features
- โ Troubleshooting guide
๐งช Testing
# Run tests vendor/bin/pest # With coverage vendor/bin/pest --coverage
๐ค Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
๐ License
This package is open-sourced software licensed under the MIT license.
๐จโ๐ป Author
FXC Jahid
- GitHub: @fxcjahid
- Email: fxcjahid3@gmail.com
๐ Support
If you find this package helpful, please give it a โญ on GitHub!