tab/app/controllers/application_controller.rb
2015-09-11 14:32:24 +02:00

27 lines
776 B
Ruby

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
rescue_from CanCan::AccessDenied do |exception|
respond_to do |format|
format.json { render nothing: true, status: :forbidden }
format.html { redirect_to root_url, alert: exception.message }
end
end
def authenticate_user_or_client!
current_user || current_client || head(:unauthorized)
end
def current_client
@current_client ||= Client.find_by key: request.headers["X-API-KEY"]
end
def current_ability
@current_ability ||=
current_client.try { |c| ClientAbility.new(c) } ||
UserAbility.new(current_user)
end
end