subject I18n.t('notifier.signup_confirm.subject')
body :url => url_for(:host => SERVER_URL,
:controller => "user", :action => "confirm",
+ :display_name => user.display_name,
:confirm_string => token.token)
end
subject I18n.t('notifier.lost_password.subject')
body :url => url_for(:host => SERVER_URL,
:controller => "user", :action => "reset_password",
- :email => user.email, :token => token.token)
- end
-
- def reset_password(user, pass)
- common_headers user
- subject I18n.t('notifier.reset_password.subject')
- body :pass => pass
+ :token => token.token)
end
def gpx_success(trace, possible_points)
common_headers trace.user
- subject "[OpenStreetMap] GPX Import success"
+ subject I18n.t('notifier.gpx_notification.success.subject')
body :trace_name => trace.name,
:trace_points => trace.size,
:trace_description => trace.description,
def gpx_failure(trace, error)
common_headers trace.user
from "webmaster@openstreetmap.org"
- subject "[OpenStreetMap] GPX Import failure"
+ subject I18n.t('notifier.gpx_notification.failure.subject')
body :trace_name => trace.name,
:trace_description => trace.description,
:trace_tags => trace.tags,
def message_notification(message)
common_headers message.recipient
- subject I18n.t('notifier.message_notification.subject', :user => message.sender.display_name)
+ from_header message.sender.display_name, "m", message.id, message.digest
+ subject I18n.t('notifier.message_notification.subject_header', :subject => message.title, :locale => locale)
body :to_user => message.recipient.display_name,
:from_user => message.sender.display_name,
:body => message.body,
def diary_comment_notification(comment)
common_headers comment.diary_entry.user
- subject I18n.t('notifier.diary_comment_notification.subject', :user => comment.user.display_name)
+ from_header comment.user.display_name, "c", comment.id, comment.digest
+ subject I18n.t('notifier.diary_comment_notification.subject', :user => comment.user.display_name, :locale => locale)
body :to_user => comment.diary_entry.user.display_name,
:from_user => comment.user.display_name,
:body => comment.body,
:replyurl => url_for(:host => SERVER_URL,
:controller => "message",
:action => "new",
- :user_id => comment.user.id,
+ :display_name => comment.user.display_name,
:title => "Re: #{comment.diary_entry.title}")
end
def friend_notification(friend)
- befriender = User.find_by_id(friend.user_id)
- befriendee = User.find_by_id(friend.friend_user_id)
-
- common_headers befriendee
- subject I18n.t('notifier.friend_notification.subject', :user => befriender.display_name)
- body :user => befriender.display_name,
- :userurl => url_for(:host => SERVER_URL,
- :controller => "user", :action => "view",
- :display_name => befriender.display_name)
+ common_headers friend.befriendee
+ subject I18n.t('notifier.friend_notification.subject', :user => friend.befriender.display_name, :locale => locale)
+ body :friend => friend
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",
+ from EMAIL_FROM
+ headers "return-path" => EMAIL_RETURN_PATH,
"Auto-Submitted" => "auto-generated"
end
+
+ def from_header(name, type, id, digest)
+ if domain = MESSAGES_DOMAIN
+ from quote_address_if_necessary("#{name} <#{type}-#{id}-#{digest[0,6]}@#{domain}>", "utf-8")
+ end
+ end
end