2023-09-04 12:07:04 +02:00
|
|
|
|
class GroupeGestionnaire < ApplicationRecord
|
|
|
|
|
belongs_to :groupe_gestionnaire, optional: true # parent
|
|
|
|
|
has_many :children, class_name: "GroupeGestionnaire", inverse_of: :groupe_gestionnaire
|
|
|
|
|
has_many :administrateurs
|
|
|
|
|
has_and_belongs_to_many :gestionnaires
|
|
|
|
|
|
2023-08-29 19:08:27 +02:00
|
|
|
|
def root_groupe_gestionnaire?
|
|
|
|
|
groupe_gestionnaire.nil?
|
|
|
|
|
end
|
|
|
|
|
|
2023-09-04 12:07:04 +02:00
|
|
|
|
def add(gestionnaire)
|
2023-08-29 19:08:27 +02:00
|
|
|
|
return if gestionnaire.nil?
|
|
|
|
|
return if in?(gestionnaire.groupe_gestionnaires)
|
|
|
|
|
|
2023-09-04 12:07:04 +02:00
|
|
|
|
gestionnaires << gestionnaire
|
|
|
|
|
end
|
|
|
|
|
|
2023-09-28 17:45:39 +02:00
|
|
|
|
def remove(gestionnaire_id, current_user)
|
|
|
|
|
if !self.root_groupe_gestionnaire? || self.gestionnaires.one?
|
|
|
|
|
alert = "Suppression impossible : il doit y avoir au moins un gestionnaire dans le groupe racine"
|
|
|
|
|
else
|
|
|
|
|
gestionnaire = Gestionnaire.find(gestionnaire_id)
|
2023-08-29 19:08:27 +02:00
|
|
|
|
|
2023-09-28 17:45:39 +02:00
|
|
|
|
if gestionnaire.nil? || !in?(gestionnaire.groupe_gestionnaires) || !gestionnaire.groupe_gestionnaires.destroy(self)
|
|
|
|
|
alert = "Le gestionnaire « #{gestionnaire.email} » n’est pas dans le groupe."
|
|
|
|
|
else
|
|
|
|
|
notice = "Le gestionnaire « #{gestionnaire.email} » a été retiré du groupe."
|
|
|
|
|
GroupeGestionnaireMailer
|
|
|
|
|
.notify_removed_gestionnaire(self, gestionnaire, current_user.email)
|
|
|
|
|
.deliver_later
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
[gestionnaire, alert, notice]
|
2023-08-29 19:08:27 +02:00
|
|
|
|
end
|
|
|
|
|
|
2023-09-28 17:45:39 +02:00
|
|
|
|
def add_gestionnaires(ids: [], emails: [], current_user: nil)
|
|
|
|
|
emails = emails.to_json
|
|
|
|
|
emails = JSON.parse(emails).map { EmailSanitizableConcern::EmailSanitizer.sanitize(_1) }
|
|
|
|
|
|
2023-09-04 12:07:04 +02:00
|
|
|
|
gestionnaires_to_add, valid_emails, invalid_emails = Gestionnaire.find_all_by_identifier_with_emails(ids:, emails:)
|
|
|
|
|
not_found_emails = valid_emails - gestionnaires_to_add.map(&:email)
|
|
|
|
|
|
|
|
|
|
# Send invitations to users without account
|
|
|
|
|
if not_found_emails.present?
|
|
|
|
|
gestionnaires_to_add += not_found_emails.map do |email|
|
|
|
|
|
user = User.create_or_promote_to_gestionnaire(email, SecureRandom.hex)
|
|
|
|
|
user.invite_gestionnaire!(self)
|
|
|
|
|
user.gestionnaire
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
# We dont't want to assign a user to an groupe_gestionnaire if they are already assigned to it
|
2023-09-28 17:45:39 +02:00
|
|
|
|
gestionnaires_duplicate = gestionnaires_to_add & gestionnaires
|
2023-09-04 12:07:04 +02:00
|
|
|
|
gestionnaires_to_add -= gestionnaires
|
|
|
|
|
gestionnaires_to_add.each { add(_1) }
|
|
|
|
|
|
2023-09-28 17:45:39 +02:00
|
|
|
|
if invalid_emails.present?
|
|
|
|
|
alert = I18n.t('activerecord.wrong_address',
|
|
|
|
|
count: invalid_emails.size,
|
|
|
|
|
emails: invalid_emails)
|
|
|
|
|
end
|
|
|
|
|
if gestionnaires_duplicate.present?
|
|
|
|
|
alert = I18n.t('activerecord.errors.duplicate_email',
|
|
|
|
|
count: invalid_emails.size,
|
2023-10-04 19:40:34 +02:00
|
|
|
|
emails: gestionnaires_duplicate.map(&:email))
|
2023-09-28 17:45:39 +02:00
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
if gestionnaires_to_add.present?
|
|
|
|
|
notice = "Les gestionnaires ont bien été affectés au groupe d'administrateurs"
|
|
|
|
|
|
|
|
|
|
GroupeGestionnaireMailer
|
|
|
|
|
.notify_added_gestionnaires(self, gestionnaires_to_add, current_user.email)
|
|
|
|
|
.deliver_later
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
[gestionnaires_to_add, alert, notice]
|
2023-09-04 12:07:04 +02:00
|
|
|
|
end
|
|
|
|
|
end
|