mirror of
https://github.com/asterisk/asterisk.git
synced 2025-11-17 15:29:05 +00:00
fix continuation line parsing (bug #2892)
git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/v1-0@4291 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
@@ -2556,33 +2556,32 @@ static int lws2sws(char *msgbuf, int len)
|
||||
}
|
||||
/* Check for end-of-line */
|
||||
if (msgbuf[h] == '\n') {
|
||||
/* Check for end-of-message */
|
||||
/* Check for end-of-message */
|
||||
if (h + 1 == len)
|
||||
break;
|
||||
/* Check for a continuation line */
|
||||
if (msgbuf[h + 1] == ' ') {
|
||||
/* Merge continuation line */
|
||||
h++;
|
||||
break;
|
||||
/* Check for a continuation line */
|
||||
if (msgbuf[h + 1] == ' ' || msgbuf[h + 1] == '\t') {
|
||||
/* Merge continuation line */
|
||||
h++;
|
||||
continue;
|
||||
}
|
||||
/* Propagate LF and start new line */
|
||||
msgbuf[t++] = msgbuf[h++];
|
||||
lws = 0;
|
||||
continue;
|
||||
}
|
||||
/* Propagate LF and start new line */
|
||||
msgbuf[t++] = msgbuf[h++];
|
||||
lws = 0;
|
||||
continue;
|
||||
}
|
||||
|
||||
if (msgbuf[h] == ' ' || msgbuf[h] == '\t') {
|
||||
if (lws) {
|
||||
h++;
|
||||
if (msgbuf[h] == ' ' || msgbuf[h] == '\t') {
|
||||
if (lws) {
|
||||
h++;
|
||||
continue;
|
||||
}
|
||||
msgbuf[t++] = msgbuf[h++];
|
||||
lws = 1;
|
||||
continue;
|
||||
}
|
||||
msgbuf[t++] = msgbuf[h++];
|
||||
lws = 1;
|
||||
continue;
|
||||
}
|
||||
msgbuf[t++] = msgbuf[h++];
|
||||
if (lws)
|
||||
lws = 0;
|
||||
if (lws)
|
||||
lws = 0;
|
||||
}
|
||||
msgbuf[t] = '\0';
|
||||
return t;
|
||||
@@ -7656,8 +7655,7 @@ static int sipsock_read(int *id, int fd, short events, void *ignore)
|
||||
debug = sip_debug_test_addr(&sin);
|
||||
if (debug)
|
||||
ast_verbose("\n\nSip read: \n%s\n", req.data);
|
||||
if (pedanticsipchecking)
|
||||
req.len = lws2sws(req.data, req.len);
|
||||
req.len = lws2sws(req.data, req.len);
|
||||
parse(&req);
|
||||
if (debug)
|
||||
ast_verbose("%d headers, %d lines\n", req.headers, req.lines);
|
||||
|
||||
Reference in New Issue
Block a user