mirror of
https://github.com/asterisk/asterisk.git
synced 2025-10-15 08:44:14 +00:00
Add white space condensing to pedantic mode of chan_sip.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@2789 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
@@ -1983,12 +1983,56 @@ static int sip_register(char *value, int lineno)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int lws2sws(char *msgbuf, int len)
|
||||||
|
{
|
||||||
|
int h = 0, t = 0;
|
||||||
|
int lws = 0;
|
||||||
|
|
||||||
|
for (; h < len;) {
|
||||||
|
/* Eliminate all CRs */
|
||||||
|
if (msgbuf[h] == '\r') {
|
||||||
|
h++;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
/* Check for end-of-line */
|
||||||
|
if (msgbuf[h] == '\n') {
|
||||||
|
/* Check for end-of-message */
|
||||||
|
if (h + 1 == len)
|
||||||
|
break;
|
||||||
|
/* Check for a continuation line */
|
||||||
|
if (msgbuf[h + 1] == ' ') {
|
||||||
|
/* Merge continuation line */
|
||||||
|
h++;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
/* Propagate LF and start new line */
|
||||||
|
msgbuf[t++] = msgbuf[h++];
|
||||||
|
lws = 0;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (msgbuf[h] == ' ' || msgbuf[h] == '\t') {
|
||||||
|
if (lws) {
|
||||||
|
h++;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
msgbuf[t++] = msgbuf[h++];
|
||||||
|
lws = 1;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
msgbuf[t++] = msgbuf[h++];
|
||||||
|
if (lws)
|
||||||
|
lws = 0;
|
||||||
|
}
|
||||||
|
msgbuf[t] = '\0';
|
||||||
|
return t;
|
||||||
|
}
|
||||||
|
|
||||||
static void parse(struct sip_request *req)
|
static void parse(struct sip_request *req)
|
||||||
{
|
{
|
||||||
/* Divide fields by NULL's */
|
/* Divide fields by NULL's */
|
||||||
char *c;
|
char *c;
|
||||||
int f = 0;
|
int f = 0;
|
||||||
int lastr = 0;
|
|
||||||
c = req->data;
|
c = req->data;
|
||||||
|
|
||||||
/* First header starts immediately */
|
/* First header starts immediately */
|
||||||
@@ -2008,25 +2052,13 @@ static void parse(struct sip_request *req)
|
|||||||
}
|
}
|
||||||
if (f >= SIP_MAX_HEADERS - 1) {
|
if (f >= SIP_MAX_HEADERS - 1) {
|
||||||
ast_log(LOG_WARNING, "Too many SIP headers...\n");
|
ast_log(LOG_WARNING, "Too many SIP headers...\n");
|
||||||
} else {
|
} else
|
||||||
if ((c[1] == ' ') || (c[1] == '\t')) {
|
f++;
|
||||||
/* Continuation of previous header */
|
req->header[f] = c + 1;
|
||||||
*c = ' ';
|
|
||||||
if (lastr) {
|
|
||||||
*(c-1) = ' ';
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
f++;
|
|
||||||
req->header[f] = c + 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
lastr = 0;
|
|
||||||
} else if (*c == '\r') {
|
} else if (*c == '\r') {
|
||||||
/* Ignore but eliminate \r's */
|
/* Ignore but eliminate \r's */
|
||||||
*c = 0;
|
*c = 0;
|
||||||
lastr = 1;
|
}
|
||||||
} else
|
|
||||||
lastr = 0;
|
|
||||||
c++;
|
c++;
|
||||||
}
|
}
|
||||||
/* Check for last header */
|
/* Check for last header */
|
||||||
@@ -5824,6 +5856,8 @@ static int sipsock_read(int *id, int fd, short events, void *ignore)
|
|||||||
req.len = res;
|
req.len = res;
|
||||||
if (sipdebug)
|
if (sipdebug)
|
||||||
ast_verbose("\n\nSip read: \n%s\n", req.data);
|
ast_verbose("\n\nSip read: \n%s\n", req.data);
|
||||||
|
if (pedanticsipchecking)
|
||||||
|
req.len = lws2sws(req.data, req.len);
|
||||||
parse(&req);
|
parse(&req);
|
||||||
if (req.headers < 2) {
|
if (req.headers < 2) {
|
||||||
/* Must have at least two headers */
|
/* Must have at least two headers */
|
||||||
|
@@ -27,6 +27,8 @@ context = default ; Default context for incoming calls
|
|||||||
;srvlookup = yes ; Enable DNS SRV lookups on outbound calls
|
;srvlookup = yes ; Enable DNS SRV lookups on outbound calls
|
||||||
; Asterisk only uses the first host in SRV records
|
; Asterisk only uses the first host in SRV records
|
||||||
;pedantic = yes ; Enable slow, pedantic checking for Pingtel
|
;pedantic = yes ; Enable slow, pedantic checking for Pingtel
|
||||||
|
; and multiline formatted headers for strict
|
||||||
|
; SIP compatibility
|
||||||
;tos=lowdelay ; IP QoS parameter, either keyword or value
|
;tos=lowdelay ; IP QoS parameter, either keyword or value
|
||||||
; like tos=184
|
; like tos=184
|
||||||
;maxexpirey=3600 ; Max length of incoming registration we allow
|
;maxexpirey=3600 ; Max length of incoming registration we allow
|
||||||
|
Reference in New Issue
Block a user