fastladder/fastladder

View on GitHub
app/controllers/application_controller.rb

Summary

Maintainability
A
25 mins
Test Coverage
class ApplicationController < ActionController::Base
  # Prevent CSRF attacks by raising an exception.
  # For APIs, you may want to use :null_session instead.
  protect_from_forgery with: :exception

  helper_method :current_member, :logged_in?

  def self.json_status(success, option = nil)
    result = { isSuccess: success, ErrorCode: success ? 0 : 1 }
    case option
    when Integer
      result[:ErrorCode] = option
    when Hash
      result.merge!(option)
    end
    result.to_json
  end

  def login_required
    redirect_to login_path unless logged_in?
  end

  def login_required_api
    nothing unless logged_in?
  end

  def nothing
    head 200
  end

  def logged_in?
    current_member.present?
  end

  def json_status(success, option = nil)
    self.class.json_status(success, option)
  end

  def render_json_status(success, option = nil)
    render json: json_status(success, option)
  end

  # extract URL from request_path(e.g. /about/http://example.com)
  def url_from_path(name)
    if (url = params[name]).present?
      if not (parsed_url = Addressable::URI.parse(url)).is_a? Addressable::URI or parsed_url.host.nil?
        url = nil
      end
    end
    unless url.present?
      # params[name] is http:/example.com because of squeeze("/")
      path = url_for(name => ".", only_path: true)
      url = request.original_fullpath.slice(path.size-1..-1)
    end
    url
  end

  private

  def current_member
    @member ||= find_current_member_by_session || find_current_member_by_auth_key
  end

  def find_current_member_by_session
    session[:member_id] && Member.find_by(id: session[:member_id])
  end

  def find_current_member_by_auth_key
    params[:auth_key].presence && Member.find_by(auth_key: params[:auth_key])
  end

  def self.params_required(params, options = {})
    params = [ params ].flatten
    before_action(options) do|controller|
      params.each do|param|
        if controller.params[param].blank?
          render json: json_status(false)
          break false
        end
      end
    end
  end
end