mirror of
https://github.com/asterisk/asterisk.git
synced 2025-09-03 11:25:35 +00:00
res_pjsip: Add TEL URI support for basic calls.
This change allows TEL URI requests to come through for basic calls. The allowed requests are INVITE, ACK, BYE, and CANCEL. The From and To headers will now allow TEL URIs, as well as the request URI. Support is only for TEL URIs present in traffic from a remote party. Asterisk does not generate any TEL URIs on its own. ASTERISK-26894 Change-Id: If5729e6cd583be7acf666373bf9f1b9d653ec29a
This commit is contained in:
committed by
Friendly Automation
parent
97b3459bd2
commit
31b3addce7
@@ -39,7 +39,8 @@ static pj_str_t PATH_SUPPORTED_NAME = { "path", 4 };
|
||||
static struct ast_sip_aor *find_aor(struct ast_sip_endpoint *endpoint, pjsip_uri *uri)
|
||||
{
|
||||
char *configured_aors, *aor_name;
|
||||
pjsip_sip_uri *sip_uri;
|
||||
const pj_str_t *uri_username;
|
||||
const pj_str_t *uri_hostname;
|
||||
char *domain_name;
|
||||
char *username;
|
||||
struct ast_str *id = NULL;
|
||||
@@ -48,11 +49,13 @@ static struct ast_sip_aor *find_aor(struct ast_sip_endpoint *endpoint, pjsip_uri
|
||||
return NULL;
|
||||
}
|
||||
|
||||
sip_uri = pjsip_uri_get_uri(uri);
|
||||
domain_name = ast_alloca(sip_uri->host.slen + 1);
|
||||
ast_copy_pj_str(domain_name, &sip_uri->host, sip_uri->host.slen + 1);
|
||||
username = ast_alloca(sip_uri->user.slen + 1);
|
||||
ast_copy_pj_str(username, &sip_uri->user, sip_uri->user.slen + 1);
|
||||
uri_hostname = ast_sip_pjsip_uri_get_hostname(uri);
|
||||
domain_name = ast_alloca(uri_hostname->slen + 1);
|
||||
ast_copy_pj_str(domain_name, uri_hostname, uri_hostname->slen + 1);
|
||||
|
||||
uri_username = ast_sip_pjsip_uri_get_username(uri);
|
||||
username = ast_alloca(uri_username->slen + 1);
|
||||
ast_copy_pj_str(username, uri_username, uri_username->slen + 1);
|
||||
|
||||
/*
|
||||
* We may want to match without any user options getting
|
||||
@@ -74,7 +77,7 @@ static struct ast_sip_aor *find_aor(struct ast_sip_endpoint *endpoint, pjsip_uri
|
||||
break;
|
||||
}
|
||||
|
||||
if (!id && !(id = ast_str_create(strlen(username) + sip_uri->host.slen + 2))) {
|
||||
if (!id && !(id = ast_str_create(strlen(username) + uri_hostname->slen + 2))) {
|
||||
aor_name = NULL;
|
||||
break;
|
||||
}
|
||||
|
Reference in New Issue
Block a user