class JWT::Verify
JWT verify methods
Public Class Methods
new(payload, options)
click to toggle source
# File lib/jwt/verify.rb, line 14 def initialize(payload, options) @payload = payload @options = options end
Public Instance Methods
verify_aud()
click to toggle source
# File lib/jwt/verify.rb, line 19 def verify_aud return unless (options_aud = extract_option(:aud)) if @payload['aud'].is_a?(Array) fail( JWT::InvalidAudError, 'Invalid audience' ) unless @payload['aud'].include?(options_aud.to_s) else fail( JWT::InvalidAudError, "Invalid audience. Expected #{options_aud}, received #{@payload['aud'] || '<none>'}" ) unless @payload['aud'].to_s == options_aud.to_s end end
verify_expiration()
click to toggle source
# File lib/jwt/verify.rb, line 35 def verify_expiration return unless @payload.include?('exp') if @payload['exp'].to_i < (Time.now.to_i - leeway) fail(JWT::ExpiredSignature, 'Signature has expired') end end
verify_iat()
click to toggle source
# File lib/jwt/verify.rb, line 43 def verify_iat return unless @payload.include?('iat') if !(@payload['iat'].is_a?(Numeric)) || @payload['iat'].to_f > (Time.now.to_f + leeway) fail(JWT::InvalidIatError, 'Invalid iat') end end
verify_iss()
click to toggle source
# File lib/jwt/verify.rb, line 51 def verify_iss return unless (options_iss = extract_option(:iss)) if @payload['iss'].to_s != options_iss.to_s fail( JWT::InvalidIssuerError, "Invalid issuer. Expected #{options_iss}, received #{@payload['iss'] || '<none>'}" ) end end
verify_jti()
click to toggle source
# File lib/jwt/verify.rb, line 62 def verify_jti options_verify_jti = extract_option(:verify_jti) if options_verify_jti.respond_to?(:call) fail(JWT::InvalidJtiError, 'Invalid jti') unless options_verify_jti.call(@payload['jti']) else fail(JWT::InvalidJtiError, 'Missing jti') if @payload['jti'].to_s.strip.empty? end end
verify_not_before()
click to toggle source
# File lib/jwt/verify.rb, line 71 def verify_not_before return unless @payload.include?('nbf') if @payload['nbf'].to_i > (Time.now.to_i + leeway) fail(JWT::ImmatureSignature, 'Signature nbf has not been reached') end end
verify_sub()
click to toggle source
# File lib/jwt/verify.rb, line 79 def verify_sub return unless (options_sub = extract_option(:sub)) fail( JWT::InvalidSubError, "Invalid subject. Expected #{options_sub}, received #{@payload['sub'] || '<none>'}" ) unless @payload['sub'].to_s == options_sub.to_s end
Private Instance Methods
extract_option(key)
click to toggle source
# File lib/jwt/verify.rb, line 90 def extract_option(key) @options.values_at(key.to_sym, key.to_s).compact.first end
leeway()
click to toggle source
# File lib/jwt/verify.rb, line 94 def leeway extract_option :leeway end