Skip to content
This repository was archived by the owner on Jun 25, 2025. It is now read-only.

kemalcr/kemal-csrf

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

34 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

kemal-csrf

⚠️ DEPRECATED: This project has been moved to kemal-session and is no longer maintained as a separate package. Please use kemal-session for CSRF protection.

Adds CSRF protection to your Kemal application.

Requires a session middleware to be initialized first.

Installation

Note: This package is deprecated. Please use kemal-session instead, which now includes CSRF protection functionality.

For historical reference, this package was previously installed by adding to your application's shard.yml:

dependencies:
  kemal-csrf:
    github: kemalcr/kemal-csrf

For new projects, use kemal-session:

dependencies:
  kemal-session:
    github: kemalcr/kemal-session

Usage

Important: This package is deprecated. For current CSRF protection, please refer to the kemal-session documentation.

Historical Usage (Deprecated)

Basic Use

require "kemal-csrf"

add_handler CSRF.new

To access the CSRF token of the active session you can do the following in your .ecr form(s)

<input type="hidden" name="authenticity_token" value='<%= env.session.string("csrf") %>'>

You can also change the name of the form field, header name, the methods which don't need csrf,error message and routes which you don't want csrf to apply. All of these are optional

require "kemal-csrf"

add_handler CSRF.new(
  header: "X_CSRF_TOKEN",
  allowed_methods: ["GET", "HEAD", "OPTIONS", "TRACE"],
  allowed_routes: ["/api/somecallback", "/api/v1/**"],
  parameter_name: "_csrf", 
  error: "CSRF Error",
  http_only: false,
  samesite: nil,
)

If you need to have some logic within your error response, you can also pass it a proc (a pointer to a function)

require "kemal-csrf"

add_handler CSRF.new(
  header: "X_CSRF_TOKEN",
  allowed_methods: ["GET", "HEAD", "OPTIONS", "TRACE"],
  allowed_routes: ["/api/somecallback", "/api/v1/**"],
  parameter_name: "_csrf", 
  error: ->myerrorhandler(HTTP::Server::Context)
)

def myerrorhandler(env)
  if env.request.headers["Content-Type"]? == "application/json"
    {"error" => "csrf error"}.to_json
  else
    "<html><head><title>Error</title><body><h1>You cannot post to this route without a valid csrf token</h1></body></html>"
  end
end

Contributing

  1. Fork it ( https://github.com/kemalcr/kemal-csrf/fork )
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create a new Pull Request

Contributors

  • sdogruyol Serdar Dogruyol - creator, maintainer

About

Add CSRF protection to your Kemal application

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 10