matrix-synapse 1.142.0rc3__cp314-abi3-musllinux_1_2_aarch64.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of matrix-synapse might be problematic. Click here for more details.

Files changed (1057) hide show
  1. matrix_synapse-1.142.0rc3.dist-info/AUTHORS.rst +51 -0
  2. matrix_synapse-1.142.0rc3.dist-info/LICENSE-AGPL-3.0 +661 -0
  3. matrix_synapse-1.142.0rc3.dist-info/LICENSE-COMMERCIAL +6 -0
  4. matrix_synapse-1.142.0rc3.dist-info/METADATA +375 -0
  5. matrix_synapse-1.142.0rc3.dist-info/RECORD +1057 -0
  6. matrix_synapse-1.142.0rc3.dist-info/WHEEL +4 -0
  7. matrix_synapse-1.142.0rc3.dist-info/entry_points.txt +14 -0
  8. matrix_synapse.libs/libgcc_s-2d945d6c.so.1 +0 -0
  9. synapse/__init__.py +97 -0
  10. synapse/_scripts/__init__.py +0 -0
  11. synapse/_scripts/export_signing_key.py +109 -0
  12. synapse/_scripts/generate_config.py +83 -0
  13. synapse/_scripts/generate_log_config.py +56 -0
  14. synapse/_scripts/generate_signing_key.py +55 -0
  15. synapse/_scripts/generate_workers_map.py +318 -0
  16. synapse/_scripts/hash_password.py +95 -0
  17. synapse/_scripts/move_remote_media_to_new_store.py +128 -0
  18. synapse/_scripts/register_new_matrix_user.py +374 -0
  19. synapse/_scripts/review_recent_signups.py +212 -0
  20. synapse/_scripts/synapse_port_db.py +1603 -0
  21. synapse/_scripts/synctl.py +365 -0
  22. synapse/_scripts/update_synapse_database.py +130 -0
  23. synapse/api/__init__.py +20 -0
  24. synapse/api/auth/__init__.py +207 -0
  25. synapse/api/auth/base.py +406 -0
  26. synapse/api/auth/internal.py +299 -0
  27. synapse/api/auth/mas.py +457 -0
  28. synapse/api/auth/msc3861_delegated.py +617 -0
  29. synapse/api/auth_blocking.py +144 -0
  30. synapse/api/constants.py +362 -0
  31. synapse/api/errors.py +907 -0
  32. synapse/api/filtering.py +539 -0
  33. synapse/api/presence.py +104 -0
  34. synapse/api/ratelimiting.py +482 -0
  35. synapse/api/room_versions.py +535 -0
  36. synapse/api/urls.py +119 -0
  37. synapse/app/__init__.py +60 -0
  38. synapse/app/_base.py +866 -0
  39. synapse/app/admin_cmd.py +388 -0
  40. synapse/app/appservice.py +30 -0
  41. synapse/app/client_reader.py +30 -0
  42. synapse/app/complement_fork_starter.py +206 -0
  43. synapse/app/event_creator.py +29 -0
  44. synapse/app/federation_reader.py +30 -0
  45. synapse/app/federation_sender.py +30 -0
  46. synapse/app/frontend_proxy.py +30 -0
  47. synapse/app/generic_worker.py +475 -0
  48. synapse/app/homeserver.py +504 -0
  49. synapse/app/media_repository.py +30 -0
  50. synapse/app/phone_stats_home.py +296 -0
  51. synapse/app/pusher.py +30 -0
  52. synapse/app/synchrotron.py +30 -0
  53. synapse/app/user_dir.py +31 -0
  54. synapse/appservice/__init__.py +461 -0
  55. synapse/appservice/api.py +569 -0
  56. synapse/appservice/scheduler.py +567 -0
  57. synapse/config/__init__.py +27 -0
  58. synapse/config/__main__.py +62 -0
  59. synapse/config/_base.py +1108 -0
  60. synapse/config/_base.pyi +217 -0
  61. synapse/config/_util.py +99 -0
  62. synapse/config/account_validity.py +116 -0
  63. synapse/config/api.py +141 -0
  64. synapse/config/appservice.py +210 -0
  65. synapse/config/auth.py +80 -0
  66. synapse/config/auto_accept_invites.py +43 -0
  67. synapse/config/background_updates.py +44 -0
  68. synapse/config/cache.py +231 -0
  69. synapse/config/captcha.py +90 -0
  70. synapse/config/cas.py +116 -0
  71. synapse/config/consent.py +73 -0
  72. synapse/config/database.py +184 -0
  73. synapse/config/emailconfig.py +367 -0
  74. synapse/config/experimental.py +595 -0
  75. synapse/config/federation.py +114 -0
  76. synapse/config/homeserver.py +141 -0
  77. synapse/config/jwt.py +55 -0
  78. synapse/config/key.py +447 -0
  79. synapse/config/logger.py +390 -0
  80. synapse/config/mas.py +191 -0
  81. synapse/config/matrixrtc.py +66 -0
  82. synapse/config/metrics.py +84 -0
  83. synapse/config/modules.py +40 -0
  84. synapse/config/oembed.py +185 -0
  85. synapse/config/oidc.py +509 -0
  86. synapse/config/password_auth_providers.py +82 -0
  87. synapse/config/push.py +64 -0
  88. synapse/config/ratelimiting.py +254 -0
  89. synapse/config/redis.py +74 -0
  90. synapse/config/registration.py +296 -0
  91. synapse/config/repository.py +311 -0
  92. synapse/config/retention.py +162 -0
  93. synapse/config/room.py +88 -0
  94. synapse/config/room_directory.py +165 -0
  95. synapse/config/saml2.py +251 -0
  96. synapse/config/server.py +1170 -0
  97. synapse/config/server_notices.py +84 -0
  98. synapse/config/spam_checker.py +66 -0
  99. synapse/config/sso.py +121 -0
  100. synapse/config/stats.py +54 -0
  101. synapse/config/third_party_event_rules.py +40 -0
  102. synapse/config/tls.py +192 -0
  103. synapse/config/tracer.py +71 -0
  104. synapse/config/user_directory.py +47 -0
  105. synapse/config/user_types.py +44 -0
  106. synapse/config/voip.py +59 -0
  107. synapse/config/workers.py +642 -0
  108. synapse/crypto/__init__.py +20 -0
  109. synapse/crypto/context_factory.py +278 -0
  110. synapse/crypto/event_signing.py +194 -0
  111. synapse/crypto/keyring.py +931 -0
  112. synapse/event_auth.py +1266 -0
  113. synapse/events/__init__.py +668 -0
  114. synapse/events/auto_accept_invites.py +216 -0
  115. synapse/events/builder.py +387 -0
  116. synapse/events/presence_router.py +245 -0
  117. synapse/events/snapshot.py +559 -0
  118. synapse/events/utils.py +928 -0
  119. synapse/events/validator.py +305 -0
  120. synapse/federation/__init__.py +22 -0
  121. synapse/federation/federation_base.py +383 -0
  122. synapse/federation/federation_client.py +2134 -0
  123. synapse/federation/federation_server.py +1544 -0
  124. synapse/federation/persistence.py +71 -0
  125. synapse/federation/send_queue.py +532 -0
  126. synapse/federation/sender/__init__.py +1165 -0
  127. synapse/federation/sender/per_destination_queue.py +884 -0
  128. synapse/federation/sender/transaction_manager.py +210 -0
  129. synapse/federation/transport/__init__.py +28 -0
  130. synapse/federation/transport/client.py +1201 -0
  131. synapse/federation/transport/server/__init__.py +334 -0
  132. synapse/federation/transport/server/_base.py +429 -0
  133. synapse/federation/transport/server/federation.py +912 -0
  134. synapse/federation/units.py +133 -0
  135. synapse/handlers/__init__.py +20 -0
  136. synapse/handlers/account.py +162 -0
  137. synapse/handlers/account_data.py +362 -0
  138. synapse/handlers/account_validity.py +361 -0
  139. synapse/handlers/admin.py +618 -0
  140. synapse/handlers/appservice.py +991 -0
  141. synapse/handlers/auth.py +2494 -0
  142. synapse/handlers/cas.py +413 -0
  143. synapse/handlers/deactivate_account.py +363 -0
  144. synapse/handlers/delayed_events.py +635 -0
  145. synapse/handlers/device.py +1873 -0
  146. synapse/handlers/devicemessage.py +399 -0
  147. synapse/handlers/directory.py +554 -0
  148. synapse/handlers/e2e_keys.py +1834 -0
  149. synapse/handlers/e2e_room_keys.py +455 -0
  150. synapse/handlers/event_auth.py +390 -0
  151. synapse/handlers/events.py +201 -0
  152. synapse/handlers/federation.py +2043 -0
  153. synapse/handlers/federation_event.py +2420 -0
  154. synapse/handlers/identity.py +812 -0
  155. synapse/handlers/initial_sync.py +528 -0
  156. synapse/handlers/jwt.py +120 -0
  157. synapse/handlers/message.py +2347 -0
  158. synapse/handlers/oidc.py +1803 -0
  159. synapse/handlers/pagination.py +768 -0
  160. synapse/handlers/password_policy.py +102 -0
  161. synapse/handlers/presence.py +2638 -0
  162. synapse/handlers/profile.py +655 -0
  163. synapse/handlers/push_rules.py +164 -0
  164. synapse/handlers/read_marker.py +79 -0
  165. synapse/handlers/receipts.py +351 -0
  166. synapse/handlers/register.py +1060 -0
  167. synapse/handlers/relations.py +624 -0
  168. synapse/handlers/reports.py +98 -0
  169. synapse/handlers/room.py +2447 -0
  170. synapse/handlers/room_list.py +632 -0
  171. synapse/handlers/room_member.py +2365 -0
  172. synapse/handlers/room_member_worker.py +146 -0
  173. synapse/handlers/room_policy.py +186 -0
  174. synapse/handlers/room_summary.py +1057 -0
  175. synapse/handlers/saml.py +524 -0
  176. synapse/handlers/search.py +723 -0
  177. synapse/handlers/send_email.py +209 -0
  178. synapse/handlers/set_password.py +71 -0
  179. synapse/handlers/sliding_sync/__init__.py +1701 -0
  180. synapse/handlers/sliding_sync/extensions.py +970 -0
  181. synapse/handlers/sliding_sync/room_lists.py +2266 -0
  182. synapse/handlers/sliding_sync/store.py +128 -0
  183. synapse/handlers/sso.py +1292 -0
  184. synapse/handlers/state_deltas.py +82 -0
  185. synapse/handlers/stats.py +322 -0
  186. synapse/handlers/sync.py +3109 -0
  187. synapse/handlers/thread_subscriptions.py +190 -0
  188. synapse/handlers/typing.py +606 -0
  189. synapse/handlers/ui_auth/__init__.py +48 -0
  190. synapse/handlers/ui_auth/checkers.py +332 -0
  191. synapse/handlers/user_directory.py +783 -0
  192. synapse/handlers/worker_lock.py +365 -0
  193. synapse/http/__init__.py +106 -0
  194. synapse/http/additional_resource.py +62 -0
  195. synapse/http/client.py +1360 -0
  196. synapse/http/connectproxyclient.py +309 -0
  197. synapse/http/federation/__init__.py +19 -0
  198. synapse/http/federation/matrix_federation_agent.py +490 -0
  199. synapse/http/federation/srv_resolver.py +196 -0
  200. synapse/http/federation/well_known_resolver.py +367 -0
  201. synapse/http/matrixfederationclient.py +1875 -0
  202. synapse/http/proxy.py +290 -0
  203. synapse/http/proxyagent.py +497 -0
  204. synapse/http/replicationagent.py +203 -0
  205. synapse/http/request_metrics.py +309 -0
  206. synapse/http/server.py +1114 -0
  207. synapse/http/servlet.py +1019 -0
  208. synapse/http/site.py +825 -0
  209. synapse/http/types.py +27 -0
  210. synapse/logging/__init__.py +31 -0
  211. synapse/logging/_remote.py +261 -0
  212. synapse/logging/_terse_json.py +95 -0
  213. synapse/logging/context.py +1211 -0
  214. synapse/logging/formatter.py +63 -0
  215. synapse/logging/handlers.py +99 -0
  216. synapse/logging/loggers.py +25 -0
  217. synapse/logging/opentracing.py +1132 -0
  218. synapse/logging/scopecontextmanager.py +161 -0
  219. synapse/media/_base.py +827 -0
  220. synapse/media/filepath.py +417 -0
  221. synapse/media/media_repository.py +1580 -0
  222. synapse/media/media_storage.py +704 -0
  223. synapse/media/oembed.py +277 -0
  224. synapse/media/preview_html.py +559 -0
  225. synapse/media/storage_provider.py +195 -0
  226. synapse/media/thumbnailer.py +833 -0
  227. synapse/media/url_previewer.py +875 -0
  228. synapse/metrics/__init__.py +754 -0
  229. synapse/metrics/_gc.py +219 -0
  230. synapse/metrics/_reactor_metrics.py +171 -0
  231. synapse/metrics/_types.py +38 -0
  232. synapse/metrics/background_process_metrics.py +556 -0
  233. synapse/metrics/common_usage_metrics.py +94 -0
  234. synapse/metrics/jemalloc.py +248 -0
  235. synapse/module_api/__init__.py +2154 -0
  236. synapse/module_api/callbacks/__init__.py +50 -0
  237. synapse/module_api/callbacks/account_validity_callbacks.py +106 -0
  238. synapse/module_api/callbacks/media_repository_callbacks.py +160 -0
  239. synapse/module_api/callbacks/ratelimit_callbacks.py +79 -0
  240. synapse/module_api/callbacks/spamchecker_callbacks.py +1113 -0
  241. synapse/module_api/callbacks/third_party_event_rules_callbacks.py +599 -0
  242. synapse/module_api/errors.py +42 -0
  243. synapse/notifier.py +972 -0
  244. synapse/push/__init__.py +212 -0
  245. synapse/push/bulk_push_rule_evaluator.py +637 -0
  246. synapse/push/clientformat.py +126 -0
  247. synapse/push/emailpusher.py +333 -0
  248. synapse/push/httppusher.py +564 -0
  249. synapse/push/mailer.py +1012 -0
  250. synapse/push/presentable_names.py +216 -0
  251. synapse/push/push_tools.py +114 -0
  252. synapse/push/push_types.py +141 -0
  253. synapse/push/pusher.py +87 -0
  254. synapse/push/pusherpool.py +501 -0
  255. synapse/push/rulekinds.py +33 -0
  256. synapse/py.typed +0 -0
  257. synapse/replication/__init__.py +20 -0
  258. synapse/replication/http/__init__.py +68 -0
  259. synapse/replication/http/_base.py +468 -0
  260. synapse/replication/http/account_data.py +297 -0
  261. synapse/replication/http/deactivate_account.py +81 -0
  262. synapse/replication/http/delayed_events.py +62 -0
  263. synapse/replication/http/devices.py +254 -0
  264. synapse/replication/http/federation.py +334 -0
  265. synapse/replication/http/login.py +106 -0
  266. synapse/replication/http/membership.py +364 -0
  267. synapse/replication/http/presence.py +133 -0
  268. synapse/replication/http/push.py +156 -0
  269. synapse/replication/http/register.py +172 -0
  270. synapse/replication/http/send_events.py +182 -0
  271. synapse/replication/http/state.py +82 -0
  272. synapse/replication/http/streams.py +101 -0
  273. synapse/replication/tcp/__init__.py +56 -0
  274. synapse/replication/tcp/client.py +552 -0
  275. synapse/replication/tcp/commands.py +569 -0
  276. synapse/replication/tcp/context.py +41 -0
  277. synapse/replication/tcp/external_cache.py +156 -0
  278. synapse/replication/tcp/handler.py +942 -0
  279. synapse/replication/tcp/protocol.py +608 -0
  280. synapse/replication/tcp/redis.py +509 -0
  281. synapse/replication/tcp/resource.py +348 -0
  282. synapse/replication/tcp/streams/__init__.py +96 -0
  283. synapse/replication/tcp/streams/_base.py +766 -0
  284. synapse/replication/tcp/streams/events.py +287 -0
  285. synapse/replication/tcp/streams/federation.py +92 -0
  286. synapse/replication/tcp/streams/partial_state.py +80 -0
  287. synapse/res/providers.json +29 -0
  288. synapse/res/templates/_base.html +29 -0
  289. synapse/res/templates/account_previously_renewed.html +6 -0
  290. synapse/res/templates/account_renewed.html +6 -0
  291. synapse/res/templates/add_threepid.html +8 -0
  292. synapse/res/templates/add_threepid.txt +6 -0
  293. synapse/res/templates/add_threepid_failure.html +7 -0
  294. synapse/res/templates/add_threepid_success.html +6 -0
  295. synapse/res/templates/already_in_use.html +12 -0
  296. synapse/res/templates/already_in_use.txt +10 -0
  297. synapse/res/templates/auth_success.html +21 -0
  298. synapse/res/templates/invalid_token.html +6 -0
  299. synapse/res/templates/mail-Element.css +7 -0
  300. synapse/res/templates/mail-Vector.css +7 -0
  301. synapse/res/templates/mail-expiry.css +4 -0
  302. synapse/res/templates/mail.css +156 -0
  303. synapse/res/templates/notice_expiry.html +46 -0
  304. synapse/res/templates/notice_expiry.txt +7 -0
  305. synapse/res/templates/notif.html +51 -0
  306. synapse/res/templates/notif.txt +22 -0
  307. synapse/res/templates/notif_mail.html +59 -0
  308. synapse/res/templates/notif_mail.txt +10 -0
  309. synapse/res/templates/password_reset.html +10 -0
  310. synapse/res/templates/password_reset.txt +7 -0
  311. synapse/res/templates/password_reset_confirmation.html +15 -0
  312. synapse/res/templates/password_reset_failure.html +7 -0
  313. synapse/res/templates/password_reset_success.html +6 -0
  314. synapse/res/templates/recaptcha.html +42 -0
  315. synapse/res/templates/registration.html +12 -0
  316. synapse/res/templates/registration.txt +10 -0
  317. synapse/res/templates/registration_failure.html +6 -0
  318. synapse/res/templates/registration_success.html +6 -0
  319. synapse/res/templates/registration_token.html +18 -0
  320. synapse/res/templates/room.html +33 -0
  321. synapse/res/templates/room.txt +9 -0
  322. synapse/res/templates/sso.css +129 -0
  323. synapse/res/templates/sso_account_deactivated.html +25 -0
  324. synapse/res/templates/sso_auth_account_details.html +186 -0
  325. synapse/res/templates/sso_auth_account_details.js +116 -0
  326. synapse/res/templates/sso_auth_bad_user.html +26 -0
  327. synapse/res/templates/sso_auth_confirm.html +27 -0
  328. synapse/res/templates/sso_auth_success.html +26 -0
  329. synapse/res/templates/sso_error.html +71 -0
  330. synapse/res/templates/sso_footer.html +19 -0
  331. synapse/res/templates/sso_login_idp_picker.html +60 -0
  332. synapse/res/templates/sso_new_user_consent.html +30 -0
  333. synapse/res/templates/sso_partial_profile.html +19 -0
  334. synapse/res/templates/sso_redirect_confirm.html +39 -0
  335. synapse/res/templates/style.css +33 -0
  336. synapse/res/templates/terms.html +27 -0
  337. synapse/rest/__init__.py +197 -0
  338. synapse/rest/admin/__init__.py +390 -0
  339. synapse/rest/admin/_base.py +72 -0
  340. synapse/rest/admin/background_updates.py +171 -0
  341. synapse/rest/admin/devices.py +221 -0
  342. synapse/rest/admin/event_reports.py +173 -0
  343. synapse/rest/admin/events.py +69 -0
  344. synapse/rest/admin/experimental_features.py +137 -0
  345. synapse/rest/admin/federation.py +243 -0
  346. synapse/rest/admin/media.py +540 -0
  347. synapse/rest/admin/registration_tokens.py +358 -0
  348. synapse/rest/admin/rooms.py +1061 -0
  349. synapse/rest/admin/scheduled_tasks.py +70 -0
  350. synapse/rest/admin/server_notice_servlet.py +132 -0
  351. synapse/rest/admin/statistics.py +132 -0
  352. synapse/rest/admin/username_available.py +58 -0
  353. synapse/rest/admin/users.py +1608 -0
  354. synapse/rest/client/__init__.py +20 -0
  355. synapse/rest/client/_base.py +113 -0
  356. synapse/rest/client/account.py +930 -0
  357. synapse/rest/client/account_data.py +319 -0
  358. synapse/rest/client/account_validity.py +103 -0
  359. synapse/rest/client/appservice_ping.py +125 -0
  360. synapse/rest/client/auth.py +218 -0
  361. synapse/rest/client/auth_metadata.py +122 -0
  362. synapse/rest/client/capabilities.py +121 -0
  363. synapse/rest/client/delayed_events.py +111 -0
  364. synapse/rest/client/devices.py +587 -0
  365. synapse/rest/client/directory.py +211 -0
  366. synapse/rest/client/events.py +116 -0
  367. synapse/rest/client/filter.py +112 -0
  368. synapse/rest/client/initial_sync.py +65 -0
  369. synapse/rest/client/keys.py +678 -0
  370. synapse/rest/client/knock.py +104 -0
  371. synapse/rest/client/login.py +754 -0
  372. synapse/rest/client/login_token_request.py +127 -0
  373. synapse/rest/client/logout.py +93 -0
  374. synapse/rest/client/matrixrtc.py +52 -0
  375. synapse/rest/client/media.py +286 -0
  376. synapse/rest/client/mutual_rooms.py +93 -0
  377. synapse/rest/client/notifications.py +137 -0
  378. synapse/rest/client/openid.py +109 -0
  379. synapse/rest/client/password_policy.py +69 -0
  380. synapse/rest/client/presence.py +131 -0
  381. synapse/rest/client/profile.py +291 -0
  382. synapse/rest/client/push_rule.py +331 -0
  383. synapse/rest/client/pusher.py +181 -0
  384. synapse/rest/client/read_marker.py +104 -0
  385. synapse/rest/client/receipts.py +165 -0
  386. synapse/rest/client/register.py +1067 -0
  387. synapse/rest/client/relations.py +138 -0
  388. synapse/rest/client/rendezvous.py +76 -0
  389. synapse/rest/client/reporting.py +207 -0
  390. synapse/rest/client/room.py +1669 -0
  391. synapse/rest/client/room_keys.py +426 -0
  392. synapse/rest/client/room_upgrade_rest_servlet.py +112 -0
  393. synapse/rest/client/sendtodevice.py +85 -0
  394. synapse/rest/client/sync.py +1131 -0
  395. synapse/rest/client/tags.py +129 -0
  396. synapse/rest/client/thirdparty.py +130 -0
  397. synapse/rest/client/thread_subscriptions.py +247 -0
  398. synapse/rest/client/tokenrefresh.py +52 -0
  399. synapse/rest/client/transactions.py +149 -0
  400. synapse/rest/client/user_directory.py +90 -0
  401. synapse/rest/client/versions.py +191 -0
  402. synapse/rest/client/voip.py +88 -0
  403. synapse/rest/consent/__init__.py +0 -0
  404. synapse/rest/consent/consent_resource.py +210 -0
  405. synapse/rest/health.py +38 -0
  406. synapse/rest/key/__init__.py +20 -0
  407. synapse/rest/key/v2/__init__.py +40 -0
  408. synapse/rest/key/v2/local_key_resource.py +125 -0
  409. synapse/rest/key/v2/remote_key_resource.py +302 -0
  410. synapse/rest/media/__init__.py +0 -0
  411. synapse/rest/media/config_resource.py +53 -0
  412. synapse/rest/media/create_resource.py +90 -0
  413. synapse/rest/media/download_resource.py +110 -0
  414. synapse/rest/media/media_repository_resource.py +113 -0
  415. synapse/rest/media/preview_url_resource.py +77 -0
  416. synapse/rest/media/thumbnail_resource.py +142 -0
  417. synapse/rest/media/upload_resource.py +187 -0
  418. synapse/rest/media/v1/__init__.py +39 -0
  419. synapse/rest/media/v1/_base.py +23 -0
  420. synapse/rest/media/v1/media_storage.py +23 -0
  421. synapse/rest/media/v1/storage_provider.py +23 -0
  422. synapse/rest/synapse/__init__.py +20 -0
  423. synapse/rest/synapse/client/__init__.py +93 -0
  424. synapse/rest/synapse/client/federation_whitelist.py +66 -0
  425. synapse/rest/synapse/client/jwks.py +77 -0
  426. synapse/rest/synapse/client/new_user_consent.py +115 -0
  427. synapse/rest/synapse/client/oidc/__init__.py +45 -0
  428. synapse/rest/synapse/client/oidc/backchannel_logout_resource.py +42 -0
  429. synapse/rest/synapse/client/oidc/callback_resource.py +48 -0
  430. synapse/rest/synapse/client/password_reset.py +129 -0
  431. synapse/rest/synapse/client/pick_idp.py +107 -0
  432. synapse/rest/synapse/client/pick_username.py +153 -0
  433. synapse/rest/synapse/client/rendezvous.py +58 -0
  434. synapse/rest/synapse/client/saml2/__init__.py +42 -0
  435. synapse/rest/synapse/client/saml2/metadata_resource.py +46 -0
  436. synapse/rest/synapse/client/saml2/response_resource.py +52 -0
  437. synapse/rest/synapse/client/sso_register.py +56 -0
  438. synapse/rest/synapse/client/unsubscribe.py +88 -0
  439. synapse/rest/synapse/mas/__init__.py +71 -0
  440. synapse/rest/synapse/mas/_base.py +55 -0
  441. synapse/rest/synapse/mas/devices.py +239 -0
  442. synapse/rest/synapse/mas/users.py +469 -0
  443. synapse/rest/well_known.py +148 -0
  444. synapse/server.py +1258 -0
  445. synapse/server_notices/__init__.py +0 -0
  446. synapse/server_notices/consent_server_notices.py +136 -0
  447. synapse/server_notices/resource_limits_server_notices.py +215 -0
  448. synapse/server_notices/server_notices_manager.py +388 -0
  449. synapse/server_notices/server_notices_sender.py +67 -0
  450. synapse/server_notices/worker_server_notices_sender.py +46 -0
  451. synapse/spam_checker_api/__init__.py +31 -0
  452. synapse/state/__init__.py +1022 -0
  453. synapse/state/v1.py +370 -0
  454. synapse/state/v2.py +985 -0
  455. synapse/static/client/login/index.html +47 -0
  456. synapse/static/client/login/js/jquery-3.4.1.min.js +2 -0
  457. synapse/static/client/login/js/login.js +291 -0
  458. synapse/static/client/login/spinner.gif +0 -0
  459. synapse/static/client/login/style.css +79 -0
  460. synapse/static/index.html +63 -0
  461. synapse/storage/__init__.py +43 -0
  462. synapse/storage/_base.py +245 -0
  463. synapse/storage/admin_client_config.py +26 -0
  464. synapse/storage/background_updates.py +1189 -0
  465. synapse/storage/controllers/__init__.py +57 -0
  466. synapse/storage/controllers/persist_events.py +1239 -0
  467. synapse/storage/controllers/purge_events.py +456 -0
  468. synapse/storage/controllers/state.py +954 -0
  469. synapse/storage/controllers/stats.py +119 -0
  470. synapse/storage/database.py +2720 -0
  471. synapse/storage/databases/__init__.py +175 -0
  472. synapse/storage/databases/main/__init__.py +424 -0
  473. synapse/storage/databases/main/account_data.py +1060 -0
  474. synapse/storage/databases/main/appservice.py +473 -0
  475. synapse/storage/databases/main/cache.py +911 -0
  476. synapse/storage/databases/main/censor_events.py +225 -0
  477. synapse/storage/databases/main/client_ips.py +817 -0
  478. synapse/storage/databases/main/delayed_events.py +560 -0
  479. synapse/storage/databases/main/deviceinbox.py +1272 -0
  480. synapse/storage/databases/main/devices.py +2581 -0
  481. synapse/storage/databases/main/directory.py +212 -0
  482. synapse/storage/databases/main/e2e_room_keys.py +690 -0
  483. synapse/storage/databases/main/end_to_end_keys.py +1896 -0
  484. synapse/storage/databases/main/event_federation.py +2509 -0
  485. synapse/storage/databases/main/event_push_actions.py +1937 -0
  486. synapse/storage/databases/main/events.py +3746 -0
  487. synapse/storage/databases/main/events_bg_updates.py +2910 -0
  488. synapse/storage/databases/main/events_forward_extremities.py +126 -0
  489. synapse/storage/databases/main/events_worker.py +2784 -0
  490. synapse/storage/databases/main/experimental_features.py +130 -0
  491. synapse/storage/databases/main/filtering.py +231 -0
  492. synapse/storage/databases/main/keys.py +291 -0
  493. synapse/storage/databases/main/lock.py +553 -0
  494. synapse/storage/databases/main/media_repository.py +1070 -0
  495. synapse/storage/databases/main/metrics.py +460 -0
  496. synapse/storage/databases/main/monthly_active_users.py +443 -0
  497. synapse/storage/databases/main/openid.py +61 -0
  498. synapse/storage/databases/main/presence.py +511 -0
  499. synapse/storage/databases/main/profile.py +541 -0
  500. synapse/storage/databases/main/purge_events.py +511 -0
  501. synapse/storage/databases/main/push_rule.py +972 -0
  502. synapse/storage/databases/main/pusher.py +794 -0
  503. synapse/storage/databases/main/receipts.py +1342 -0
  504. synapse/storage/databases/main/registration.py +3076 -0
  505. synapse/storage/databases/main/rejections.py +38 -0
  506. synapse/storage/databases/main/relations.py +1118 -0
  507. synapse/storage/databases/main/room.py +2781 -0
  508. synapse/storage/databases/main/roommember.py +2112 -0
  509. synapse/storage/databases/main/search.py +941 -0
  510. synapse/storage/databases/main/session.py +151 -0
  511. synapse/storage/databases/main/signatures.py +94 -0
  512. synapse/storage/databases/main/sliding_sync.py +603 -0
  513. synapse/storage/databases/main/state.py +1006 -0
  514. synapse/storage/databases/main/state_deltas.py +329 -0
  515. synapse/storage/databases/main/stats.py +791 -0
  516. synapse/storage/databases/main/stream.py +2580 -0
  517. synapse/storage/databases/main/tags.py +360 -0
  518. synapse/storage/databases/main/task_scheduler.py +225 -0
  519. synapse/storage/databases/main/thread_subscriptions.py +591 -0
  520. synapse/storage/databases/main/transactions.py +681 -0
  521. synapse/storage/databases/main/ui_auth.py +420 -0
  522. synapse/storage/databases/main/user_directory.py +1331 -0
  523. synapse/storage/databases/main/user_erasure_store.py +117 -0
  524. synapse/storage/databases/state/__init__.py +22 -0
  525. synapse/storage/databases/state/bg_updates.py +499 -0
  526. synapse/storage/databases/state/deletion.py +558 -0
  527. synapse/storage/databases/state/store.py +949 -0
  528. synapse/storage/engines/__init__.py +70 -0
  529. synapse/storage/engines/_base.py +154 -0
  530. synapse/storage/engines/postgres.py +261 -0
  531. synapse/storage/engines/sqlite.py +199 -0
  532. synapse/storage/invite_rule.py +112 -0
  533. synapse/storage/keys.py +40 -0
  534. synapse/storage/prepare_database.py +731 -0
  535. synapse/storage/push_rule.py +28 -0
  536. synapse/storage/roommember.py +89 -0
  537. synapse/storage/schema/README.md +4 -0
  538. synapse/storage/schema/__init__.py +182 -0
  539. synapse/storage/schema/common/delta/25/00background_updates.sql +40 -0
  540. synapse/storage/schema/common/delta/35/00background_updates_add_col.sql +36 -0
  541. synapse/storage/schema/common/delta/58/00background_update_ordering.sql +38 -0
  542. synapse/storage/schema/common/full_schemas/72/full.sql.postgres +8 -0
  543. synapse/storage/schema/common/full_schemas/72/full.sql.sqlite +6 -0
  544. synapse/storage/schema/common/schema_version.sql +60 -0
  545. synapse/storage/schema/main/delta/12/v12.sql +82 -0
  546. synapse/storage/schema/main/delta/13/v13.sql +38 -0
  547. synapse/storage/schema/main/delta/14/v14.sql +42 -0
  548. synapse/storage/schema/main/delta/15/appservice_txns.sql +50 -0
  549. synapse/storage/schema/main/delta/15/presence_indices.sql +2 -0
  550. synapse/storage/schema/main/delta/15/v15.sql +24 -0
  551. synapse/storage/schema/main/delta/16/events_order_index.sql +4 -0
  552. synapse/storage/schema/main/delta/16/remote_media_cache_index.sql +2 -0
  553. synapse/storage/schema/main/delta/16/remove_duplicates.sql +9 -0
  554. synapse/storage/schema/main/delta/16/room_alias_index.sql +3 -0
  555. synapse/storage/schema/main/delta/16/unique_constraints.sql +72 -0
  556. synapse/storage/schema/main/delta/16/users.sql +56 -0
  557. synapse/storage/schema/main/delta/17/drop_indexes.sql +37 -0
  558. synapse/storage/schema/main/delta/17/server_keys.sql +43 -0
  559. synapse/storage/schema/main/delta/17/user_threepids.sql +9 -0
  560. synapse/storage/schema/main/delta/18/server_keys_bigger_ints.sql +51 -0
  561. synapse/storage/schema/main/delta/19/event_index.sql +38 -0
  562. synapse/storage/schema/main/delta/20/dummy.sql +1 -0
  563. synapse/storage/schema/main/delta/20/pushers.py +93 -0
  564. synapse/storage/schema/main/delta/21/end_to_end_keys.sql +53 -0
  565. synapse/storage/schema/main/delta/21/receipts.sql +57 -0
  566. synapse/storage/schema/main/delta/22/receipts_index.sql +41 -0
  567. synapse/storage/schema/main/delta/22/user_threepids_unique.sql +19 -0
  568. synapse/storage/schema/main/delta/24/stats_reporting.sql +37 -0
  569. synapse/storage/schema/main/delta/25/fts.py +81 -0
  570. synapse/storage/schema/main/delta/25/guest_access.sql +44 -0
  571. synapse/storage/schema/main/delta/25/history_visibility.sql +44 -0
  572. synapse/storage/schema/main/delta/25/tags.sql +57 -0
  573. synapse/storage/schema/main/delta/26/account_data.sql +36 -0
  574. synapse/storage/schema/main/delta/27/account_data.sql +55 -0
  575. synapse/storage/schema/main/delta/27/forgotten_memberships.sql +45 -0
  576. synapse/storage/schema/main/delta/27/ts.py +61 -0
  577. synapse/storage/schema/main/delta/28/event_push_actions.sql +46 -0
  578. synapse/storage/schema/main/delta/28/events_room_stream.sql +39 -0
  579. synapse/storage/schema/main/delta/28/public_roms_index.sql +39 -0
  580. synapse/storage/schema/main/delta/28/receipts_user_id_index.sql +41 -0
  581. synapse/storage/schema/main/delta/28/upgrade_times.sql +40 -0
  582. synapse/storage/schema/main/delta/28/users_is_guest.sql +41 -0
  583. synapse/storage/schema/main/delta/29/push_actions.sql +54 -0
  584. synapse/storage/schema/main/delta/30/alias_creator.sql +35 -0
  585. synapse/storage/schema/main/delta/30/as_users.py +82 -0
  586. synapse/storage/schema/main/delta/30/deleted_pushers.sql +44 -0
  587. synapse/storage/schema/main/delta/30/presence_stream.sql +49 -0
  588. synapse/storage/schema/main/delta/30/public_rooms.sql +42 -0
  589. synapse/storage/schema/main/delta/30/push_rule_stream.sql +57 -0
  590. synapse/storage/schema/main/delta/30/threepid_guest_access_tokens.sql +43 -0
  591. synapse/storage/schema/main/delta/31/invites.sql +61 -0
  592. synapse/storage/schema/main/delta/31/local_media_repository_url_cache.sql +46 -0
  593. synapse/storage/schema/main/delta/31/pushers_0.py +92 -0
  594. synapse/storage/schema/main/delta/31/pushers_index.sql +41 -0
  595. synapse/storage/schema/main/delta/31/search_update.py +65 -0
  596. synapse/storage/schema/main/delta/32/events.sql +35 -0
  597. synapse/storage/schema/main/delta/32/openid.sql +9 -0
  598. synapse/storage/schema/main/delta/32/pusher_throttle.sql +42 -0
  599. synapse/storage/schema/main/delta/32/remove_indices.sql +52 -0
  600. synapse/storage/schema/main/delta/32/reports.sql +44 -0
  601. synapse/storage/schema/main/delta/33/access_tokens_device_index.sql +36 -0
  602. synapse/storage/schema/main/delta/33/devices.sql +40 -0
  603. synapse/storage/schema/main/delta/33/devices_for_e2e_keys.sql +38 -0
  604. synapse/storage/schema/main/delta/33/devices_for_e2e_keys_clear_unknown_device.sql +39 -0
  605. synapse/storage/schema/main/delta/33/event_fields.py +61 -0
  606. synapse/storage/schema/main/delta/33/remote_media_ts.py +43 -0
  607. synapse/storage/schema/main/delta/33/user_ips_index.sql +36 -0
  608. synapse/storage/schema/main/delta/34/appservice_stream.sql +42 -0
  609. synapse/storage/schema/main/delta/34/cache_stream.py +50 -0
  610. synapse/storage/schema/main/delta/34/device_inbox.sql +43 -0
  611. synapse/storage/schema/main/delta/34/push_display_name_rename.sql +39 -0
  612. synapse/storage/schema/main/delta/34/received_txn_purge.py +36 -0
  613. synapse/storage/schema/main/delta/35/contains_url.sql +36 -0
  614. synapse/storage/schema/main/delta/35/device_outbox.sql +58 -0
  615. synapse/storage/schema/main/delta/35/device_stream_id.sql +40 -0
  616. synapse/storage/schema/main/delta/35/event_push_actions_index.sql +36 -0
  617. synapse/storage/schema/main/delta/35/public_room_list_change_stream.sql +52 -0
  618. synapse/storage/schema/main/delta/35/stream_order_to_extrem.sql +56 -0
  619. synapse/storage/schema/main/delta/36/readd_public_rooms.sql +45 -0
  620. synapse/storage/schema/main/delta/37/remove_auth_idx.py +89 -0
  621. synapse/storage/schema/main/delta/37/user_threepids.sql +71 -0
  622. synapse/storage/schema/main/delta/38/postgres_fts_gist.sql +38 -0
  623. synapse/storage/schema/main/delta/39/appservice_room_list.sql +48 -0
  624. synapse/storage/schema/main/delta/39/device_federation_stream_idx.sql +35 -0
  625. synapse/storage/schema/main/delta/39/event_push_index.sql +36 -0
  626. synapse/storage/schema/main/delta/39/federation_out_position.sql +41 -0
  627. synapse/storage/schema/main/delta/39/membership_profile.sql +39 -0
  628. synapse/storage/schema/main/delta/40/current_state_idx.sql +36 -0
  629. synapse/storage/schema/main/delta/40/device_inbox.sql +40 -0
  630. synapse/storage/schema/main/delta/40/device_list_streams.sql +79 -0
  631. synapse/storage/schema/main/delta/40/event_push_summary.sql +57 -0
  632. synapse/storage/schema/main/delta/40/pushers.sql +58 -0
  633. synapse/storage/schema/main/delta/41/device_list_stream_idx.sql +36 -0
  634. synapse/storage/schema/main/delta/41/device_outbound_index.sql +35 -0
  635. synapse/storage/schema/main/delta/41/event_search_event_id_idx.sql +36 -0
  636. synapse/storage/schema/main/delta/41/ratelimit.sql +41 -0
  637. synapse/storage/schema/main/delta/42/current_state_delta.sql +48 -0
  638. synapse/storage/schema/main/delta/42/device_list_last_id.sql +52 -0
  639. synapse/storage/schema/main/delta/42/event_auth_state_only.sql +36 -0
  640. synapse/storage/schema/main/delta/42/user_dir.py +88 -0
  641. synapse/storage/schema/main/delta/43/blocked_rooms.sql +40 -0
  642. synapse/storage/schema/main/delta/43/quarantine_media.sql +36 -0
  643. synapse/storage/schema/main/delta/43/url_cache.sql +35 -0
  644. synapse/storage/schema/main/delta/43/user_share.sql +52 -0
  645. synapse/storage/schema/main/delta/44/expire_url_cache.sql +60 -0
  646. synapse/storage/schema/main/delta/45/group_server.sql +186 -0
  647. synapse/storage/schema/main/delta/45/profile_cache.sql +47 -0
  648. synapse/storage/schema/main/delta/46/drop_refresh_tokens.sql +36 -0
  649. synapse/storage/schema/main/delta/46/drop_unique_deleted_pushers.sql +54 -0
  650. synapse/storage/schema/main/delta/46/group_server.sql +51 -0
  651. synapse/storage/schema/main/delta/46/local_media_repository_url_idx.sql +43 -0
  652. synapse/storage/schema/main/delta/46/user_dir_null_room_ids.sql +54 -0
  653. synapse/storage/schema/main/delta/46/user_dir_typos.sql +43 -0
  654. synapse/storage/schema/main/delta/47/last_access_media.sql +35 -0
  655. synapse/storage/schema/main/delta/47/postgres_fts_gin.sql +36 -0
  656. synapse/storage/schema/main/delta/47/push_actions_staging.sql +47 -0
  657. synapse/storage/schema/main/delta/48/add_user_consent.sql +37 -0
  658. synapse/storage/schema/main/delta/48/add_user_ips_last_seen_index.sql +36 -0
  659. synapse/storage/schema/main/delta/48/deactivated_users.sql +44 -0
  660. synapse/storage/schema/main/delta/48/group_unique_indexes.py +67 -0
  661. synapse/storage/schema/main/delta/48/groups_joinable.sql +41 -0
  662. synapse/storage/schema/main/delta/49/add_user_consent_server_notice_sent.sql +39 -0
  663. synapse/storage/schema/main/delta/49/add_user_daily_visits.sql +40 -0
  664. synapse/storage/schema/main/delta/49/add_user_ips_last_seen_only_index.sql +36 -0
  665. synapse/storage/schema/main/delta/50/add_creation_ts_users_index.sql +38 -0
  666. synapse/storage/schema/main/delta/50/erasure_store.sql +40 -0
  667. synapse/storage/schema/main/delta/50/make_event_content_nullable.py +102 -0
  668. synapse/storage/schema/main/delta/51/e2e_room_keys.sql +58 -0
  669. synapse/storage/schema/main/delta/51/monthly_active_users.sql +46 -0
  670. synapse/storage/schema/main/delta/52/add_event_to_state_group_index.sql +38 -0
  671. synapse/storage/schema/main/delta/52/device_list_streams_unique_idx.sql +55 -0
  672. synapse/storage/schema/main/delta/52/e2e_room_keys.sql +72 -0
  673. synapse/storage/schema/main/delta/53/add_user_type_to_users.sql +38 -0
  674. synapse/storage/schema/main/delta/53/drop_sent_transactions.sql +35 -0
  675. synapse/storage/schema/main/delta/53/event_format_version.sql +35 -0
  676. synapse/storage/schema/main/delta/53/user_dir_populate.sql +49 -0
  677. synapse/storage/schema/main/delta/53/user_ips_index.sql +49 -0
  678. synapse/storage/schema/main/delta/53/user_share.sql +63 -0
  679. synapse/storage/schema/main/delta/53/user_threepid_id.sql +48 -0
  680. synapse/storage/schema/main/delta/53/users_in_public_rooms.sql +47 -0
  681. synapse/storage/schema/main/delta/54/account_validity_with_renewal.sql +49 -0
  682. synapse/storage/schema/main/delta/54/add_validity_to_server_keys.sql +42 -0
  683. synapse/storage/schema/main/delta/54/delete_forward_extremities.sql +42 -0
  684. synapse/storage/schema/main/delta/54/drop_legacy_tables.sql +49 -0
  685. synapse/storage/schema/main/delta/54/drop_presence_list.sql +35 -0
  686. synapse/storage/schema/main/delta/54/relations.sql +46 -0
  687. synapse/storage/schema/main/delta/54/stats.sql +99 -0
  688. synapse/storage/schema/main/delta/54/stats2.sql +47 -0
  689. synapse/storage/schema/main/delta/55/access_token_expiry.sql +37 -0
  690. synapse/storage/schema/main/delta/55/track_threepid_validations.sql +50 -0
  691. synapse/storage/schema/main/delta/55/users_alter_deactivated.sql +38 -0
  692. synapse/storage/schema/main/delta/56/add_spans_to_device_lists.sql +39 -0
  693. synapse/storage/schema/main/delta/56/current_state_events_membership.sql +41 -0
  694. synapse/storage/schema/main/delta/56/current_state_events_membership_mk2.sql +43 -0
  695. synapse/storage/schema/main/delta/56/delete_keys_from_deleted_backups.sql +44 -0
  696. synapse/storage/schema/main/delta/56/destinations_failure_ts.sql +44 -0
  697. synapse/storage/schema/main/delta/56/destinations_retry_interval_type.sql.postgres +18 -0
  698. synapse/storage/schema/main/delta/56/device_stream_id_insert.sql +39 -0
  699. synapse/storage/schema/main/delta/56/devices_last_seen.sql +43 -0
  700. synapse/storage/schema/main/delta/56/drop_unused_event_tables.sql +39 -0
  701. synapse/storage/schema/main/delta/56/event_expiry.sql +40 -0
  702. synapse/storage/schema/main/delta/56/event_labels.sql +49 -0
  703. synapse/storage/schema/main/delta/56/event_labels_background_update.sql +36 -0
  704. synapse/storage/schema/main/delta/56/fix_room_keys_index.sql +37 -0
  705. synapse/storage/schema/main/delta/56/hidden_devices.sql +37 -0
  706. synapse/storage/schema/main/delta/56/hidden_devices_fix.sql.sqlite +42 -0
  707. synapse/storage/schema/main/delta/56/nuke_empty_communities_from_db.sql +48 -0
  708. synapse/storage/schema/main/delta/56/public_room_list_idx.sql +35 -0
  709. synapse/storage/schema/main/delta/56/redaction_censor.sql +35 -0
  710. synapse/storage/schema/main/delta/56/redaction_censor2.sql +41 -0
  711. synapse/storage/schema/main/delta/56/redaction_censor3_fix_update.sql.postgres +25 -0
  712. synapse/storage/schema/main/delta/56/redaction_censor4.sql +35 -0
  713. synapse/storage/schema/main/delta/56/remove_tombstoned_rooms_from_directory.sql +38 -0
  714. synapse/storage/schema/main/delta/56/room_key_etag.sql +36 -0
  715. synapse/storage/schema/main/delta/56/room_membership_idx.sql +37 -0
  716. synapse/storage/schema/main/delta/56/room_retention.sql +52 -0
  717. synapse/storage/schema/main/delta/56/signing_keys.sql +75 -0
  718. synapse/storage/schema/main/delta/56/signing_keys_nonunique_signatures.sql +41 -0
  719. synapse/storage/schema/main/delta/56/stats_separated.sql +175 -0
  720. synapse/storage/schema/main/delta/56/unique_user_filter_index.py +46 -0
  721. synapse/storage/schema/main/delta/56/user_external_ids.sql +43 -0
  722. synapse/storage/schema/main/delta/56/users_in_public_rooms_idx.sql +36 -0
  723. synapse/storage/schema/main/delta/57/delete_old_current_state_events.sql +41 -0
  724. synapse/storage/schema/main/delta/57/device_list_remote_cache_stale.sql +44 -0
  725. synapse/storage/schema/main/delta/57/local_current_membership.py +111 -0
  726. synapse/storage/schema/main/delta/57/remove_sent_outbound_pokes.sql +40 -0
  727. synapse/storage/schema/main/delta/57/rooms_version_column.sql +43 -0
  728. synapse/storage/schema/main/delta/57/rooms_version_column_2.sql.postgres +35 -0
  729. synapse/storage/schema/main/delta/57/rooms_version_column_2.sql.sqlite +22 -0
  730. synapse/storage/schema/main/delta/57/rooms_version_column_3.sql.postgres +39 -0
  731. synapse/storage/schema/main/delta/57/rooms_version_column_3.sql.sqlite +23 -0
  732. synapse/storage/schema/main/delta/58/02remove_dup_outbound_pokes.sql +41 -0
  733. synapse/storage/schema/main/delta/58/03persist_ui_auth.sql +55 -0
  734. synapse/storage/schema/main/delta/58/05cache_instance.sql.postgres +30 -0
  735. synapse/storage/schema/main/delta/58/06dlols_unique_idx.py +83 -0
  736. synapse/storage/schema/main/delta/58/07add_method_to_thumbnail_constraint.sql.postgres +33 -0
  737. synapse/storage/schema/main/delta/58/07add_method_to_thumbnail_constraint.sql.sqlite +44 -0
  738. synapse/storage/schema/main/delta/58/07persist_ui_auth_ips.sql +44 -0
  739. synapse/storage/schema/main/delta/58/08_media_safe_from_quarantine.sql.postgres +18 -0
  740. synapse/storage/schema/main/delta/58/08_media_safe_from_quarantine.sql.sqlite +18 -0
  741. synapse/storage/schema/main/delta/58/09shadow_ban.sql +37 -0
  742. synapse/storage/schema/main/delta/58/10_pushrules_enabled_delete_obsolete.sql +47 -0
  743. synapse/storage/schema/main/delta/58/10drop_local_rejections_stream.sql +41 -0
  744. synapse/storage/schema/main/delta/58/10federation_pos_instance_name.sql +41 -0
  745. synapse/storage/schema/main/delta/58/11dehydration.sql +39 -0
  746. synapse/storage/schema/main/delta/58/11fallback.sql +43 -0
  747. synapse/storage/schema/main/delta/58/11user_id_seq.py +38 -0
  748. synapse/storage/schema/main/delta/58/12room_stats.sql +51 -0
  749. synapse/storage/schema/main/delta/58/13remove_presence_allow_inbound.sql +36 -0
  750. synapse/storage/schema/main/delta/58/14events_instance_name.sql +35 -0
  751. synapse/storage/schema/main/delta/58/14events_instance_name.sql.postgres +28 -0
  752. synapse/storage/schema/main/delta/58/15_catchup_destination_rooms.sql +61 -0
  753. synapse/storage/schema/main/delta/58/15unread_count.sql +45 -0
  754. synapse/storage/schema/main/delta/58/16populate_stats_process_rooms_fix.sql +41 -0
  755. synapse/storage/schema/main/delta/58/17_catchup_last_successful.sql +40 -0
  756. synapse/storage/schema/main/delta/58/18stream_positions.sql +41 -0
  757. synapse/storage/schema/main/delta/58/19instance_map.sql.postgres +25 -0
  758. synapse/storage/schema/main/delta/58/19txn_id.sql +59 -0
  759. synapse/storage/schema/main/delta/58/20instance_name_event_tables.sql +36 -0
  760. synapse/storage/schema/main/delta/58/20user_daily_visits.sql +37 -0
  761. synapse/storage/schema/main/delta/58/21as_device_stream.sql +36 -0
  762. synapse/storage/schema/main/delta/58/21drop_device_max_stream_id.sql +1 -0
  763. synapse/storage/schema/main/delta/58/22puppet_token.sql +36 -0
  764. synapse/storage/schema/main/delta/58/22users_have_local_media.sql +2 -0
  765. synapse/storage/schema/main/delta/58/23e2e_cross_signing_keys_idx.sql +36 -0
  766. synapse/storage/schema/main/delta/58/24drop_event_json_index.sql +38 -0
  767. synapse/storage/schema/main/delta/58/25user_external_ids_user_id_idx.sql +36 -0
  768. synapse/storage/schema/main/delta/58/26access_token_last_validated.sql +37 -0
  769. synapse/storage/schema/main/delta/58/27local_invites.sql +37 -0
  770. synapse/storage/schema/main/delta/58/28drop_last_used_column.sql.postgres +16 -0
  771. synapse/storage/schema/main/delta/58/28drop_last_used_column.sql.sqlite +62 -0
  772. synapse/storage/schema/main/delta/59/01ignored_user.py +85 -0
  773. synapse/storage/schema/main/delta/59/02shard_send_to_device.sql +37 -0
  774. synapse/storage/schema/main/delta/59/03shard_send_to_device_sequence.sql.postgres +25 -0
  775. synapse/storage/schema/main/delta/59/04_event_auth_chains.sql +71 -0
  776. synapse/storage/schema/main/delta/59/04_event_auth_chains.sql.postgres +16 -0
  777. synapse/storage/schema/main/delta/59/04drop_account_data.sql +36 -0
  778. synapse/storage/schema/main/delta/59/05cache_invalidation.sql +36 -0
  779. synapse/storage/schema/main/delta/59/06chain_cover_index.sql +36 -0
  780. synapse/storage/schema/main/delta/59/06shard_account_data.sql +39 -0
  781. synapse/storage/schema/main/delta/59/06shard_account_data.sql.postgres +32 -0
  782. synapse/storage/schema/main/delta/59/07shard_account_data_fix.sql +37 -0
  783. synapse/storage/schema/main/delta/59/08delete_pushers_for_deactivated_accounts.sql +39 -0
  784. synapse/storage/schema/main/delta/59/08delete_stale_pushers.sql +39 -0
  785. synapse/storage/schema/main/delta/59/09rejected_events_metadata.sql +45 -0
  786. synapse/storage/schema/main/delta/59/10delete_purged_chain_cover.sql +36 -0
  787. synapse/storage/schema/main/delta/59/11add_knock_members_to_stats.sql +39 -0
  788. synapse/storage/schema/main/delta/59/11drop_thumbnail_constraint.sql.postgres +22 -0
  789. synapse/storage/schema/main/delta/59/12account_validity_token_used_ts_ms.sql +37 -0
  790. synapse/storage/schema/main/delta/59/12presence_stream_instance.sql +37 -0
  791. synapse/storage/schema/main/delta/59/12presence_stream_instance_seq.sql.postgres +20 -0
  792. synapse/storage/schema/main/delta/59/13users_to_send_full_presence_to.sql +53 -0
  793. synapse/storage/schema/main/delta/59/14refresh_tokens.sql +53 -0
  794. synapse/storage/schema/main/delta/59/15locks.sql +56 -0
  795. synapse/storage/schema/main/delta/59/16federation_inbound_staging.sql +51 -0
  796. synapse/storage/schema/main/delta/60/01recreate_stream_ordering.sql.postgres +45 -0
  797. synapse/storage/schema/main/delta/60/02change_stream_ordering_columns.sql.postgres +30 -0
  798. synapse/storage/schema/main/delta/61/01change_appservices_txns.sql.postgres +23 -0
  799. synapse/storage/schema/main/delta/61/01insertion_event_lookups.sql +68 -0
  800. synapse/storage/schema/main/delta/61/02drop_redundant_room_depth_index.sql +37 -0
  801. synapse/storage/schema/main/delta/61/03recreate_min_depth.py +74 -0
  802. synapse/storage/schema/main/delta/62/01insertion_event_extremities.sql +43 -0
  803. synapse/storage/schema/main/delta/63/01create_registration_tokens.sql +42 -0
  804. synapse/storage/schema/main/delta/63/02delete_unlinked_email_pushers.sql +39 -0
  805. synapse/storage/schema/main/delta/63/02populate-rooms-creator.sql +36 -0
  806. synapse/storage/schema/main/delta/63/03session_store.sql +42 -0
  807. synapse/storage/schema/main/delta/63/04add_presence_stream_not_offline_index.sql +37 -0
  808. synapse/storage/schema/main/delta/64/01msc2716_chunk_to_batch_rename.sql.postgres +23 -0
  809. synapse/storage/schema/main/delta/64/01msc2716_chunk_to_batch_rename.sql.sqlite +37 -0
  810. synapse/storage/schema/main/delta/65/01msc2716_insertion_event_edges.sql +38 -0
  811. synapse/storage/schema/main/delta/65/03remove_hidden_devices_from_device_inbox.sql +41 -0
  812. synapse/storage/schema/main/delta/65/04_local_group_updates.sql +37 -0
  813. synapse/storage/schema/main/delta/65/05_remove_room_stats_historical_and_user_stats_historical.sql +38 -0
  814. synapse/storage/schema/main/delta/65/06remove_deleted_devices_from_device_inbox.sql +53 -0
  815. synapse/storage/schema/main/delta/65/07_arbitrary_relations.sql +37 -0
  816. synapse/storage/schema/main/delta/65/08_device_inbox_background_updates.sql +37 -0
  817. synapse/storage/schema/main/delta/65/10_expirable_refresh_tokens.sql +47 -0
  818. synapse/storage/schema/main/delta/65/11_devices_auth_provider_session.sql +46 -0
  819. synapse/storage/schema/main/delta/67/01drop_public_room_list_stream.sql +37 -0
  820. synapse/storage/schema/main/delta/68/01event_columns.sql +45 -0
  821. synapse/storage/schema/main/delta/68/02_msc2409_add_device_id_appservice_stream_type.sql +40 -0
  822. synapse/storage/schema/main/delta/68/03_delete_account_data_for_deactivated_accounts.sql +39 -0
  823. synapse/storage/schema/main/delta/68/04_refresh_tokens_index_next_token_id.sql +47 -0
  824. synapse/storage/schema/main/delta/68/04partial_state_rooms.sql +60 -0
  825. synapse/storage/schema/main/delta/68/05_delete_non_strings_from_event_search.sql.sqlite +22 -0
  826. synapse/storage/schema/main/delta/68/05partial_state_rooms_triggers.py +80 -0
  827. synapse/storage/schema/main/delta/68/06_msc3202_add_device_list_appservice_stream_type.sql +42 -0
  828. synapse/storage/schema/main/delta/69/01as_txn_seq.py +54 -0
  829. synapse/storage/schema/main/delta/69/01device_list_oubound_by_room.sql +57 -0
  830. synapse/storage/schema/main/delta/69/02cache_invalidation_index.sql +37 -0
  831. synapse/storage/schema/main/delta/70/01clean_table_purged_rooms.sql +39 -0
  832. synapse/storage/schema/main/delta/71/01rebuild_event_edges.sql.postgres +43 -0
  833. synapse/storage/schema/main/delta/71/01rebuild_event_edges.sql.sqlite +47 -0
  834. synapse/storage/schema/main/delta/71/01remove_noop_background_updates.sql +80 -0
  835. synapse/storage/schema/main/delta/71/02event_push_summary_unique.sql +37 -0
  836. synapse/storage/schema/main/delta/72/01add_room_type_to_state_stats.sql +38 -0
  837. synapse/storage/schema/main/delta/72/01event_push_summary_receipt.sql +54 -0
  838. synapse/storage/schema/main/delta/72/02event_push_actions_index.sql +38 -0
  839. synapse/storage/schema/main/delta/72/03bg_populate_events_columns.py +57 -0
  840. synapse/storage/schema/main/delta/72/03drop_event_reference_hashes.sql +36 -0
  841. synapse/storage/schema/main/delta/72/03remove_groups.sql +50 -0
  842. synapse/storage/schema/main/delta/72/04drop_column_application_services_state_last_txn.sql.postgres +17 -0
  843. synapse/storage/schema/main/delta/72/04drop_column_application_services_state_last_txn.sql.sqlite +40 -0
  844. synapse/storage/schema/main/delta/72/05receipts_event_stream_ordering.sql +38 -0
  845. synapse/storage/schema/main/delta/72/05remove_unstable_private_read_receipts.sql +38 -0
  846. synapse/storage/schema/main/delta/72/06add_consent_ts_to_users.sql +35 -0
  847. synapse/storage/schema/main/delta/72/06thread_notifications.sql +49 -0
  848. synapse/storage/schema/main/delta/72/07force_update_current_state_events_membership.py +67 -0
  849. synapse/storage/schema/main/delta/72/07thread_receipts.sql.postgres +30 -0
  850. synapse/storage/schema/main/delta/72/07thread_receipts.sql.sqlite +70 -0
  851. synapse/storage/schema/main/delta/72/08begin_cache_invalidation_seq_at_2.sql.postgres +23 -0
  852. synapse/storage/schema/main/delta/72/08thread_receipts.sql +39 -0
  853. synapse/storage/schema/main/delta/72/09partial_indices.sql.sqlite +56 -0
  854. synapse/storage/schema/main/delta/73/01event_failed_pull_attempts.sql +48 -0
  855. synapse/storage/schema/main/delta/73/02add_pusher_enabled.sql +35 -0
  856. synapse/storage/schema/main/delta/73/02room_id_indexes_for_purging.sql +41 -0
  857. synapse/storage/schema/main/delta/73/03pusher_device_id.sql +39 -0
  858. synapse/storage/schema/main/delta/73/03users_approved_column.sql +39 -0
  859. synapse/storage/schema/main/delta/73/04partial_join_details.sql +42 -0
  860. synapse/storage/schema/main/delta/73/04pending_device_list_updates.sql +47 -0
  861. synapse/storage/schema/main/delta/73/05old_push_actions.sql.postgres +22 -0
  862. synapse/storage/schema/main/delta/73/05old_push_actions.sql.sqlite +24 -0
  863. synapse/storage/schema/main/delta/73/06thread_notifications_thread_id_idx.sql +42 -0
  864. synapse/storage/schema/main/delta/73/08thread_receipts_non_null.sql.postgres +23 -0
  865. synapse/storage/schema/main/delta/73/08thread_receipts_non_null.sql.sqlite +76 -0
  866. synapse/storage/schema/main/delta/73/09partial_joined_via_destination.sql +37 -0
  867. synapse/storage/schema/main/delta/73/09threads_table.sql +49 -0
  868. synapse/storage/schema/main/delta/73/10_update_sqlite_fts4_tokenizer.py +71 -0
  869. synapse/storage/schema/main/delta/73/10login_tokens.sql +54 -0
  870. synapse/storage/schema/main/delta/73/11event_search_room_id_n_distinct.sql.postgres +33 -0
  871. synapse/storage/schema/main/delta/73/12refactor_device_list_outbound_pokes.sql +72 -0
  872. synapse/storage/schema/main/delta/73/13add_device_lists_index.sql +39 -0
  873. synapse/storage/schema/main/delta/73/20_un_partial_stated_room_stream.sql +51 -0
  874. synapse/storage/schema/main/delta/73/21_un_partial_stated_room_stream_seq.sql.postgres +20 -0
  875. synapse/storage/schema/main/delta/73/22_rebuild_user_dir_stats.sql +48 -0
  876. synapse/storage/schema/main/delta/73/22_un_partial_stated_event_stream.sql +53 -0
  877. synapse/storage/schema/main/delta/73/23_fix_thread_index.sql +52 -0
  878. synapse/storage/schema/main/delta/73/23_un_partial_stated_room_stream_seq.sql.postgres +20 -0
  879. synapse/storage/schema/main/delta/73/24_events_jump_to_date_index.sql +36 -0
  880. synapse/storage/schema/main/delta/73/25drop_presence.sql +36 -0
  881. synapse/storage/schema/main/delta/74/01_user_directory_stale_remote_users.sql +58 -0
  882. synapse/storage/schema/main/delta/74/02_set_device_id_for_pushers_bg_update.sql +38 -0
  883. synapse/storage/schema/main/delta/74/03_membership_tables_event_stream_ordering.sql.postgres +29 -0
  884. synapse/storage/schema/main/delta/74/03_membership_tables_event_stream_ordering.sql.sqlite +23 -0
  885. synapse/storage/schema/main/delta/74/03_room_membership_index.sql +38 -0
  886. synapse/storage/schema/main/delta/74/04_delete_e2e_backup_keys_for_deactivated_users.sql +36 -0
  887. synapse/storage/schema/main/delta/74/04_membership_tables_event_stream_ordering_triggers.py +87 -0
  888. synapse/storage/schema/main/delta/74/05_events_txn_id_device_id.sql +72 -0
  889. synapse/storage/schema/main/delta/74/90COMMENTS_destinations.sql.postgres +52 -0
  890. synapse/storage/schema/main/delta/76/01_add_profiles_full_user_id_column.sql +39 -0
  891. synapse/storage/schema/main/delta/76/02_add_user_filters_full_user_id_column.sql +39 -0
  892. synapse/storage/schema/main/delta/76/03_per_user_experimental_features.sql +46 -0
  893. synapse/storage/schema/main/delta/76/04_add_room_forgetter.sql +43 -0
  894. synapse/storage/schema/main/delta/77/01_add_profiles_not_valid_check.sql.postgres +16 -0
  895. synapse/storage/schema/main/delta/77/02_add_user_filters_not_valid_check.sql.postgres +16 -0
  896. synapse/storage/schema/main/delta/77/03bg_populate_full_user_id_profiles.sql +35 -0
  897. synapse/storage/schema/main/delta/77/04bg_populate_full_user_id_user_filters.sql +35 -0
  898. synapse/storage/schema/main/delta/77/05thread_notifications_backfill.sql +67 -0
  899. synapse/storage/schema/main/delta/77/06thread_notifications_not_null.sql.sqlite +102 -0
  900. synapse/storage/schema/main/delta/77/06thread_notifications_not_null_event_push_actions.sql.postgres +27 -0
  901. synapse/storage/schema/main/delta/77/06thread_notifications_not_null_event_push_actions_staging.sql.postgres +27 -0
  902. synapse/storage/schema/main/delta/77/06thread_notifications_not_null_event_push_summary.sql.postgres +29 -0
  903. synapse/storage/schema/main/delta/77/14bg_indices_event_stream_ordering.sql +39 -0
  904. synapse/storage/schema/main/delta/78/01_validate_and_update_profiles.py +99 -0
  905. synapse/storage/schema/main/delta/78/02_validate_and_update_user_filters.py +100 -0
  906. synapse/storage/schema/main/delta/78/03_remove_unused_indexes_user_filters.py +72 -0
  907. synapse/storage/schema/main/delta/78/03event_extremities_constraints.py +65 -0
  908. synapse/storage/schema/main/delta/78/04_add_full_user_id_index_user_filters.py +32 -0
  909. synapse/storage/schema/main/delta/79/03_read_write_locks_triggers.sql.postgres +102 -0
  910. synapse/storage/schema/main/delta/79/03_read_write_locks_triggers.sql.sqlite +72 -0
  911. synapse/storage/schema/main/delta/79/04_mitigate_stream_ordering_update_race.py +70 -0
  912. synapse/storage/schema/main/delta/79/05_read_write_locks_triggers.sql.postgres +69 -0
  913. synapse/storage/schema/main/delta/79/05_read_write_locks_triggers.sql.sqlite +65 -0
  914. synapse/storage/schema/main/delta/80/01_users_alter_locked.sql +35 -0
  915. synapse/storage/schema/main/delta/80/02_read_write_locks_unlogged.sql.postgres +30 -0
  916. synapse/storage/schema/main/delta/80/02_scheduled_tasks.sql +47 -0
  917. synapse/storage/schema/main/delta/80/03_read_write_locks_triggers.sql.postgres +37 -0
  918. synapse/storage/schema/main/delta/80/04_read_write_locks_deadlock.sql.postgres +71 -0
  919. synapse/storage/schema/main/delta/82/02_scheduled_tasks_index.sql +35 -0
  920. synapse/storage/schema/main/delta/82/04_add_indices_for_purging_rooms.sql +39 -0
  921. synapse/storage/schema/main/delta/82/05gaps.sql +44 -0
  922. synapse/storage/schema/main/delta/83/01_drop_old_tables.sql +43 -0
  923. synapse/storage/schema/main/delta/83/03_instance_name_receipts.sql.sqlite +17 -0
  924. synapse/storage/schema/main/delta/83/05_cross_signing_key_update_grant.sql +34 -0
  925. synapse/storage/schema/main/delta/83/06_event_push_summary_room.sql +36 -0
  926. synapse/storage/schema/main/delta/84/01_auth_links_stats.sql.postgres +20 -0
  927. synapse/storage/schema/main/delta/84/02_auth_links_index.sql +16 -0
  928. synapse/storage/schema/main/delta/84/03_auth_links_analyze.sql.postgres +16 -0
  929. synapse/storage/schema/main/delta/84/04_access_token_index.sql +15 -0
  930. synapse/storage/schema/main/delta/85/01_add_suspended.sql +14 -0
  931. synapse/storage/schema/main/delta/85/02_add_instance_names.sql +27 -0
  932. synapse/storage/schema/main/delta/85/03_new_sequences.sql.postgres +54 -0
  933. synapse/storage/schema/main/delta/85/04_cleanup_device_federation_outbox.sql +15 -0
  934. synapse/storage/schema/main/delta/85/05_add_instance_names_converted_pos.sql +16 -0
  935. synapse/storage/schema/main/delta/85/06_add_room_reports.sql +20 -0
  936. synapse/storage/schema/main/delta/86/01_authenticate_media.sql +15 -0
  937. synapse/storage/schema/main/delta/86/02_receipts_event_id_index.sql +15 -0
  938. synapse/storage/schema/main/delta/87/01_sliding_sync_memberships.sql +169 -0
  939. synapse/storage/schema/main/delta/87/02_per_connection_state.sql +81 -0
  940. synapse/storage/schema/main/delta/87/03_current_state_index.sql +19 -0
  941. synapse/storage/schema/main/delta/88/01_add_delayed_events.sql +43 -0
  942. synapse/storage/schema/main/delta/88/01_custom_profile_fields.sql +15 -0
  943. synapse/storage/schema/main/delta/88/02_fix_sliding_sync_membership_snapshots_forgotten_column.sql +21 -0
  944. synapse/storage/schema/main/delta/88/03_add_otk_ts_added_index.sql +18 -0
  945. synapse/storage/schema/main/delta/88/04_current_state_delta_index.sql +18 -0
  946. synapse/storage/schema/main/delta/88/05_drop_old_otks.sql.postgres +19 -0
  947. synapse/storage/schema/main/delta/88/05_drop_old_otks.sql.sqlite +19 -0
  948. synapse/storage/schema/main/delta/88/05_sliding_sync_room_config_index.sql +20 -0
  949. synapse/storage/schema/main/delta/88/06_events_received_ts_index.sql +17 -0
  950. synapse/storage/schema/main/delta/89/01_sliding_sync_membership_snapshot_index.sql +15 -0
  951. synapse/storage/schema/main/delta/90/01_add_column_participant_room_memberships_table.sql +16 -0
  952. synapse/storage/schema/main/delta/91/01_media_hash.sql +28 -0
  953. synapse/storage/schema/main/delta/92/01_remove_trigger.sql.postgres +16 -0
  954. synapse/storage/schema/main/delta/92/01_remove_trigger.sql.sqlite +16 -0
  955. synapse/storage/schema/main/delta/92/02_remove_populate_participant_bg_update.sql +17 -0
  956. synapse/storage/schema/main/delta/92/04_ss_membership_snapshot_idx.sql +16 -0
  957. synapse/storage/schema/main/delta/92/04_thread_subscriptions.sql +59 -0
  958. synapse/storage/schema/main/delta/92/04_thread_subscriptions_seq.sql.postgres +19 -0
  959. synapse/storage/schema/main/delta/92/05_fixup_max_depth_cap.sql +17 -0
  960. synapse/storage/schema/main/delta/92/05_thread_subscriptions_comments.sql.postgres +18 -0
  961. synapse/storage/schema/main/delta/92/06_device_federation_inbox_index.sql +16 -0
  962. synapse/storage/schema/main/delta/92/06_threads_last_sent_stream_ordering_comments.sql.postgres +24 -0
  963. synapse/storage/schema/main/delta/92/07_add_user_reports.sql +22 -0
  964. synapse/storage/schema/main/delta/92/07_event_txn_id_device_id_txn_id2.sql +15 -0
  965. synapse/storage/schema/main/delta/92/08_room_ban_redactions.sql +21 -0
  966. synapse/storage/schema/main/delta/92/08_thread_subscriptions_seq_fixup.sql.postgres +19 -0
  967. synapse/storage/schema/main/delta/92/09_thread_subscriptions_update.sql +20 -0
  968. synapse/storage/schema/main/delta/92/09_thread_subscriptions_update.sql.postgres +18 -0
  969. synapse/storage/schema/main/full_schemas/72/full.sql.postgres +1344 -0
  970. synapse/storage/schema/main/full_schemas/72/full.sql.sqlite +646 -0
  971. synapse/storage/schema/state/delta/23/drop_state_index.sql +35 -0
  972. synapse/storage/schema/state/delta/32/remove_state_indices.sql +38 -0
  973. synapse/storage/schema/state/delta/35/add_state_index.sql +36 -0
  974. synapse/storage/schema/state/delta/35/state.sql +41 -0
  975. synapse/storage/schema/state/delta/35/state_dedupe.sql +36 -0
  976. synapse/storage/schema/state/delta/47/state_group_seq.py +38 -0
  977. synapse/storage/schema/state/delta/56/state_group_room_idx.sql +36 -0
  978. synapse/storage/schema/state/delta/61/02state_groups_state_n_distinct.sql.postgres +34 -0
  979. synapse/storage/schema/state/delta/70/08_state_group_edges_unique.sql +36 -0
  980. synapse/storage/schema/state/delta/89/01_state_groups_deletion.sql +39 -0
  981. synapse/storage/schema/state/delta/90/02_delete_unreferenced_state_groups.sql +16 -0
  982. synapse/storage/schema/state/delta/90/03_remove_old_deletion_bg_update.sql +15 -0
  983. synapse/storage/schema/state/full_schemas/72/full.sql.postgres +30 -0
  984. synapse/storage/schema/state/full_schemas/72/full.sql.sqlite +20 -0
  985. synapse/storage/types.py +185 -0
  986. synapse/storage/util/__init__.py +20 -0
  987. synapse/storage/util/id_generators.py +909 -0
  988. synapse/storage/util/partial_state_events_tracker.py +194 -0
  989. synapse/storage/util/sequence.py +315 -0
  990. synapse/streams/__init__.py +43 -0
  991. synapse/streams/config.py +92 -0
  992. synapse/streams/events.py +203 -0
  993. synapse/synapse_rust/__init__.pyi +3 -0
  994. synapse/synapse_rust/acl.pyi +20 -0
  995. synapse/synapse_rust/events.pyi +136 -0
  996. synapse/synapse_rust/http_client.pyi +32 -0
  997. synapse/synapse_rust/push.pyi +86 -0
  998. synapse/synapse_rust/rendezvous.pyi +30 -0
  999. synapse/synapse_rust/segmenter.pyi +1 -0
  1000. synapse/synapse_rust.abi3.so +0 -0
  1001. synapse/types/__init__.py +1600 -0
  1002. synapse/types/handlers/__init__.py +93 -0
  1003. synapse/types/handlers/policy_server.py +16 -0
  1004. synapse/types/handlers/sliding_sync.py +909 -0
  1005. synapse/types/rest/__init__.py +25 -0
  1006. synapse/types/rest/client/__init__.py +415 -0
  1007. synapse/types/state.py +635 -0
  1008. synapse/types/storage/__init__.py +66 -0
  1009. synapse/util/__init__.py +170 -0
  1010. synapse/util/async_helpers.py +1067 -0
  1011. synapse/util/batching_queue.py +202 -0
  1012. synapse/util/caches/__init__.py +300 -0
  1013. synapse/util/caches/cached_call.py +143 -0
  1014. synapse/util/caches/deferred_cache.py +530 -0
  1015. synapse/util/caches/descriptors.py +694 -0
  1016. synapse/util/caches/dictionary_cache.py +350 -0
  1017. synapse/util/caches/expiringcache.py +251 -0
  1018. synapse/util/caches/lrucache.py +977 -0
  1019. synapse/util/caches/response_cache.py +323 -0
  1020. synapse/util/caches/stream_change_cache.py +370 -0
  1021. synapse/util/caches/treecache.py +189 -0
  1022. synapse/util/caches/ttlcache.py +197 -0
  1023. synapse/util/cancellation.py +63 -0
  1024. synapse/util/check_dependencies.py +335 -0
  1025. synapse/util/clock.py +500 -0
  1026. synapse/util/constants.py +22 -0
  1027. synapse/util/daemonize.py +165 -0
  1028. synapse/util/distributor.py +159 -0
  1029. synapse/util/events.py +134 -0
  1030. synapse/util/file_consumer.py +164 -0
  1031. synapse/util/frozenutils.py +57 -0
  1032. synapse/util/gai_resolver.py +180 -0
  1033. synapse/util/hash.py +38 -0
  1034. synapse/util/httpresourcetree.py +108 -0
  1035. synapse/util/iterutils.py +189 -0
  1036. synapse/util/json.py +56 -0
  1037. synapse/util/linked_list.py +156 -0
  1038. synapse/util/logcontext.py +46 -0
  1039. synapse/util/logformatter.py +28 -0
  1040. synapse/util/macaroons.py +325 -0
  1041. synapse/util/manhole.py +191 -0
  1042. synapse/util/metrics.py +340 -0
  1043. synapse/util/module_loader.py +116 -0
  1044. synapse/util/msisdn.py +51 -0
  1045. synapse/util/patch_inline_callbacks.py +250 -0
  1046. synapse/util/pydantic_models.py +56 -0
  1047. synapse/util/ratelimitutils.py +420 -0
  1048. synapse/util/retryutils.py +339 -0
  1049. synapse/util/rlimit.py +42 -0
  1050. synapse/util/rust.py +134 -0
  1051. synapse/util/sentinel.py +21 -0
  1052. synapse/util/stringutils.py +293 -0
  1053. synapse/util/task_scheduler.py +493 -0
  1054. synapse/util/templates.py +126 -0
  1055. synapse/util/threepids.py +123 -0
  1056. synapse/util/wheel_timer.py +112 -0
  1057. synapse/visibility.py +836 -0
@@ -0,0 +1,1006 @@
1
+ #
2
+ # This file is licensed under the Affero General Public License (AGPL) version 3.
3
+ #
4
+ # Copyright 2020 The Matrix.org Foundation C.I.C.
5
+ # Copyright 2014-2016 OpenMarket Ltd
6
+ # Copyright (C) 2023 New Vector, Ltd
7
+ #
8
+ # This program is free software: you can redistribute it and/or modify
9
+ # it under the terms of the GNU Affero General Public License as
10
+ # published by the Free Software Foundation, either version 3 of the
11
+ # License, or (at your option) any later version.
12
+ #
13
+ # See the GNU Affero General Public License for more details:
14
+ # <https://www.gnu.org/licenses/agpl-3.0.html>.
15
+ #
16
+ # Originally licensed under the Apache License, Version 2.0:
17
+ # <http://www.apache.org/licenses/LICENSE-2.0>.
18
+ #
19
+ # [This file includes modifications made by New Vector Limited]
20
+ #
21
+ #
22
+ import collections.abc
23
+ import logging
24
+ from typing import (
25
+ TYPE_CHECKING,
26
+ Any,
27
+ Collection,
28
+ Iterable,
29
+ Mapping,
30
+ MutableMapping,
31
+ Optional,
32
+ TypeVar,
33
+ Union,
34
+ cast,
35
+ overload,
36
+ )
37
+
38
+ import attr
39
+
40
+ from synapse.api.constants import EventContentFields, EventTypes, Membership
41
+ from synapse.api.errors import NotFoundError, UnsupportedRoomVersionError
42
+ from synapse.api.room_versions import KNOWN_ROOM_VERSIONS, RoomVersion
43
+ from synapse.events import EventBase
44
+ from synapse.events.snapshot import EventContext
45
+ from synapse.logging.opentracing import trace
46
+ from synapse.replication.tcp.streams import UnPartialStatedEventStream
47
+ from synapse.replication.tcp.streams.partial_state import UnPartialStatedEventStreamRow
48
+ from synapse.storage._base import SQLBaseStore
49
+ from synapse.storage.database import (
50
+ DatabasePool,
51
+ LoggingDatabaseConnection,
52
+ LoggingTransaction,
53
+ make_in_list_sql_clause,
54
+ )
55
+ from synapse.storage.databases.main.events_worker import EventsWorkerStore
56
+ from synapse.storage.databases.main.roommember import RoomMemberWorkerStore
57
+ from synapse.types import JsonDict, JsonMapping, StateKey, StateMap, StrCollection
58
+ from synapse.types.state import StateFilter
59
+ from synapse.util.caches import intern_string
60
+ from synapse.util.caches.descriptors import cached, cachedList
61
+ from synapse.util.cancellation import cancellable
62
+ from synapse.util.iterutils import batch_iter
63
+
64
+ if TYPE_CHECKING:
65
+ from synapse.server import HomeServer
66
+
67
+ logger = logging.getLogger(__name__)
68
+
69
+ _T = TypeVar("_T")
70
+
71
+ MAX_STATE_DELTA_HOPS = 100
72
+
73
+
74
+ # Freeze so it's immutable and we can use it as a cache value
75
+ @attr.s(slots=True, frozen=True, auto_attribs=True)
76
+ class Sentinel:
77
+ pass
78
+
79
+
80
+ ROOM_UNKNOWN_SENTINEL = Sentinel()
81
+
82
+
83
+ @attr.s(slots=True, frozen=True, auto_attribs=True)
84
+ class EventMetadata:
85
+ """Returned by `get_metadata_for_events`"""
86
+
87
+ room_id: str
88
+ event_type: str
89
+ state_key: Optional[str]
90
+ rejection_reason: Optional[str]
91
+
92
+
93
+ def _retrieve_and_check_room_version(room_id: str, room_version_id: str) -> RoomVersion:
94
+ v = KNOWN_ROOM_VERSIONS.get(room_version_id)
95
+ if not v:
96
+ raise UnsupportedRoomVersionError(
97
+ "Room %s uses a room version %s which is no longer supported"
98
+ % (room_id, room_version_id)
99
+ )
100
+ return v
101
+
102
+
103
+ # this inherits from EventsWorkerStore because it calls self.get_events
104
+ class StateGroupWorkerStore(EventsWorkerStore, SQLBaseStore):
105
+ """The parts of StateGroupStore that can be called from workers."""
106
+
107
+ def __init__(
108
+ self,
109
+ database: DatabasePool,
110
+ db_conn: LoggingDatabaseConnection,
111
+ hs: "HomeServer",
112
+ ):
113
+ super().__init__(database, db_conn, hs)
114
+ self._instance_name: str = hs.get_instance_name()
115
+
116
+ def process_replication_rows(
117
+ self,
118
+ stream_name: str,
119
+ instance_name: str,
120
+ token: int,
121
+ rows: Iterable[Any],
122
+ ) -> None:
123
+ if stream_name == UnPartialStatedEventStream.NAME:
124
+ for row in rows:
125
+ assert isinstance(row, UnPartialStatedEventStreamRow)
126
+ self._get_state_group_for_event.invalidate((row.event_id,))
127
+ self.is_partial_state_event.invalidate((row.event_id,))
128
+
129
+ super().process_replication_rows(stream_name, instance_name, token, rows)
130
+
131
+ async def get_room_version(self, room_id: str) -> RoomVersion:
132
+ """Get the room_version of a given room
133
+ Raises:
134
+ NotFoundError: if the room is unknown
135
+ UnsupportedRoomVersionError: if the room uses an unknown room version.
136
+ Typically this happens if support for the room's version has been
137
+ removed from Synapse.
138
+ """
139
+ room_version_id = await self.get_room_version_id(room_id)
140
+ return _retrieve_and_check_room_version(room_id, room_version_id)
141
+
142
+ def get_room_version_txn(
143
+ self, txn: LoggingTransaction, room_id: str
144
+ ) -> RoomVersion:
145
+ """Get the room_version of a given room
146
+ Args:
147
+ txn: Transaction object
148
+ room_id: The room_id of the room you are trying to get the version for
149
+ Raises:
150
+ NotFoundError: if the room is unknown
151
+ UnsupportedRoomVersionError: if the room uses an unknown room version.
152
+ Typically this happens if support for the room's version has been
153
+ removed from Synapse.
154
+ """
155
+ room_version_id = self.get_room_version_id_txn(txn, room_id)
156
+ return _retrieve_and_check_room_version(room_id, room_version_id)
157
+
158
+ @cached(max_entries=10000)
159
+ async def get_room_version_id(self, room_id: str) -> str:
160
+ """Get the room_version of a given room
161
+ Raises:
162
+ NotFoundError: if the room is unknown
163
+ """
164
+ return await self.db_pool.runInteraction(
165
+ "get_room_version_id_txn",
166
+ self.get_room_version_id_txn,
167
+ room_id,
168
+ )
169
+
170
+ def get_room_version_id_txn(self, txn: LoggingTransaction, room_id: str) -> str:
171
+ """Get the room_version of a given room
172
+ Args:
173
+ txn: Transaction object
174
+ room_id: The room_id of the room you are trying to get the version for
175
+ Raises:
176
+ NotFoundError: if the room is unknown
177
+ """
178
+
179
+ # We really should have an entry in the rooms table for every room we
180
+ # care about, but let's be a bit paranoid.
181
+ room_version = self.db_pool.simple_select_one_onecol_txn(
182
+ txn,
183
+ table="rooms",
184
+ keyvalues={"room_id": room_id},
185
+ retcol="room_version",
186
+ allow_none=True,
187
+ )
188
+
189
+ if room_version is None:
190
+ raise NotFoundError("Could not find room_version for %s" % (room_id,))
191
+
192
+ return room_version
193
+
194
+ @trace
195
+ async def get_metadata_for_events(
196
+ self, event_ids: Collection[str]
197
+ ) -> dict[str, EventMetadata]:
198
+ """Get some metadata (room_id, type, state_key) for the given events.
199
+
200
+ This method is a faster alternative than fetching the full events from
201
+ the DB, and should be used when the full event is not needed.
202
+
203
+ Returns metadata for rejected and redacted events. Events that have not
204
+ been persisted are omitted from the returned dict.
205
+ """
206
+
207
+ def get_metadata_for_events_txn(
208
+ txn: LoggingTransaction,
209
+ batch_ids: Collection[str],
210
+ ) -> dict[str, EventMetadata]:
211
+ clause, args = make_in_list_sql_clause(
212
+ self.database_engine, "e.event_id", batch_ids
213
+ )
214
+
215
+ sql = f"""
216
+ SELECT e.event_id, e.room_id, e.type, se.state_key, r.reason
217
+ FROM events AS e
218
+ LEFT JOIN state_events se USING (event_id)
219
+ LEFT JOIN rejections r USING (event_id)
220
+ WHERE {clause}
221
+ """
222
+
223
+ txn.execute(sql, args)
224
+ return {
225
+ event_id: EventMetadata(
226
+ room_id=room_id,
227
+ event_type=event_type,
228
+ state_key=state_key,
229
+ rejection_reason=rejection_reason,
230
+ )
231
+ for event_id, room_id, event_type, state_key, rejection_reason in txn
232
+ }
233
+
234
+ result_map: dict[str, EventMetadata] = {}
235
+ for batch_ids in batch_iter(event_ids, 1000):
236
+ result_map.update(
237
+ await self.db_pool.runInteraction(
238
+ "get_metadata_for_events",
239
+ get_metadata_for_events_txn,
240
+ batch_ids=batch_ids,
241
+ )
242
+ )
243
+
244
+ return result_map
245
+
246
+ async def get_room_predecessor(self, room_id: str) -> Optional[JsonMapping]:
247
+ """Get the predecessor of an upgraded room if it exists.
248
+ Otherwise return None.
249
+
250
+ Args:
251
+ room_id: The room ID.
252
+
253
+ Returns:
254
+ A dictionary containing the structure of the predecessor
255
+ field from the room's create event. The structure is subject to other servers,
256
+ but it is expected to be:
257
+ * room_id (str): The room ID of the predecessor room
258
+ * event_id (str): The ID of the tombstone event in the predecessor room
259
+
260
+ None if a predecessor key is not found, or is not a dictionary.
261
+
262
+ Raises:
263
+ NotFoundError if the given room is unknown
264
+ """
265
+ # Retrieve the room's create event
266
+ create_event = await self.get_create_event_for_room(room_id)
267
+
268
+ # Retrieve the predecessor key of the create event
269
+ predecessor = create_event.content.get("predecessor", None)
270
+
271
+ # Ensure the key is a dictionary
272
+ if not isinstance(predecessor, collections.abc.Mapping):
273
+ return None
274
+
275
+ # The keys must be strings since the data is JSON.
276
+ return predecessor
277
+
278
+ async def get_create_event_for_room(self, room_id: str) -> EventBase:
279
+ """Get the create state event for a room.
280
+
281
+ Args:
282
+ room_id: The room ID.
283
+
284
+ Returns:
285
+ The room creation event.
286
+
287
+ Raises:
288
+ NotFoundError if the room is unknown
289
+ """
290
+ state_ids = await self.get_partial_current_state_ids(room_id)
291
+
292
+ if not state_ids:
293
+ raise NotFoundError(f"Current state for room {room_id} is empty")
294
+
295
+ create_id = state_ids.get((EventTypes.Create, ""))
296
+
297
+ # If we can't find the create event, assume we've hit a dead end
298
+ if not create_id:
299
+ raise NotFoundError(f"No create event in current state for room {room_id}")
300
+
301
+ # Retrieve the room's create event and return
302
+ create_event = await self.get_event(create_id)
303
+ return create_event
304
+
305
+ @cached(max_entries=10000)
306
+ async def get_room_type(self, room_id: str) -> Union[Optional[str], Sentinel]:
307
+ """Fetch room type for given room.
308
+
309
+ Since this function is cached, any missing values would be cached as
310
+ `None`. In order to distinguish between an unencrypted room that has
311
+ `None` encryption and a room that is unknown to the server where we
312
+ might want to omit the value (which would make it cached as `None`),
313
+ instead we use the sentinel value `ROOM_UNKNOWN_SENTINEL`.
314
+ """
315
+
316
+ try:
317
+ create_event = await self.get_create_event_for_room(room_id)
318
+ return create_event.content.get(EventContentFields.ROOM_TYPE)
319
+ except NotFoundError:
320
+ # We use the sentinel value to distinguish between `None` which is a
321
+ # valid room type and a room that is unknown to the server so the value
322
+ # is just unset.
323
+ return ROOM_UNKNOWN_SENTINEL
324
+
325
+ @cachedList(cached_method_name="get_room_type", list_name="room_ids")
326
+ async def bulk_get_room_type(
327
+ self, room_ids: set[str]
328
+ ) -> Mapping[str, Union[Optional[str], Sentinel]]:
329
+ """
330
+ Bulk fetch room types for the given rooms (via current state).
331
+
332
+ Since this function is cached, any missing values would be cached as `None`. In
333
+ order to distinguish between an unencrypted room that has `None` encryption and
334
+ a room that is unknown to the server where we might want to omit the value
335
+ (which would make it cached as `None`), instead we use the sentinel value
336
+ `ROOM_UNKNOWN_SENTINEL`.
337
+
338
+ Returns:
339
+ A mapping from room ID to the room's type (`None` is a valid room type).
340
+ Rooms unknown to this server will return `ROOM_UNKNOWN_SENTINEL`.
341
+ """
342
+
343
+ def txn(
344
+ txn: LoggingTransaction,
345
+ ) -> MutableMapping[str, Union[Optional[str], Sentinel]]:
346
+ clause, args = make_in_list_sql_clause(
347
+ txn.database_engine, "room_id", room_ids
348
+ )
349
+
350
+ # We can't rely on `room_stats_state.room_type` if the server has left the
351
+ # room because the `room_id` will still be in the table but everything will
352
+ # be set to `None` but `None` is a valid room type value. We join against
353
+ # the `room_stats_current` table which keeps track of the
354
+ # `current_state_events` count (and a proxy value `local_users_in_room`
355
+ # which can used to assume the server is participating in the room and has
356
+ # current state) to ensure that the data in `room_stats_state` is up-to-date
357
+ # with the current state.
358
+ #
359
+ # FIXME: Use `room_stats_current.current_state_events` instead of
360
+ # `room_stats_current.local_users_in_room` once
361
+ # https://github.com/element-hq/synapse/issues/17457 is fixed.
362
+ sql = f"""
363
+ SELECT room_id, room_type
364
+ FROM room_stats_state
365
+ INNER JOIN room_stats_current USING (room_id)
366
+ WHERE
367
+ {clause}
368
+ AND local_users_in_room > 0
369
+ """
370
+
371
+ txn.execute(sql, args)
372
+
373
+ room_id_to_type_map = {}
374
+ for row in txn:
375
+ room_id_to_type_map[row[0]] = row[1]
376
+
377
+ return room_id_to_type_map
378
+
379
+ results = await self.db_pool.runInteraction(
380
+ "bulk_get_room_type",
381
+ txn,
382
+ )
383
+
384
+ # If we haven't updated `room_stats_state` with the room yet, query the
385
+ # create events directly. This should happen only rarely so we don't
386
+ # mind if we do this in a loop.
387
+ for room_id in room_ids - results.keys():
388
+ try:
389
+ create_event = await self.get_create_event_for_room(room_id)
390
+ room_type = create_event.content.get(EventContentFields.ROOM_TYPE)
391
+ results[room_id] = room_type
392
+ except NotFoundError:
393
+ # We use the sentinel value to distinguish between `None` which is a
394
+ # valid room type and a room that is unknown to the server so the value
395
+ # is just unset.
396
+ results[room_id] = ROOM_UNKNOWN_SENTINEL
397
+
398
+ return results
399
+
400
+ @cached(max_entries=10000)
401
+ async def get_room_encryption(self, room_id: str) -> Optional[str]:
402
+ raise NotImplementedError()
403
+
404
+ @cachedList(cached_method_name="get_room_encryption", list_name="room_ids")
405
+ async def bulk_get_room_encryption(
406
+ self, room_ids: set[str]
407
+ ) -> Mapping[str, Union[Optional[str], Sentinel]]:
408
+ """
409
+ Bulk fetch room encryption for the given rooms (via current state).
410
+
411
+ Since this function is cached, any missing values would be cached as `None`. In
412
+ order to distinguish between an unencrypted room that has `None` encryption and
413
+ a room that is unknown to the server where we might want to omit the value
414
+ (which would make it cached as `None`), instead we use the sentinel value
415
+ `ROOM_UNKNOWN_SENTINEL`.
416
+
417
+ Returns:
418
+ A mapping from room ID to the room's encryption algorithm if the room is
419
+ encrypted, otherwise `None`. Rooms unknown to this server will return
420
+ `ROOM_UNKNOWN_SENTINEL`.
421
+ """
422
+
423
+ def txn(
424
+ txn: LoggingTransaction,
425
+ ) -> MutableMapping[str, Union[Optional[str], Sentinel]]:
426
+ clause, args = make_in_list_sql_clause(
427
+ txn.database_engine, "room_id", room_ids
428
+ )
429
+
430
+ # We can't rely on `room_stats_state.encryption` if the server has left the
431
+ # room because the `room_id` will still be in the table but everything will
432
+ # be set to `None` but `None` is a valid encryption value. We join against
433
+ # the `room_stats_current` table which keeps track of the
434
+ # `current_state_events` count (and a proxy value `local_users_in_room`
435
+ # which can used to assume the server is participating in the room and has
436
+ # current state) to ensure that the data in `room_stats_state` is up-to-date
437
+ # with the current state.
438
+ #
439
+ # FIXME: Use `room_stats_current.current_state_events` instead of
440
+ # `room_stats_current.local_users_in_room` once
441
+ # https://github.com/element-hq/synapse/issues/17457 is fixed.
442
+ sql = f"""
443
+ SELECT room_id, encryption
444
+ FROM room_stats_state
445
+ INNER JOIN room_stats_current USING (room_id)
446
+ WHERE
447
+ {clause}
448
+ AND local_users_in_room > 0
449
+ """
450
+
451
+ txn.execute(sql, args)
452
+
453
+ room_id_to_encryption_map = {}
454
+ for row in txn:
455
+ room_id_to_encryption_map[row[0]] = row[1]
456
+
457
+ return room_id_to_encryption_map
458
+
459
+ results = await self.db_pool.runInteraction(
460
+ "bulk_get_room_encryption",
461
+ txn,
462
+ )
463
+
464
+ # If we haven't updated `room_stats_state` with the room yet, query the state
465
+ # directly. This should happen only rarely so we don't mind if we do this in a
466
+ # loop.
467
+ encryption_event_ids: list[str] = []
468
+ for room_id in room_ids - results.keys():
469
+ state_map = await self.get_partial_filtered_current_state_ids(
470
+ room_id,
471
+ state_filter=StateFilter.from_types(
472
+ [
473
+ (EventTypes.Create, ""),
474
+ (EventTypes.RoomEncryption, ""),
475
+ ]
476
+ ),
477
+ )
478
+ # We can use the create event as a canary to tell whether the server has
479
+ # seen the room before
480
+ create_event_id = state_map.get((EventTypes.Create, ""))
481
+ encryption_event_id = state_map.get((EventTypes.RoomEncryption, ""))
482
+
483
+ if create_event_id is None:
484
+ # We use the sentinel value to distinguish between `None` which is a
485
+ # valid room type and a room that is unknown to the server so the value
486
+ # is just unset.
487
+ results[room_id] = ROOM_UNKNOWN_SENTINEL
488
+ continue
489
+
490
+ if encryption_event_id is None:
491
+ results[room_id] = None
492
+ else:
493
+ encryption_event_ids.append(encryption_event_id)
494
+
495
+ encryption_event_map = await self.get_events(encryption_event_ids)
496
+
497
+ for encryption_event_id in encryption_event_ids:
498
+ encryption_event = encryption_event_map.get(encryption_event_id)
499
+ # If the curent state says there is an encryption event, we should have it
500
+ # in the database.
501
+ assert encryption_event is not None
502
+
503
+ results[encryption_event.room_id] = encryption_event.content.get(
504
+ EventContentFields.ENCRYPTION_ALGORITHM
505
+ )
506
+
507
+ return results
508
+
509
+ @cached(max_entries=100000, iterable=True)
510
+ async def get_partial_current_state_ids(self, room_id: str) -> StateMap[str]:
511
+ """Get the current state event ids for a room based on the
512
+ current_state_events table.
513
+
514
+ This may be the partial state if we're lazy joining the room.
515
+
516
+ Args:
517
+ room_id: The room to get the state IDs of.
518
+
519
+ Returns:
520
+ The current state of the room.
521
+ """
522
+
523
+ def _get_current_state_ids_txn(txn: LoggingTransaction) -> StateMap[str]:
524
+ txn.execute(
525
+ """SELECT type, state_key, event_id FROM current_state_events
526
+ WHERE room_id = ?
527
+ """,
528
+ (room_id,),
529
+ )
530
+
531
+ return {(intern_string(r[0]), intern_string(r[1])): r[2] for r in txn}
532
+
533
+ return await self.db_pool.runInteraction(
534
+ "get_partial_current_state_ids", _get_current_state_ids_txn
535
+ )
536
+
537
+ async def check_if_events_in_current_state(
538
+ self, event_ids: StrCollection
539
+ ) -> frozenset[str]:
540
+ """Checks and returns which of the given events is part of the current state."""
541
+ rows = await self.db_pool.simple_select_many_batch(
542
+ table="current_state_events",
543
+ column="event_id",
544
+ iterable=event_ids,
545
+ retcols=("event_id",),
546
+ desc="check_if_events_in_current_state",
547
+ )
548
+
549
+ return frozenset(event_id for (event_id,) in rows)
550
+
551
+ # FIXME: how should this be cached?
552
+ @cancellable
553
+ async def get_partial_filtered_current_state_ids(
554
+ self, room_id: str, state_filter: Optional[StateFilter] = None
555
+ ) -> StateMap[str]:
556
+ """Get the current state event of a given type for a room based on the
557
+ current_state_events table. This may not be as up-to-date as the result
558
+ of doing a fresh state resolution as per state_handler.get_current_state
559
+
560
+ This may be the partial state if we're lazy joining the room.
561
+
562
+ Args:
563
+ room_id
564
+ state_filter: The state filter used to fetch state
565
+ from the database.
566
+
567
+ Returns:
568
+ Map from type/state_key to event ID.
569
+ """
570
+ if state_filter is None:
571
+ state_filter = StateFilter.all()
572
+
573
+ where_clause, where_args = (state_filter).make_sql_filter_clause()
574
+
575
+ if not where_clause:
576
+ # We delegate to the cached version
577
+ return await self.get_partial_current_state_ids(room_id)
578
+
579
+ def _get_filtered_current_state_ids_txn(
580
+ txn: LoggingTransaction,
581
+ ) -> StateMap[str]:
582
+ results = StateMapWrapper(state_filter=state_filter)
583
+
584
+ sql = """
585
+ SELECT type, state_key, event_id FROM current_state_events
586
+ WHERE room_id = ?
587
+ """
588
+
589
+ if where_clause:
590
+ sql += " AND (%s)" % (where_clause,)
591
+
592
+ args = [room_id]
593
+ args.extend(where_args)
594
+ txn.execute(sql, args)
595
+ for row in txn:
596
+ typ, state_key, event_id = row
597
+ key = (intern_string(typ), intern_string(state_key))
598
+ results[key] = event_id
599
+
600
+ return results
601
+
602
+ return await self.db_pool.runInteraction(
603
+ "get_filtered_current_state_ids", _get_filtered_current_state_ids_txn
604
+ )
605
+
606
+ @cached(max_entries=50000)
607
+ async def _get_state_group_for_event(self, event_id: str) -> Optional[int]:
608
+ return await self.db_pool.simple_select_one_onecol(
609
+ table="event_to_state_groups",
610
+ keyvalues={"event_id": event_id},
611
+ retcol="state_group",
612
+ allow_none=True,
613
+ desc="_get_state_group_for_event",
614
+ )
615
+
616
+ @cachedList(
617
+ cached_method_name="_get_state_group_for_event",
618
+ list_name="event_ids",
619
+ num_args=1,
620
+ )
621
+ async def _get_state_group_for_events(
622
+ self, event_ids: Collection[str]
623
+ ) -> Mapping[str, int]:
624
+ """Returns mapping event_id -> state_group.
625
+
626
+ Raises:
627
+ RuntimeError if the state is unknown at any of the given events
628
+ """
629
+ rows = cast(
630
+ list[tuple[str, int]],
631
+ await self.db_pool.simple_select_many_batch(
632
+ table="event_to_state_groups",
633
+ column="event_id",
634
+ iterable=event_ids,
635
+ keyvalues={},
636
+ retcols=("event_id", "state_group"),
637
+ desc="_get_state_group_for_events",
638
+ ),
639
+ )
640
+
641
+ res = dict(rows)
642
+ for e in event_ids:
643
+ if e not in res:
644
+ raise RuntimeError("No state group for unknown or outlier event %s" % e)
645
+ return res
646
+
647
+ async def get_referenced_state_groups(
648
+ self, state_groups: Iterable[int]
649
+ ) -> set[int]:
650
+ """Check if the state groups are referenced by events.
651
+
652
+ Args:
653
+ state_groups
654
+
655
+ Returns:
656
+ The subset of state groups that are referenced.
657
+ """
658
+
659
+ rows = cast(
660
+ list[tuple[int]],
661
+ await self.db_pool.simple_select_many_batch(
662
+ table="event_to_state_groups",
663
+ column="state_group",
664
+ iterable=state_groups,
665
+ keyvalues={},
666
+ retcols=("DISTINCT state_group",),
667
+ desc="get_referenced_state_groups",
668
+ ),
669
+ )
670
+
671
+ return {row[0] for row in rows}
672
+
673
+ async def update_state_for_partial_state_event(
674
+ self,
675
+ event: EventBase,
676
+ context: EventContext,
677
+ ) -> None:
678
+ """Update the state group for a partial state event"""
679
+ async with (
680
+ self._un_partial_stated_events_stream_id_gen.get_next() as un_partial_state_event_stream_id
681
+ ):
682
+ await self.db_pool.runInteraction(
683
+ "update_state_for_partial_state_event",
684
+ self._update_state_for_partial_state_event_txn,
685
+ event,
686
+ context,
687
+ un_partial_state_event_stream_id,
688
+ )
689
+
690
+ def _update_state_for_partial_state_event_txn(
691
+ self,
692
+ txn: LoggingTransaction,
693
+ event: EventBase,
694
+ context: EventContext,
695
+ un_partial_state_event_stream_id: int,
696
+ ) -> None:
697
+ # we shouldn't have any outliers here
698
+ assert not event.internal_metadata.is_outlier()
699
+
700
+ # anything that was rejected should have the same state as its
701
+ # predecessor.
702
+ if context.rejected:
703
+ state_group = context.state_group_before_event
704
+ else:
705
+ state_group = context.state_group
706
+
707
+ self.db_pool.simple_update_txn(
708
+ txn,
709
+ table="event_to_state_groups",
710
+ keyvalues={"event_id": event.event_id},
711
+ updatevalues={"state_group": state_group},
712
+ )
713
+
714
+ # the event may now be rejected where it was not before, or vice versa,
715
+ # in which case we need to update the rejected flags.
716
+ rejection_status_changed = bool(context.rejected) != (
717
+ event.rejected_reason is not None
718
+ )
719
+ if rejection_status_changed:
720
+ self.mark_event_rejected_txn(txn, event.event_id, context.rejected)
721
+
722
+ self.db_pool.simple_delete_one_txn(
723
+ txn,
724
+ table="partial_state_events",
725
+ keyvalues={"event_id": event.event_id},
726
+ )
727
+
728
+ txn.call_after(self.is_partial_state_event.invalidate, (event.event_id,))
729
+ txn.call_after(
730
+ self._get_state_group_for_event.prefill,
731
+ (event.event_id,),
732
+ state_group,
733
+ )
734
+
735
+ self.db_pool.simple_insert_txn(
736
+ txn,
737
+ "un_partial_stated_event_stream",
738
+ {
739
+ "stream_id": un_partial_state_event_stream_id,
740
+ "instance_name": self._instance_name,
741
+ "event_id": event.event_id,
742
+ "rejection_status_changed": rejection_status_changed,
743
+ },
744
+ )
745
+ txn.call_after(self.hs.get_notifier().on_new_replication_data)
746
+
747
+
748
+ class MainStateBackgroundUpdateStore(RoomMemberWorkerStore):
749
+ CURRENT_STATE_INDEX_UPDATE_NAME = "current_state_members_idx"
750
+ EVENT_STATE_GROUP_INDEX_UPDATE_NAME = "event_to_state_groups_sg_index"
751
+ DELETE_CURRENT_STATE_UPDATE_NAME = "delete_old_current_state_events"
752
+ MEMBERS_CURRENT_STATE_UPDATE_NAME = "current_state_events_members_room_index"
753
+
754
+ def __init__(
755
+ self,
756
+ database: DatabasePool,
757
+ db_conn: LoggingDatabaseConnection,
758
+ hs: "HomeServer",
759
+ ):
760
+ super().__init__(database, db_conn, hs)
761
+
762
+ self.server_name: str = hs.hostname
763
+
764
+ self.db_pool.updates.register_background_index_update(
765
+ self.CURRENT_STATE_INDEX_UPDATE_NAME,
766
+ index_name="current_state_events_member_index",
767
+ table="current_state_events",
768
+ columns=["state_key"],
769
+ where_clause="type='m.room.member'",
770
+ )
771
+ self.db_pool.updates.register_background_index_update(
772
+ self.EVENT_STATE_GROUP_INDEX_UPDATE_NAME,
773
+ index_name="event_to_state_groups_sg_index",
774
+ table="event_to_state_groups",
775
+ columns=["state_group"],
776
+ )
777
+ self.db_pool.updates.register_background_update_handler(
778
+ self.DELETE_CURRENT_STATE_UPDATE_NAME,
779
+ self._background_remove_left_rooms,
780
+ )
781
+ self.db_pool.updates.register_background_index_update(
782
+ self.MEMBERS_CURRENT_STATE_UPDATE_NAME,
783
+ index_name="current_state_events_members_room_index",
784
+ table="current_state_events",
785
+ columns=["room_id", "membership"],
786
+ where_clause="type='m.room.member'",
787
+ )
788
+
789
+ async def _background_remove_left_rooms(
790
+ self, progress: JsonDict, batch_size: int
791
+ ) -> int:
792
+ """Background update to delete rows from `current_state_events` and
793
+ `event_forward_extremities` tables of rooms that the server is no
794
+ longer joined to.
795
+ """
796
+
797
+ last_room_id = progress.get("last_room_id", "")
798
+
799
+ def _background_remove_left_rooms_txn(
800
+ txn: LoggingTransaction,
801
+ ) -> tuple[bool, set[str]]:
802
+ # get a batch of room ids to consider
803
+ sql = """
804
+ SELECT DISTINCT room_id FROM current_state_events
805
+ WHERE room_id > ? ORDER BY room_id LIMIT ?
806
+ """
807
+
808
+ txn.execute(sql, (last_room_id, batch_size))
809
+ room_ids = [row[0] for row in txn]
810
+ if not room_ids:
811
+ return True, set()
812
+
813
+ ###########################################################################
814
+ #
815
+ # exclude rooms where we have active members
816
+
817
+ sql = """
818
+ SELECT room_id
819
+ FROM local_current_membership
820
+ WHERE
821
+ room_id > ? AND room_id <= ?
822
+ AND membership = 'join'
823
+ GROUP BY room_id
824
+ """
825
+
826
+ txn.execute(sql, (last_room_id, room_ids[-1]))
827
+ joined_room_ids = {row[0] for row in txn}
828
+ to_delete = set(room_ids) - joined_room_ids
829
+
830
+ ###########################################################################
831
+ #
832
+ # exclude rooms which we are in the process of constructing; these otherwise
833
+ # qualify as "rooms with no local users", and would have their
834
+ # forward extremities cleaned up.
835
+
836
+ # the following query will return a list of rooms which have forward
837
+ # extremities that are *not* also the create event in the room - ie
838
+ # those that are not being created currently.
839
+
840
+ sql = """
841
+ SELECT DISTINCT efe.room_id
842
+ FROM event_forward_extremities efe
843
+ LEFT JOIN current_state_events cse ON
844
+ cse.event_id = efe.event_id
845
+ AND cse.type = 'm.room.create'
846
+ AND cse.state_key = ''
847
+ WHERE
848
+ cse.event_id IS NULL
849
+ AND efe.room_id > ? AND efe.room_id <= ?
850
+ """
851
+
852
+ txn.execute(sql, (last_room_id, room_ids[-1]))
853
+
854
+ # build a set of those rooms within `to_delete` that do not appear in
855
+ # the above, leaving us with the rooms in `to_delete` that *are* being
856
+ # created.
857
+ creating_rooms = to_delete.difference(row[0] for row in txn)
858
+ logger.info("skipping rooms which are being created: %s", creating_rooms)
859
+
860
+ # now remove the rooms being created from the list of those to delete.
861
+ #
862
+ # (we could have just taken the intersection of `to_delete` with the result
863
+ # of the sql query, but it's useful to be able to log `creating_rooms`; and
864
+ # having done so, it's quicker to remove the (few) creating rooms from
865
+ # `to_delete` than it is to form the intersection with the (larger) list of
866
+ # not-creating-rooms)
867
+
868
+ to_delete -= creating_rooms
869
+
870
+ ###########################################################################
871
+ #
872
+ # now clear the state for the rooms
873
+
874
+ logger.info("Deleting current state left rooms: %r", to_delete)
875
+
876
+ # First we get all users that we still think were joined to the
877
+ # room. This is so that we can mark those device lists as
878
+ # potentially stale, since there may have been a period where the
879
+ # server didn't share a room with the remote user and therefore may
880
+ # have missed any device updates.
881
+ rows = cast(
882
+ list[tuple[str]],
883
+ self.db_pool.simple_select_many_txn(
884
+ txn,
885
+ table="current_state_events",
886
+ column="room_id",
887
+ iterable=to_delete,
888
+ keyvalues={
889
+ "type": EventTypes.Member,
890
+ "membership": Membership.JOIN,
891
+ },
892
+ retcols=("state_key",),
893
+ ),
894
+ )
895
+
896
+ potentially_left_users = {row[0] for row in rows}
897
+
898
+ # Now lets actually delete the rooms from the DB.
899
+ self.db_pool.simple_delete_many_txn(
900
+ txn,
901
+ table="current_state_events",
902
+ column="room_id",
903
+ values=to_delete,
904
+ keyvalues={},
905
+ )
906
+
907
+ self.db_pool.simple_delete_many_txn(
908
+ txn,
909
+ table="event_forward_extremities",
910
+ column="room_id",
911
+ values=to_delete,
912
+ keyvalues={},
913
+ )
914
+
915
+ self.db_pool.updates._background_update_progress_txn(
916
+ txn,
917
+ self.DELETE_CURRENT_STATE_UPDATE_NAME,
918
+ {"last_room_id": room_ids[-1]},
919
+ )
920
+
921
+ return False, potentially_left_users
922
+
923
+ finished, potentially_left_users = await self.db_pool.runInteraction(
924
+ "_background_remove_left_rooms", _background_remove_left_rooms_txn
925
+ )
926
+
927
+ if finished:
928
+ await self.db_pool.updates._end_background_update(
929
+ self.DELETE_CURRENT_STATE_UPDATE_NAME
930
+ )
931
+
932
+ # Now go and check if we still share a room with the remote users in
933
+ # the deleted rooms. If not mark their device lists as stale.
934
+ joined_users = await self.get_users_server_still_shares_room_with(
935
+ potentially_left_users
936
+ )
937
+
938
+ for user_id in potentially_left_users - joined_users:
939
+ await self.mark_remote_user_device_list_as_unsubscribed(user_id) # type: ignore[attr-defined]
940
+
941
+ return batch_size
942
+
943
+
944
+ class StateStore(StateGroupWorkerStore, MainStateBackgroundUpdateStore):
945
+ """Keeps track of the state at a given event.
946
+
947
+ This is done by the concept of `state groups`. Every event is a assigned
948
+ a state group (identified by an arbitrary string), which references a
949
+ collection of state events. The current state of an event is then the
950
+ collection of state events referenced by the event's state group.
951
+
952
+ Hence, every change in the current state causes a new state group to be
953
+ generated. However, if no change happens (e.g., if we get a message event
954
+ with only one parent it inherits the state group from its parent.)
955
+
956
+ There are three tables:
957
+ * `state_groups`: Stores group name, first event with in the group and
958
+ room id.
959
+ * `event_to_state_groups`: Maps events to state groups.
960
+ * `state_groups_state`: Maps state group to state events.
961
+ """
962
+
963
+ def __init__(
964
+ self,
965
+ database: DatabasePool,
966
+ db_conn: LoggingDatabaseConnection,
967
+ hs: "HomeServer",
968
+ ):
969
+ super().__init__(database, db_conn, hs)
970
+
971
+
972
+ @attr.s(auto_attribs=True, slots=True)
973
+ class StateMapWrapper(dict[StateKey, str]):
974
+ """A wrapper around a StateMap[str] to ensure that we only query for items
975
+ that were not filtered out.
976
+
977
+ This is to help prevent bugs where we filter out state but other bits of the
978
+ code expect the state to be there.
979
+ """
980
+
981
+ state_filter: StateFilter
982
+
983
+ def __getitem__(self, key: StateKey) -> str:
984
+ if key not in self.state_filter:
985
+ raise Exception("State map was filtered and doesn't include: %s", key)
986
+ return super().__getitem__(key)
987
+
988
+ @overload # type: ignore[override]
989
+ def get(self, key: StateKey, default: None = None, /) -> Optional[str]: ...
990
+ @overload
991
+ def get(self, key: StateKey, default: str, /) -> str: ...
992
+ @overload
993
+ def get(self, key: StateKey, default: _T, /) -> Union[str, _T]: ...
994
+
995
+ def get(
996
+ self, key: StateKey, default: Union[str, _T, None] = None
997
+ ) -> Union[str, _T, None]:
998
+ if key not in self.state_filter:
999
+ raise Exception("State map was filtered and doesn't include: %s", key)
1000
+ return super().get(key, default)
1001
+
1002
+ def __contains__(self, key: Any) -> bool:
1003
+ if key not in self.state_filter:
1004
+ raise Exception("State map was filtered and doesn't include: %s", key)
1005
+
1006
+ return super().__contains__(key)