Changeset 5963


Ignore:
Timestamp:
Apr 8, 2019 1:18:17 AM (6 years ago)
Author:
riza
Message:

Misc (re #2147): Enable to change SIP outbound instance id when modifying account.
Thanks to Jure Erznožnik for the report.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • pjproject/trunk/pjsip/src/pjsua-lib/pjsua_acc.c

    r5946 r5963  
    164164 
    165165/* 
     166 * Initialize outbound settings. 
     167 */ 
     168static void init_outbound_setting(pjsua_acc *acc) 
     169{ 
     170    pjsua_acc_config *acc_cfg = &acc->cfg; 
     171    if (acc_cfg->rfc5626_instance_id.slen == 0) { 
     172        const pj_str_t *hostname; 
     173        pj_uint32_t hval; 
     174        pj_size_t pos; 
     175        char instprm[] = ";+sip.instance=\"<urn:uuid:00000000-0000-0000-0000-0000CCDDEEFF>\""; 
     176 
     177        hostname = pj_gethostname(); 
     178        pos = pj_ansi_strlen(instprm) - 10; 
     179        hval = pj_hash_calc(0, hostname->ptr, (unsigned)hostname->slen); 
     180        pj_val_to_hex_digit(((char*)&hval)[0], instprm + pos + 0); 
     181        pj_val_to_hex_digit(((char*)&hval)[1], instprm + pos + 2); 
     182        pj_val_to_hex_digit(((char*)&hval)[2], instprm + pos + 4); 
     183        pj_val_to_hex_digit(((char*)&hval)[3], instprm + pos + 6); 
     184 
     185        pj_strdup2(acc->pool, &acc->rfc5626_instprm, instprm); 
     186    } else { 
     187        const char *prmname = ";+sip.instance=\""; 
     188        pj_size_t len; 
     189 
     190        len = pj_ansi_strlen(prmname) + acc_cfg->rfc5626_instance_id.slen + 1; 
     191        acc->rfc5626_instprm.ptr = (char*)pj_pool_alloc(acc->pool, len + 1); 
     192        pj_ansi_snprintf(acc->rfc5626_instprm.ptr, len + 1, 
     193                         "%s%.*s\"", 
     194                         prmname, 
     195                         (int)acc_cfg->rfc5626_instance_id.slen, 
     196                         acc_cfg->rfc5626_instance_id.ptr); 
     197        acc->rfc5626_instprm.slen = len; 
     198    } 
     199 
     200    if (acc_cfg->rfc5626_reg_id.slen == 0) { 
     201        acc->rfc5626_regprm = pj_str(";reg-id=1"); 
     202    } else { 
     203        const char *prmname = ";reg-id="; 
     204        pj_size_t len; 
     205 
     206        len = pj_ansi_strlen(prmname) + acc_cfg->rfc5626_reg_id.slen; 
     207        acc->rfc5626_regprm.ptr = (char*)pj_pool_alloc(acc->pool, len + 1); 
     208        pj_ansi_snprintf(acc->rfc5626_regprm.ptr, len + 1, 
     209                         "%s%.*s\"", 
     210                         prmname, 
     211                         (int)acc_cfg->rfc5626_reg_id.slen, 
     212                         acc_cfg->rfc5626_reg_id.ptr); 
     213        acc->rfc5626_regprm.slen = len; 
     214    } 
     215 
     216    acc->rfc5626_status = OUTBOUND_WANTED; 
     217} 
     218 
     219/* 
    166220 * Initialize a new account (after configuration is set). 
    167221 */ 
     
    341395     */ 
    342396    if (acc_cfg->use_rfc5626) { 
    343         if (acc_cfg->rfc5626_instance_id.slen==0) { 
    344             const pj_str_t *hostname; 
    345             pj_uint32_t hval; 
    346             pj_size_t pos; 
    347             char instprm[] = ";+sip.instance=\"<urn:uuid:00000000-0000-0000-0000-0000CCDDEEFF>\""; 
    348  
    349             hostname = pj_gethostname(); 
    350             pos = pj_ansi_strlen(instprm) - 10; 
    351             hval = pj_hash_calc(0, hostname->ptr, (unsigned)hostname->slen); 
    352             pj_val_to_hex_digit( ((char*)&hval)[0], instprm+pos+0); 
    353             pj_val_to_hex_digit( ((char*)&hval)[1], instprm+pos+2); 
    354             pj_val_to_hex_digit( ((char*)&hval)[2], instprm+pos+4); 
    355             pj_val_to_hex_digit( ((char*)&hval)[3], instprm+pos+6); 
    356  
    357             pj_strdup2(acc->pool, &acc->rfc5626_instprm, instprm); 
    358         } else { 
    359             const char *prmname = ";+sip.instance=\""; 
    360             pj_size_t len; 
    361  
    362             len = pj_ansi_strlen(prmname) + acc_cfg->rfc5626_instance_id.slen + 1; 
    363             acc->rfc5626_instprm.ptr = (char*)pj_pool_alloc(acc->pool, len+1); 
    364             pj_ansi_snprintf(acc->rfc5626_instprm.ptr, len+1, 
    365                              "%s%.*s\"", 
    366                              prmname, 
    367                              (int)acc_cfg->rfc5626_instance_id.slen, 
    368                              acc_cfg->rfc5626_instance_id.ptr); 
    369             acc->rfc5626_instprm.slen = len; 
    370         } 
    371  
    372         if (acc_cfg->rfc5626_reg_id.slen==0) { 
    373             acc->rfc5626_regprm = pj_str(";reg-id=1"); 
    374         } else { 
    375             const char *prmname = ";reg-id="; 
    376             pj_size_t len; 
    377  
    378             len = pj_ansi_strlen(prmname) + acc_cfg->rfc5626_reg_id.slen; 
    379             acc->rfc5626_regprm.ptr = (char*)pj_pool_alloc(acc->pool, len+1); 
    380             pj_ansi_snprintf(acc->rfc5626_regprm.ptr, len+1, 
    381                              "%s%.*s\"", 
    382                              prmname, 
    383                              (int)acc_cfg->rfc5626_reg_id.slen, 
    384                              acc_cfg->rfc5626_reg_id.ptr); 
    385             acc->rfc5626_regprm.slen = len; 
    386         } 
    387  
    388         acc->rfc5626_status = OUTBOUND_WANTED; 
     397        init_outbound_setting(acc); 
    389398    } 
    390399 
     
    13051314        pj_strcmp(&acc->cfg.rfc5626_instance_id, &cfg->rfc5626_instance_id) || 
    13061315        pj_strcmp(&acc->cfg.rfc5626_reg_id, &cfg->rfc5626_reg_id)) 
    1307     { 
     1316    {    
     1317        if (acc->cfg.use_rfc5626 != cfg->use_rfc5626) 
     1318            acc->cfg.use_rfc5626 = cfg->use_rfc5626; 
     1319 
     1320        if (pj_strcmp(&acc->cfg.rfc5626_instance_id,  
     1321                      &cfg->rfc5626_instance_id))  
     1322        { 
     1323            pj_strdup_with_null(acc->pool, &acc->cfg.rfc5626_instance_id, 
     1324                                &cfg->rfc5626_instance_id); 
     1325        } 
     1326        if (pj_strcmp(&acc->cfg.rfc5626_reg_id, &cfg->rfc5626_reg_id)) { 
     1327            pj_strdup_with_null(acc->pool, &acc->cfg.rfc5626_reg_id, 
     1328                                &cfg->rfc5626_reg_id); 
     1329        } 
     1330        init_outbound_setting(acc); 
    13081331        update_reg = PJ_TRUE; 
     1332        unreg_first = PJ_TRUE; 
    13091333    } 
    13101334 
Note: See TracChangeset for help on using the changeset viewer.