summaryrefslogtreecommitdiff
path: root/internal/cache/cache.go
diff options
context:
space:
mode:
Diffstat (limited to 'internal/cache/cache.go')
-rw-r--r--internal/cache/cache.go14
1 files changed, 10 insertions, 4 deletions
diff --git a/internal/cache/cache.go b/internal/cache/cache.go
index df7d9a7ae..63564935e 100644
--- a/internal/cache/cache.go
+++ b/internal/cache/cache.go
@@ -93,13 +93,14 @@ func (c *Caches) setuphooks() {
})
c.GTS.EmojiCategory().SetInvalidateCallback(func(category *gtsmodel.EmojiCategory) {
- // Invalidate entire emoji cache,
- // as we can't know which emojis
- // specifically this will effect.
- c.GTS.Emoji().Clear()
+ // Invalidate any emoji in this category.
+ c.GTS.Emoji().Invalidate("CategoryID", category.ID)
})
c.GTS.Follow().SetInvalidateCallback(func(follow *gtsmodel.Follow) {
+ // Invalidate any related list entries.
+ c.GTS.ListEntry().Invalidate("FollowID", follow.ID)
+
// Invalidate follow origin account ID cached visibility.
c.Visibility.Invalidate("ItemID", follow.AccountID)
c.Visibility.Invalidate("RequesterID", follow.AccountID)
@@ -122,6 +123,11 @@ func (c *Caches) setuphooks() {
c.GTS.Follow().Invalidate("ID", followReq.ID)
})
+ c.GTS.List().SetInvalidateCallback(func(list *gtsmodel.List) {
+ // Invalidate all cached entries of this list.
+ c.GTS.ListEntry().Invalidate("ListID", list.ID)
+ })
+
c.GTS.Status().SetInvalidateCallback(func(status *gtsmodel.Status) {
// Invalidate status ID cached visibility.
c.Visibility.Invalidate("ItemID", status.ID)