1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72
|
# frozen_string_literal: true
module JWT
module JWK
# Base for JWK implementations
class KeyBase
def self.inherited(klass)
super
::JWT::JWK.classes << klass
end
def initialize(options, params = {})
options ||= {}
@parameters = params.transform_keys(&:to_sym) # Uniform interface
# For backwards compatibility, kid_generator may be specified in the parameters
options[:kid_generator] ||= @parameters.delete(:kid_generator)
# Make sure the key has a kid
kid_generator = options[:kid_generator] || ::JWT.configuration.jwk.kid_generator
self[:kid] ||= kid_generator.new(self).generate
end
def kid
self[:kid]
end
def hash
self[:kid].hash
end
def [](key)
@parameters[key.to_sym]
end
def []=(key, value)
@parameters[key.to_sym] = value
end
def ==(other)
other.is_a?(::JWT::JWK::KeyBase) && self[:kid] == other[:kid]
end
def verify(**kwargs)
jwa.verify(**kwargs, verification_key: verify_key)
end
def sign(**kwargs)
jwa.sign(**kwargs, signing_key: signing_key)
end
alias eql? ==
def <=>(other)
return nil unless other.is_a?(::JWT::JWK::KeyBase)
self[:kid] <=> other[:kid]
end
def jwa
raise JWT::JWKError, 'Could not resolve the JWA, the "alg" parameter is missing' unless self[:alg]
JWA.resolve(self[:alg]).tap do |jwa|
raise JWT::JWKError, 'none algorithm usage not supported via JWK' if jwa.is_a?(JWA::None)
end
end
attr_reader :parameters
end
end
end
|