29 lines
538 B
Ruby
29 lines
538 B
Ruby
|
# frozen_string_literal: true
|
||
|
|
||
|
require 'jwt'
|
||
|
|
||
|
module JSONWebToken
|
||
|
class HMACToken < Token
|
||
|
IAT_LEEWAY = 60
|
||
|
JWT_ALGORITHM = 'HS256'
|
||
|
|
||
|
def initialize(secret)
|
||
|
super()
|
||
|
|
||
|
@secret = secret
|
||
|
end
|
||
|
|
||
|
def self.decode(token, secret, leeway: IAT_LEEWAY, verify_iat: true)
|
||
|
JWT.decode(token, secret, true, leeway: leeway, verify_iat: verify_iat, algorithm: JWT_ALGORITHM)
|
||
|
end
|
||
|
|
||
|
def encoded
|
||
|
JWT.encode(payload, secret, JWT_ALGORITHM, { typ: 'JWT' })
|
||
|
end
|
||
|
|
||
|
private
|
||
|
|
||
|
attr_reader :secret
|
||
|
end
|
||
|
end
|