X-Git-Url: https://code.wpia.club/?p=gigi.git;a=blobdiff_plain;f=src%2Forg%2Fcacert%2Fgigi%2Femail%2FEmailProvider.java;h=a55a1c205259cb0a592e8c57446bda6edec4fa07;hp=ea6679cd1a98e0c878173c13c35d770999eea427;hb=0b86fb147b4a61f315770fa5bba4466ca18ddfa8;hpb=f97a9d4028195b328b7ff4267b7b4d893eee8995 diff --git a/src/org/cacert/gigi/email/EmailProvider.java b/src/org/cacert/gigi/email/EmailProvider.java index ea6679cd..a55a1c20 100644 --- a/src/org/cacert/gigi/email/EmailProvider.java +++ b/src/org/cacert/gigi/email/EmailProvider.java @@ -22,6 +22,7 @@ import javax.net.ssl.SSLSocketFactory; import org.cacert.gigi.crypto.SMIME; import org.cacert.gigi.database.GigiPreparedStatement; import org.cacert.gigi.util.DNSUtil; +import org.cacert.gigi.util.DomainAssessment; public abstract class EmailProvider { @@ -40,8 +41,7 @@ public abstract class EmailProvider { protected final void sendSigned(String contents, PrintWriter output) throws IOException, GeneralSecurityException { if (k == null || c == null) { - output.println("Content-Transfer-Encoding: base64"); - output.println(); + output.print("Content-Transfer-Encoding: base64\r\n\r\n"); output.print(contents); } else { SMIME.smime(contents, k, c, output); @@ -71,10 +71,20 @@ public abstract class EmailProvider { public static final String FAIL = "FAIL"; - public static final Pattern MAIL = Pattern.compile("^([a-zA-Z0-9])+([a-zA-Z0-9\\+\\._-])*@([a-zA-Z0-9_-])+([a-zA-Z0-9\\._-]+)+$"); + private static final String MAIL_P_RFC_WORD = "[A-Za-z0-9\\+\\.!#$%&'*/=?^_`|~{}-]+"; + + private static final String MAIL_P_RFC_LOCAL = MAIL_P_RFC_WORD + "(?:\\." + MAIL_P_RFC_WORD + ")*"; + + private static final String MAIL_P_RFC_LABEL = "(?!(?!xn)..--|-)(?:[A-Za-z0-9-]+)(?