class Users::DossiersController < UsersController before_action :authenticate_user! def index @dossiers = Dossier.all.decorate end def show @dossier = Dossier.find(params[:id]) @etablissement = @dossier.etablissement @entreprise = @dossier.entreprise.decorate rescue ActiveRecord::RecordNotFound flash.alert = t('errors.messages.dossier_not_found') redirect_to url_for(controller: :siret) end def create procedure = Procedure.find(params['procedure_id']) @etablissement = Etablissement.new(SIADE::EtablissementAdapter.new(siret).to_params) @entreprise = Entreprise.new(SIADE::EntrepriseAdapter.new(siren).to_params) @dossier = Dossier.create @dossier.draft! @dossier.procedure = procedure @dossier.save @entreprise.dossier = @dossier @entreprise.save @etablissement.dossier = @dossier @etablissement.entreprise = @entreprise @etablissement.save redirect_to url_for(controller: :dossiers, action: :show, id: @dossier.id) rescue RestClient::ResourceNotFound flash.alert = t('errors.messages.invalid_siret') redirect_to url_for(controller: :siret, procedure_id: params['procedure_id']) rescue ActiveRecord::RecordNotFound flash.alert = t('errors.messages.dossier_not_found') redirect_to url_for(controller: :siret) end def update @dossier = Dossier.find(params[:id]) if checked_autorisation_donnees? @dossier.update_attributes(update_params) redirect_to url_for(controller: :description, action: :show, dossier_id: @dossier.id) else @etablissement = @dossier.etablissement @entreprise = @dossier.entreprise.decorate flash.now.alert = 'Les conditions sont obligatoires.' render 'show' end end private def update_params params.require(:dossier).permit(:autorisation_donnees) end def dossier_id_is_present? @dossier_id != '' end def checked_autorisation_donnees? update_params[:autorisation_donnees] == '1' end def siret params[:siret] end def siren siret[0..8] end end