summaryrefslogtreecommitdiff
path: root/lib/json_web_token/hmac_token.rb
diff options
context:
space:
mode:
authorAsh McKenzie <amckenzie@gitlab.com>2018-11-08 20:28:13 +1100
committerAsh McKenzie <amckenzie@gitlab.com>2018-11-13 08:36:57 +1100
commita3c80014f5dc849af1933570877f8230d98417f1 (patch)
tree71b39ceca7c983125dc565356572767811a2fcbe /lib/json_web_token/hmac_token.rb
parentb3b9817e5100ae2e827794d87ac6a6649571eddc (diff)
downloadgitlab-ce-a3c80014f5dc849af1933570877f8230d98417f1.tar.gz
Relocate JSONWebToken::HMACToken from EEashmckenzie/hmac-token-decode-and-tests
Diffstat (limited to 'lib/json_web_token/hmac_token.rb')
-rw-r--r--lib/json_web_token/hmac_token.rb28
1 files changed, 28 insertions, 0 deletions
diff --git a/lib/json_web_token/hmac_token.rb b/lib/json_web_token/hmac_token.rb
new file mode 100644
index 00000000000..ceb1b9c913f
--- /dev/null
+++ b/lib/json_web_token/hmac_token.rb
@@ -0,0 +1,28 @@
+# 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)
+ end
+
+ private
+
+ attr_reader :secret
+ end
+end