mirror of
https://github.com/LaCasemate/fab-manager.git
synced 2025-01-10 00:46:15 +01:00
93 lines
2.9 KiB
Ruby
93 lines
2.9 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
# Main controller for the backend application. All controllers inherits from it
|
|
class ApplicationController < ActionController::Base
|
|
include Pundit
|
|
# Prevent CSRF attacks by raising an exception.
|
|
# For APIs, you may want to use :null_session instead.
|
|
protect_from_forgery with: :exception
|
|
after_action :set_csrf_cookie
|
|
cache_sweeper :stylesheet_sweeper
|
|
|
|
respond_to :html, :json
|
|
|
|
before_action :configure_permitted_parameters, if: :devise_controller?
|
|
around_action :switch_locale
|
|
|
|
# Globally rescue Authorization Errors in controller.
|
|
# Returning 403 Forbidden if permission is denied
|
|
rescue_from Pundit::NotAuthorizedError, with: :permission_denied
|
|
|
|
def index; end
|
|
|
|
def sso_redirect
|
|
@authorization_token = request.query_parameters[:auth_token]
|
|
@authentication_token = form_authenticity_token
|
|
@active_provider = AuthProvider.active
|
|
end
|
|
|
|
protected
|
|
|
|
def set_csrf_cookie
|
|
cookies['XSRF-TOKEN'] = form_authenticity_token if protect_against_forgery?
|
|
end
|
|
|
|
def verified_request?
|
|
super || valid_authenticity_token?(session, request.headers['X-XSRF-TOKEN'])
|
|
end
|
|
|
|
def configure_permitted_parameters
|
|
devise_parameter_sanitizer.permit(:sign_up,
|
|
keys: [
|
|
{
|
|
profile_attributes: %i[phone last_name first_name interest software_mastered],
|
|
invoicing_profile_attributes: [
|
|
organization_attributes: [:name, address_attributes: [:address]],
|
|
address_attributes: [:address]
|
|
],
|
|
statistic_profile_attributes: %i[gender birthday]
|
|
},
|
|
:username, :is_allow_contact, :is_allow_newsletter, :cgu, :group_id
|
|
])
|
|
end
|
|
|
|
def default_url_options
|
|
{
|
|
host: Rails.application.secrets.default_host,
|
|
protocol: Rails.application.secrets.default_protocol
|
|
}
|
|
end
|
|
|
|
def permission_denied
|
|
head 403
|
|
end
|
|
|
|
# Set the configured locale for each action (API call)
|
|
# @see https://guides.rubyonrails.org/i18n.html
|
|
def switch_locale(&action)
|
|
locale = params[:locale] || Rails.application.secrets.rails_locale
|
|
I18n.with_locale(locale, &action)
|
|
end
|
|
|
|
# @return [User]
|
|
# This is a placeholder for Devise's current_user.
|
|
# As Devise generate the method at runtime, IDEs autocomplete features will complain about 'method not found'
|
|
def current_user
|
|
super
|
|
end
|
|
|
|
# This is a placeholder for Devise's authenticate_user! method.
|
|
def authenticate_user!
|
|
super
|
|
end
|
|
|
|
# N+1 query detection (https://github.com/flyerhzm/bullet)
|
|
def skip_bullet
|
|
previous_value = Bullet.enable?
|
|
Bullet.enable = false
|
|
yield
|
|
ensure
|
|
Bullet.enable = previous_value
|
|
end
|
|
end
|