NAME
Mojolicious::Plugin::CSRFProtect - Mojolicious Plugin
SYNOPSIS
# Mojolicious
$self->plugin('CSRFProtect');
# Mojolicious::Lite
plugin 'CSRFProtect';
# Use C<form_for> helper and all your html forms will have CSRF protection token
<%= form_for login => (method => 'post') => begin %>
<%= text_field 'first_name' %>
<%= submit_button %>
<% end %>
# Place jquery_ajax_csrf_protection helper to your layout template
# and all AJAX requests will have CSRF protection token (requires JQuery)
<%= jquery_ajax_csrf_protection %>
DESCRIPTION
Mojolicious::Plugin::CSRFProtect is a Mojolicious plugin which fully protects you from CSRF attacks.
It does next things:
1. Adds a hidden input (with name 'csrftoken') with CSRF protection token to every form (works only if you use form_for
helper from Mojolicious::Plugin::TagHelpers.)
2. Adds the header "X-CSRF-Token" with CSRF token to every AJAX request (works with JQuery only)
3. Rejects all non GET requests without the correct CSRF protection token.
If you want protect your GET requests then you can do it manually
In template: <a href="/delete_user/123/?csrftoken=<%= csrftoken %>">
In controller: $self->is_valid_csrftoken()
HELPERS
form_for
This helper overrides the C<form_for> helper from Mojolicious::Plugin::TagHelpers
and adds hidden input with CSRF protection token.
jquery_ajax_csrf_protection
This helper adds CSRF protection headers to all JQuery AJAX requests.
You should add <%= jquery_ajax_csrf_protection %> in head of your HTML page.
csrftoken
returns CSRF Protection token.
In templates <%= csrftoken %>
In controller $self->csrftoken;
is_valid_csrftoken
With this helper you can check $csrftoken manually. It will take $csrftoken from $c->param('csrftoken');
$self->is_valid_csrftoken() will return 1 or 0
SEE ALSO
- Mojolicious::Plugin::CSRFDefender
-
This plugin followes the same aproach but it works in different manner.
It will parse your response body searching for '<form>' tag and then will insert CSRF token there.
LICENSE AND COPYRIGHT
Copyright 2011 Viktor Turskyi
This program is free software; you can redistribute it and/or modify it under the terms of either: the GNU General Public License as published by the Free Software Foundation; or the Artistic License.
See http://dev.perl.org/licenses/ for more information.