Gokul595/api_guard

View on GitHub
lib/api_guard/jwt_auth/blacklist_token.rb

Summary

Maintainability
A
0 mins
Test Coverage
A
100%
# frozen_string_literal: true

module ApiGuard
  module JwtAuth
    # Common module for token blacklisting functionality
    module BlacklistToken
      def blacklisted_token_association(resource)
        resource.class.blacklisted_token_association
      end

      def token_blacklisting_enabled?(resource)
        blacklisted_token_association(resource).present?
      end

      def blacklisted_tokens_for(resource)
        blacklisted_token_association = blacklisted_token_association(resource)
        resource.send(blacklisted_token_association)
      end

      # Returns whether the JWT token is blacklisted or not
      def blacklisted?(resource)
        return false unless token_blacklisting_enabled?(resource)

        blacklisted_tokens_for(resource).exists?(token: @token)
      end

      # Blacklist the current JWT token from future access
      def blacklist_token
        return unless token_blacklisting_enabled?(current_resource)

        blacklisted_tokens_for(current_resource).create(token: @token, expire_at: Time.at(@decoded_token[:exp]).utc)
      end
    end
  end
end