<p>Alexei Gradinari has uploaded this change for <strong>review</strong>.</p><p><a href="https://gerrit.asterisk.org/9103">View Change</a></p><pre style="font-family: monospace,monospace; white-space: pre-wrap;">pjsip_options: handle modification of qualify options in realtime<br><br>Currentrly pjsip_options code does not handle the situation when the<br>qualify options were changed in realtime database.<br>Only 'module reload res_pjsip' helps.<br><br>This patch add a check on contact add/update observers if the contact<br>qualify options are different than local aor qualify options.<br>If the qualify options were modified then synchronize<br>the pjsip_options AOR local state.<br><br>ASTERISK-27872<br><br>Change-Id: Id55210a18e62ed5d35a88e408d5fe84a3c513c62<br>---<br>M res/res_pjsip/pjsip_options.c<br>1 file changed, 45 insertions(+), 9 deletions(-)<br><br></pre><pre style="font-family: monospace,monospace; white-space: pre-wrap;">git pull ssh://gerrit.asterisk.org:29418/asterisk refs/changes/03/9103/1</pre><pre style="font-family: monospace,monospace; white-space: pre-wrap;">diff --git a/res/res_pjsip/pjsip_options.c b/res/res_pjsip/pjsip_options.c<br>index 904e70c..918dda3 100644<br>--- a/res/res_pjsip/pjsip_options.c<br>+++ b/res/res_pjsip/pjsip_options.c<br>@@ -2059,6 +2059,29 @@<br>    struct ast_sip_contact *contact;<br> };<br> <br>+<br>+/*!<br>+ * \brief Check if the contact qualify options are different than local aor qualify options<br>+ */<br>+static int has_qualify_changed (struct ast_sip_contact *contact, struct sip_options_aor *aor_options)<br>+{<br>+    if (!contact) {<br>+          return 0;<br>+        }<br>+<br>+ if (!aor_options) {<br>+          if (contact->qualify_frequency) {<br>+                 return 1;<br>+            }<br>+    } else if (contact->qualify_frequency != aor_options->qualify_frequency<br>+                || contact->authenticate_qualify != aor_options->authenticate_qualify<br>+          || ((int)(contact->qualify_timeout * 1000)) != ((int)(aor_options->qualify_timeout * 1000))) {<br>+         return 1;<br>+    }<br>+<br>+ return 0;<br>+}<br>+<br> /*!<br>  * \brief Task which adds a dynamic contact to an AOR<br>  * \note Run by aor_options->serializer<br>@@ -2129,23 +2152,21 @@<br>  task_data.contact = obj;<br>      task_data.aor_options = ao2_find(sip_options_aors, task_data.contact->aor,<br>                 OBJ_SEARCH_KEY);<br>-     if (!task_data.aor_options) {<br>+<br>+     if (has_qualify_changed(task_data.contact, task_data.aor_options)) {<br>          struct ast_sip_aor *aor;<br> <br>-          /*<br>-            * The only reason this would occur is if the AOR was sourced<br>-                 * after the last reload happened.  To handle this we fetch the<br>-               * AOR and treat it as if we received notification that it had<br>-                * been created.  This will create the needed AOR feeder<br>-              * compositor and will cause any associated contact statuses and<br>-              * endpoint state compositors to also get created if needed.<br>-          */<br>           aor = ast_sorcery_retrieve_by_id(ast_sip_get_sorcery(), "aor",<br>                      task_data.contact->aor);<br>           if (aor) {<br>+                   ast_debug(3, "AOR '%s' qualify options have been modified. Synchronize an AOR local state\n",<br>+                              task_data.contact->aor);<br>                   sip_options_aor_observer_modified_task(aor);<br>                  ao2_ref(aor, -1);<br>             }<br>+    }<br>+<br>+ if (!task_data.aor_options) {<br>                 return 0;<br>     }<br> <br>@@ -2207,6 +2228,21 @@<br>  task_data->contact = (struct ast_sip_contact *) obj;<br>       task_data->aor_options = ao2_find(sip_options_aors, task_data->contact->aor,<br>                 OBJ_SEARCH_KEY);<br>+<br>+  if (has_qualify_changed(task_data->contact, task_data->aor_options)) {<br>+         struct ast_sip_aor *aor;<br>+<br>+          aor = ast_sorcery_retrieve_by_id(ast_sip_get_sorcery(), "aor",<br>+                     task_data->contact->aor);<br>+              if (aor) {<br>+                   ast_debug(3, "AOR '%s' qualify options have been modified. Synchronize an AOR local state\n",<br>+                              task_data->contact->aor);<br>+                      ast_sip_push_task_wait_serializer(management_serializer,<br>+                             sip_options_aor_observer_modified_task, aor);<br>+                        ao2_ref(aor, -1);<br>+            }<br>+    }<br>+<br>  if (!task_data->aor_options) {<br>             ast_free(task_data);<br>          return;<br></pre><p>To view, visit <a href="https://gerrit.asterisk.org/9103">change 9103</a>. To unsubscribe, 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/9103"/><meta itemprop="name" content="View Change"/></div></div>

<div style="display:none"> Gerrit-Project: asterisk </div>
<div style="display:none"> Gerrit-Branch: master </div>
<div style="display:none"> Gerrit-MessageType: newchange </div>
<div style="display:none"> Gerrit-Change-Id: Id55210a18e62ed5d35a88e408d5fe84a3c513c62 </div>
<div style="display:none"> Gerrit-Change-Number: 9103 </div>
<div style="display:none"> Gerrit-PatchSet: 1 </div>
<div style="display:none"> Gerrit-Owner: Alexei Gradinari <alex2grad@gmail.com> </div>