-class Notifier < ActionMailer::Base
- default :from => EMAIL_FROM,
- :return_path => EMAIL_RETURN_PATH,
+class Notifier < ApplicationMailer
+ include ActionView::Helpers::AssetUrlHelper
+
+ self.delivery_job = ActionMailer::MailDeliveryJob
+
+ default :from => Settings.email_from,
+ :return_path => Settings.email_return_path,
:auto_submitted => "auto-generated"
helper :application
before_action :set_shared_template_vars
@readurl = diary_entry_url(comment.diary_entry.user, comment.diary_entry, :anchor => "comment#{comment.id}")
@commenturl = diary_entry_url(comment.diary_entry.user, comment.diary_entry, :anchor => "newcomment")
@replyurl = new_message_url(comment.user, :message => { :title => "Re: #{comment.diary_entry.title}" })
-
@author = @from_user
attach_user_avatar(comment.user)
+ set_references("diary", comment.diary_entry)
+
mail :from => from_address(comment.user.display_name, "c", comment.id, comment.digest, recipient.id),
:to => recipient.email,
:subject => I18n.t("notifier.diary_comment_notification.subject", :user => comment.user.display_name)
end
end
- def friend_notification(friend)
- with_recipient_locale friend.befriendee do
- @friend = friend
- @viewurl = user_url(@friend.befriender)
- @friendurl = url_for(:controller => "users", :action => "make_friend",
- :display_name => @friend.befriender.display_name)
- @author = @friend.befriender.display_name
+ def friendship_notification(friendship)
+ with_recipient_locale friendship.befriendee do
+ @friendship = friendship
+ @viewurl = user_url(@friendship.befriender)
+ @friendurl = make_friend_url(@friendship.befriender)
+ @author = @friendship.befriender.display_name
- attach_user_avatar(@friend.befriender)
- mail :to => friend.befriendee.email,
- :subject => I18n.t("notifier.friend_notification.subject", :user => friend.befriender.display_name)
+ attach_user_avatar(@friendship.befriender)
+ mail :to => friendship.befriendee.email,
+ :subject => I18n.t("notifier.friendship_notification.subject", :user => friendship.befriender.display_name)
end
end
@author = @commenter
attach_user_avatar(comment.author)
+ set_references("note", comment.note)
+
subject = if @owner
I18n.t("notifier.note_comment_notification.#{@event}.subject_own", :commenter => @commenter)
else
attach_user_avatar(comment.author)
+ set_references("changeset", comment.changeset)
+
mail :to => recipient.email, :subject => subject
end
end
end
def attach_project_logo
- attachments.inline["logo.png"] = File.read(Rails.root.join("app", "assets", "images", "osm_logo_30.png"))
+ attachments.inline["logo.png"] = File.read(Rails.root.join("app/assets/images/osm_logo_30.png"))
end
def attach_user_avatar(user)
- attachments.inline["avatar.png"] = File.read(user_avatar_file_path(user))
+ attachments.inline["avatar.png"] = user_avatar_file(user)
end
- def user_avatar_file_path(user)
- image = user&.image
- if image&.file?
- return image.path(:small)
+ def user_avatar_file(user)
+ avatar = user&.avatar
+ if avatar&.attached?
+ if avatar.variable?
+ image = avatar.variant(:resize => "50x50>").processed
+ image.service.download(image.key)
+ else
+ avatar.blob.download
+ end
else
- return Rails.root.join("app", "assets", "images", "users", "images", "small.png")
+ File.read(Rails.root.join("app/assets/images/avatar_small.png"))
end
end
- def with_recipient_locale(recipient)
- I18n.with_locale Locale.available.preferred(recipient.preferred_languages) do
- yield
- end
+ def with_recipient_locale(recipient, &block)
+ I18n.with_locale(Locale.available.preferred(recipient.preferred_languages), &block)
end
def from_address(name, type, id, digest, user_id = nil)
- if Object.const_defined?(:MESSAGES_DOMAIN) && domain = MESSAGES_DOMAIN
+ if Settings.key?(:messages_domain) && domain = Settings.messages_domain
if user_id
"#{name} <#{type}-#{id}-#{user_id}-#{digest[0, 6]}@#{domain}>"
else
"#{name} <#{type}-#{id}-#{digest[0, 6]}@#{domain}>"
end
else
- EMAIL_FROM
+ Settings.email_from
end
end
+
+ def set_references(scope, reference_object)
+ ref = "osm-#{scope}-#{reference_object.id}@#{Settings.server_url}"
+
+ headers["X-Entity-Ref-ID"] = ref
+ headers["In-Reply-To"] = ref
+ headers["References"] = ref
+ end
end