mirror of
				https://github.com/matrix-org/synapse.git
				synced 2025-10-26 22:01:02 +01:00 
			
		
		
		
	Merge pull request #2238 from matrix-org/erikj/faster_push_rules
Speed up calculating push rules
This commit is contained in:
		
						commit
						ccd62415ac
					
				| @ -200,6 +200,13 @@ class RulesForRoom(object): | |||||||
|         # not update the cache with it. |         # not update the cache with it. | ||||||
|         self.sequence = 0 |         self.sequence = 0 | ||||||
| 
 | 
 | ||||||
|  |         # A cache of user_ids that we *know* aren't interesting, e.g. user_ids | ||||||
|  |         # owned by AS's, or remote users, etc. (I.e. users we will never need to | ||||||
|  |         # calculate push for) | ||||||
|  |         # These never need to be invalidated as we will never set up push for | ||||||
|  |         # them. | ||||||
|  |         self.uninteresting_user_set = set() | ||||||
|  | 
 | ||||||
|         # We need to be clever on the invalidating caches callbacks, as |         # We need to be clever on the invalidating caches callbacks, as | ||||||
|         # otherwise the invalidation callback holds a reference to the object, |         # otherwise the invalidation callback holds a reference to the object, | ||||||
|         # potentially causing it to leak. |         # potentially causing it to leak. | ||||||
| @ -231,10 +238,24 @@ class RulesForRoom(object): | |||||||
| 
 | 
 | ||||||
|             # Loop through to see which member events we've seen and have rules |             # Loop through to see which member events we've seen and have rules | ||||||
|             # for and which we need to fetch |             # for and which we need to fetch | ||||||
|             for key, event_id in current_state_ids.iteritems(): |             for key in current_state_ids: | ||||||
|                 if key[0] != EventTypes.Member: |                 typ, user_id = key | ||||||
|  |                 if typ != EventTypes.Member: | ||||||
|                     continue |                     continue | ||||||
| 
 | 
 | ||||||
|  |                 if user_id in self.uninteresting_user_set: | ||||||
|  |                     continue | ||||||
|  | 
 | ||||||
|  |                 if not self.is_mine_id(user_id): | ||||||
|  |                     self.uninteresting_user_set.add(user_id) | ||||||
|  |                     continue | ||||||
|  | 
 | ||||||
|  |                 if self.store.get_if_app_services_interested_in_user(user_id): | ||||||
|  |                     self.uninteresting_user_set.add(user_id) | ||||||
|  |                     continue | ||||||
|  | 
 | ||||||
|  |                 event_id = current_state_ids[key] | ||||||
|  | 
 | ||||||
|                 res = self.member_map.get(event_id, None) |                 res = self.member_map.get(event_id, None) | ||||||
|                 if res: |                 if res: | ||||||
|                     user_id, state = res |                     user_id, state = res | ||||||
| @ -244,13 +265,6 @@ class RulesForRoom(object): | |||||||
|                             ret_rules_by_user[user_id] = rules |                             ret_rules_by_user[user_id] = rules | ||||||
|                     continue |                     continue | ||||||
| 
 | 
 | ||||||
|                 user_id = key[1] |  | ||||||
|                 if not self.is_mine_id(user_id): |  | ||||||
|                     continue |  | ||||||
| 
 |  | ||||||
|                 if self.store.get_if_app_services_interested_in_user(user_id): |  | ||||||
|                     continue |  | ||||||
| 
 |  | ||||||
|                 # If a user has left a room we remove their push rule. If they |                 # If a user has left a room we remove their push rule. If they | ||||||
|                 # joined then we readd it later in _update_rules_with_member_event_ids |                 # joined then we readd it later in _update_rules_with_member_event_ids | ||||||
|                 ret_rules_by_user.pop(user_id, None) |                 ret_rules_by_user.pop(user_id, None) | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user