aboutsummaryrefslogtreecommitdiffstats
path: root/mail/messagewall
diff options
context:
space:
mode:
Diffstat (limited to 'mail/messagewall')
-rw-r--r--mail/messagewall/Makefile11
-rw-r--r--mail/messagewall/files/esmtpsize.patch39
2 files changed, 50 insertions, 0 deletions
diff --git a/mail/messagewall/Makefile b/mail/messagewall/Makefile
index 898b96a3f7fd..6723552c03ca 100644
--- a/mail/messagewall/Makefile
+++ b/mail/messagewall/Makefile
@@ -34,6 +34,11 @@ pre-fetch:
@${ECHO} " The profile for the first recipient will be applied to all"
@${ECHO} " recipients of the message."
@${ECHO} ""
+ @${ECHO} " -DWITH_ESMTP_SIZE_OPTION to allow messagewall to handle the"
+ @${ECHO} " size option in MAIL FROM: <foo@bar.com> SIZE=12345678 (RFC1870)"
+ @${ECHO} " This can safe a lot of bandwith, because it rejects any email,"
+ @${ECHO} " if message size is greater than max message size."
+ @${ECHO} ""
# Patch from "Quentin Guernsey" <quentin@wingateweb.com>
# for details see http://www.messagewall.org/cgi-bin/ezmlm-browse.cgi?command=showmsg&list=messagewall-discuss&month=200303&msgnum=921&threadid=lcjcimckfmdphlhpjjhn
@@ -41,6 +46,12 @@ pre-fetch:
EXTRA_PATCHES+= ${PATCHDIR}/allow-multiple-recipients.patch
.endif
+# Patch from "Michael Ranner" <mranner@inode.at>
+# for details see http://www.ranner.jawa.at/messagewall.php
+.if defined(WITH_ESMTP_SIZE_OPTION)
+EXTRA_PATCHES+= ${PATCHDIR}/esmtpsize.patch
+.endif
+
post-patch:
${REINPLACE_CMD} -e 's|/usr/local|${LOCALBASE}|g' \
${WRKSRC}/firemake.cflags \
diff --git a/mail/messagewall/files/esmtpsize.patch b/mail/messagewall/files/esmtpsize.patch
new file mode 100644
index 000000000000..724bcc291312
--- /dev/null
+++ b/mail/messagewall/files/esmtpsize.patch
@@ -0,0 +1,39 @@
+--- smtp.c.orig Fri Jan 16 00:00:00 2004
++++ smtp.c Fri Jan 16 00:04:04 2004
+@@ -394,6 +394,8 @@
+ int atsign;
+ int l;
+ int j;
++ int k;
++ long message_size;
+
+ if (outline.a == 0)
+ firestring_estr_alloc(&outline,SMTP_LINE_MAXLEN);
+@@ -582,6 +584,27 @@
+ fprintf(stderr,"{%d} (%d) SMTP/REJECT: MAIL path too long\n",process,client);
+ tls_client_write(client,SMTP_BADCHAR,sizeof(SMTP_BADCHAR) - 1);
+ return 0;
++ }
++
++ /*
++ * ESMPT SIZE patch (2004-01-16) from Michael Ranner <mranner@inode.at>
++ * With this patch, messagewall handles the ESMTP SIZE option (RFC1870)
++ * "MAIL FROM: <mranner@inode.at> SIZE=12345" like sendmail does.
++ * This patch can help you to safe a lot of bandwith.
++ */
++ k = firestring_estr_stristr(line,"size",l);
++
++ if (k > -1) {
++ k = firestring_estr_strchr(line,'=',k);
++ if ((k > -1) && (line->l > ++k)) {
++ message_size = strtol(&line->s[k],(char **)NULL,10);
++ if (message_size > max_message_size) {
++ fprintf(stderr,"{%d} (%d) SMTP/REJECT: esmtp size %d bytes, message too long\n",process,client,message_size);
++ tls_client_write(client,SMTP_MESSAGE_TOOLONG,sizeof(SMTP_MESSAGE_TOOLONG) + 1);
++ } else {
++ fprintf(stderr,"{%d} (%d) SMTP/STATUS: esmtp size %d bytes\n",process,client,message_size);
++ }
++ }
+ }
+
+ /*