kemal-jwt-auth v1.0.1

Drop-in authentication for Kemal using JWTs

Kemal JWT Authentication

Drop-in authentication middleware for Kemal, independent of user model. See example.cr for a full example.

TL;DR:

require "kemal"
require "kemal_jwt_auth"
# you can use your existing users collection data-structure.
require "./my_users"

# Your `MyUsers` must include the `KemalJWTAuth::UsersCollection` module
collection = MyUsers.default_config

add_handler KemalJWTAuth::Handler.new users: collection

get "/test" do |context|
  if user = context.current_user?
    "Welcome, #{user}!"
  else
    "no user found"
  end
end

Kemal.run

JavaScript companion

There is a JavaScript companion library to make using this library with an SPA or other JavaScript client a cinch. See the client repository for more information

Installation

  1. Add the dependency to your shard.yml:

    dependencies:
      kemal_jwt_auth:
        github: dscottboggs/kemal_jwt_auth
        version: ~> 1.0
    
  2. Run shards install

Contributing

  1. Fork it (https://github.com/dscottboggs/kemal_jwt_auth/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

Repository

kemal-jwt-auth

Owner
Statistic
  • 6
  • 1
  • 0
  • 0
  • 3
  • over 5 years ago
  • March 10, 2019
License

MIT License

Links
Synced at

Tue, 21 Jan 2025 02:54:05 GMT

Languages