Mailhandler Frontend for SubAddressing¶
This page was written for early versions of Redmine. In Redmine 3.2 and later, you can enable sub-addressing with "--project-from-subaddress" option of rdm-mailhandler.rb (#20732). See Receiving emails.
When using rdm-mailhandler.rb, one thing that can be very useful is having a single email address to enable multiple projects without having to override the project all the time in the email body. This is possible using the subaddress format as defined in the following RFCs:
How it works¶
The subaddress is separated from the real address using the "+" sign, so for example, the email:
<redmine@example.com>
will become
<redmine+project@example.com>
Compatible MTAs will still send these emails to the <redmine@example.com> recipient, and it is up to that recipient to make good use of the subaddress portion.
The sub-mailhandler.py script is a front-end for rdm-mailhandler.rb that reads the header of the email, looks for a subaddress and then launches rdm-mailhandler.rb with the specified project, or the default project if specified. It can literally be "inserted" in front of the command line.
Usage¶
Usage: sub-mailhandler.py -h | -e <email> [ -p <project> ] -- <command-line> The <command-line> portion is the full rdm-mailhandler.rb command that would normally be executed as the mail handler. The full path to the executable is required. This command should not include a project; use the build-in --project argument instead. Options: -h, --help show this help message and exit -e EMAIL, --email=EMAIL Known email to look for (i.e. redmine recipient) -p PROJECT, --project=PROJECT Default project to pass to rdm-mailhandler.rb if there is no subaddress
Example¶
Lets say you have this .forward file:
"|/home/redmine/rdm-mailhandler.rb --url http://redmine.example.com --project myproject --allow-override project,tracker,category,priority,status --key xxxxxxxxxxxxxxx"
You always have to provide the recipient email, and in this case you would have to move the default project argument to sub-mailhandler.py. Everything else is copied verbatim:
"|/home/redmine/sub-mailhandler.py --email redmine@example.com --project myproject -- /home/redmine/rdm-mailhandler.rb --url http://redmine.example.com --allow-override project,tracker,category,priority,status --key xxxxxxxxxxxxxxx"
Now, you can still send email to <redmine@example.com> and have the default project (and override it). However if you want to send an email for "projectx", then you cen send it to <redmine+projectx@example.com> and the project will be set accordingly.
Credits¶
This script and wiki page have been originally written by Thomas Guyot-Sionnest <thomas@gmail.com>
Updated by Go MAEDA about 7 years ago ยท 3 revisions