<p>Joshua Colp has uploaded this change for <strong>review</strong>.</p><p><a href="https://gerrit.asterisk.org/9658">View Change</a></p><pre style="font-family: monospace,monospace; white-space: pre-wrap;">devicestate: Don't create topic when change isn't cached.<br><br>When publishing a device state the change can be marked as being<br>cachable or not. If it is not cached the change is just published<br>to all interested and not stored away for later query. This was not<br>fully taken into account when publishing in stasis. The act of<br>publishing would create a topic for the device even if it may be<br>ephemeral.<br><br>This change makes it so messages which are not cached won't create<br>a topic for the device. If a topic does already exist it will be<br>published to but otherwise the change will only be published to<br>the device state all topic.<br><br>ASTERISK-27591<br><br>Change-Id: I18da0e8cbb18e79602e731020c46ba4101e59f0a<br>---<br>M include/asterisk/stasis.h<br>M main/devicestate.c<br>M main/stasis.c<br>3 files changed, 36 insertions(+), 4 deletions(-)<br><br></pre><pre style="font-family: monospace,monospace; white-space: pre-wrap;">git pull ssh://gerrit.asterisk.org:29418/asterisk refs/changes/58/9658/1</pre><pre style="font-family: monospace,monospace; white-space: pre-wrap;"><span>diff --git a/include/asterisk/stasis.h b/include/asterisk/stasis.h</span><br><span>index de44206..03899d3 100644</span><br><span>--- a/include/asterisk/stasis.h</span><br><span>+++ b/include/asterisk/stasis.h</span><br><span>@@ -756,6 +756,16 @@</span><br><span> */</span><br><span> struct stasis_topic *stasis_topic_pool_get_topic(struct stasis_topic_pool *pool, const char *topic_name);</span><br><span> </span><br><span style="color: hsl(120, 100%, 40%);">+/*!</span><br><span style="color: hsl(120, 100%, 40%);">+ * \brief Check if a topic exists in a pool</span><br><span style="color: hsl(120, 100%, 40%);">+ * \param pool Pool to check</span><br><span style="color: hsl(120, 100%, 40%);">+ * \param topic_name Name of the topic to check</span><br><span style="color: hsl(120, 100%, 40%);">+ * \retval 1 exists</span><br><span style="color: hsl(120, 100%, 40%);">+ * \retval 0 does not exist</span><br><span style="color: hsl(120, 100%, 40%);">+ * \since 13.23.0</span><br><span style="color: hsl(120, 100%, 40%);">+ */</span><br><span style="color: hsl(120, 100%, 40%);">+int stasis_topic_pool_check_topic(const struct stasis_topic_pool *pool, const char *topic_name);</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span> /*! @} */</span><br><span> </span><br><span> /*! \addtogroup StasisTopicsAndMessages</span><br><span>diff --git a/main/devicestate.c b/main/devicestate.c</span><br><span>index 4bc0bed..845fa31 100644</span><br><span>--- a/main/devicestate.c</span><br><span>+++ b/main/devicestate.c</span><br><span>@@ -739,7 +739,7 @@</span><br><span> {</span><br><span> RAII_VAR(struct ast_device_state_message *, device_state, NULL, ao2_cleanup);</span><br><span> RAII_VAR(struct stasis_message *, message, NULL, ao2_cleanup);</span><br><span style="color: hsl(0, 100%, 40%);">- struct stasis_topic *device_specific_topic;</span><br><span style="color: hsl(120, 100%, 40%);">+ struct stasis_topic *topic;</span><br><span> </span><br><span> ast_assert(!ast_strlen_zero(device));</span><br><span> </span><br><span>@@ -758,12 +758,21 @@</span><br><span> return -1;</span><br><span> }</span><br><span> </span><br><span style="color: hsl(0, 100%, 40%);">- device_specific_topic = ast_device_state_topic(device);</span><br><span style="color: hsl(0, 100%, 40%);">- if (!device_specific_topic) {</span><br><span style="color: hsl(120, 100%, 40%);">+ /* When this device state change is not cached we only publish</span><br><span style="color: hsl(120, 100%, 40%);">+ * on its own pool topic if one already exists. This means that</span><br><span style="color: hsl(120, 100%, 40%);">+ * something external is explicitly monitoring it.</span><br><span style="color: hsl(120, 100%, 40%);">+ */</span><br><span style="color: hsl(120, 100%, 40%);">+ if (cachable || stasis_topic_pool_check_topic(device_state_topic_pool, device)) {</span><br><span style="color: hsl(120, 100%, 40%);">+ topic = ast_device_state_topic(device);</span><br><span style="color: hsl(120, 100%, 40%);">+ } else {</span><br><span style="color: hsl(120, 100%, 40%);">+ topic = ast_device_state_topic_all();</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 (!topic) {</span><br><span> return -1;</span><br><span> }</span><br><span> </span><br><span style="color: hsl(0, 100%, 40%);">- stasis_publish(device_specific_topic, message);</span><br><span style="color: hsl(120, 100%, 40%);">+ stasis_publish(topic, message);</span><br><span> return 0;</span><br><span> }</span><br><span> </span><br><span>diff --git a/main/stasis.c b/main/stasis.c</span><br><span>index a668e82..5c3615c 100644</span><br><span>--- a/main/stasis.c</span><br><span>+++ b/main/stasis.c</span><br><span>@@ -1198,6 +1198,19 @@</span><br><span> return topic_pool_entry->topic;</span><br><span> }</span><br><span> </span><br><span style="color: hsl(120, 100%, 40%);">+int stasis_topic_pool_check_topic(const struct stasis_topic_pool *pool, const char *topic_name)</span><br><span style="color: hsl(120, 100%, 40%);">+{</span><br><span style="color: hsl(120, 100%, 40%);">+ struct topic_pool_entry *topic_pool_entry;</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+ topic_pool_entry = ao2_find(pool->pool_container, topic_name, OBJ_SEARCH_KEY);</span><br><span style="color: hsl(120, 100%, 40%);">+ if (!topic_pool_entry) {</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%);">+ ao2_ref(topic_pool_entry, -1);</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> void stasis_log_bad_type_access(const char *name)</span><br><span> {</span><br><span> #ifdef AST_DEVMODE</span><br><span></span><br></pre><p>To view, visit <a href="https://gerrit.asterisk.org/9658">change 9658</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/9658"/><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: I18da0e8cbb18e79602e731020c46ba4101e59f0a </div>
<div style="display:none"> Gerrit-Change-Number: 9658 </div>
<div style="display:none"> Gerrit-PatchSet: 1 </div>
<div style="display:none"> Gerrit-Owner: Joshua Colp <jcolp@digium.com> </div>