demarches-normaliennes/app/controllers/new_administrateur/jeton_particulier_controller.rb
simon lehericey ee6d19e3ee an admin can save it's api particulier token
Co-authored-by: François VANTOMME <akarzim@gmail.com>
2021-09-15 14:56:42 +02:00

41 lines
1.3 KiB
Ruby

module NewAdministrateur
class JetonParticulierController < AdministrateurController
before_action :retrieve_procedure
def api_particulier
end
def show
end
def update
@procedure.api_particulier_token = token
if @procedure.valid? && fetch_scopes(token).any?
@procedure.save
redirect_to admin_procedure_api_particulier_jeton_path(procedure_id: @procedure.id),
notice: "Le jeton a bien été mis à jour"
else
flash.now.alert = "Mise à jour impossible : le jeton n'est pas valide<br /><br />Vérifier le auprès de <a href='https://datapass.api.gouv.fr/'>https://datapass.api.gouv.fr/</a>"
render :show
end
rescue APIParticulier::Error::Unauthorized
flash.now.alert = "Mise à jour impossible : le jeton n'a pas été trouvé ou n'est pas actif<br /><br />Vérifier le auprès de <a href='https://datapass.api.gouv.fr/'>https://datapass.api.gouv.fr/</a>"
render :show
rescue APIParticulier::Error::HttpError
flash.now.alert = "Mise à jour impossible : une erreur réseau est survenue"
render :show
end
private
def fetch_scopes(token)
@scopes ||= APIParticulier::API.new(token).scopes
end
def token
params[:procedure][:api_particulier_token]
end
end
end