summary refs log tree commit diff
diff options
context:
space:
mode:
authorAndrew Morgan <andrew@amorgan.xyz>2020-02-26 12:13:06 +0000
committerAndrew Morgan <andrew@amorgan.xyz>2020-02-26 12:13:06 +0000
commitbebf75666a9ee5b78a5e4a72c14c01336d8ab8a9 (patch)
tree6c5082438de7d5a4f60f1d2f0c1bfb7228876fbf
parentMerge pull request #6153 from matrix-org/erikj/fix_room_list_non_federatable (diff)
parentMerge pull request #6154 from matrix-org/erikj/fix_appservice_pagination (diff)
downloadsynapse-bebf75666a9ee5b78a5e4a72c14c01336d8ab8a9.tar.xz
Merge pull request #6154 from matrix-org/erikj/fix_appservice_pagination
-rw-r--r--changelog.d/6154.misc1
-rw-r--r--synapse/storage/room.py36
2 files changed, 19 insertions, 18 deletions
diff --git a/changelog.d/6154.misc b/changelog.d/6154.misc
new file mode 100644

index 0000000000..dfee73c28f --- /dev/null +++ b/changelog.d/6154.misc
@@ -0,0 +1 @@ +Improve performance of the public room list directory. diff --git a/synapse/storage/room.py b/synapse/storage/room.py
index 3e1ca6ea39..9f67c1862c 100644 --- a/synapse/storage/room.py +++ b/synapse/storage/room.py
@@ -153,6 +153,24 @@ class RoomWorkerStore(SQLBaseStore): where_clauses = [] query_args = [] + if network_tuple: + if network_tuple.appservice_id: + published_sql = """ + SELECT room_id from appservice_room_list + WHERE appservice_id = ? AND network_id = ? + """ + query_args.append(network_tuple.appservice_id) + query_args.append(network_tuple.network_id) + else: + published_sql = """ + SELECT room_id FROM rooms WHERE is_public + """ + else: + published_sql = """ + SELECT room_id FROM rooms WHERE is_public + UNION SELECT room_id from appservice_room_list + """ + # Work out the bounds if we're given them, these bounds look slightly # odd, but are designed to help query planner use indices by pulling # out a common bound. @@ -194,24 +212,6 @@ class RoomWorkerStore(SQLBaseStore): ) query_args += [search_term, search_term, search_term] - if network_tuple: - if network_tuple.appservice_id: - published_sql = """ - SELECT room_id from appservice_room_list - WHERE appservice_id = ? AND network_id = ? - """ - query_args.append(network_tuple.appservice_id) - query_args.append(network_tuple.network_id) - else: - published_sql = """ - SELECT room_id FROM rooms WHERE is_public - """ - else: - published_sql = """ - SELECT room_id FROM rooms WHERE is_public - UNION SELECT room_id from appservice_room_list - """ - where_clause = "" if where_clauses: where_clause = " AND " + " AND ".join(where_clauses)