FormatExtensionResolver
The FormatExtensionResolver
cannot be used by itself. Instead, it is a "decorator" for
another resolver. It adds the ability to set the correct file extension when a filter converted the image format.
Configuration
To use this cache resolver, you must first define the cache resolver it will decorate. In this example, we will use the Web Path Resolver.
Next, we need to define a service for this cache resolver and inject the web path cache resolver service to decorate.
1 2 3 4 5 6 7 8 9 10
# app/config/services.yml
services:
acme.imagine.cache.format_extension:
class: Liip\ImagineBundle\Imagine\Cache\Resolver\FormatExtensionResolver
arguments:
- "@acme.imagine.cache.resolver.web_path"
- "@liip_imagine.filter.configuration"
tags:
- { name: "liip_imagine.cache.resolver", resolver: "format_extension" }
With this configuration, the format extension resolver will rewrite the extension to match the filter format.
For example, you have the source image image.png
and you apply filter with format jpg
you will get jpeg-image image.jpg
.
Usage
After configuring FormatExtensionResolver
, you can set it as the default cache resolver
for LiipImagineBundle
using the following configuration.
1 2 3 4
# app/config/config.yml
liip_imagine:
cache: format_extension
Usage on a Specific Filter
Alternatively, you can set FormatExtensionResolver
as the cache resolver for a specific
filter set using the following configuration.
1 2 3 4 5 6 7 8 9
# app/config/config.yml
liip_imagine:
filter_sets:
cache: ~
my_thumb:
cache: format_extension
filters:
# the filter list