euskadi31 / cache-service-provider
A Cache Service Provider for Silex 2.0, using the doctrine/cache package
Installs: 532
Dependents: 1
Suggesters: 1
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
pkg:composer/euskadi31/cache-service-provider
Requires
- doctrine/cache: ^1.4
- silex/silex: ~2.0@dev
Requires (Dev)
- leaphub/phpcs-symfony2-standard: ~2.0.1
- phpunit/phpunit: ^4.7
This package is not auto-updated.
Last update: 2025-10-11 23:22:12 UTC
README
This service provider for Silex 2.0 uses the Cache classes from Doctrine Common to provide a cache service to a Silex application, and other service providers.
Install
Add euskadi31/cache-service-provider to your composer.json:
% php composer.phar require euskadi31/cache-service-provider:~1.0
Usage
Configuration
If you only need one application wide cache, then it's sufficient to
only define a default cache, by setting the default key in cache.options.
The cache definition is an array of options, with driver being the
only mandatory option. All other options in the array, are treated as
constructor arguments to the driver class.
The cache named default is the cache available through the app's
cache service.
<?php $app = new Silex\Application; $app->register(new \Euskadi31\Silex\Provider\CacheServiceProvider, [ 'cache.options' => [ 'default' => [ 'driver' => 'apc' ] ] ]);
The driver name can be either:
- A fully qualified class name
- A simple identifier like "apc", which then gets translated to \Doctrine\Common\Cache\ApcCache.
- A Closure, which returns an object implementing \Doctrine\Common\Cache\Cache.
This cache is then available through the cache service, and provides
an instance of Doctrine\Common\Cache\Cache:
if ($app['cache']->contains('foo')) { echo $app['cache']->fetch('foo'), "<br />"; } else { $app['cache']->save('foo', 'bar'); }
To configure multiple caches, define them as additional keys in cache.options:
$app->register(new \Euskadi31\Silex\Provider\CacheServiceProvider, [ 'cache.options' => [ 'default' => [ 'driver' => 'apc' ], 'file' => [ 'driver' => 'filesystem', 'directory' => '/tmp/myapp' ], 'global' => [ 'driver' => function() { $redis = new \Doctrine\Common\Cache\RedisCache; $redis->setRedis($app['redis']); return $redis; } ] ] ]);
All caches (including the default) are then available via the caches service:
$app['caches']['file']->save('foo', 'bar');
License
CacheServiceProvider is licensed under the MIT license.