]> git.ipfire.org Git - thirdparty/asterisk.git/commitdiff
This patch resolves 10143; thanks to irroot for the patch; looked acceptable. Let...
authorSteve Murphy <murf@digium.com>
Thu, 12 Jul 2007 20:42:08 +0000 (20:42 +0000)
committerSteve Murphy <murf@digium.com>
Thu, 12 Jul 2007 20:42:08 +0000 (20:42 +0000)
git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.4@74955 65c4cc65-6c06-0410-ace0-fbb531ad65f3

channels/chan_sip.c

index f0a0c047c3b0736c465502e222b93c4a1865812b..8523888cf6cfcf312978bd52ffcb493ae1802890 100644 (file)
@@ -13201,7 +13201,8 @@ static int handle_invite_replaces(struct sip_pvt *p, struct sip_request *req, in
        ast_mutex_unlock(&p->refer->refer_call->lock);
 
        /* Make sure that the masq does not free our PVT for the old call */
-       ast_set_flag(&p->refer->refer_call->flags[0], SIP_DEFER_BYE_ON_TRANSFER);       /* Delay hangup */
+       if (! earlyreplace && ! oneleggedreplace )
+               ast_set_flag(&p->refer->refer_call->flags[0], SIP_DEFER_BYE_ON_TRANSFER);       /* Delay hangup */
                
        /* Prepare the masquerade - if this does not happen, we will be gone */
        if(ast_channel_masquerade(replacecall, c))
@@ -13418,7 +13419,7 @@ static int handle_request_invite(struct sip_pvt *p, struct sip_request *req, int
                        error = 1;
                }
 
-               if (!error && p->refer->refer_call->owner->_state != AST_STATE_RING && p->refer->refer_call->owner->_state != AST_STATE_UP ) {
+               if (!error && p->refer->refer_call->owner->_state != AST_STATE_RINGING && p->refer->refer_call->owner->_state != AST_STATE_RING && p->refer->refer_call->owner->_state != AST_STATE_UP ) {
                        ast_log(LOG_NOTICE, "Supervised transfer attempted to replace non-ringing or active call id (%s)!\n", replace_id);
                        transmit_response(p, "603 Declined (Replaces)", req);
                        error = 1;