[Asterisk-code-review] Revert "stasis cache: Stop caching stasis subscription chan... (asterisk[15.7])
George Joseph
asteriskteam at digium.com
Wed Dec 26 11:35:07 CST 2018
George Joseph has submitted this change and it was merged. ( https://gerrit.asterisk.org/10839 )
Change subject: Revert "stasis_cache: Stop caching stasis subscription change messages"
......................................................................
Revert "stasis_cache: Stop caching stasis subscription change messages"
This reverts commit ad961fd7c3313f989d6fa16ba2fc9b138cee4cb5.
This commit caused issues with polling when combined with
the revert commit "Revert "app_voicemail: Remove need to subscribe to stasis"
ASTERISK-28222
Reported by: abelbeck
Change-Id: I582534ef730923b16e137021e24f6f87dad0d2b4
---
M main/stasis_cache.c
1 file changed, 22 insertions(+), 9 deletions(-)
Approvals:
Kevin Harwell: Looks good to me, approved
George Joseph: Approved for Submit
diff --git a/main/stasis_cache.c b/main/stasis_cache.c
index 3d353b3..dfb154d 100644
--- a/main/stasis_cache.c
+++ b/main/stasis_cache.c
@@ -825,16 +825,29 @@
msg_type = stasis_message_type(message);
- /*
- * app_voicemail used to rely on the cache containing every topic subscribe and
- * unsubscribe in order to determine if anyone was currently subscribed to a
- * particular mailbox. This caused the cache to grow unabated for the life of
- * the asterisk instance. Since it no longer needs the cache of these message
- * types, and no other function needs them, we no longer cache them.
- */
if (stasis_subscription_change_type() == msg_type) {
- ao2_cleanup(caching_topic_needs_unref);
- return;
+ struct stasis_subscription_change *change = stasis_message_data(message);
+
+ /*
+ * If this change type is an unsubscribe, we need to find the original
+ * subscribe and remove it from the cache otherwise the cache will
+ * continue to grow unabated.
+ */
+ if (strcmp(change->description, "Unsubscribe") == 0) {
+ struct stasis_cache_entry *sub;
+
+ ao2_wrlock(caching_topic->cache->entries);
+ sub = cache_find(caching_topic->cache->entries, stasis_subscription_change_type(), change->uniqueid);
+ if (sub) {
+ cache_remove(caching_topic->cache->entries, sub, stasis_message_eid(message));
+ ao2_cleanup(sub);
+ }
+ ao2_unlock(caching_topic->cache->entries);
+ ao2_cleanup(caching_topic_needs_unref);
+ return;
+ }
+ msg_put = message;
+ msg = message;
} else if (stasis_cache_clear_type() == msg_type) {
/* Cache clear event. */
msg_put = NULL;
--
To view, visit https://gerrit.asterisk.org/10839
To unsubscribe, or for help writing mail filters, visit https://gerrit.asterisk.org/settings
Gerrit-Project: asterisk
Gerrit-Branch: 15.7
Gerrit-MessageType: merged
Gerrit-Change-Id: I582534ef730923b16e137021e24f6f87dad0d2b4
Gerrit-Change-Number: 10839
Gerrit-PatchSet: 1
Gerrit-Owner: George Joseph <gjoseph at digium.com>
Gerrit-Reviewer: Friendly Automation (1000185)
Gerrit-Reviewer: George Joseph <gjoseph at digium.com>
Gerrit-Reviewer: Kevin Harwell <kharwell at digium.com>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.digium.com/pipermail/asterisk-code-review/attachments/20181226/d06b07e9/attachment-0001.html>
More information about the asterisk-code-review
mailing list