Plack::Middleware::ETag - Adds automatically an ETag header. [![Build Status](https://travis-ci.org/franckcuny/plack-middleware-etag.svg?branch=travis-ci)](https://travis-ci.org/franckcuny/plack-middleware-etag) ## SYNOPSIS ```perl use Plack::Builder; my $app = builder { enable "Plack::Middleware::ETag", file_etag => [qw/inode mtime size/]; sub {['200', ['Content-Type' => 'text/html'}, ['hello world']]}; }; ``` ## DESCRIPTION Plack::Middleware::ETag adds automatically an ETag header. You may want to use it with "Plack::Middleware::ConditionalGET". ```perl my $app = builder { enable "Plack::Middleware::ConditionalGET"; enable "Plack::Middleware::ETag", file_etag => "inode"; sub {['200', ['Content-Type' => 'text/html'}, ['hello world']]}; }; ``` ## CONFIGURATION ### file_etag If the content is a file handle, the ETag will be set using the inode, modified time and the file size. You can select which attributes of the file will be used to set the ETag: ```perl enable "Plack::Middleware::ETag", file_etag => [qw/size/]; ``` ### cache_control It's possible to add 'Cache-Control' header. ```perl enable "Plack::Middleware::ETag", cache_control => 1; ``` Will add "Cache-Control: must-revalidate" to the headers. ```perl enable "Plack::Middleware::ETag", cache_control => [ 'must-revalidate', 'max-age=3600' ]; ``` Will add "Cache-Control: must-revalidate, max-age=3600" to the headers. ```perl check_last_modified_header ``` Will not add an ETag if there is already a Last-Modified header. ## AUTHOR Franck Cuny <franckcuny@gmail.com> ## LICENSE This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.