mirror of
https://github.com/asterisk/asterisk.git
synced 2025-09-03 11:25:35 +00:00
Merge "res_pjsip_session: Reinvite using active stream topology if none requested."
This commit is contained in:
@@ -3878,10 +3878,15 @@ static struct pjmedia_sdp_session *create_local_sdp(pjsip_inv_session *inv, stru
|
||||
|
||||
if (!session->pending_media_state->topology || !ast_stream_topology_get_count(session->pending_media_state->topology)) {
|
||||
/* We've encountered a situation where we have been told to create a local SDP but noone has given us any indication
|
||||
* of what kind of stream topology they would like. As a fallback we use the topology from the configured endpoint.
|
||||
* of what kind of stream topology they would like. We try to not alter the current state of the SDP negotiation
|
||||
* by using what is currently negotiated. If this is unavailable we fall back to what is configured on the endpoint.
|
||||
*/
|
||||
ast_stream_topology_free(session->pending_media_state->topology);
|
||||
session->pending_media_state->topology = ast_stream_topology_clone(session->endpoint->media.topology);
|
||||
if (session->active_media_state->topology) {
|
||||
session->pending_media_state->topology = ast_stream_topology_clone(session->active_media_state->topology);
|
||||
} else {
|
||||
session->pending_media_state->topology = ast_stream_topology_clone(session->endpoint->media.topology);
|
||||
}
|
||||
if (!session->pending_media_state->topology) {
|
||||
return NULL;
|
||||
}
|
||||
|
Reference in New Issue
Block a user