87 lines
3.1 KiB
Ruby
87 lines
3.1 KiB
Ruby
module CreateAvisConcern
|
||
extend ActiveSupport::Concern
|
||
|
||
private
|
||
|
||
def create_avis_from_params(dossier, instructeur_or_expert, confidentiel = false)
|
||
if create_avis_params[:emails].empty?
|
||
avis = Avis.new(create_avis_params)
|
||
errors = avis.errors
|
||
errors.add(:emails, :blank)
|
||
|
||
flash.alert = errors.full_message(:emails, errors[:emails].first)
|
||
|
||
return avis
|
||
end
|
||
|
||
confidentiel ||= create_avis_params[:confidentiel]
|
||
# Because of a limitation of the email_field rails helper,
|
||
# the :emails parameter is a 1-element array.
|
||
# Hence the call to first
|
||
# https://github.com/rails/rails/issues/17225
|
||
expert_emails = create_avis_params[:emails].presence || [].to_json
|
||
expert_emails = JSON.parse(expert_emails).map(&:strip).map(&:downcase)
|
||
allowed_dossiers = [dossier]
|
||
|
||
if create_avis_params[:invite_linked_dossiers].present?
|
||
allowed_dossiers += dossier.linked_dossiers_for(instructeur_or_expert)
|
||
end
|
||
|
||
if (instructeur_or_expert.is_a?(Instructeur)) && !instructeur_or_expert.follows.exists?(dossier: dossier)
|
||
instructeur_or_expert.follow(dossier)
|
||
end
|
||
|
||
create_results = Avis.create(
|
||
expert_emails.flat_map do |email|
|
||
user = User.create_or_promote_to_expert(email, SecureRandom.hex)
|
||
experts_procedure = user.valid? ? ExpertsProcedure.find_or_create_by(procedure: dossier.procedure, expert: user.expert) : nil
|
||
allowed_dossiers.map do |dossier|
|
||
{
|
||
email: email,
|
||
introduction: create_avis_params[:introduction],
|
||
introduction_file: create_avis_params[:introduction_file],
|
||
claimant: instructeur_or_expert,
|
||
dossier: dossier,
|
||
confidentiel: confidentiel,
|
||
experts_procedure: experts_procedure,
|
||
question_label: create_avis_params[:question_label]
|
||
}
|
||
end
|
||
end
|
||
)
|
||
dossier.avis.reload # unload non-persisted avis from dossier
|
||
|
||
persisted, failed = create_results.partition(&:persisted?)
|
||
|
||
if persisted.any?
|
||
dossier.update!(last_avis_updated_at: Time.zone.now)
|
||
sent_emails_addresses = []
|
||
persisted.each do |avis|
|
||
avis.dossier.demander_un_avis!(avis)
|
||
if avis.dossier == dossier
|
||
AvisMailer.avis_invitation(avis).deliver_later
|
||
sent_emails_addresses << avis.expert.email
|
||
# the email format is already verified, we update value to nil
|
||
avis.update_column(:email, nil)
|
||
end
|
||
end
|
||
flash.notice = "Une demande d’avis a été envoyée à #{sent_emails_addresses.uniq.join(", ")}"
|
||
end
|
||
|
||
if failed.any?
|
||
flash.now.alert = failed
|
||
.filter { |avis| avis.errors.present? }
|
||
.map { |avis| "#{avis.email} : #{avis.errors.full_messages_for(:email).join(', ')}" }
|
||
|
||
# When an error occurs, return the avis back to the controller
|
||
# to give the user a chance to correct and resubmit
|
||
Avis.new(create_avis_params.merge(emails: [failed.map(&:email).uniq.join(", ")]))
|
||
else
|
||
nil
|
||
end
|
||
end
|
||
|
||
def create_avis_params
|
||
params.require(:avis).permit(:introduction_file, :introduction, :confidentiel, :invite_linked_dossiers, :emails, :question_label)
|
||
end
|
||
end
|