epwt / cache-bundle
EPWT/Cache Symfony Bundle PSR-6 Cache Item Pool
Installs: 10
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 2
Forks: 0
Open Issues: 0
Type:symfony-bundle
Requires
- php: >=5.3
- epwt/cache: ~1.0
Suggests
- snc/redis-bundle: Provides nice and quick integration of phpredis & predis to Symfony application
This package is auto-updated.
Last update: 2021-01-17 09:20:32 UTC
README
The EPWTCacheBundle provides wrapper for epwt/cache library smashed with Symfony DependencyInjection magic.
EPWT/Cache
EPWT/Cache is PSR-6 (Yes it only proposed) compiliant CacheItemPool implementation for Redis and maybe in future other Cache storage.
Require
- Symfony >2.3
- phpredis/predis (SncRedisBundle does really fine)
Instalation
composer require epwt/cache-bundle "~1.0"
public function registerBundles() { $bundles[] = new EPWT\CacheBundle\EPWTCacheBundle(); }
Configuration
All CacheItemPool configuration is done via Symfony Container
Currently supported drivers:
- redis
- sncredis
Configuration Examples
Redis Driver
<service id="acme.demo.items.pool" class="stdClass"> <tag name="epwt_cache_pool" alias="acme_demo_pool" driver="redis" redis-id="acme.demo.redis"/> </service>
SncRedis Driver
<service id="acme.demo.items.pool" class="stdClass"> <tag name="epwt_cache_pool" alias="acme_demo_pool" driver="snc_redis" sncredis-client="default"/> </service>
Additional Options
- If you want you can extend
CacheItemPool
class and specify it inclass
attribute. - By default
CacheItemPool
name isalias
attribute value but if you want use different one specify withpool-name
attribute - If you want to specify whole
CacheItemPool
default TTL use attributedefault-ttl
value is in seconds from setting value
Usage Examples
- This bundle has
CacheItemPoolsContainer
service with idepwt_cache_pools
- This budnle also provides
CacheItemPoolsAwareTrait
with requires$this->getContainer
method,$this->container
property or$this->get()
method (In Controllers only) and providesgetCacheItemPool($name)
method for gettingCacheItemPool
With Trait
class HelloWorldCommand extends ContainerAwareCommand { use CacheItemPoolsAwareTrait; protected function configure() { $this->setName('acme:hello'); } protected function execute(InputInterface $input, OutputInterface $output) { $pool = $this->getCacheItemPool('acme_demo_pool'); $poolItem = new CacheItem('foo'); $poolItem->set('bar'); $pool->save($poolItem); } }
Without Trait
class HelloWorldCommand extends ContainerAwareCommand { protected function configure() { $this->setName('acme:hello'); } protected function execute(InputInterface $input, OutputInterface $output) { $pool = $this->getContainer()->get('epwt_cache_pools')->get('acme_demo_pool'); $poolItem = new CacheItem('foo'); $poolItem->set('bar'); $pool->save($poolItem); } }
License
This bundle is under the MIT license. See the complete license in the bundle:
Resources/meta/LICENSE
About
EPWTCacheBundle is brought to you by Aurimas Niekis.
Reporting an issue or a feature request
Issues and feature requests are tracked in the Github issue tracker.
When reporting a bug, it may be a good idea to reproduce it in a basic project built using the Symfony Standard Edition to allow developers of the bundle to reproduce the issue by simply cloning it and following some steps.