mirror of
https://github.com/asterisk/asterisk.git
synced 2025-09-03 11:25:35 +00:00
res_http_websocket: Avoid reading past end of string
We read beyond the end of the buffer when copying the string out of the buffer when we used ast_copy_string() because the original string was not null terminated. Instead switch to ast_strndup() which does not exhibit the same behavior. ASTERISK-28975 #close Change-Id: Ib4a75cffeb1eb8cf01136ef30306bd623e531a2a
This commit is contained in:
committed by
Joshua Colp
parent
5fbed5af24
commit
e4d24f5137
@@ -1473,11 +1473,10 @@ int AST_OPTIONAL_API_NAME(ast_websocket_read_string)
|
||||
}
|
||||
}
|
||||
|
||||
if (!(*buf = ast_malloc(payload_len + 1))) {
|
||||
if (!(*buf = ast_strndup(payload, payload_len))) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
ast_copy_string(*buf, payload, payload_len + 1);
|
||||
return payload_len + 1;
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user