Download the PHP package adevendorf/craft-pretzelimage without Composer
On this page you can find all versions of the php package adevendorf/craft-pretzelimage. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download adevendorf/craft-pretzelimage
More information about adevendorf/craft-pretzelimage
Files in adevendorf/craft-pretzelimage
Package craft-pretzelimage
Short Description Generate image transforms upon image request in realtime -- load via web server directly as public files, or combine with a CDN.
License mit
Informations about the package craft-pretzelimage
Pretzel Image
Pretzel Image generates image transforms at browser request time. The resulting image is stored in a public folder. Because the controller route is the same as the actual file, we let the web server serve the actual file before passing it off to the plugin to process the request.
The generated file can be deleted from the server at any time because it will just be recreated if it no longer exists.
The images are organized into a two character directory, then asset ID subdirectory. This is done to mitigate the possibility, of too many directories/files in a single folder.
The original purpose of this plugin is to place a CDN in front of the site so that these generated images would only live a short time on the actual Craft CMS server.
In practice, this plugin works well for multi-instance Craft CMS setups on high traffic sites. By utilizing an NFS server, you can reuse the same generated images between all the servers, then load balance the CMS for image generation.
Configuration
Pretzel should work out of the box, but you can customize it.
PRETZEL_PATH
By default images are stored in the @web/_imgs directory, but you can override it in your .env file with PREZTEL_PATH
PRETZEL_PATH="images"
PRETZEL_HOSTS
Pretzel will allow images to be generated by any host when in Craft CMS is in Dev Mode, otherwise it will only accept referrers from the current defined site url, or hosts you define in:
PRETZEL_HOSTS="www.somesite.com,help.somesite.com"
How to use
There are 3 arguments you pass into a url method.
- The Craft CMS Asset
- Object (or Array) of transformations
- (Optional) Default object of transformations that will be applied to all images
Twig
If multiple transformation configurations are passed, an array is returned instead of a URL string.
PHP (Element API)
Image Options
width
height:
ratio
position: 50-50 (default)
mode: crop (default), fill
Requirements
This plugin requires Craft CMS 4 or later, and PHP 8.0.2 or later.
TODO
- Automatically remove old images from the file space based on age of the file.
- Provide an option to never store the generated file.
- Allow the definition of the CDN URL instead of using the Craft CMS Site URL.
- Test GraphQL Support