Lazy static site generator for Laravel 4
Lassy is lazy static site generator. It means that every request (well not every… check out Filters section) will generate a HTML file with its contents inside.
Every next request will be redirected to this file.
Add radmen/lassy
to composer.json
:
{
"require": {
"radmen/lassy": "1.1.*"
}
}
Then in app/config/app.php
add:
'Radmen\Lassy\LassyServiceProvider'
to providers
'Lassy' => 'Radmen\Lassy\Facade'
to aliases
And publish config: php artisan config:publish radmen/lassy
Lassy only genereates HTML files. All requests must be rewrited to this files.
Here are some example configs for such rewrites.
Note that _static
is only example dirname. It can be changed in config file.
RewriteCond %{DOCUMENT_ROOT}/_static/%{REQUEST_URI} -f
RewriteRule ^(.*)$ /_static/$1 [QSA,PT,L]
RewriteCond %{DOCUMENT_ROOT}/_static/%{REQUEST_URI}/index.html -f
RewriteRule ^(.*)$ /_static/$1/index.html [QSA,PT,L]
If you have problem with server rewrites (it happens to me all the time) you can serve static files through Laravel application.
In app/filters.php
add:
App::before(function($request)
{
$path = Lassy::getFilePath($request);
if(true === is_file($path))
{
Lassy::disable();
return file_get_contents($path);
}
});
In some situations static file should not be generated. That’s where filters come in action.
Filter is closure which returns boolean. If it’s FALSE
Lassy will be disabled.
Lassy provides some basic filters:
Radmen\Lassy\Filter\AjaxRequest
checks if request is an AJAX call. If TRUE
disable LassyRadmen\Lassy\Filter\GetRequest
enables Lassy only for GET
requestsRadmen\Lassy\Filter\HtmlResponse
enables Lassy only for valid (response code = 200
) HTML responsesRadmen\Lassy\Filter\QueriedRequest
disables Lassy when request has data in queryFilters can be specified in package config file.
Lassy can be enabled / disabled manually during the request. To do this run Lassy::enable()
, or Lassy::disable()
in your code.
If you want to delete generated files just run php artisan lassy:clear
in console.
The Lassy package is open-sourced software licensed under the MIT license.