| Maintainability | Issues | Downloads | Release |
|---|---|---|---|
This bundle provides a simple page caching solution working as an in-app reverse proxy.
"php": "^5.3.9|^7.0",
"symfony/cache": "^3.1"Download composer at https://getcomposer.org/download/
composer require bigyouth/page-cache-bundleEnable the bundle by adding it to the bundles array of the registerBundles method in your project's app/AppKernel.php file :
<?php
# app/AppKernel.php
// ...
class AppKernel extends Kernel
{
public function registerBundles()
{
$bundles = [
// ...
new Bigyouth\BigyouthPageCacheBundle\BigyouthPageCacheBundle(),
];
// ...
}
// ...
}Here is the default bundle configuration :
# app/config/config.yml
bigyouth_page_cache:
enabled: false
ttl: 300
type: "filesystem"
exclude: []default : falseSet to true to enable the bundle.
default : 300Cache lifetime. This value varies by +5%/-5% to avoid multiple caches to expire at the same time.
default: filesystemTwo value can be set for this parameter : filesystem and redis.
If you use filesystem, the cache will be written in the cache folder : var/cache/by_cache.
default : empty arrayThis parameter allows you to define url schemes that will be excluded from the page caching.
ex :
exclude:
- "app_dev.php"
- "back"
- "login"
- "logout"
- "login_check"Every url that contains one of the terms above will not be processed by the BigyouthPageCacheBundle.
default : localhostRedis host. This parameter is only used when the type parameter is set to redis.
default : 6379Redis port. This parameter is only used when the type parameter is set to redis.
To use the BigyouthPageCacheBundle, your controller must extend the PageCacheController.php class and use the render function :
<?php
// ...
class AcmeController extends PageCacheController
{
// ...
public function indexAction(Request $request)
{
// ...
return $this->render('FrontBundle:Page:index.html.twig');
}
}The PageCacheController rewrites the render function to manage and render cache data. All of your controller actions that use the render function will be cached.
The BigyouthPageCacheBundle uses cache tags to identify your cache data. The tags are defined by the url scheme of the cached page.
For example, the page behind /products/list/my-product will be tagged with products, list and my-product.
Therefore you can invalidate a product page by doing the following in your controller :
// ...
$this->get('by.page_cache')->invalidate(["my-product"]);
// ...or if you want to invalidate all product pages :
// ...
$this->get('by.page_cache')->invalidate(["products"]);
// ...- Alexis Smadja - Initial work - Alxss
See also the list of contributors who participated in this project.
This project is licensed under the MIT License - see the LICENSE file for details.