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