summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGilles Chehade <gilles@cvs.openbsd.org>2009-09-12 09:50:32 +0000
committerGilles Chehade <gilles@cvs.openbsd.org>2009-09-12 09:50:32 +0000
commitdd37f97a862be2eb3b277eedea80d6a4fd42719f (patch)
treed209d830192c4f3e011149c169d0c8e5c628aa4e
parent2c98bd94179faa79d880be3373e0ac0de7787d66 (diff)
fix a wrong computation in session_readline() where the length of line was
deduced from the buffer size prior and after evbuffer_readline() call. the problem is that this accounts for the characters which evbuffer_readline() removed and we do not know how many they were (\n, \r\n ..). fix just does a strlen() call of line which is a bit slower but way safer. This could very well fix the broken headers issue some people reported
-rw-r--r--usr.sbin/smtpd/smtp_session.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/usr.sbin/smtpd/smtp_session.c b/usr.sbin/smtpd/smtp_session.c
index 640e5162180..ac75eeace68 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.118 2009/09/12 09:38:45 gilles Exp $ */
+/* $OpenBSD: smtp_session.c,v 1.119 2009/09/12 09:50:31 gilles Exp $ */
/*
* Copyright (c) 2008 Gilles Chehade <gilles@openbsd.org>
@@ -1001,7 +1001,7 @@ session_readline(struct session *s, size_t *nr)
{
char *line, *line2;
- *nr = EVBUFFER_LENGTH(s->s_bev->input);
+ *nr = 0;
line = evbuffer_readline(s->s_bev->input);
if (line == NULL) {
if (EVBUFFER_LENGTH(s->s_bev->input) > SMTP_ANYLINE_MAX) {
@@ -1011,7 +1011,6 @@ session_readline(struct session *s, size_t *nr)
}
return NULL;
}
- *nr -= EVBUFFER_LENGTH(s->s_bev->input);
if (s->s_flags & F_WRITEONLY)
fatalx("session_readline: corrupt session");
@@ -1027,6 +1026,7 @@ session_readline(struct session *s, size_t *nr)
return NULL;
}
+ *nr = strlen(line);
return line;
}