vert-x3/vertx-mail-client

EmailAddress class doesn't handle parentheses in the display name properly per RFC5322

Closed this issue · 1 comments

Questions

I found a bug in the EmailAddress class where it doesn't properly handle parentheses in the display name according to RFC5322.

Version

vertx-mail-client

Context

According to RFC5322, a valid mailbox is composed of a display name and an email address. The display name can be non-special characters or a quoted string, which can include parentheses. Thus, "display(name)" <sample@email.com> should be a valid fullAddress value.

In the EmailAddress class's constructor, there is an if/else block that checks if the full address contains parentheses. If it does, the class treats it like it's in a legacy simple format such as sample@email.com (displayname).

The issue is, if the full address contains parentheses but does not match the regex for the legacy format, the class throws an IllegalArgumentException saying it's an invalid email address. However, this address should be valid per the description given in RFC5322.

  • Link to github project/gist

https://github.com/vert-x3/vertx-mail-client/blob/4.4/src/main/java/io/vertx/ext/mail/mailencoder/EmailAddress.java

Steps to reproduce

Provide an email address with parentheses in the display name to the EmailAddress class's constructor, such as "display(name)" <sample@email.com>

The EmailAddress class will throw an IllegalArgumentException saying "Invalid email address"

This is not the expected behaviour as per RFC5322.

I'm affected by this issue too, so I made a small PR which just moves around the order in which the fullAddress is checked for parentheses vs. angle brackets. Hopefully this doesn't cause another problem for existing cases/logic. As I noted in my commit notes,

This fixes isse #218, though there are still edge cases for valid
emails which won't be allowed (such as those with comments) or
invalid emails which will still be allowed
(eg. this"is"invalid@email.com). The best choice for accuracy would
be to add a parser, but this could slow down runtime. It may not
be a worthy sacrifice.

Let me know if there's anything else I can do to help move this along. :)