mirror of
https://github.com/sheumann/hush.git
synced 2024-12-27 01:32:08 +00:00
sendmail: fix for long headers (by Vladimir)
Signed-off-by: Vladimir Dronnikov <dronnikov@gmail.com> Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
This commit is contained in:
parent
2ace0ad2d7
commit
8dbe9bba8e
@ -229,10 +229,15 @@ int sendmail_main(int argc UNUSED_PARAM, char **argv)
|
||||
rcptto(sane_address(s+5));
|
||||
free(s);
|
||||
// N.B. Bcc: vanishes from headers!
|
||||
|
||||
// other headers go verbatim
|
||||
// N.B. we allow MAX_HEADERS generic headers at most to prevent attacks
|
||||
} else if (strchr(s, ':')) {
|
||||
|
||||
// N.B. RFC2822 2.2.3 "Long Header Fields" allows for headers to occupy several lines.
|
||||
// Continuation is denoted by prefixing additional lines with whitespace(s).
|
||||
// Thanks (stefan.seyfried at googlemail.com) for pointing this out.
|
||||
} else if (strchr(s, ':') || (list && skip_whitespace(s) != s)) {
|
||||
addheader:
|
||||
// N.B. we allow MAX_HEADERS generic headers at most to prevent attacks
|
||||
if (MAX_HEADERS && ++nheaders >= MAX_HEADERS)
|
||||
goto bail;
|
||||
llist_add_to_end(&list, s);
|
||||
|
Loading…
Reference in New Issue
Block a user