2019-02-15 15:39:39 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'jwt'
|
|
|
|
|
|
|
|
module JSONWebToken
|
|
|
|
class HMACToken < Token
|
2023-09-09 18:01:29 +05:30
|
|
|
LEEWAY = 60
|
2019-02-15 15:39:39 +05:30
|
|
|
JWT_ALGORITHM = 'HS256'
|
|
|
|
|
|
|
|
def initialize(secret)
|
|
|
|
super()
|
|
|
|
|
|
|
|
@secret = secret
|
|
|
|
end
|
|
|
|
|
2023-09-09 18:01:29 +05:30
|
|
|
def self.decode(token, secret, leeway: LEEWAY, verify_iat: false)
|
2019-02-15 15:39:39 +05:30
|
|
|
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
|