Make __init__ consitstent across Store heirarchy
Add db_conn parameters to the `__init__` methods of the *Store classes, so that they are all consistent, which makes the multiple inheritance work correctly (and so that we can later extract mixins which can be used in the slavedstores)pull/2658/head
							parent
							
								
									ab335edb02
								
							
						
					
					
						commit
						6cfee09be9
					
				|  | @ -25,7 +25,7 @@ logger = logging.getLogger(__name__) | |||
| 
 | ||||
| class BaseSlavedStore(SQLBaseStore): | ||||
|     def __init__(self, db_conn, hs): | ||||
|         super(BaseSlavedStore, self).__init__(hs) | ||||
|         super(BaseSlavedStore, self).__init__(db_conn, hs) | ||||
|         if isinstance(self.database_engine, PostgresEngine): | ||||
|             self._cache_id_gen = SlavedIdTracker( | ||||
|                 db_conn, "cache_invalidation_stream", "stream_id", | ||||
|  |  | |||
|  | @ -268,7 +268,7 @@ class DataStore(RoomMemberStore, RoomStore, | |||
|         self._stream_order_on_start = self.get_room_max_stream_ordering() | ||||
|         self._min_stream_order_on_start = self.get_room_min_stream_ordering() | ||||
| 
 | ||||
|         super(DataStore, self).__init__(hs) | ||||
|         super(DataStore, self).__init__(db_conn, hs) | ||||
| 
 | ||||
|     def take_presence_startup_info(self): | ||||
|         active_on_startup = self._presence_on_startup | ||||
|  |  | |||
|  | @ -162,7 +162,7 @@ class PerformanceCounters(object): | |||
| class SQLBaseStore(object): | ||||
|     _TXN_ID = 0 | ||||
| 
 | ||||
|     def __init__(self, hs): | ||||
|     def __init__(self, db_conn, hs): | ||||
|         self.hs = hs | ||||
|         self._clock = hs.get_clock() | ||||
|         self._db_pool = hs.get_db_pool() | ||||
|  |  | |||
|  | @ -48,8 +48,8 @@ def _make_exclusive_regex(services_cache): | |||
| 
 | ||||
| class ApplicationServiceStore(SQLBaseStore): | ||||
| 
 | ||||
|     def __init__(self, hs): | ||||
|         super(ApplicationServiceStore, self).__init__(hs) | ||||
|     def __init__(self, db_conn, hs): | ||||
|         super(ApplicationServiceStore, self).__init__(db_conn, hs) | ||||
|         self.hostname = hs.hostname | ||||
|         self.services_cache = load_appservices( | ||||
|             hs.hostname, | ||||
|  | @ -173,8 +173,8 @@ class ApplicationServiceStore(SQLBaseStore): | |||
| 
 | ||||
| class ApplicationServiceTransactionStore(SQLBaseStore): | ||||
| 
 | ||||
|     def __init__(self, hs): | ||||
|         super(ApplicationServiceTransactionStore, self).__init__(hs) | ||||
|     def __init__(self, db_conn, hs): | ||||
|         super(ApplicationServiceTransactionStore, self).__init__(db_conn, hs) | ||||
| 
 | ||||
|     @defer.inlineCallbacks | ||||
|     def get_appservices_by_state(self, state): | ||||
|  |  | |||
|  | @ -80,8 +80,8 @@ class BackgroundUpdateStore(SQLBaseStore): | |||
|     BACKGROUND_UPDATE_INTERVAL_MS = 1000 | ||||
|     BACKGROUND_UPDATE_DURATION_MS = 100 | ||||
| 
 | ||||
|     def __init__(self, hs): | ||||
|         super(BackgroundUpdateStore, self).__init__(hs) | ||||
|     def __init__(self, db_conn, hs): | ||||
|         super(BackgroundUpdateStore, self).__init__(db_conn, hs) | ||||
|         self._background_update_performance = {} | ||||
|         self._background_update_queue = [] | ||||
|         self._background_update_handlers = {} | ||||
|  |  | |||
|  | @ -32,14 +32,14 @@ LAST_SEEN_GRANULARITY = 120 * 1000 | |||
| 
 | ||||
| 
 | ||||
| class ClientIpStore(background_updates.BackgroundUpdateStore): | ||||
|     def __init__(self, hs): | ||||
|     def __init__(self, db_conn, hs): | ||||
|         self.client_ip_last_seen = Cache( | ||||
|             name="client_ip_last_seen", | ||||
|             keylen=4, | ||||
|             max_entries=50000 * CACHE_SIZE_FACTOR, | ||||
|         ) | ||||
| 
 | ||||
|         super(ClientIpStore, self).__init__(hs) | ||||
|         super(ClientIpStore, self).__init__(db_conn, hs) | ||||
| 
 | ||||
|         self.register_background_index_update( | ||||
|             "user_ips_device_index", | ||||
|  |  | |||
|  | @ -29,8 +29,8 @@ logger = logging.getLogger(__name__) | |||
| class DeviceInboxStore(BackgroundUpdateStore): | ||||
|     DEVICE_INBOX_STREAM_ID = "device_inbox_stream_drop" | ||||
| 
 | ||||
|     def __init__(self, hs): | ||||
|         super(DeviceInboxStore, self).__init__(hs) | ||||
|     def __init__(self, db_conn, hs): | ||||
|         super(DeviceInboxStore, self).__init__(db_conn, hs) | ||||
| 
 | ||||
|         self.register_background_index_update( | ||||
|             "device_inbox_stream_index", | ||||
|  |  | |||
|  | @ -26,8 +26,8 @@ logger = logging.getLogger(__name__) | |||
| 
 | ||||
| 
 | ||||
| class DeviceStore(SQLBaseStore): | ||||
|     def __init__(self, hs): | ||||
|         super(DeviceStore, self).__init__(hs) | ||||
|     def __init__(self, db_conn, hs): | ||||
|         super(DeviceStore, self).__init__(db_conn, hs) | ||||
| 
 | ||||
|         # Map of (user_id, device_id) -> bool. If there is an entry that implies | ||||
|         # the device exists. | ||||
|  |  | |||
|  | @ -39,8 +39,8 @@ class EventFederationStore(SQLBaseStore): | |||
| 
 | ||||
|     EVENT_AUTH_STATE_ONLY = "event_auth_state_only" | ||||
| 
 | ||||
|     def __init__(self, hs): | ||||
|         super(EventFederationStore, self).__init__(hs) | ||||
|     def __init__(self, db_conn, hs): | ||||
|         super(EventFederationStore, self).__init__(db_conn, hs) | ||||
| 
 | ||||
|         self.register_background_update_handler( | ||||
|             self.EVENT_AUTH_STATE_ONLY, | ||||
|  |  | |||
|  | @ -65,8 +65,8 @@ def _deserialize_action(actions, is_highlight): | |||
| class EventPushActionsStore(SQLBaseStore): | ||||
|     EPA_HIGHLIGHT_INDEX = "epa_highlight_index" | ||||
| 
 | ||||
|     def __init__(self, hs): | ||||
|         super(EventPushActionsStore, self).__init__(hs) | ||||
|     def __init__(self, db_conn, hs): | ||||
|         super(EventPushActionsStore, self).__init__(db_conn, hs) | ||||
| 
 | ||||
|         self.register_background_index_update( | ||||
|             self.EPA_HIGHLIGHT_INDEX, | ||||
|  |  | |||
|  | @ -197,8 +197,8 @@ class EventsStore(SQLBaseStore): | |||
|     EVENT_ORIGIN_SERVER_TS_NAME = "event_origin_server_ts" | ||||
|     EVENT_FIELDS_SENDER_URL_UPDATE_NAME = "event_fields_sender_url" | ||||
| 
 | ||||
|     def __init__(self, hs): | ||||
|         super(EventsStore, self).__init__(hs) | ||||
|     def __init__(self, db_conn, hs): | ||||
|         super(EventsStore, self).__init__(db_conn, hs) | ||||
|         self._clock = hs.get_clock() | ||||
|         self.register_background_update_handler( | ||||
|             self.EVENT_ORIGIN_SERVER_TS_NAME, self._background_reindex_origin_server_ts | ||||
|  |  | |||
|  | @ -27,8 +27,8 @@ logger = logging.getLogger(__name__) | |||
| 
 | ||||
| 
 | ||||
| class ReceiptsStore(SQLBaseStore): | ||||
|     def __init__(self, hs): | ||||
|         super(ReceiptsStore, self).__init__(hs) | ||||
|     def __init__(self, db_conn, hs): | ||||
|         super(ReceiptsStore, self).__init__(db_conn, hs) | ||||
| 
 | ||||
|         self._receipts_stream_cache = StreamChangeCache( | ||||
|             "ReceiptsRoomChangeCache", self._receipts_id_gen.get_current_token() | ||||
|  |  | |||
|  | @ -24,8 +24,8 @@ from synapse.util.caches.descriptors import cached, cachedInlineCallbacks | |||
| 
 | ||||
| class RegistrationStore(background_updates.BackgroundUpdateStore): | ||||
| 
 | ||||
|     def __init__(self, hs): | ||||
|         super(RegistrationStore, self).__init__(hs) | ||||
|     def __init__(self, db_conn, hs): | ||||
|         super(RegistrationStore, self).__init__(db_conn, hs) | ||||
| 
 | ||||
|         self.clock = hs.get_clock() | ||||
| 
 | ||||
|  |  | |||
|  | @ -49,8 +49,8 @@ _MEMBERSHIP_PROFILE_UPDATE_NAME = "room_membership_profile_update" | |||
| 
 | ||||
| 
 | ||||
| class RoomMemberStore(SQLBaseStore): | ||||
|     def __init__(self, hs): | ||||
|         super(RoomMemberStore, self).__init__(hs) | ||||
|     def __init__(self, db_conn, hs): | ||||
|         super(RoomMemberStore, self).__init__(db_conn, hs) | ||||
|         self.register_background_update_handler( | ||||
|             _MEMBERSHIP_PROFILE_UPDATE_NAME, self._background_add_membership_profile | ||||
|         ) | ||||
|  |  | |||
|  | @ -33,8 +33,8 @@ class SearchStore(BackgroundUpdateStore): | |||
|     EVENT_SEARCH_ORDER_UPDATE_NAME = "event_search_order" | ||||
|     EVENT_SEARCH_USE_GIST_POSTGRES_NAME = "event_search_postgres_gist" | ||||
| 
 | ||||
|     def __init__(self, hs): | ||||
|         super(SearchStore, self).__init__(hs) | ||||
|     def __init__(self, db_conn, hs): | ||||
|         super(SearchStore, self).__init__(db_conn, hs) | ||||
|         self.register_background_update_handler( | ||||
|             self.EVENT_SEARCH_UPDATE_NAME, self._background_reindex_search | ||||
|         ) | ||||
|  |  | |||
|  | @ -63,8 +63,8 @@ class StateStore(SQLBaseStore): | |||
|     STATE_GROUP_INDEX_UPDATE_NAME = "state_group_state_type_index" | ||||
|     CURRENT_STATE_INDEX_UPDATE_NAME = "current_state_members_idx" | ||||
| 
 | ||||
|     def __init__(self, hs): | ||||
|         super(StateStore, self).__init__(hs) | ||||
|     def __init__(self, db_conn, hs): | ||||
|         super(StateStore, self).__init__(db_conn, hs) | ||||
|         self.register_background_update_handler( | ||||
|             self.STATE_GROUP_DEDUPLICATION_UPDATE_NAME, | ||||
|             self._background_deduplicate_state, | ||||
|  |  | |||
|  | @ -46,8 +46,8 @@ class TransactionStore(SQLBaseStore): | |||
|     """A collection of queries for handling PDUs. | ||||
|     """ | ||||
| 
 | ||||
|     def __init__(self, hs): | ||||
|         super(TransactionStore, self).__init__(hs) | ||||
|     def __init__(self, db_conn, hs): | ||||
|         super(TransactionStore, self).__init__(db_conn, hs) | ||||
| 
 | ||||
|         self._clock.looping_call(self._cleanup_transactions, 30 * 60 * 1000) | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 Richard van der Hoff
						Richard van der Hoff