summaryrefslogtreecommitdiff
path: root/usr.sbin
diff options
context:
space:
mode:
Diffstat (limited to 'usr.sbin')
-rw-r--r--usr.sbin/smtpd/smtp_session.c144
1 files changed, 72 insertions, 72 deletions
diff --git a/usr.sbin/smtpd/smtp_session.c b/usr.sbin/smtpd/smtp_session.c
index 2d2b951a974..53329edd48d 100644
--- a/usr.sbin/smtpd/smtp_session.c
+++ b/usr.sbin/smtpd/smtp_session.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: smtp_session.c,v 1.321 2018/04/28 08:49:13 eric Exp $ */
+/* $OpenBSD: smtp_session.c,v 1.322 2018/04/28 08:58:36 eric Exp $ */
/*
* Copyright (c) 2008 Gilles Chehade <gilles@poolp.org>
@@ -1102,77 +1102,6 @@ smtp_io(struct io *io, int evt, void *arg)
}
}
-static int
-smtp_tx(struct smtp_session *s)
-{
- struct smtp_tx *tx;
-
- tx = calloc(1, sizeof(*tx));
- if (tx == NULL)
- return 0;
-
- TAILQ_INIT(&tx->rcpts);
-
- s->tx = tx;
- tx->session = s;
-
- /* setup the envelope */
- s->tx->evp.ss = s->ss;
- (void)strlcpy(s->tx->evp.tag, s->listener->tag, sizeof(s->tx->evp.tag));
- (void)strlcpy(s->tx->evp.smtpname, s->smtpname, sizeof(s->tx->evp.smtpname));
- (void)strlcpy(s->tx->evp.hostname, s->hostname, sizeof s->tx->evp.hostname);
- (void)strlcpy(s->tx->evp.helo, s->helo, sizeof s->tx->evp.helo);
-
- if (s->flags & SF_BOUNCE)
- s->tx->evp.flags |= EF_BOUNCE;
- if (s->flags & SF_AUTHENTICATED)
- s->tx->evp.flags |= EF_AUTHENTICATED;
-
- /* Setup parser and callbacks */
- rfc2822_parser_init(&tx->rfc2822_parser);
- rfc2822_header_default_callback(&tx->rfc2822_parser,
- header_default_callback, s);
- rfc2822_header_callback(&tx->rfc2822_parser, "bcc",
- header_bcc_callback, s);
- rfc2822_header_callback(&tx->rfc2822_parser, "from",
- header_domain_append_callback, s);
- rfc2822_header_callback(&tx->rfc2822_parser, "to",
- header_domain_append_callback, s);
- rfc2822_header_callback(&tx->rfc2822_parser, "cc",
- header_domain_append_callback, s);
- rfc2822_body_callback(&tx->rfc2822_parser,
- dataline_callback, s);
-
- if (s->listener->local || s->listener->port == htons(587)) {
- rfc2822_missing_header_callback(&tx->rfc2822_parser, "date",
- header_missing_callback, s);
- rfc2822_missing_header_callback(&tx->rfc2822_parser, "message-id",
- header_missing_callback, s);
- }
-
- return 1;
-}
-
-static void
-smtp_tx_free(struct smtp_tx *tx)
-{
- struct smtp_rcpt *rcpt;
-
- rfc2822_parser_release(&tx->rfc2822_parser);
-
- while ((rcpt = TAILQ_FIRST(&tx->rcpts))) {
- TAILQ_REMOVE(&tx->rcpts, rcpt, entry);
- free(rcpt);
- }
-
- if (tx->ofile)
- fclose(tx->ofile);
-
- tx->session->tx = NULL;
-
- free(tx);
-}
-
static void
smtp_command(struct smtp_session *s, char *line)
{
@@ -2171,6 +2100,77 @@ smtp_auth_failure_pause(struct smtp_session *s)
evtimer_add(&s->pause, &tv);
}
+static int
+smtp_tx(struct smtp_session *s)
+{
+ struct smtp_tx *tx;
+
+ tx = calloc(1, sizeof(*tx));
+ if (tx == NULL)
+ return 0;
+
+ TAILQ_INIT(&tx->rcpts);
+
+ s->tx = tx;
+ tx->session = s;
+
+ /* setup the envelope */
+ s->tx->evp.ss = s->ss;
+ (void)strlcpy(s->tx->evp.tag, s->listener->tag, sizeof(s->tx->evp.tag));
+ (void)strlcpy(s->tx->evp.smtpname, s->smtpname, sizeof(s->tx->evp.smtpname));
+ (void)strlcpy(s->tx->evp.hostname, s->hostname, sizeof s->tx->evp.hostname);
+ (void)strlcpy(s->tx->evp.helo, s->helo, sizeof s->tx->evp.helo);
+
+ if (s->flags & SF_BOUNCE)
+ s->tx->evp.flags |= EF_BOUNCE;
+ if (s->flags & SF_AUTHENTICATED)
+ s->tx->evp.flags |= EF_AUTHENTICATED;
+
+ /* Setup parser and callbacks */
+ rfc2822_parser_init(&tx->rfc2822_parser);
+ rfc2822_header_default_callback(&tx->rfc2822_parser,
+ header_default_callback, s);
+ rfc2822_header_callback(&tx->rfc2822_parser, "bcc",
+ header_bcc_callback, s);
+ rfc2822_header_callback(&tx->rfc2822_parser, "from",
+ header_domain_append_callback, s);
+ rfc2822_header_callback(&tx->rfc2822_parser, "to",
+ header_domain_append_callback, s);
+ rfc2822_header_callback(&tx->rfc2822_parser, "cc",
+ header_domain_append_callback, s);
+ rfc2822_body_callback(&tx->rfc2822_parser,
+ dataline_callback, s);
+
+ if (s->listener->local || s->listener->port == htons(587)) {
+ rfc2822_missing_header_callback(&tx->rfc2822_parser, "date",
+ header_missing_callback, s);
+ rfc2822_missing_header_callback(&tx->rfc2822_parser, "message-id",
+ header_missing_callback, s);
+ }
+
+ return 1;
+}
+
+static void
+smtp_tx_free(struct smtp_tx *tx)
+{
+ struct smtp_rcpt *rcpt;
+
+ rfc2822_parser_release(&tx->rfc2822_parser);
+
+ while ((rcpt = TAILQ_FIRST(&tx->rcpts))) {
+ TAILQ_REMOVE(&tx->rcpts, rcpt, entry);
+ free(rcpt);
+ }
+
+ if (tx->ofile)
+ fclose(tx->ofile);
+
+ tx->session->tx = NULL;
+
+ free(tx);
+}
+
static void
smtp_tx_create_message(struct smtp_tx *tx)
{