X-Git-Url: https://diplodocus.org/git/nmh/blobdiff_plain/aaf014c77a4fb19bdc33370f5b6af5b8497decf8..63621a81d16ab743de6b57d47578a9a2c670ad22:/test/fakesmtp.c diff --git a/test/fakesmtp.c b/test/fakesmtp.c index 449fdec0..d48531de 100644 --- a/test/fakesmtp.c +++ b/test/fakesmtp.c @@ -41,6 +41,7 @@ main(int argc, char *argv[]) int rc, conn, smtp_state; FILE *f; const char *xoauth = getenv("XOAUTH"); + const char *smtputf8 = getenv("SMTPUTF8"); if (argc != 3) { fprintf(stderr, "Usage: %s output-filename port\n", argv[0]); @@ -70,7 +71,8 @@ main(int argc, char *argv[]) if (rc == -1) break; /* EOF */ - fprintf(f, "%s\n", line); + fputs(line, f); + putc('\n', f); switch (smtp_state) { case SMTP_DATA: @@ -101,17 +103,20 @@ main(int argc, char *argv[]) smtp_state = SMTP_DATA; continue; } - if (xoauth == NULL) { + if (strncmp(line, "EHLO", 4) == 0) { putcrlf(conn, "250-ready"); - putcrlf(conn, "250-8BITMIME"); - putcrlf(conn, "250-SMTPUTF8"); - } else { - /* XOAUTH2 support enabled; handle EHLO and AUTH. */ - if (strncmp(line, "EHLO", 4) == 0) { - putcrlf(conn, "250-ready"); - putcrlf(conn, "250 AUTH XOAUTH2"); - continue; + if (smtputf8 != NULL) { + putcrlf(conn, "250-8BITMIME"); + putcrlf(conn, "250-SMTPUTF8"); + } + if (xoauth != NULL) { + putcrlf(conn, "250-AUTH XOAUTH2"); } + putcrlf(conn, "250 I'll buy that for a dollar!"); + continue; + } + if (xoauth != NULL) { + /* XOAUTH2 support enabled; handle AUTH (and EHLO above). */ if (strncmp(line, "AUTH", 4) == 0) { if (strncmp(line, "AUTH XOAUTH2", 12) == 0 && strstr(line, xoauth) != NULL) {