From: Automerge Script Date: Fri, 18 May 2007 16:24:42 +0000 (+0000) Subject: automerge commit X-Git-Tag: 1.2.19-netsec~40 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=133c75b2c708edf4d6e17ed214065828ff0eb6e0;p=thirdparty%2Fasterisk.git automerge commit git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.2-netsec@65120 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- diff --git a/channels/chan_sip.c b/channels/chan_sip.c index 308b02edee..8188168a8c 100644 --- a/channels/chan_sip.c +++ b/channels/chan_sip.c @@ -9969,10 +9969,15 @@ static void handle_response_invite(struct sip_pvt *p, int resp, char *rest, stru This transaction is already scheduled to be killed by sip_hangup(). */ transmit_request(p, SIP_ACK, seqno, 0, 0); - if (p->owner && !ignore) + if (p->owner && !ignore) { ast_queue_hangup(p->owner); - else if (!ignore) + append_history(p, "Hangup", "Got 487 on CANCEL request from us. Queued AST hangup request"); + } else if (!ignore) { update_call_counter(p, DEC_CALL_LIMIT); + append_history(p, "Hangup", "Got 487 on CANCEL request from us on call without owner. Killing this dialog."); + ast_set_flag(p, SIP_NEEDDESTROY); + ast_set_flag(p, SIP_ALREADYGONE); + } break; case 491: /* Pending */ /* we have to wait a while, then retransmit */