41 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			41 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| class ApplicationController < ActionController::Base
 | |
|   include Authentication
 | |
|   include Pundit::Authorization
 | |
| 
 | |
|   before_action :set_title, :set_current_user, :set_lang
 | |
|   after_action :verify_authorized
 | |
| 
 | |
|   # Only allow modern browsers supporting webp images, web push, badges, import maps, CSS nesting, and CSS :has.
 | |
|   allow_browser versions: :modern
 | |
|   rescue_from Pundit::NotAuthorizedError, with: :user_not_authorized
 | |
|   layout "authenticated"
 | |
| 
 | |
|   private
 | |
| 
 | |
|   def set_title
 | |
|     t_action_name = action_name
 | |
|     t_action_name = "new" if action_name == "create"
 | |
|     t_action_name = "edit" if action_name == "update"
 | |
|     @title = I18n.t("#{controller_name}.#{t_action_name}.title")
 | |
|   end
 | |
| 
 | |
|   def set_current_user
 | |
|     @current_user = current_user
 | |
|   end
 | |
| 
 | |
|   def set_lang
 | |
|     I18n.locale = @current_user.lang if @current_user
 | |
|   end
 | |
| 
 | |
|   def user_not_authorized(exception)
 | |
|     policy_name = exception.policy.class.to_s.underscore
 | |
| 
 | |
|     flash[:error] = t "#{policy_name}.#{exception.query}", scope: "pundit", default: :default
 | |
|     redirect_back_or_to(root_path)
 | |
|   end
 | |
| 
 | |
|   def not_found
 | |
|     render file: "#{Rails.root}/public/404.html", layout: false, status: :not_found
 | |
|   end
 | |
| end
 |