mirror of
https://github.com/asterisk/asterisk.git
synced 2025-09-03 11:25:35 +00:00
chan_sip: Don't crash in Dial on invalid destination
Stripping the DNID in a SIP dial string can result in attempting to call the argument parsing macros on an empty string, causing a crash. ASTERISK-26131 #close Reported by: Dwayne Hubbard Patches: dw-asterisk-master-dnid-crash.patch (license #6257) patch uploaded by Dwayne Hubbard Change-Id: Ib84c1f740a9ec0539d582b09d847fc85ddca1c5e
This commit is contained in:
@@ -30465,6 +30465,17 @@ static struct ast_channel *sip_request_call(const char *type, struct ast_format_
|
||||
ast_string_field_set(p, todnid, dnid);
|
||||
}
|
||||
|
||||
/* If stripping the DNID left us with nothing, bail out */
|
||||
if (ast_strlen_zero(tmp)) {
|
||||
dialog_unlink_all(p);
|
||||
dialog_unref(p, "unref dialog p from bad destination");
|
||||
*cause = AST_CAUSE_DESTINATION_OUT_OF_ORDER;
|
||||
if (callid) {
|
||||
ast_callid_unref(callid);
|
||||
}
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Divvy up the items separated by slashes */
|
||||
AST_NONSTANDARD_APP_ARGS(args, tmp, '/');
|
||||
|
||||
|
Reference in New Issue
Block a user