mirror of
https://github.com/asterisk/asterisk.git
synced 2025-10-26 14:27:14 +00:00
pjsip: restrict function PJSIP_PARSE_URI to parse only SIP/SIPS URIs
The next usage of PJSIP_PARSE_URI will crash asterisk
${PJSIP_PARSE_URI(tel:+1234567890,host)}
or
${PJSIP_PARSE_URI(192.168.1.1:5060,host)}
The function pjsip_parse_uri successfully parses then, but returns
struct pjsip_other_uri *.
This patch restricts parsing only SIP/SIPS URIs.
Change-Id: I16f255c2b86a80a67e9f9604b94b129a381dd25e
This commit is contained in:
@@ -1124,7 +1124,7 @@ static int parse_uri_cb(void *data)
|
|||||||
|
|
||||||
pj_strdup2_with_null(pool, &tmp, args->uri);
|
pj_strdup2_with_null(pool, &tmp, args->uri);
|
||||||
uri = (pjsip_name_addr *)pjsip_parse_uri(pool, tmp.ptr, tmp.slen, PJSIP_PARSE_URI_AS_NAMEADDR);
|
uri = (pjsip_name_addr *)pjsip_parse_uri(pool, tmp.ptr, tmp.slen, PJSIP_PARSE_URI_AS_NAMEADDR);
|
||||||
if (!uri) {
|
if (!uri || (!PJSIP_URI_SCHEME_IS_SIP(uri) && !PJSIP_URI_SCHEME_IS_SIPS(uri))) {
|
||||||
ast_log(LOG_WARNING, "Failed to parse URI '%s'\n", args->uri);
|
ast_log(LOG_WARNING, "Failed to parse URI '%s'\n", args->uri);
|
||||||
pjsip_endpt_release_pool(ast_sip_get_pjsip_endpoint(), pool);
|
pjsip_endpt_release_pool(ast_sip_get_pjsip_endpoint(), pool);
|
||||||
args->ret = -1;
|
args->ret = -1;
|
||||||
|
|||||||
Reference in New Issue
Block a user