Sha256: 727cbff64f45084682af4ef6fc976494e0930b5635a0142783c310575ade5a43
Contents?: true
Size: 1.51 KB
Versions: 1
Compression:
Stored size: 1.51 KB
Contents
require 'omniauth' require 'jwt' module OmniAuth module Strategies class JWT class ClaimInvalid < StandardError; end include OmniAuth::Strategy args [:secret] option :secret, nil option :algorithm, 'HS256' option :uid_key, 'email' option :required_claims, %w(name email) option :info_map, {"name" => "name", "email" => "email"} option :auth_url, nil option :valid_within, nil def request_phase redirect options.auth_url end def decoded @decoded ||= ::JWT.decode(request.params['jwt'], options.secret, options.algorithm) (options.required_claims || []).each do |field| raise ClaimInvalid.new("Missing required '#{field}' claim.") if !@decoded.key?(field.to_s) end raise ClaimInvalid.new("Missing required 'iat' claim.") if options.valid_within && !@decoded["iat"] raise ClaimInvalid.new("'iat' timestamp claim is too skewed from present.") if options.valid_within && (Time.now.to_i - @decoded["iat"]).abs > options.valid_within @decoded end def callback_phase super rescue ClaimInvalid => e fail! :claim_invalid, e end uid{ decoded[options.uid_field] } extra do {:raw_info => decoded} end info do options.info_map.inject({}) do |h,(k,v)| h[k.to_s] = decoded[v.to_s] h end end end class Jwt < JWT; end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
omniauth-jwt-0.0.1 | lib/omniauth/strategies/jwt.rb |