EPWTCacheBundle
, (*1)
, (*2)
The EPWTCacheBundle provides wrapper for epwt/cache library smashed with Symfony DependencyInjection magic., (*3)
EPWT/Cache
EPWT/Cache is PSR-6 (Yes it only proposed) compiliant CacheItemPool implementation for Redis and maybe in future other Cache storage., (*4)
Require
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, (*5)
Currently supported drivers:
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 in class
attribute.
- By default
CacheItemPool
name is alias
attribute value but if you want use different one specify with pool-name
attribute
- If you want to specify whole
CacheItemPool
default TTL use attribute default-ttl
value is in seconds from setting value
Usage Examples
- This bundle has
CacheItemPoolsContainer
service with id epwt_cache_pools
- This budnle also provides
CacheItemPoolsAwareTrait
with requires $this->getContainer
method, $this->container
property or $this->get()
method (In Controllers only) and provides getCacheItemPool($name)
method for getting CacheItemPool
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:, (*6)
Resources/meta/LICENSE
About
EPWTCacheBundle is brought to you by Aurimas Niekis., (*7)
Reporting an issue or a feature request
Issues and feature requests are tracked in the Github issue tracker., (*8)
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., (*9)