lgromanowski/acme-plugin

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

Summary

Maintainability
A
0 mins
Test Coverage
module AcmePlugin
  class ApplicationController < ActionController::Base
    before_action :challenge_response, only: [:index]
    before_action :validate_length, only: [:index]
    protect_from_forgery with: :exception

    def index
      # There is only one item in DB with challenge response from our task
      # we will use it to render plain text response
      render plain: @response.response, status: :ok
    end

    private

    def validate_length
      # Challenge request should have at least 128bit
      challenge_failed('Challenge failed - Request has invalid length!') if invalid_length
    end

    def challenge_response
      @response = AcmePlugin.config.challenge_dir_name.present? ? Challenge.new : Challenge.first
      challenge_failed('Challenge failed - Can not get response from database!') if @response.nil?
    end

    def challenge_failed(msg)
      Rails.logger.error(msg)
      render plain: msg, status: :bad_request
    end

    def invalid_length
      params[:challenge].nil? || params[:challenge].length < 16 || params[:challenge].length > 256
    end
  end
end