]> git.ipfire.org Git - thirdparty/asterisk.git/commitdiff
Merged revisions 300216 via svnmerge from
authorTerry Wilson <twilson@digium.com>
Tue, 4 Jan 2011 17:37:26 +0000 (17:37 +0000)
committerTerry Wilson <twilson@digium.com>
Tue, 4 Jan 2011 17:37:26 +0000 (17:37 +0000)
https://origsvn.digium.com/svn/asterisk/branches/1.4

........
  r300216 | twilson | 2011-01-04 11:11:48 -0600 (Tue, 04 Jan 2011) | 15 lines

  Don't authenticate SUBSCRIBE re-transmissions

  This only skips authentication on retransmissions that are already
  authenticated. A similar method is already used for INVITES. This
  is the kind of thing we end up having to do when we don't have a
  transaction layer...

  (closes issue #18075)
  Reported by: mdu113
  Patches:
        diff.txt uploaded by twilson (license 396)
  Tested by: twilson, mdu113

  Review: https://reviewboard.asterisk.org/r/1005/
........

git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.6.2@300298 65c4cc65-6c06-0410-ace0-fbb531ad65f3

channels/chan_sip.c

index 880443c0d57d64b59f2a37e217ae84bb78998b90..5636db78af56cdfeb9e86403054655a6e4d33338 100644 (file)
@@ -21445,7 +21445,7 @@ static int handle_request_subscribe(struct sip_pvt *p, struct sip_request *req,
        int firststate = AST_EXTENSION_REMOVED;
        struct sip_peer *authpeer = NULL;
        const char *eventheader = get_header(req, "Event");     /* Get Event package name */
-       int resubscribe = (p->subscribed != NONE);
+       int resubscribe = (p->subscribed != NONE) && !req->ignore;
        char *temp, *event;
 
        if (p->initreq.headers) {       
@@ -21461,7 +21461,7 @@ static int handle_request_subscribe(struct sip_pvt *p, struct sip_request *req,
                        if (resubscribe)
                                ast_debug(1, "Got a re-subscribe on existing subscription %s\n", p->callid);
                        else
-                               ast_debug(1, "Got a new subscription %s (possibly with auth)\n", p->callid);
+                               ast_debug(1, "Got a new subscription %s (possibly with auth) or retransmission\n", p->callid);
                }
        }
 
@@ -21515,19 +21515,25 @@ static int handle_request_subscribe(struct sip_pvt *p, struct sip_request *req,
        } else
                event = (char *) eventheader;           /* XXX is this legal ? */
 
-       /* Handle authentication */
-       res = check_user_full(p, req, SIP_SUBSCRIBE, e, 0, sin, &authpeer);
-       /* if an authentication response was sent, we are done here */
-       if (res == AUTH_CHALLENGE_SENT) /* authpeer = NULL here */
-               return 0;
-       if (res < 0) {
-               if (res == AUTH_FAKE_AUTH) {
-                       ast_log(LOG_NOTICE, "Sending fake auth rejection for device %s\n", get_header(req, "From"));
-                       transmit_fake_auth_response(p, SIP_SUBSCRIBE, req, XMIT_UNRELIABLE);
-               } else {
-                       ast_log(LOG_NOTICE, "Failed to authenticate device %s for SUBSCRIBE\n", get_header(req, "From"));
-                       transmit_response_reliable(p, "403 Forbidden", req);
+       /* Handle authentication if we're new and not a retransmission. We can't just
+        * use if !req->ignore, because then we'll end up sending
+        * a 200 OK if someone retransmits without sending auth */
+       if (p->subscribed == NONE || resubscribe) {
+               res = check_user_full(p, req, SIP_SUBSCRIBE, e, 0, sin, &authpeer);
+
+               /* if an authentication response was sent, we are done here */
+               if (res == AUTH_CHALLENGE_SENT) /* authpeer = NULL here */
+                       return 0;
+               if (res < 0) {
+                       if (res == AUTH_FAKE_AUTH) {
+                               ast_log(LOG_NOTICE, "Sending fake auth rejection for device %s\n", get_header(req, "From"));
+                               transmit_fake_auth_response(p, SIP_SUBSCRIBE, req, XMIT_UNRELIABLE);
+                       } else {
+                               ast_log(LOG_NOTICE, "Failed to authenticate device %s for SUBSCRIBE\n", get_header(req, "From"));
+                               transmit_response_reliable(p, "403 Forbidden", req);
+                       }
                }
+
                pvt_set_needdestroy(p, "authentication failed");
                return 0;
        }