You are viewing a plain text version of this content. The canonical link for it is here.
Posted to mailet-api@james.apache.org by "Adrian Baker (JIRA)" <ma...@james.apache.org> on 2012/12/20 17:35:14 UTC
[jira] [Created] (MAILET-85) Resend mailet mistakenly treats
SpecialAddress.RECIPIENTS as SpecialAddress.TO
Adrian Baker created MAILET-85:
----------------------------------
Summary: Resend mailet mistakenly treats SpecialAddress.RECIPIENTS as SpecialAddress.TO
Key: MAILET-85
URL: https://issues.apache.org/jira/browse/MAILET-85
Project: James Mailet
Issue Type: Bug
Affects Versions: 3.0
Reporter: Adrian Baker
In org.apache.james.transport.mailets.AbstractRedirect#replaceInternetAddresses(Mail, Collection), this code block means that using the "recipients" special adresses in the Resend mailet config incorrectly gives you the TO addresses:
{code:java}
} else if (internetAddress.equals(SpecialAddress.TO.toInternetAddress()) || internetAddress.equals(SpecialAddress.RECIPIENTS.toInternetAddress())) {
try {
String[] toHeaders = mail.getMessage().getHeader(RFC2822Headers.TO);
if (toHeaders != null) {
for (int i = 0; i < toHeaders.length; i++) {
try {
InternetAddress[] originalToInternetAddresses = InternetAddress.parse(toHeaders[i], false);
for (int j = 0; j < originalToInternetAddresses.length; j++) {
newList.add(originalToInternetAddresses[j]);
}
{code}
The fix is straightforward:
{code:java}
} else if (internetAddress.equals(SpecialAddress.TO.toInternetAddress())) {
...
} else if (internetAddress.equals(SpecialAddress.RECIPIENTS.toInternetAddress())) {
if(mail.getRecipients() != null) {
for(Object recipient : mail.getRecipients()) {
newList.add(((MailAddress)recipient).toInternetAddress());
}
}
{code}
--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators
For more information on JIRA, see: http://www.atlassian.com/software/jira