data:image/s3,"s3://crabby-images/2523c/2523ce4b8b64bade795ffc89574cfc29f35428d3" alt="Deno 2.2 Improves Dependency Management and Expands Node.js Compatibility"
Security News
Deno 2.2 Improves Dependency Management and Expands Node.js Compatibility
Deno 2.2 enhances Node.js compatibility, improves dependency management, adds OpenTelemetry support, and expands linting and task automation for developers.
This gem provides JSON Web Token (JWT) based authentication.
Add this line to your application's Gemfile
:
gem 'rack-jwt'
And then execute:
$ bundle install
Or install it directly with:
$ gem install rack-jwt
Rack::JWT::Auth
accepts several configuration options. All options are passed in a single Ruby Hash:
secret
: required : String
|| OpenSSL::PKey::RSA
|| OpenSSL::PKey::EC
: A cryptographically secure String (for HMAC algorithms) or a public key object of an appropriate type for public key algorithms. Set to nil
if you are using the 'none'
algorithm.
verify
: optional : Boolean : Determines whether JWT will verify tokens keys for mismatch key types when decoded. Default is true
. Set to false
if you are using the 'none'
algorithm.
options
: optional : Hash : A hash of options that are passed through to JWT to configure supported claims and algorithms. See the ruby-jwt docs for more information of the algorithms and their requirements as well as more information on the supported claims. These options are passed through without change to the underlying ruby-jwt
gem. By default only expiration (exp) and Not Before (nbf) claims are verified. Pass in an algorithm choice like { algorithm: 'HS256' }
.
exclude
: optional : Array : An Array of path strings representing paths that should not be checked for the presence of a valid JWT token. Excludes sub-paths as of specified paths as well (e.g. %w(/docs)
excludes /docs/some/thing.html
also). Each path should start with a /
. If a path matches the current request path this entire middleware is skipped and no authentication or verification of tokens takes place.
Where my_args
is a Hash
containing valid keys. See spec/example_spec.rb
for a more complete example of the valid arguments for creating and verifying
tokens.
use Rack::JWT::Auth, my_args
Cuba.use Rack::JWT::Auth, my_args
Rails.application.config.middleware.use Rack::JWT::Auth, my_args
You can generate JSON Web Tokens for your users using the
Rack::JWT::Token#encode
method which takes payload
,
secret
, and algorithm
params.
The secret will be either a cryptographically strong random string, or the secret key component of a public/private keypair of an accepted type depending on the algorithm you choose. You can see examples of using the various key types at the ruby-jwt gem repo
The algorithm
is an optional String and can be one of the following (default HMAC 'HS256'):
%w(none HS256 HS384 HS512 RS256 RS384 RS512 ED25519 ES256 ES384 ES512)
HS256 is the default
Note that ED25519
support depends on the rbnacl
which is not already included by the
rack-jwt
gem. If you wish to use the ED25519
algorith, you must also manually require
rbnacl
gem in addition to rack-jwt
.
Here is a sample payload with illustrative data. You don't have to use all, or even most, of these.
secret = 'your_secret_token_or_key'
my_payload = {
data: 'data',
exp: Time.now.to_i + 4 * 3600,
nbf: Time.now.to_i - 3600,
iss: 'https://my.awesome.website/',
aud: 'audience',
jti: Digest::MD5.hexdigest([hmac_secret, iat].join(':').to_s),
iat: Time.now.to_i,
sub: 'subject'
}
alg = 'HS256'
Rack::JWT::Token.encode(my_payload, secret, alg)
git checkout -b my-new-feature
)git commit -am 'Add some feature'
)git push origin my-new-feature
)FAQs
Unknown package
We found that rack-jwt demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Deno 2.2 enhances Node.js compatibility, improves dependency management, adds OpenTelemetry support, and expands linting and task automation for developers.
Security News
React's CRA deprecation announcement sparked community criticism over framework recommendations, leading to quick updates acknowledging build tools like Vite as valid alternatives.
Security News
Ransomware payment rates hit an all-time low in 2024 as law enforcement crackdowns, stronger defenses, and shifting policies make attacks riskier and less profitable.