feat(mail): link with hosts for recipient for notification mailer

This commit is contained in:
Colin Darie 2024-03-26 18:37:25 +01:00
parent f8a9e72aa2
commit 5bf580b6ac
No known key found for this signature in database
GPG key ID: 8C76CADD40253590
3 changed files with 17 additions and 4 deletions

View file

@ -27,7 +27,8 @@ module MailerHeadersConfigurableConcern
end end
self.class.default from: from, reply_to: from self.class.default from: from, reply_to: from
self.class.default_url_options = { host: Current.host } self.class.default_url_options[:host] = Current.host
Rails.application.routes.default_url_options[:host] = Current.host # link generated by url helpers in tags substitutions
self.class.asset_host = Current.application_base_url self.class.asset_host = Current.application_base_url
end end

View file

@ -33,6 +33,8 @@ class NotificationMailer < ApplicationMailer
return return
end end
configure_defaults_for_user(@dossier.user)
@subject = "Votre dossier rempli par le mandataire #{@dossier.mandataire_first_name} #{@dossier.mandataire_last_name} a été mis à jour" @subject = "Votre dossier rempli par le mandataire #{@dossier.mandataire_first_name} #{@dossier.mandataire_last_name} a été mis à jour"
@email = @dossier.individual.email @email = @dossier.individual.email
@logo_url = procedure_logo_url(@dossier.procedure) @logo_url = procedure_logo_url(@dossier.procedure)
@ -78,6 +80,7 @@ class NotificationMailer < ApplicationMailer
def set_dossier def set_dossier
@dossier = params[:dossier] @dossier = params[:dossier]
configure_defaults_for_user(@dossier.user)
if @dossier.skip_user_notification_email? if @dossier.skip_user_notification_email?
mail.perform_deliveries = false mail.perform_deliveries = false

View file

@ -73,8 +73,8 @@ RSpec.describe NotificationMailer, type: :mailer do
end end
it 'renders the actions' do it 'renders the actions' do
expect(mail.body).to have_link('Consulter mon dossier', href: dossier_url(dossier)) expect(mail.body).to have_link('Consulter mon dossier', href: dossier_url(dossier, host: ENV.fetch("APP_HOST_LEGACY")))
expect(mail.body).to have_link('Jai une question', href: messagerie_dossier_url(dossier)) expect(mail.body).to have_link('Jai une question', href: messagerie_dossier_url(dossier, host: ENV.fetch("APP_HOST_LEGACY")))
end end
context 'when the template body contains tags' do context 'when the template body contains tags' do
@ -85,7 +85,16 @@ RSpec.describe NotificationMailer, type: :mailer do
end end
it 'replaces link tags with a clickable link' do it 'replaces link tags with a clickable link' do
expect(mail.body).to have_link(dossier_url(dossier)) expect(mail.body).to have_link(dossier_url(dossier, host: ENV.fetch("APP_HOST_LEGACY")))
end
context "when user has preferred domain" do
let(:user) { create(:user, preferred_domain: :demarches_gouv_fr) }
it do
expect(mail.body).to have_link(dossier_url(dossier, host: ENV.fetch("APP_HOST")))
expect(header_value("From", mail)).to include("@demarches.gouv.fr")
end
end end
end end