This repository has been archived by the owner on Apr 26, 2024. It is now read-only.
-
-
Notifications
You must be signed in to change notification settings - Fork 2.1k
speed up /members and add at= and membership params #3568
Merged
Merged
Changes from all commits
Commits
Show all changes
31 commits
Select commit
Hold shift + click to select a range
7b7fd27
untested attempt at deduplicating lazy-loaded members
ara4n c341d81
Merge branch 'develop' into matthew/remove_redundant_lazy_members
ara4n f7bd5da
add include_redundant_members filter option & make it work
ara4n 589e5aa
merge and apply isort
ara4n 8e66dd1
merge in #2970
ara4n a08b37b
fix bad merge
ara4n 7362e6c
make /context lazyload & filter aware
ara4n cd28d2f
speed up /members and add at= and membership params
ara4n a17f0b6
make it work
ara4n 9ba6ef2
Merge branch 'matthew/lazy_load_apis' into matthew/members_at
ara4n c6117fa
make it work
ara4n 8f1585d
make filtering work
ara4n f9c3c26
Merge branch 'matthew/filter_members' into matthew/remove_redundant_l…
ara4n c2870ab
Merge branch 'matthew/remove_redundant_lazy_members' into matthew/laz…
ara4n ffb7a4c
Merge branch 'matthew/lazy_load_apis' into matthew/members_at
ara4n 7d99b0e
changelog
ara4n cd27a77
changelog
ara4n 4018a6d
changelog
ara4n d32e5f8
Merge branch 'matthew/filter_members' into matthew/remove_redundant_l…
ara4n 238f750
deduplicating redundant members via event_id rather than mxid
ara4n 2a79e1a
Merge branch 'matthew/remove_redundant_lazy_members' into matthew/laz…
ara4n 48f3e43
Merge branch 'matthew/lazy_load_apis' into matthew/members_at
ara4n 08af91d
fix merge fail
ara4n e952368
incorporate review
ara4n 2d9c062
Merge branch 'develop' into matthew/members_at
ara4n eebee08
convert /members?at= to take a stream token
ara4n 859ad35
incorporate PR review
ara4n dd4498f
Merge branch 'develop' into matthew/members_at
ara4n 217d5dd
Merge branch 'develop' into matthew/members_at
ara4n f5189b9
remove incorrectly reintroduced method
richvdh 0d5770d
cleanups
richvdh File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
add support for the include_redundant_members filter param as per MSC1227 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
make the /context API filter & lazy-load aware as per MSC1227 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
speed up /members API and add `at` and `membership` params as per MSC1227 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't understanding the caching stuff to know how best to handle this - or whether this method should be combined with get_current_state_ids above, and somehow share the same caching.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I guess you've got three choices:
treat each call to
get_filtered_current_state_ids
as a separate cacheable thing - so for example if you do a lookup ofget_filtered_current_state_ids(room, None, None)
, a lookup ofget_filtered_current_state_ids(room, [(t, k)], None)
would not hit the cache. To do this, you just need an @cached decorator, plus invalidation calls.Implement this in terms of a call to
get_current_state_ids
followed by a filter. This might increase cache hits, but cache misses will of course be very expensive.use a DictionaryCache, like
_state_group_cache
uses, sinceDictionaryCache
has support for partial caches. The keys would be room ids rather than state group ids. again you'd need to consider invalidation.Not bother with caching and see how much it hurts?