]> git.ipfire.org Git - thirdparty/asterisk.git/commitdiff
Do not swallow frames on channels leaving bridges. 07/1307/1
authorMark Michelson <mmichelson@digium.com>
Thu, 24 Sep 2015 19:49:46 +0000 (14:49 -0500)
committerMark Michelson <mmichelson@digium.com>
Thu, 24 Sep 2015 20:00:18 +0000 (15:00 -0500)
When leaving a bridge, indications on a channel could be swallowed by
the internal indication logic because it appears that the channel is on
its way to be hung up anyway. One such situation where this is
detrimental is when channels on hold are redirected out of a bridge. The
AST_CONTROL_UNHOLD indication from the bridging code is swallowed,
leaving the channel in question to still appear to be on hold.

The fix here is to modify the logic inside ast_indicate_data() to not
drop the indication if the channel is simply leaving a bridge. This way,
channels on hold redirected out of a bridge revert to their expected "in
use" state after the redirection.

ASTERISK-25418 #close
Reported by Mark Michelson

Change-Id: If6115204dfa0551c050974ee138fabd15f978949

main/channel.c

index 8be7aab3616249fcde02cebcabf0410bc595be36..d84bf7236a023517425a39956ca7e2d6718e4678 100644 (file)
@@ -4435,7 +4435,7 @@ int ast_indicate_data(struct ast_channel *chan, int _condition,
 
        /* Don't bother if the channel is about to go away, anyway. */
        if ((ast_test_flag(ast_channel_flags(chan), AST_FLAG_ZOMBIE)
-                       || ast_check_hangup(chan))
+                       || (ast_check_hangup(chan) && !ast_channel_is_leaving_bridge(chan)))
                && condition != AST_CONTROL_MASQUERADE_NOTIFY) {
                res = -1;
                goto indicate_cleanup;