class FranceConnect::ParticulierController < ApplicationController before_action :redirect_to_login_if_fc_aborted, only: [:callback] def login if FranceConnectService.enabled? redirect_to FranceConnectService.authorization_uri else redirect_to new_user_session_path end end def callback fci = FranceConnectService.find_or_retrieve_france_connect_information(params[:code]) fci.associate_user! if fci.user && !fci.user.can_france_connect? fci.destroy redirect_to new_user_session_path, alert: t('errors.messages.france_connect.forbidden_html', reset_link: new_user_password_path) return end connect_france_connect_particulier(fci.user) rescue Rack::OAuth2::Client::Error => e Rails.logger.error e.message redirect_france_connect_error_connection end private def redirect_to_login_if_fc_aborted if params[:code].blank? redirect_to new_user_session_path end end def connect_france_connect_particulier(user) if user_signed_in? sign_out :user end if instructeur_signed_in? sign_out :instructeur end if administrateur_signed_in? sign_out :administrateur end sign_in user user.update_attribute('loged_in_with_france_connect', User.loged_in_with_france_connects.fetch(:particulier)) redirect_to stored_location_for(current_user) || root_path(current_user) end def redirect_france_connect_error_connection flash.alert = t('errors.messages.france_connect.connexion') redirect_to(new_user_session_path) end end