Prevent buffer overflows in ast_uri_encode()

ABE-2705


git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.4@301305 65c4cc65-6c06-0410-ace0-fbb531ad65f3
1.4
Matthew Nicholson 15 years ago
parent 25181e5bdb
commit 08fcb05bc6

@ -388,28 +388,27 @@ char *ast_uri_encode(const char *string, char *outbuf, int buflen, int doreserve
char *reserved = ";/?:@&=+$,# "; /* Reserved chars */
const char *ptr = string; /* Start with the string */
char *out = NULL;
char *buf = NULL;
char *out = outbuf;
ast_copy_string(outbuf, string, buflen);
/* If there's no characters to convert, just go through and don't do anything */
while (*ptr) {
/* If there's no characters to convert, just go through and copy the string */
while (*ptr && out - outbuf < buflen - 1) {
if ((*ptr < 32) || (doreserved && strchr(reserved, *ptr))) {
/* Oops, we need to start working here */
if (!buf) {
buf = outbuf;
out = buf + (ptr - string) ; /* Set output ptr */
if (out - outbuf >= buflen - 3) {
break;
}
out += sprintf(out, "%%%02x", (unsigned char) *ptr);
} else if (buf) {
*out = *ptr; /* Continue copying the string */
} else {
*out = *ptr; /* copy the character */
out++;
}
}
ptr++;
}
if (buf)
if (buflen) {
*out = '\0';
}
return outbuf;
}

Loading…
Cancel
Save