there4 / slim-stash-middleware
Slim Stash Cache Middleware
v0.1.2
2014-11-01 17:11 UTC
Requires
- tedivm/stash: 0.12.*
This package is auto-updated.
Last update: 2024-11-20 05:24:36 UTC
README
Caching middleware layer for Slim using Stash
About
A simple middleware layer for Slim that provides a caching mechanism for endpoints.
Example Setup
Here is an example of the middleware setup. It's using a config setting to enable the cache.
<?php // Stash Page Cache Middleware // ----------------------------------------------------------------------------- // A generalized way of caching the output of an endpoint $app->container->singleton('stash', function () use ($app) { if (!is_dir($app->config('caches.path'))) { mkdir($app->config('caches.path'), 0777, true); } $stashFileSystem = new \Stash\Driver\FileSystem(array( 'path' => $app->config('caches.path') )); return new \Stash\Pool($stashFileSystem); }); if ($app->config('enable_cache')) { $app->add(new \There4\Slim\Middleware\StashCache($app->stash)); }
And an endpoint that uses the cache:
<?php // Root of the site // ----------------------------------------------------------------------------- // Simple index page - no data $app->get('/', function () use ($app) { $app->response->allowCache = true; $app->response->cacheExpiration = 3600; $app->render('index.html'); }); // User Profile Page // ----------------------------------------------------------------------------- // This would need to be coupled with a cache invalidation on a user change $app->get('/profile', function () use ($app) { $user = $app->currentUser; $app->response->allowCache = true; $app->response->cacheExpiration = 3600; $app->response->signature = 'userProfile' . $user->id; $app->render('index.html'); });
Quick API Reference
- $app->response->allowCache
bool
enable caching - $app->response->cacheExpiration
int
seconds to hold data in cache; - $app->response->signature
mixed
leave unset for automatic url based. String for simple signature. Callback function will be executed. Array incall_user_func
format is acceptable as well.
TODO
- Cache warming script
- Tests