se7enxweb / ezplatform-http-cache
HTTP cache handling for Exponential Platform.
Installs: 16
Dependents: 7
Suggesters: 0
Security: 0
Stars: 2
Watchers: 0
Forks: 24
Type:ezplatform-bundle
pkg:composer/se7enxweb/ezplatform-http-cache
Requires
- php: >=7.3
- ezsystems/ezplatform-kernel: ^4.0
- ezsystems/ezplatform-rest: ^4.0
- friendsofsymfony/http-cache: ^2.9
- friendsofsymfony/http-cache-bundle: ^2.8
- php-http/curl-client: ^2.1
- psr/http-client: ^1.0
- symfony/config: ^5.0
- symfony/dependency-injection: ^5.0
- symfony/event-dispatcher: ^5.0
- symfony/http-foundation: ^5.0
- symfony/http-kernel: ^5.0
- symfony/routing: ^5.0
- symfony/yaml: ^5.0
- toflar/psr6-symfony-http-cache-store: ^2.2
Requires (Dev)
- ezsystems/doctrine-dbal-schema: ^4.0
- ezsystems/ezplatform-code-style: ^0.1.0
- friendsofphp/php-cs-fixer: ^2.16.0
- ibexa/ci-scripts: ^0.2
- matthiasnoback/symfony-dependency-injection-test: ^4.1
- phpspec/phpspec: ^6.1
- phpunit/phpunit: ^8.5
- symfony/phpunit-bridge: ^5.1
- v4.0.0-alpha2
- v4.0.0-alpha1
- 2.3.x-dev
- v2.3.17
- v2.3.16
- v2.3.15
- v2.3.14
- v2.3.13
- v2.3.12
- v2.3.11
- v2.3.10
- v2.3.9
- v2.3.8
- v2.3.7
- v2.3.6
- v2.3.5
- v2.3.4
- v2.3.3
- v2.3.2
- v2.3.1
- v2.3.0
- v2.3.0-rc2
- v2.3.0-rc1
- v2.3.0-beta1
- 2.2.x-dev
- v2.2.3
- v2.2.2
- v2.2.1
- v2.2.0
- v2.2.0-rc1
- v2.2.0-beta1
- 2.1.x-dev
- v2.1.4
- v2.1.3
- v2.1.2
- v2.1.1
- v2.1.0
- v2.1.0-rc1
- v2.1.0-beta1
- 2.0.x-dev
- v2.0.2
- v2.0.1
- v2.0.0
- v2.0.0-rc1
- v2.0.0-beta1
- 1.0.x-dev
- v1.0.6
- v1.0.5
- v1.0.4
- v1.0.3
- v1.0.2
- v1.0.1
- v1.0.0
- v1.0.0-rc1
- v1.0.0-beta4
- v1.0.0-beta3
- v1.0.0-beta2
- v1.0.0-beta1
- 0.9.x-dev
- v0.9.5
- v0.9.4
- v0.9.3
- v0.9.3-rc1
- v0.9.2
- v0.9.2-rc2
- v0.9.2-rc1
- v0.9.1
- v0.9.1-rc2
- v0.9.1-rc1
- v0.9.0
- v0.9.0-rc3
- v0.9.0-rc2
- v0.9.0-rc1
- 0.8.x-dev
- v0.8.3
- v0.8.2
- v0.8.1
- v0.8.0
- v0.8.0-rc2
- v0.8.0-rc1
- v0.8.0-beta1
- v0.7.1-rc1
- v0.7.0
- v0.7.0-rc2
- v0.7.0-rc1
- v0.7.0-beta1
- v0.6.1.1
- v0.6.1
- v0.6.1-rc1
- v0.6.0.2
- v0.6.0.1
- v0.6.0
- v0.6.0-rc2
- v0.6.0-rc1
- v0.5.0
- v0.5.0-rc4
- v0.5.0-rc3
- v0.5.0-rc2
- v0.5.0-rc1
- v0.5.0-beta1
- v0.4.2.3
- v0.4.2.2
- v0.4.2.1
- v0.4.2
- v0.4.2-rc2
- v0.4.1
- v0.4.1-rc2
- v0.4.1-rc1
- v0.4.0
- v0.4.0-rc1
- v0.4.0-beta1
- v0.3.0
- v0.3.0-rc4
- v0.3.0-rc3
- v0.3.0-rc2
- v0.3.0-rc1
- v0.2.5
- v0.2.4
- v0.2.3
- v0.2.2
- v0.2.1.1
- v0.2.1
- v0.2.0
- v0.1.1
- v0.1.1-rc1
- v0.1.1-beta1
- v0.1.0
- v0.1.0-rc1
- dev-IBX-3014_v2
- dev-snapshot-master
- dev-IBX-828-Moved-jobs-to-GitHubActions-08
- dev-dfs_static_files
- dev-cache_REST_post_views
- dev-adriendupuis-patch-1
- dev-ezee-3422-update-3.3-licenses
- dev-switch-travis-to-flex
- dev-fix-notifications
- dev-load-varnish-only-when-used
- dev-master_remove-http-as-valid-purge-type
- dev-symfony4
- dev-view_parameters_tagger
- dev-behat_view_cache
This package is auto-updated.
Last update: 2025-09-28 08:58:47 UTC
README
platform-http-cache
Provides HTTP cache handling for eZ Platform, by default since version 1.12. From ezpublish-kernel, it adds support for mult-tagging for Symfony Proxy, Varnish (using xkey). Support for Fastly is part of the eZ Platform Cloud Enterprise offer as of 1.13 LTS.
Usage with Varnish
For usage with Varnish see the dedicated document in docs/varnish
Features
xkey header on ContentView responses
Responses from /content/view will be tagged based on their contents:
curl -i -X HEAD 'http://localhost:8000/'
HTTP/1.1 200 OK
Host: localhost:8000
Connection: close
Cache-Control: public, s-maxage=60
Content-Type: text/html; charset=UTF-8
Vary: X-User-Hash
xkey: content-1 content-type-1 location-2 parent-1 path-1 path-2 ez-all
As of v0.7, if you have several repositories configured, the tags will be prefixed by repository name on non default repository. E.g. "intranet_path-1".
For further reading on tags see docs/using_tags.md.
Toggling of cache on ContentView responses
Responses from /content/view will be made cachable, and the shared max age will be set if it is enabled.
Purging of tagged HTTP cache on Repository operations
A set of Slots will send HTTP PURGE requests for each cache tag affected by write operations.
Configuration
Drivers
This bundle lets you configure drivers for handling HTTP cache. The following exists from eZ:
- local: extended Symfony Proxy to support tagging and varying by user rights (available in this bundle)
- httpaka- varnish: Varnish proxy using and customizing FosHttpCache for purging (available in this bundle)
- fastly: Fastly CDN proxy (available with eZ Platform Enterprise and documented separately)
Configuring these is done using global ezpublish.http_cache.purge_type config. By default it is set to use
%purge_type% parameter, and can be set in app/config/parameters.yml like so:
parameters:
    purge_type: varnish
For further reading on drivers see docs/drivers.md.
Tags
For further reading on tags see docs/using_tags.md.