SpinaCMS/Spina

View on GitHub
app/controllers/spina/api/api_controller.rb

Summary

Maintainability
A
0 mins
Test Coverage
A
100%
module Spina
  module Api
    class ApiController < ActionController::Base
      include Spina::CurrentTheme
      include Spina::CurrentSpinaAccount

      protect_from_forgery unless: -> { request.format.json? }

      rescue_from ActiveRecord::RecordNotFound, with: :render_404

      TOKEN = Spina.config.api_key

      before_action :authenticate_api

      private

      def render_404
        render json: {error: "Not Found"}, status: :not_found
      end

      def authenticate_api
        head :not_found and return if TOKEN.blank?
        authenticate_or_request_with_http_token do |token, options|
          ActiveSupport::SecurityUtils.secure_compare(token, TOKEN)
        end
      end
    end
  end
end