]> git.ipfire.org Git - thirdparty/asterisk.git/commitdiff
Fix a bug with switching between host=dynamic and using specific hosts for
authorRussell Bryant <russell@russellbryant.com>
Wed, 11 Apr 2007 15:05:36 +0000 (15:05 +0000)
committerRussell Bryant <russell@russellbryant.com>
Wed, 11 Apr 2007 15:05:36 +0000 (15:05 +0000)
peers.  The code would only reset the peer's address when it is dynamic if
it was a new peer structure.  Now, it will also reset the address if it was
already in the peer list, but before the reload, it was not dynamic.
(issue #9515, reported by caio1982, fixed by me)

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

channels/chan_sip.c

index 448dc00c63e6cb8df5c4cacdabb3a60e9463e4d1..db2e4b700fbcae2e082a9807b1bf6644d8e75117 100644 (file)
@@ -12415,7 +12415,7 @@ static struct sip_peer *build_peer(const char *name, struct ast_variable *v, int
 
        if (peer) {
                /* Already in the list, remove it and it will be added back (or FREE'd)  */
-               found++;
+               found = 1;
        } else {
                peer = malloc(sizeof(*peer));
                if (peer) {
@@ -12514,10 +12514,9 @@ static struct sip_peer *build_peer(const char *name, struct ast_variable *v, int
                                        ast_log(LOG_WARNING, "You can't have a dynamic outbound proxy, you big silly head at line %d.\n", v->lineno);
                                } else {
                                        /* They'll register with us */
-                                       ast_set_flag(&peer->flags_page2, SIP_PAGE2_DYNAMIC);
-                                       if (!found) {
-                                               /* Initialize stuff iff we're not found, otherwise
-                                                  we keep going with what we had */
+                                       if (!found || !ast_test_flag(&peer->flags_page2, SIP_PAGE2_DYNAMIC)) {
+                                               /* Initialize stuff if this is a new peer, or if it used to be
+                                                * non-dynamic before the reload. */
                                                memset(&peer->addr.sin_addr, 0, 4);
                                                if (peer->addr.sin_port) {
                                                        /* If we've already got a port, make it the default rather than absolute */
@@ -12525,6 +12524,7 @@ static struct sip_peer *build_peer(const char *name, struct ast_variable *v, int
                                                        peer->addr.sin_port = 0;
                                                }
                                        }
+                                       ast_set_flag(&peer->flags_page2, SIP_PAGE2_DYNAMIC);
                                }
                        } else {
                                /* Non-dynamic.  Make sure we become that way if we're not */