Class: Auth::Token
- Inherits:
-
Object
- Object
- Auth::Token
- Defined in:
- app/models/auth/token.rb
Constant Summary collapse
- SECRET_KEY =
Rails.application.credentials.secret_key_base
- ALGORITHM =
'HS256'- PURPOSES =
{ reset_password: :reset_password, verify_email: :verify_email, access_ressources: :access_ressources, create_password_and_verify_email: :create_password_and_verify_email }.with_indifferent_access
- EXP_BY_PURPOSE =
{ reset_password: 3.hours, verify_email: 3.days, access_ressources: 24.hours, create_password_and_verify_email: 7.days }.with_indifferent_access
Class Method Summary collapse
Class Method Details
.decode(token:, purposes: []) ⇒ Object
39 40 41 42 43 44 45 46 47 |
# File 'app/models/auth/token.rb', line 39 def decode(token:, purposes: []) decoded = JWT.decode(token, SECRET_KEY, true, { algorithm: ALGORITHM })[0] decoded = ActiveSupport::HashWithIndifferentAccess.new decoded lacks_purpose = (purposes.map(&:to_s) - decoded[:purposes].map(&:to_s)).any? raise 'Token lacks purpose' if lacks_purpose decoded end |
.encode(user_id:, purposes: []) ⇒ Object
24 25 26 27 28 29 30 31 32 33 34 35 36 37 |
# File 'app/models/auth/token.rb', line 24 def encode( user_id:, purposes: [] ) exp = purposes.map { |purpose| EXP_BY_PURPOSE[purpose] }.max.from_now.to_i payload = { user_id: user_id, exp: exp || 24.hours.from_now.to_i, purposes: purposes } Rails.logger.info "Encode token with payload: #{payload} with secret key: #{SECRET_KEY} and algorithm: #{ALGORITHM} this way: JWT.encode(#{payload}, #{SECRET_KEY}, #{ALGORITHM})" JWT.encode(payload, SECRET_KEY, ALGORITHM) end |