scinote-web/app/controllers/application_controller.rb

94 lines
2.2 KiB
Ruby
Raw Normal View History

2016-02-12 23:52:43 +08:00
class ApplicationController < ActionController::Base
include PermissionHelper
include FirstTimeDataGenerator
# Prevent CSRF attacks by raising an exception.
# For APIs, you may want to use :null_session instead.
protect_from_forgery with: :exception
before_action :authenticate_user!
helper_method :current_organization
2016-02-12 23:52:43 +08:00
before_action :generate_intro_tutorial, if: :is_current_page_root?
around_action :set_time_zone, if: :current_user
2016-10-11 22:16:48 +08:00
layout 'main'
2016-02-12 23:52:43 +08:00
def forbidden
render_403
end
def not_found
render_404
end
def is_current_page_root?
2016-10-11 22:16:48 +08:00
controller_name == 'projects' && action_name == 'index'
2016-02-12 23:52:43 +08:00
end
# Sets current organization for all controllers
def current_organization
Organization.find_by_id(current_user.current_organization_id)
end
2016-02-12 23:52:43 +08:00
protected
def log(message)
if @my_module
@my_module.log(message)
elsif @project
@project.log(message)
elsif @organization
@organization.log(message)
else
logger.error(message)
end
end
def render_403
2016-07-21 19:11:15 +08:00
respond_to do |format|
format.html {
render file: 'public/403.html', status: :forbidden, layout: false
}
format.json {
render json: {}, status: :forbidden
}
end
return true
2016-02-12 23:52:43 +08:00
end
def render_404
2016-07-21 19:11:15 +08:00
respond_to do |format|
format.html {
render :file => 'public/404.html', :status => :not_found, :layout => false
}
format.json {
render json: {}, status: :not_found
}
end
return true
2016-02-12 23:52:43 +08:00
end
private
def generate_intro_tutorial
if Rails.configuration.x.enable_tutorial &&
current_user.no_tutorial_done? &&
current_user.organizations.where(created_by: current_user).count > 0 then
demo_cookie = seed_demo_data current_user
cookies[:tutorial_data] = {
value: demo_cookie,
expires: 1.week.from_now
}
current_user.update(tutorial_status: 1)
end
end
# With this Devise callback user is redirected directly to sign in page instead
# of to root path. Therefore notification for sign out is displayed.
def after_sign_out_path_for(resource_or_scope)
new_user_session_path
end
def set_time_zone(&block)
Time.use_zone(current_user.time_zone, &block)
end
end