From: Russell Bryant Date: Tue, 5 Apr 2005 10:08:53 +0000 (+0000) Subject: Clear out received tag in 407/401's (bug #3885) X-Git-Tag: 1.0.11.1~160 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=8b6aa2741c3eb8e65cb61dad2676af7b787edb1d;p=thirdparty%2Fasterisk.git Clear out received tag in 407/401's (bug #3885) git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/v1-0@5404 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- diff --git a/CHANGES b/CHANGES index 38fbdf3584..7f1f9725b6 100755 --- a/CHANGES +++ b/CHANGES @@ -12,6 +12,8 @@ -- We no longer send a "to" tag on "100 Trying" messages, as it is inappropriate to do so. -- We now respond correctly to an invite for T.38 with a "488 Not acceptable here" + -- We now discard saved tags on 401/407 responses in case the provider we're talking + to tries to pull a dirty trick on us and change it. -- chan_mgcp -- Fixed setting of accountcode -- Fixed where *67 to block callerid only worked for first call diff --git a/channels/chan_sip.c b/channels/chan_sip.c index 37fe16e37f..f24d29c4b4 100755 --- a/channels/chan_sip.c +++ b/channels/chan_sip.c @@ -6821,6 +6821,7 @@ static void handle_response(struct sip_pvt *p, int resp, char *rest, struct sip_ /* First we ACK */ transmit_request(p, "ACK", seqno, 0, 0); /* Then we AUTH */ + p->theirtag[0]='\0'; /* forget their old tag, so we don't match tags when getting response */ if ((p->authtries > 1) || do_proxy_auth(p, req, "WWW-Authenticate", "Authorization", "INVITE", 1)) { ast_log(LOG_NOTICE, "Failed to authenticate on INVITE to '%s'\n", get_header(&p->initreq, "From")); p->needdestroy = 1; @@ -6855,6 +6856,7 @@ static void handle_response(struct sip_pvt *p, int resp, char *rest, struct sip_ /* Then we AUTH */ /* But only if the packet wasn't marked as ignore in handle_request */ if(!ignore){ + p->theirtag[0]='\0'; /* forget their old tag, so we don't match tags when getting response */ if ((p->authtries > 1) || do_proxy_auth(p, req, "Proxy-Authenticate", "Proxy-Authorization", "INVITE", 1)) { ast_log(LOG_NOTICE, "Failed to authenticate on INVITE to '%s'\n", get_header(&p->initreq, "From")); p->needdestroy = 1;