Arie/serveme

View on GitHub
app/controllers/api/application_controller.rb

Summary

Maintainability
A
0 mins
Test Coverage
# frozen_string_literal: true

module Api
  class ApplicationController < ActionController::Base
    respond_to :json
    rescue_from ActiveRecord::RecordNotFound,       with: :handle_not_found
    rescue_from ActionController::ParameterMissing, with: :handle_unprocessable_entity

    before_action :verify_api_key
    before_action :set_default_response_format
    skip_forgery_protection

    def verify_api_key
      api_user
    end

    def api_user
      @api_user ||= authenticate_params || authenticate_token || unauthorized
    end

    def uid_user
      @uid_user ||= User.find_by_uid(params[:steam_uid])
    end

    def current_user
      @current_user ||= ((api_user&.admin? || api_user&.trusted_api?) && uid_user) || api_user
    end

    def handle_not_found
      head :not_found
    end

    def handle_unprocessable_entity
      Rails.logger.warn "UNPROCESSABLE ENTITY: #{request.body.read}"
      head :unprocessable_entity
    end

    private

    def authenticate_params
      User.find_by(api_key: params[:api_key]) if params[:api_key]
    end

    def authenticate_token
      authenticate_with_http_token do |token, _options|
        User.find_by(api_key: token)
      end
    end

    def unauthorized
      head :unauthorized
      nil
    end

    def set_default_response_format
      request.format = :json
    end

    def current_admin
      @current_admin ||= current_user&.admin? && current_user
    end

    def current_league_admin
      @current_league_admin ||= current_user&.league_admin? && current_user
    end

    def current_trusted_api
      @current_trusted_api ||= current_user&.trusted_api? && current_user
    end

    def require_site_or_league_admin
      redirect_to root_path unless current_admin || current_league_admin
    end
  end
end