Static websites aren’t suitable for every situation, but they have several advantages over dynamic apps; they’re more efficient, more secure and simpler to deploy. That said, developing and maintaining a static site is a pain, there’s just too much repetitive boilerplate code. Enter
Wallflower
, it generates static websites from PSGI compatible Perl web applications. You get the best of both worlds: develop the routes, templates and unit tests in your favourite web framework but deploy it as a static website with Wallflower.
Requirements
The CPAN Testers
results
for the latest version (v1.004) of App::Wallflower show it runs on just about any Perl and operating system, including Windows. You can install it from CPAN by going to the command line and typing:
Wallflower in action
Let’s create a simple application using
Dancer2
:
This will create a skeleton application for us. Now change into the root application directory and create a new directory to hold the static files, we’ll call it “static”:
$ cd MyApp
$ mkdir static
That’s all we need to generate the static site with wallflower:
$ wallflower --a bin/app.pl --d static
Wallflower will request the application root page (‘/’) and spider all links it finds from there, copying the files to the static folder. This includes files referenced in your html and css, such as JavaScript files. If your app has links to all of its pages, this is all you need.
Test the static site with nginx
Let’s deploy the site with nginx locally (you’ll need nginx installed for this). First create the virtual host file:
server {
listen 80;
server_name localhost;
root /var/www/MyApp/static;
location / {
index index.html;
rewrite ^/$ /index.html break;
Assuming a unix-like platform, save the virtual host file to “/etc/nginx/sites-available/localhost”. Next enter these commands:
$ sudo mkdir /var/www/MyApp
$ sudo cp static /var/www/MyApp
$ cd /etc/nginx/sites-enabled
$ sudo ln -s ../sites-available/localhost
Now we need to start nginx. On RHEL/Fedora/CentOS you can start nginx with:
On Ubuntu:
Now check out the site at http://localhost:
Looks pretty good to me!
Wallflower Tips
A few things I’ve found whilst using Wallflower:
Use absolute urls over relative ones. So if you host your font files in your css directory, use: “/css/MyFont.ttf” instead of “MyFont.ttf” in your css files.
Think about files you use but aren’t directly linked to in your app’s HTML pages, the sitemap.xml file for example. Feed urls for these files to Wallflower with the -F option.
Watch out for urls in commented code as Wallflower will copy these too!
The Wallflower docs recommend using extensions in your urls to ensure the correct content-type is set. I found this wasn’t required when I deployed the files with nginx.
Conclusion
Whether you prefer developing applications with Catalyst, Dancer or Mojolicious, Wallflower is a useful tool that can be incorporated into your development and deployment process. For further examples of Wallflower in action, check out the tutorial and advent calendar entry by Wallflower creator Philippe Bruhat (BooK).
Cover image © Ruth Hartnup
This article was originally posted on PerlTricks.com.
David Farrell
David is a professional programmer who regularly tweets and blogs about code and the art of programming.
Legal
Perl.com and the authors make no representations with respect to the accuracy or completeness of the contents of all work on this website and specifically disclaim all warranties, including without limitation warranties of fitness for a particular purpose. The information published on this website may not be suitable for every situation. All work on this website is provided with the understanding that Perl.com and the authors are not engaged in rendering professional services. Neither Perl.com nor the authors shall be liable for damages arising herefrom.