Defect #14699
closed
Cannot change "From" header in email notifications
Added by Zach Hamman over 12 years ago.
Updated about 11 years ago.
Category:
Code cleanup/refactoring
Description
In Redmine 1.x (Rails 2.3), using from method in custom mailer changed the From header from Setting.mail_from.
According to Rails 3 Action Mailer documentation, mail method can receive :from header. Redmine 2.x's Mailer#mail does header.merge!{'From'=>Setting.mail_from,...}. This results in the from header being overridden and removes default functionality.
I have made a change to Mailer#mail to do header.reverse_merge! instead of header.merge!, but I am unsure if this is the best path. However, this did set up the email headers correctly.
Files
Here is a patch where we use the headers.reverse_merge! method instead of headers.merge!
As we can pass headers as a parameter, I think we should use a reverse_merge in order to not override our hash with default values:
def mail(headers={}, &block)
headers.reverse_merge! 'X-Mailer' => 'Redmine',
'X-Redmine-Host' => Setting.host_name,
'X-Redmine-Site' => Setting.app_title,
'X-Auto-Response-Suppress' => 'OOF',
'Auto-Submitted' => 'auto-generated',
'From' => Setting.mail_from,
'List-Id' => "<#{Setting.mail_from.to_s.gsub('@', '.')}>"
This could be very useful in some of my plugins. Thanks
- Target version set to 2.6.1
- Category changed from Email notifications to Code cleanup/refactoring
- Status changed from New to Resolved
- Assignee set to Jean-Philippe Lang
- Resolution set to Fixed
Fix committed in r13784, thanks.
- Status changed from Resolved to Closed
Also available in: Atom
PDF