- Fixed regression with the extension class when
ttl_header
is not set.
- Added:
cache_control.ttl_header
to configure the TTL header name for thereverse_proxy_ttl
cache control rule configuration. #638
- Fixed extension to depend on the DependencyInjection component rather than the HttpKernel.
- Fixed regression in AttributesListener: Ignore other attributes on controller methods.
- Minimum PHP version is now 8.1
- Support Symfony 6.4 and 7
- Drop obsolete annotations support, use attributes
Remove all configuration you have at
fos_http_cache.tags.annotations
- Make
fastly
andcloudflare
clients lazy loaded to support Symfony secrets that are only available at runtime, but not yet when the container is built. - Removed deprecated
FOS\HttpCacheBundle\UserContext\AnonymousRequestMatcher
, use the class from theFOSHttpCache
component instead:FOS\HttpCache\UserContext\AnonymousRequestMatcher
. - Removed obsolete
ContextInvalidationLogoutHandler
, useContextInvalidationSessionLogoutHandler
instead. - Fixed service loading to not fail when Twig is not available.
- Fix readthedocs build.
- Support to configure the fastly CDN client.
- Catch
SessionNotFoundException
in FlashMessageListener, as Symfony 6 moved from returningnull
to throwing an exception. - Add
: void
to commands to avoid warning from Symfony 6.3, prepare for Symfony 7 support.
- Add
: void
return to compiler passes to avoid warning from Symfony 6.3, and prepare for Symfony 7 support.
- Added support for AWS cloudfront, using the
jean-beru/fos-http-cache-cloudfront
package.
- Added Cloudflare proxy client.
- Fix handling of custom glue for response tags. If you use custom glue with the Symfony HttpCache,
you can now configure a customized tag header parser on the
PurgeTagsListener
.
- Fix Symfony 6 deprecations on the command name configuration.
- Fix some PHP 8.1 deprecation warnings.
- Support Symfony 6
- Drop support for Symfony 3 and 4.3 (keep using
2.11.*
for legacy projects).
- Fixed
servers_from_jsonenv
to actually work with an array.
- Fixed readthedocs.io configuration. This needs a release to show up as the latest doc (which had no longer been updated in quite a while because of build errors)
- New configuration option
servers_from_jsonenv
to support a variable amount of proxy servers defined via an environment variable.
- Do not error in
InvalidationListener
norTagListener
whensymfony/expression-language
is missing but no expression is used. - Properly report missing
symfony/expression-language
when an expression is used in response configuration.
- The fix about overwriting flash messages on multiple redirects introduced in version 2.9.1 created the risk of losing flash messages when redirecting to a path that is outside the firewall or destroys the session. This version hopefully fixes both cases. Existing flash messages in a request cookie are merged with new flash messages from the session.
- Fix typehint in PHP 8 attributes handling to use ControllerResolverInterface
- Adjusted to work with PHP 8
- Dropped support for PHP 7.2
- Added support for PHP 8 Attributes
- The fix about overwriting flash messages on multiple redirects introduced in version 2.9.1 created the risk of losing flash messages when redirecting to a path that is outside the firewall or destroys the session. This version hopefully fixes both cases. Existing flash messages in a request cookie are merged with new flash messages from the session.
- Flash messages won't be lost even when redirecting multiple times.
- New Feature: Command
fos:httpcache:clear
to clear the whole http cache.
- Adjusted to work with Twig 3
- Adjusted to work with Symfony 5
- Allow Httplug 2
- Avoid deprecation warning about
ContainerAwareCommand
.
- Avoid deprecation warning about
TokenInterface::getRoles
. - Improve exception message if a tag capable client is not found.
- Allow to use environment variables to configure the caching proxy.
- Invalidate the user context cache also when impersonating a user and when stopping to impersonate.
- Do not leak the
Symfony-Session-NoAutoCacheControl
header when the Symfony session system is not enabled.
- User context lookup now tags the hash lookup response. The logout listener can now invalidate that tag instead of doing a BAN request. The previous varnish BAN request has been incorrect and banned all cache entries on Varnish. The logout handler is now also activated by default for the Symfony HttpCache in addition to Varnish and Noop.
- Cache Tagging: It is now possible to use cache tagging without installing the
SensioFrameworkExtraBundle
. There is a new configuration optiontags.annotations.enabled
that can be set tofalse
.
- Cache Tagging: Clear the SymfonyResponseTagger after we tagged a response. Usually PHP uses a new instance for every request. But for example the hash lookup when using Symfony HttpCache does two requests in the same PHP process.
- New Feature: Support for the max_header_value_length option to split huge tag lists into multiple headers. #483
- Cache control on Symfony 4.1 now also works when the Vary header for user_context_hash is already present on the response. #485
- Adjust session_listener to work with Symfony 3.4.12 (symfony/symfony#27467).
-
Support for the Varnish xkey vmod for more efficient cache tagging.
-
Autoconfigure support for custom context providers.
-
Autowiring support for the services in this bundle:
- fos_http_cache.cache_manager => FOS\HttpCacheBundle\CacheManager
- fos_http_cache.http.symfony_response_tagger => FOS\HttpCacheBundle\Http\SymfonyResponseTagger
- fos_http_cache.event_listener.cache_control => FOS\HttpCacheBundle\EventListener\CacheControlListener
- fos_http_cache.proxy_client.default => FOS\HttpCache\ProxyClient\ProxyClient
The old service names are still available, but using them directly is deprecated.
- Regression in the configuration when you explicitly specified the
default
proxy client. This started to be reported as error in 2.3.0 and now works again.
- [Symfony HttpCache] You can now configure the Symfony proxy client to
directly call the
HttpCache
for invalidation requests instead of executing real web requests. Use the new configuration optionproxy_client.symfony.use_kernel_dispatcher
and follow the instructions in FOSHttpCache to adjust your kernel and bootstrap things accordingly.
- Fix
session_listener
decoration when session is not enabled.
- Adjust user context listener to handle Symfony 4.1 breaking behaviour change.
Support for Symfony 4. (Note that only the fos_http_cache.cache_manager
service is public in Symfony 4. Use dependency injection if you need direct
access to other services.)
-
You can now use cache tags and invalidate them with the Symfony
HttpCache
reverse proxy. You can tweak configuration in theproxy_client.symfony
section of the configuration. See the FOSHttpCache documentation for instructions on how to set up the cache. -
Allow to configure the purge method for the Symfony proxy client.
-
You can now also match requests with regular expressions on the query string. The new option
match.query_string
is available for cache control rules, tags and invalidation. -
ETags can now be false, strong or weak by setting
headers.etag
option to"strong"
or"weak"
respectively. Valuetrue
due to backward compatibility will be resolved as"strong"
.
-
The FlashMessageListener has been broken during refactoring for 2.0 and now works again. Constructor uses an options array.
-
Tag annotations now work with SensioFrameworkExtraBundle 4. An accidental exception prevents using them with FOSHttpCacheBundle 2.0 and 2.1.
-
User context is more reliable not cache when the hash mismatches. (E.g. after login/logout.)
-
The
ContextInvalidationLogoutHandler
has been deprecated in favor of theContextInvalidationSessionLogoutHandler
. The original handler was called after the invalidation of the session, and thus did not invalidate the session it should have but a newly created one. You should remove the deprecated servicefos_http_cache.user_context.logout_handler
from the logout.handlers section of your firewall configuration. -
User context compatibility which was broken due to Symfony making responses private if the session is started as of Symfony 3.4+.
- Setting up custom services with the commands provided in this bundle has been
deprecated. The
$commandName
constructor argument will be removed in 3.0.
-
Individual rules in the
cache_control
can now again have amatch_response
oradditional_response_status
configuration to limit the rule to certain responses.For this, the signature of CacheControlListener::addRule had to be changed. It now expects a RuleMatcherInterface instead of the ResponseMatcherInterface. If you extended the listener or change the service configuration, this could be a BC BREAK for your application.
-
If no response matching is configured on
cache_control
, the globalcacheable
configuration is now respected to decide whether cache headers should be set. By default, this follows RFC 7234, only responses with status 200, 203, 204, 206, 300, 301, 404, 405, 410, 414 or 501 get cache headers.We decided to consider this a bugfix, but if your relied on this behaviour it will be a BC BREAK for your application.
- Updated the version of FOSHttpCache to 2.0.0. See the FOSHttpCache changelog for more information. Most importantly, we removed the hard coupling on the Guzzle HTTP client (using HTTPlug). Your composer.json now needs to specify which HTTP client to install; see the installation instructions
- Deprecated methods have been removed.
- The configuration for the proxy client has been adjusted. Proxy servers are
now configured under
http
andservers
must be a list - a comma separated string of server IPs is no longer supported.
- BC break: the
UserContextListener
constructor signature was changed to take an array of options. - BC break: renamed the event listener classes to
XyzListener
.
-
BC break: The
match_response
andadditional_cacheable_status
configuration parameters were removed for individual match rules. Note thatmatch_response
andadditional_response_status
have been re-added forcache_control
in 2.0.1. -
BC break: The second argument of the
RuleMatcher
constructor was changed to take aResponseMatcherInterface
. -
Cacheable status codes are now configured globally (
cacheable.response.additional_status
orcacheable.response.expression
).
- BC break: The TagHandler has been split. Invalidating tags happens through
CacheManager::invalidateTags (if you use annotations for tag invalidation, you
don't need to change anything). Recording tags and writing them into the
responses is now done through the SymfonyResponseTagger.
The service
fos_http_cache.handler.tag_handler
no longer exists. For tagging responses, usefos_http_cache.http.symfony_response_tagger
instead, and to invalidate tags use the servicefos_http_cache.cache_manager
. - BC break: The configuration
tags.header
has been removed. Configuring the header for tagging responses is now done attags.response_header
. Configuring the header for tag invalidation requests is now done atproxy_client.varnish.tags_header
.
- BC break: Dropped the proxy client services as they where not used anywhere. The
services
fos_http_cache.test.client.varnish
andfos_http_cache.test.client.nginx
no longer exist.
- Added an option
always_vary_on_context_hash
to make it possible to disable automatically setting the vary headers for the user hash.
- Adjust session_listener to work with Symfony 3.4.12 (symfony/symfony#27467).
- Fix session_listener decoration when session is not enabled.
- User context compatibility which was broken due to Symfony making responses private if the session is started as of Symfony 3.4+.
-
Symfony HttpCache User Context: Move the AnonymousRequestMatcher to FOSHttpCache.
The recommended way to ignore cookie based sessions is to set
session_name_prefix
to false rather than omit the Cookie header fromuser_identifier_headers
.
- Prevent potential accidental caching on user context hash mismatch (particularly with symfony HttpCache).
- #395 : Compatibility with SensioFrameworkExtraBundle 4.
- Avoid calling deprecated method in Symfony 3.2.
- Fix configuration handling when only custom proxy client is configured.
- Do not sanity check hash on anonymous requests.
- Add a sanity check on UserContextHash to avoid invalid content being cached
(example: anonymous cache set for authenticated user). This scenario occures
when the UserContextHash is cached by Varnish via
fos_http_cache.user_context.hash_cache_ttl
> 0 and the session is lost via garbage collector. The data given is the anonymous one despite having a hash for authenticated, all authenticated users will then have the anonymous version. Same problem could occurs with users having is role changed or anything else that can modify the hash.
- Fixed some status codes (such as 204 and 302) not triggering invalidation.
- Fixed configuration handling with symfony and nginx cache client. Cache tagging is now immediately reported to not work with those clients.
- Added configuration for Symfony HttpCache client and HttpCache now loads purge and refresh handlers by default.
- Configured/annotated cache tags on subrequests (in Twig:
render(controller())
) are no longer ignored. Additionally, it is now possible to add tags from code before the response object has been created, by using the TagHandler, and from Twig with thefos_httpcache_tag
function. If you defined custom services for theInvalidateTagCommand
, you should now inject the TagHandler instead of the CacheManager. - deprecated
CacheManager::tagResponse
in favor ofTagHandler::addTags
- Added configuration option for custom proxy client (#208)
- Added support for a simple Etag header in the header configuration (#207)
-
Refactored the Symfony built-in HttpCache support to be extensible.
FOS\HttpCacheBundle\HttpCache
is deprecated in favor ofEventDispatchingHttpCache
.BC break: If you overwrite cleanupForwardRequest in your cache kernel, you need to extend FOS\HttpCache\SymfonyCache\UserContextSubscriber and move that logic to the method cleanupHashLookupRequest in there.
- Allow cache headers overwrite.
- Added support for the user context lookup with Symfony built-in reverse
proxy, aka
HttpCache
.
Initial release. To migrate from other Symfony2 cache bundles, see LiipCacheControlBundle or DriebitHttpCacheBundle.