NAME

   Mojolicious::Plugin::Gzip - Plugin to Gzip Mojolicious responses

STATUS

SYNOPSIS

     # Mojolicious::Lite
     plugin 'Gzip';

     # With minimum size in bytes required before gzipping. Default is 860.
     plugin Gzip => {min_size => 1500};

     # Mojolicious
     $app->plugin('Gzip');

     # With minimum size in bytes required before gzipping. Default is 860.
     $app->plugin(Gzip => {min_size => 1500});

DESCRIPTION

   Mojolicious::Plugin::Gzip gzips all responses equal to or greater than
   a "min_size" by using the "after_dispatch" in Mojolicious hook.
   Mojolicious::Plugin::Gzip will only gzip a response if all of these
   conditions are met:

     * The "accept_encoding" in Mojo::Headers header contains 'gzip'.

     * The "body_size" in Mojo::Content of the response is greater than or
     equal to "min_size".

     * The "code" in Mojo::Message::Response is 200.

     * The "content_encoding" in Mojo::Headers for the response is not
     set.

   Mojolicious::Plugin::Gzip will do these things if those conditions are
   met:

     * Set "body" in Mojo::Message to the gzipped version of the previous
     "body" in Mojo::Message.

     * Set "body_size" in Mojo::Message to the size of the gzipped
     content.

     * Set "content_encoding" in Mojo::Headers to "gzip".

     * If "etag" in Mojo::Headers was set, append "-gzip" to the existing
     "etag" in Mojo::Headers. This is done according to RFC-7232
     <https://tools.ietf.org/html/rfc7232#section-2.3.3>, which states
     that ETags should be content-coding aware.

     * Use "append" in Mojo::Headers to append "Accept-Encoding" to the
     "vary" in Mojo::Headers header.

OPTIONS

min_size

     # Mojolicious::Lite
     plugin 'Gzip' => {min_size => 1500};

     # Mojolicious
     $app->plugin(Gzip => {min_size => 1500});

   Sets the minimum "body_size" in Mojo::Content required before response
   content will be gzipped. If the "body_size" in Mojo::Content is greater
   than or equal to "min_size", then it will be gzipped. Default is 860.

AUTHOR

   Adam Hopkins <[email protected]>

COPYRIGHT

   Copyright 2019- Adam Hopkins

LICENSE

   This library is free software; you can redistribute it and/or modify it
   under the same terms as Perl itself.

SEE ALSO

     * MojoX::Encode::Gzip

     * Mojolicious

     * https://mojolicious.org