user_authentication.rb 812 B

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. # frozen_string_literal: true
  2. require './lib/json_web_token'
  3. module UserAuthentication
  4. extend ActiveSupport::Concern
  5. included do
  6. def current_user
  7. @current_user ||=
  8. begin
  9. result = JsonWebToken.decode(jwt)
  10. User.find(result.first['id'])
  11. rescue StandardError => e
  12. Rails.logger.error(e.message)
  13. Rails.logger.debug(e.backtrace.join("\n"))
  14. nil
  15. end
  16. end
  17. def current_user=(user)
  18. self.jwt = JsonWebToken.encode(id: user.id, username: user.username)
  19. end
  20. def logged_in?
  21. !current_user.nil?
  22. end
  23. end
  24. private
  25. def jwt
  26. cookies[:jwt]
  27. end
  28. def jwt=(jwt)
  29. cookies[:jwt] = {
  30. value: jwt,
  31. httponly: true,
  32. secure: !(Rails.env.development? || Rails.env.test?),
  33. }
  34. end
  35. end