X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/5620d7263a36fe842f4d97bc21dda5edd0651b37..5b0024e61abe15543740bdc4b58c673d62a394d2:/app/models/notifier.rb diff --git a/app/models/notifier.rb b/app/models/notifier.rb index 84d097341..b291c2b57 100644 --- a/app/models/notifier.rb +++ b/app/models/notifier.rb @@ -1,38 +1,39 @@ - class Notifier < ActionMailer::Base def signup_confirm(user, token) - recipients user.email - from "webmaster@openstreetmap.org" + common_headers user subject "[OpenStreetMap] Confirm your email address" - headers "Auto-Submitted" => "auto-generated" body :url => url_for(:host => SERVER_URL, :controller => "user", :action => "confirm", :confirm_string => token.token) end + def email_confirm(user, token) + common_headers user + recipients user.new_email + subject "[OpenStreetMap] Confirm your email address" + body :address => user.new_email, + :url => url_for(:host => SERVER_URL, + :controller => "user", :action => "confirm_email", + :confirm_string => token.token) + end + def lost_password(user, token) - recipients user.email - from "webmaster@openstreetmap.org" + common_headers user subject "[OpenStreetMap] Password reset request" - headers "Auto-Submitted" => "auto-generated" body :url => url_for(:host => SERVER_URL, :controller => "user", :action => "reset_password", :email => user.email, :token => token.token) end def reset_password(user, pass) - recipients user.email - from "webmaster@openstreetmap.org" + common_headers user subject "[OpenStreetMap] Password reset" - headers "Auto-Submitted" => "auto-generated" body :pass => pass end def gpx_success(trace, possible_points) - recipients trace.user.email - from "webmaster@openstreetmap.org" + common_headers trace.user subject "[OpenStreetMap] GPX Import success" - headers "Auto-Submitted" => "auto-generated" body :trace_name => trace.name, :trace_points => trace.size, :trace_description => trace.description, @@ -41,10 +42,9 @@ class Notifier < ActionMailer::Base end def gpx_failure(trace, error) - recipients trace.user.email + common_headers trace.user from "webmaster@openstreetmap.org" subject "[OpenStreetMap] GPX Import failure" - headers "Auto-Submitted" => "auto-generated" body :trace_name => trace.name, :trace_description => trace.description, :trace_tags => trace.tags, @@ -52,10 +52,8 @@ class Notifier < ActionMailer::Base end def message_notification(message) - recipients message.recipient.email - from "webmaster@openstreetmap.org" + common_headers message.recipient subject "[OpenStreetMap] #{message.sender.display_name} sent you a new message" - headers "Auto-Submitted" => "auto-generated" body :to_user => message.recipient.display_name, :from_user => message.sender.display_name, :body => message.body, @@ -69,10 +67,8 @@ class Notifier < ActionMailer::Base end def diary_comment_notification(comment) - recipients comment.diary_entry.user.email - from "webmaster@openstreetmap.org" + common_headers comment.diary_entry.user subject "[OpenStreetMap] #{comment.user.display_name} commented on your diary entry" - headers "Auto-Submitted" => "auto-generated" body :to_user => comment.diary_entry.user.display_name, :from_user => comment.user.display_name, :body => comment.body, @@ -100,13 +96,21 @@ class Notifier < ActionMailer::Base befriender = User.find_by_id(friend.user_id) befriendee = User.find_by_id(friend.friend_user_id) - recipients befriendee.email - from "webmaster@openstreetmap.org" + common_headers befriendee subject "[OpenStreetMap] #{befriender.display_name} added you as a friend" - headers "Auto-Submitted" => "auto-generated" body :user => befriender.display_name, :userurl => url_for(:host => SERVER_URL, :controller => "user", :action => "view", :display_name => befriender.display_name) end + +private + + def common_headers(recipient) + recipients recipient.email + locale recipient.preferred_language_from(I18n.available_locales) + from "webmaster@openstreetmap.org" + headers "return-path" => "bounces@openstreetmap.org", + "Auto-Submitted" => "auto-generated" + end end