Changeset 3000


Ignore:
Timestamp:
Nov 9, 2009 1:40:26 PM (14 years ago)
Author:
nanang
Message:

Ticket #957: Fixed 0.0.0.0:0 address returned by SIP TLS client transport, which would cause 0.0.0.0:0 address in SIP via header.

Location:
pjproject/trunk
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • pjproject/trunk/pjlib/src/pj/ssl_sock_ossl.c

    r2998 r3000  
    20902090    status = pj_sock_getsockname(ssock->sock, &ssock->local_addr, 
    20912091                                 &ssock->addr_len); 
    2092     if (status != PJ_SUCCESS) 
    2093         pj_sockaddr_cp(&ssock->local_addr, localaddr); 
     2092    /* Note that we may not get an IP address here. This can 
     2093     * happen for example on Windows, where getsockname() 
     2094     * would return 0.0.0.0 if socket has just started the 
     2095     * async connect. In this case, just leave the local 
     2096     * address with 0.0.0.0 for now; it will be updated 
     2097     * once the socket is established. 
     2098     */ 
    20942099 
    20952100    /* Set remote address */ 
  • pjproject/trunk/pjsip/src/pjsip/sip_transport_tls.c

    r2998 r3000  
    528528 
    529529    tls->base.addr_len = sizeof(pj_sockaddr_in); 
    530     pj_memcpy(&tls->base.local_addr, local, sizeof(pj_sockaddr_in)); 
    531     sockaddr_to_host_port(pool, &tls->base.local_name, local); 
     530     
     531    /* Set initial local address */ 
     532    if (!pj_sockaddr_has_addr(local)) { 
     533        pj_sockaddr_cp(&tls->base.local_addr, 
     534                       &listener->factory.local_addr); 
     535    } else { 
     536        pj_sockaddr_cp(&tls->base.local_addr, local); 
     537    } 
     538     
     539    sockaddr_to_host_port(pool, &tls->base.local_name,  
     540                          (pj_sockaddr_in*)&tls->base.local_addr); 
    532541    sockaddr_to_host_port(pool, &tls->base.remote_name, remote); 
    533542 
     
    857866        pj_ssl_sock_info info; 
    858867 
    859         /* Update (again) local address, just in case local address currently 
    860          * set is different now that asynchronous connect() is started. 
     868        /* Update local address, just in case local address currently set is  
     869         * different now that asynchronous connect() is started. 
    861870         */ 
    862871 
     
    864873        status = pj_ssl_sock_get_info(tls->ssock, &info); 
    865874        if (status == PJ_SUCCESS) { 
    866             pj_sockaddr_in *tp_addr = (pj_sockaddr_in*)&tls->base.local_addr; 
    867  
    868             pj_assert(pj_sockaddr_get_len((pj_sockaddr_t*)&info.local_addr) <=  
    869                       sizeof(local_addr)); 
    870             pj_sockaddr_cp((pj_sockaddr_t*)&local_addr, (pj_sockaddr_t*)&info.local_addr); 
    871  
    872             /* Some systems (like old Win32 perhaps) may not set local address 
    873              * properly before socket is fully connected. 
    874              */ 
    875             if (tp_addr->sin_addr.s_addr != local_addr.sin_addr.s_addr && 
    876                 local_addr.sin_addr.s_addr != 0)  
     875            pj_uint16_t new_port; 
     876 
     877            new_port = pj_sockaddr_get_port((pj_sockaddr_t*)&info.local_addr); 
     878 
     879            if (pj_sockaddr_has_addr((pj_sockaddr_t*)&info.local_addr)) { 
     880                /* Update sockaddr */ 
     881                pj_sockaddr_cp((pj_sockaddr_t*)&tls->base.local_addr, 
     882                               (pj_sockaddr_t*)&info.local_addr); 
     883            } else if (new_port && new_port != pj_sockaddr_get_port( 
     884                                        (pj_sockaddr_t*)&tls->base.local_addr)) 
    877885            { 
    878                 tp_addr->sin_addr.s_addr = local_addr.sin_addr.s_addr; 
    879                 tp_addr->sin_port = local_addr.sin_port; 
    880                 sockaddr_to_host_port(tls->base.pool, &tls->base.local_name, 
    881                                       &local_addr); 
     886                /* Update port only */ 
     887                pj_sockaddr_set_port((pj_sockaddr_t*)&tls->base.local_addr,  
     888                                     new_port); 
    882889            } 
     890 
     891            sockaddr_to_host_port(tls->base.pool, &tls->base.local_name, 
     892                                  (pj_sockaddr_in*)&tls->base.local_addr); 
    883893        } 
    884          
     894 
    885895        PJ_LOG(4,(tls->base.obj_name,  
    886896                  "TLS transport %.*s:%d is connecting to %.*s:%d...", 
Note: See TracChangeset for help on using the changeset viewer.