gem 'jwt'
bundle install
Create an api controller that all of the api related controllers will inherit from
class ApiController < ApplicationController
  skip_before_action :verify_authenticity_token
  before_action :set_default_format
  private
  def set_default_format
    request.format = :json
  end
endclass CreateJwtBlacklists < ActiveRecord::Migration[5.2]
  def change
    create_table :jwt_blacklist do |t|
      t.string :jti, null: false
      t.datetime :exp, null: false
    end
    add_index :jwt_blacklist, :jti
  end
endCreate two seperate secret_key_bases to encode both the token itself and the jti attribute of the token
Generate a secret key with rails secret in the console
Add those keys to rails secret credentials file with EDITOR=nano rails credentials:edit
Create a json_web_token service object (model that doesn't inherit from base or have a column in the database associated with it) and instantiate the constants for the secret keys we just created
class JsonWebToken
  API_KEY_BASE = Rails.application.credentials.api[:secret_key_base]
  JTI_SECRET = Rails.application.credentials.api[:jti_secret]
end