<p>Alexei Gradinari has uploaded this change for <strong>review</strong>.</p><p><a href="https://gerrit.asterisk.org/10577">View Change</a></p><pre style="font-family: monospace,monospace; white-space: pre-wrap;">pjsip: New function PJSIP_PARSE_URI to parse URI and return part of URI<br><br>New dialplan function PJSIP_PARSE_URI added to parse an URI and return<br>a specified part of the URI.<br><br>This is useful when need to get part of the URI instead of cutting it<br>using a CUT function.<br><br>For example to get 'user' part of Remote URI<br>${PJSIP_PARSE_URI(${CHANNEL(pjsip,remote_uri)},user)}<br><br>ASTERISK-28144 #close<br><br>Change-Id: I5d828fb87f6803b6c1152bb7b44835f027bb9d5a<br>---<br>M CHANGES<br>M channels/chan_pjsip.c<br>M channels/pjsip/dialplan_functions.c<br>M channels/pjsip/include/dialplan_functions.h<br>4 files changed, 170 insertions(+), 0 deletions(-)<br><br></pre><pre style="font-family: monospace,monospace; white-space: pre-wrap;">git pull ssh://gerrit.asterisk.org:29418/asterisk refs/changes/77/10577/1</pre><pre style="font-family: monospace,monospace; white-space: pre-wrap;"><span>diff --git a/CHANGES b/CHANGES</span><br><span>index 45c964e..78df99d 100644</span><br><span>--- a/CHANGES</span><br><span>+++ b/CHANGES</span><br><span>@@ -12,6 +12,11 @@</span><br><span> --- Functionality changes from Asterisk 13.23.0 to Asterisk 13.24.0 ----------</span><br><span> ------------------------------------------------------------------------------</span><br><span> </span><br><span style="color: hsl(120, 100%, 40%);">+chan_pjsip</span><br><span style="color: hsl(120, 100%, 40%);">+------------------</span><br><span style="color: hsl(120, 100%, 40%);">+ * New dialplan function PJSIP_PARSE_URI added to parse an URI and return</span><br><span style="color: hsl(120, 100%, 40%);">+ a specified part of the URI.</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span> res_rtp_asterisk</span><br><span> ------------------</span><br><span> * The existing strictrtp option in rtp.conf has a new choice availabe, called</span><br><span>diff --git a/channels/chan_pjsip.c b/channels/chan_pjsip.c</span><br><span>index 4da0361..1d74db6 100644</span><br><span>--- a/channels/chan_pjsip.c</span><br><span>+++ b/channels/chan_pjsip.c</span><br><span>@@ -2773,6 +2773,11 @@</span><br><span> .read = pjsip_acf_dial_contacts_read,</span><br><span> };</span><br><span> </span><br><span style="color: hsl(120, 100%, 40%);">+static struct ast_custom_function chan_pjsip_parse_uri_function = {</span><br><span style="color: hsl(120, 100%, 40%);">+ .name = "PJSIP_PARSE_URI",</span><br><span style="color: hsl(120, 100%, 40%);">+ .read = pjsip_acf_parse_uri_read,</span><br><span style="color: hsl(120, 100%, 40%);">+};</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span> static struct ast_custom_function media_offer_function = {</span><br><span> .name = "PJSIP_MEDIA_OFFER",</span><br><span> .read = pjsip_acf_media_offer_read,</span><br><span>@@ -2824,6 +2829,11 @@</span><br><span> goto end;</span><br><span> }</span><br><span> </span><br><span style="color: hsl(120, 100%, 40%);">+ if (ast_custom_function_register(&chan_pjsip_parse_uri_function)) {</span><br><span style="color: hsl(120, 100%, 40%);">+ ast_log(LOG_ERROR, "Unable to register PJSIP_PARSE_URI dialplan function\n");</span><br><span style="color: hsl(120, 100%, 40%);">+ goto end;</span><br><span style="color: hsl(120, 100%, 40%);">+ }</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span> if (ast_custom_function_register(&media_offer_function)) {</span><br><span> ast_log(LOG_WARNING, "Unable to register PJSIP_MEDIA_OFFER dialplan function\n");</span><br><span> goto end;</span><br><span>@@ -2896,6 +2906,7 @@</span><br><span> ast_custom_function_unregister(&dtmf_mode_function);</span><br><span> ast_custom_function_unregister(&media_offer_function);</span><br><span> ast_custom_function_unregister(&chan_pjsip_dial_contacts_function);</span><br><span style="color: hsl(120, 100%, 40%);">+ ast_custom_function_unregister(&chan_pjsip_parse_uri_function);</span><br><span> ast_custom_function_unregister(&session_refresh_function);</span><br><span> ast_channel_unregister(&chan_pjsip_tech);</span><br><span> ast_rtp_glue_unregister(&chan_pjsip_rtp_glue);</span><br><span>@@ -2920,6 +2931,7 @@</span><br><span> ast_custom_function_unregister(&dtmf_mode_function);</span><br><span> ast_custom_function_unregister(&media_offer_function);</span><br><span> ast_custom_function_unregister(&chan_pjsip_dial_contacts_function);</span><br><span style="color: hsl(120, 100%, 40%);">+ ast_custom_function_unregister(&chan_pjsip_parse_uri_function);</span><br><span> ast_custom_function_unregister(&session_refresh_function);</span><br><span> </span><br><span> ast_channel_unregister(&chan_pjsip_tech);</span><br><span>diff --git a/channels/pjsip/dialplan_functions.c b/channels/pjsip/dialplan_functions.c</span><br><span>index b7a7460..8ef4f7f 100644</span><br><span>--- a/channels/pjsip/dialplan_functions.c</span><br><span>+++ b/channels/pjsip/dialplan_functions.c</span><br><span>@@ -121,6 +121,60 @@</span><br><span> <ref type="function">PJSIP_MEDIA_OFFER</ref></span><br><span> </see-also></span><br><span> </function></span><br><span style="color: hsl(120, 100%, 40%);">+<function name="PJSIP_PARSE_URI" language="en_US"></span><br><span style="color: hsl(120, 100%, 40%);">+ <synopsis></span><br><span style="color: hsl(120, 100%, 40%);">+ Parse an <literal>uri</literal> and return a <literal>type</literal> part of the URI.</span><br><span style="color: hsl(120, 100%, 40%);">+ </synopsis></span><br><span style="color: hsl(120, 100%, 40%);">+ <syntax></span><br><span style="color: hsl(120, 100%, 40%);">+ <parameter name="uri" required="true"></span><br><span style="color: hsl(120, 100%, 40%);">+ <para>URI to parse</para></span><br><span style="color: hsl(120, 100%, 40%);">+ </parameter></span><br><span style="color: hsl(120, 100%, 40%);">+ <parameter name="type" required="true"></span><br><span style="color: hsl(120, 100%, 40%);">+ <para>The <literal>type</literal> parameter specifies which URI part to read</para></span><br><span style="color: hsl(120, 100%, 40%);">+ <enumlist></span><br><span style="color: hsl(120, 100%, 40%);">+ <enum name="display"></span><br><span style="color: hsl(120, 100%, 40%);">+ <para>Display name.</para></span><br><span style="color: hsl(120, 100%, 40%);">+ </enum></span><br><span style="color: hsl(120, 100%, 40%);">+ <enum name="scheme"></span><br><span style="color: hsl(120, 100%, 40%);">+ <para>URI scheme.</para></span><br><span style="color: hsl(120, 100%, 40%);">+ </enum></span><br><span style="color: hsl(120, 100%, 40%);">+ <enum name="user"></span><br><span style="color: hsl(120, 100%, 40%);">+ <para>User part.</para></span><br><span style="color: hsl(120, 100%, 40%);">+ </enum></span><br><span style="color: hsl(120, 100%, 40%);">+ <enum name="passwd"></span><br><span style="color: hsl(120, 100%, 40%);">+ <para>Password part.</para></span><br><span style="color: hsl(120, 100%, 40%);">+ </enum></span><br><span style="color: hsl(120, 100%, 40%);">+ <enum name="host"></span><br><span style="color: hsl(120, 100%, 40%);">+ <para>Host part.</para></span><br><span style="color: hsl(120, 100%, 40%);">+ </enum></span><br><span style="color: hsl(120, 100%, 40%);">+ <enum name="port"></span><br><span style="color: hsl(120, 100%, 40%);">+ <para>Port number, or zero.</para></span><br><span style="color: hsl(120, 100%, 40%);">+ </enum></span><br><span style="color: hsl(120, 100%, 40%);">+ <enum name="user_param"></span><br><span style="color: hsl(120, 100%, 40%);">+ <para>User parameter.</para></span><br><span style="color: hsl(120, 100%, 40%);">+ </enum></span><br><span style="color: hsl(120, 100%, 40%);">+ <enum name="method_param"></span><br><span style="color: hsl(120, 100%, 40%);">+ <para>Method parameter.</para></span><br><span style="color: hsl(120, 100%, 40%);">+ </enum></span><br><span style="color: hsl(120, 100%, 40%);">+ <enum name="transport_param"></span><br><span style="color: hsl(120, 100%, 40%);">+ <para>Transport parameter.</para></span><br><span style="color: hsl(120, 100%, 40%);">+ </enum></span><br><span style="color: hsl(120, 100%, 40%);">+ <enum name="ttl_param"></span><br><span style="color: hsl(120, 100%, 40%);">+ <para>TTL param, or -1.</para></span><br><span style="color: hsl(120, 100%, 40%);">+ </enum></span><br><span style="color: hsl(120, 100%, 40%);">+ <enum name="lr_param"></span><br><span style="color: hsl(120, 100%, 40%);">+ <para>Loose routing param, or zero.</para></span><br><span style="color: hsl(120, 100%, 40%);">+ </enum></span><br><span style="color: hsl(120, 100%, 40%);">+ <enum name="maddr_param"></span><br><span style="color: hsl(120, 100%, 40%);">+ <para>Maddr param.</para></span><br><span style="color: hsl(120, 100%, 40%);">+ </enum></span><br><span style="color: hsl(120, 100%, 40%);">+ </enumlist></span><br><span style="color: hsl(120, 100%, 40%);">+ </parameter></span><br><span style="color: hsl(120, 100%, 40%);">+ </syntax></span><br><span style="color: hsl(120, 100%, 40%);">+ <description></span><br><span style="color: hsl(120, 100%, 40%);">+ <para>Parse an URI and return a specified part of the URI.</para></span><br><span style="color: hsl(120, 100%, 40%);">+ </description></span><br><span style="color: hsl(120, 100%, 40%);">+</function></span><br><span> <info name="CHANNEL" language="en_US" tech="PJSIP"></span><br><span> <enumlist></span><br><span> <enum name="rtp"></span><br><span>@@ -987,6 +1041,92 @@</span><br><span> return 0;</span><br><span> }</span><br><span> </span><br><span style="color: hsl(120, 100%, 40%);">+int pjsip_acf_parse_uri_read(struct ast_channel *chan, const char *cmd, char *data, char *buf, size_t buflen)</span><br><span style="color: hsl(120, 100%, 40%);">+{</span><br><span style="color: hsl(120, 100%, 40%);">+ pj_pool_t *pool;</span><br><span style="color: hsl(120, 100%, 40%);">+ pjsip_name_addr *uri;</span><br><span style="color: hsl(120, 100%, 40%);">+ pjsip_sip_uri *sip_uri;</span><br><span style="color: hsl(120, 100%, 40%);">+ pj_str_t tmp;</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+ AST_DECLARE_APP_ARGS(args,</span><br><span style="color: hsl(120, 100%, 40%);">+ AST_APP_ARG(uri_str);</span><br><span style="color: hsl(120, 100%, 40%);">+ AST_APP_ARG(type);</span><br><span style="color: hsl(120, 100%, 40%);">+ );</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+ AST_STANDARD_APP_ARGS(args, data);</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+ if (ast_strlen_zero(args.uri_str)) {</span><br><span style="color: hsl(120, 100%, 40%);">+ ast_log(LOG_WARNING, "An URI must be specified when using the '%s' dialplan function\n", cmd);</span><br><span style="color: hsl(120, 100%, 40%);">+ return -1;</span><br><span style="color: hsl(120, 100%, 40%);">+ }</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+ if (ast_strlen_zero(args.type)) {</span><br><span style="color: hsl(120, 100%, 40%);">+ ast_log(LOG_WARNING, "A type part of the URI must be specified when using the '%s' dialplan function\n", cmd);</span><br><span style="color: hsl(120, 100%, 40%);">+ return -1;</span><br><span style="color: hsl(120, 100%, 40%);">+ }</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+ pool = pjsip_endpt_create_pool(ast_sip_get_pjsip_endpoint(), "ParseUri", 128, 128);</span><br><span style="color: hsl(120, 100%, 40%);">+ if (!pool) {</span><br><span style="color: hsl(120, 100%, 40%);">+ ast_log(LOG_ERROR, "Failed to allocate ParseUri endpoint pool.\n");</span><br><span style="color: hsl(120, 100%, 40%);">+ return -1;</span><br><span style="color: hsl(120, 100%, 40%);">+ }</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+ pj_strdup2_with_null(pool, &tmp, args.uri_str);</span><br><span style="color: hsl(120, 100%, 40%);">+ uri = (pjsip_name_addr *)pjsip_parse_uri(pool, tmp.ptr, tmp.slen, PJSIP_PARSE_URI_AS_NAMEADDR);</span><br><span style="color: hsl(120, 100%, 40%);">+ if (!uri) {</span><br><span style="color: hsl(120, 100%, 40%);">+ ast_log(LOG_WARNING, "Failed to parse URI '%s'\n", args.uri_str);</span><br><span style="color: hsl(120, 100%, 40%);">+ pjsip_endpt_release_pool(ast_sip_get_pjsip_endpoint(), pool);</span><br><span style="color: hsl(120, 100%, 40%);">+ return -1;</span><br><span style="color: hsl(120, 100%, 40%);">+ }</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+ if (!strcmp(args.type, "scheme")) {</span><br><span style="color: hsl(120, 100%, 40%);">+ ast_copy_pj_str(buf, pjsip_uri_get_scheme(uri), buflen);</span><br><span style="color: hsl(120, 100%, 40%);">+ pjsip_endpt_release_pool(ast_sip_get_pjsip_endpoint(), pool);</span><br><span style="color: hsl(120, 100%, 40%);">+ return 0;</span><br><span style="color: hsl(120, 100%, 40%);">+ } else if (!strcmp(args.type, "display")) {</span><br><span style="color: hsl(120, 100%, 40%);">+ ast_copy_pj_str(buf, &uri->display, buflen);</span><br><span style="color: hsl(120, 100%, 40%);">+ pjsip_endpt_release_pool(ast_sip_get_pjsip_endpoint(), pool);</span><br><span style="color: hsl(120, 100%, 40%);">+ return 0;</span><br><span style="color: hsl(120, 100%, 40%);">+ }</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+ sip_uri = pjsip_uri_get_uri(uri);</span><br><span style="color: hsl(120, 100%, 40%);">+ if (!sip_uri) {</span><br><span style="color: hsl(120, 100%, 40%);">+ ast_log(LOG_ERROR, "Failed to get SIP URI\n");</span><br><span style="color: hsl(120, 100%, 40%);">+ pjsip_endpt_release_pool(ast_sip_get_pjsip_endpoint(), pool);</span><br><span style="color: hsl(120, 100%, 40%);">+ return -1;</span><br><span style="color: hsl(120, 100%, 40%);">+ }</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+ if (!strcmp(args.type, "user")) {</span><br><span style="color: hsl(120, 100%, 40%);">+ ast_copy_pj_str(buf, &sip_uri->user, buflen);</span><br><span style="color: hsl(120, 100%, 40%);">+ } else if (!strcmp(args.type, "passwd")) {</span><br><span style="color: hsl(120, 100%, 40%);">+ ast_copy_pj_str(buf, &sip_uri->passwd, buflen);</span><br><span style="color: hsl(120, 100%, 40%);">+ } else if (!strcmp(args.type, "host")) {</span><br><span style="color: hsl(120, 100%, 40%);">+ ast_copy_pj_str(buf, &sip_uri->host, buflen);</span><br><span style="color: hsl(120, 100%, 40%);">+ } else if (!strcmp(args.type, "port")) {</span><br><span style="color: hsl(120, 100%, 40%);">+ snprintf(buf, buflen, "%d", sip_uri->port);</span><br><span style="color: hsl(120, 100%, 40%);">+ } else if (!strcmp(args.type, "user_param")) {</span><br><span style="color: hsl(120, 100%, 40%);">+ ast_copy_pj_str(buf, &sip_uri->user_param, buflen);</span><br><span style="color: hsl(120, 100%, 40%);">+ } else if (!strcmp(args.type, "method_param")) {</span><br><span style="color: hsl(120, 100%, 40%);">+ ast_copy_pj_str(buf, &sip_uri->method_param, buflen);</span><br><span style="color: hsl(120, 100%, 40%);">+ } else if (!strcmp(args.type, "transport_param")) {</span><br><span style="color: hsl(120, 100%, 40%);">+ ast_copy_pj_str(buf, &sip_uri->transport_param, buflen);</span><br><span style="color: hsl(120, 100%, 40%);">+ } else if (!strcmp(args.type, "ttl_param")) {</span><br><span style="color: hsl(120, 100%, 40%);">+ snprintf(buf, buflen, "%d", sip_uri->ttl_param);</span><br><span style="color: hsl(120, 100%, 40%);">+ } else if (!strcmp(args.type, "lr_param")) {</span><br><span style="color: hsl(120, 100%, 40%);">+ snprintf(buf, buflen, "%d", sip_uri->lr_param);</span><br><span style="color: hsl(120, 100%, 40%);">+ } else if (!strcmp(args.type, "maddr_param")) {</span><br><span style="color: hsl(120, 100%, 40%);">+ ast_copy_pj_str(buf, &sip_uri->maddr_param, buflen);</span><br><span style="color: hsl(120, 100%, 40%);">+ } else {</span><br><span style="color: hsl(120, 100%, 40%);">+ ast_log(AST_LOG_WARNING, "Unknown type part '%s' specified\n", args.type);</span><br><span style="color: hsl(120, 100%, 40%);">+ pjsip_endpt_release_pool(ast_sip_get_pjsip_endpoint(), pool);</span><br><span style="color: hsl(120, 100%, 40%);">+ return -1;</span><br><span style="color: hsl(120, 100%, 40%);">+ }</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+ pjsip_endpt_release_pool(ast_sip_get_pjsip_endpoint(), pool);</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+ return 0;</span><br><span style="color: hsl(120, 100%, 40%);">+}</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span> static int media_offer_read_av(struct ast_sip_session *session, char *buf,</span><br><span> size_t len, enum ast_media_type media_type)</span><br><span> {</span><br><span>diff --git a/channels/pjsip/include/dialplan_functions.h b/channels/pjsip/include/dialplan_functions.h</span><br><span>index 731e91d..a9332a2 100644</span><br><span>--- a/channels/pjsip/include/dialplan_functions.h</span><br><span>+++ b/channels/pjsip/include/dialplan_functions.h</span><br><span>@@ -110,4 +110,17 @@</span><br><span> */</span><br><span> int pjsip_acf_dial_contacts_read(struct ast_channel *chan, const char *cmd, char *data, char *buf, size_t len);</span><br><span> </span><br><span style="color: hsl(120, 100%, 40%);">+/*!</span><br><span style="color: hsl(120, 100%, 40%);">+ * \brief PJSIP_PARSE_URI function read callback</span><br><span style="color: hsl(120, 100%, 40%);">+ * \param chan The channel the function is called on</span><br><span style="color: hsl(120, 100%, 40%);">+ * \param cmd The name of the function</span><br><span style="color: hsl(120, 100%, 40%);">+ * \param data Arguments passed to the function</span><br><span style="color: hsl(120, 100%, 40%);">+ * \param buf Out buffer that should be populated with the data</span><br><span style="color: hsl(120, 100%, 40%);">+ * \param len Size of the buffer</span><br><span style="color: hsl(120, 100%, 40%);">+ *</span><br><span style="color: hsl(120, 100%, 40%);">+ * \retval 0 on success</span><br><span style="color: hsl(120, 100%, 40%);">+ * \retval -1 on failure</span><br><span style="color: hsl(120, 100%, 40%);">+ */</span><br><span style="color: hsl(120, 100%, 40%);">+int pjsip_acf_parse_uri_read(struct ast_channel *chan, const char *cmd, char *data, char *buf, size_t len);</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span> #endif /* _PJSIP_DIALPLAN_FUNCTIONS */</span><br><span>\ No newline at end of file</span><br><span></span><br></pre><p>To view, visit <a href="https://gerrit.asterisk.org/10577">change 10577</a>. To unsubscribe, or for help writing mail filters, visit <a href="https://gerrit.asterisk.org/settings">settings</a>.</p><div itemscope itemtype="http://schema.org/EmailMessage"><div itemscope itemprop="action" itemtype="http://schema.org/ViewAction"><link itemprop="url" href="https://gerrit.asterisk.org/10577"/><meta itemprop="name" content="View Change"/></div></div>
<div style="display:none"> Gerrit-Project: asterisk </div>
<div style="display:none"> Gerrit-Branch: 13 </div>
<div style="display:none"> Gerrit-MessageType: newchange </div>
<div style="display:none"> Gerrit-Change-Id: I5d828fb87f6803b6c1152bb7b44835f027bb9d5a </div>
<div style="display:none"> Gerrit-Change-Number: 10577 </div>
<div style="display:none"> Gerrit-PatchSet: 1 </div>
<div style="display:none"> Gerrit-Owner: Alexei Gradinari <alex2grad@gmail.com> </div>