Project

General

Profile

Actions

Defect #14699

closed

Cannot change "From" header in email notifications

Added by Zach Hamman over 11 years ago. Updated almost 10 years ago.

Status:
Closed
Priority:
Normal
Category:
Code cleanup/refactoring
Target version:
Start date:
Due date:
% Done:

0%

Estimated time:
Resolution:
Fixed
Affected version:

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

merge_headers.diff (488 Bytes) merge_headers.diff Vincent Robert, 2014-11-24 10:46
Actions #1

Updated by Vincent Robert almost 10 years ago

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

Actions #2

Updated by Jean-Philippe Lang almost 10 years ago

  • Target version set to 2.6.1
Actions #3

Updated by Jean-Philippe Lang almost 10 years ago

  • 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.

Actions #4

Updated by Jean-Philippe Lang almost 10 years ago

  • Status changed from Resolved to Closed
Actions

Also available in: Atom PDF