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,1211 @@
1
+ #
2
+ # This file is licensed under the Affero General Public License (AGPL) version 3.
3
+ #
4
+ # Copyright 2019 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
+
23
+ """Thread-local-alike tracking of log contexts within synapse
24
+
25
+ This module provides objects and utilities for tracking contexts through
26
+ synapse code, so that log lines can include a request identifier, and so that
27
+ CPU and database activity can be accounted for against the request that caused
28
+ them.
29
+
30
+ See doc/log_contexts.rst for details on how this works.
31
+ """
32
+
33
+ import logging
34
+ import threading
35
+ import typing
36
+ from types import TracebackType
37
+ from typing import (
38
+ TYPE_CHECKING,
39
+ Any,
40
+ Awaitable,
41
+ Callable,
42
+ Literal,
43
+ Optional,
44
+ TypeVar,
45
+ Union,
46
+ overload,
47
+ )
48
+
49
+ import attr
50
+ from typing_extensions import ParamSpec
51
+
52
+ from twisted.internet import defer, threads
53
+ from twisted.python.threadpool import ThreadPool
54
+
55
+ from synapse.logging.loggers import ExplicitlyConfiguredLogger
56
+ from synapse.util.stringutils import random_string_insecure_fast
57
+
58
+ if TYPE_CHECKING:
59
+ from synapse.logging.scopecontextmanager import _LogContextScope
60
+ from synapse.types import ISynapseReactor
61
+
62
+ logger = logging.getLogger(__name__)
63
+
64
+ original_logger_class = logging.getLoggerClass()
65
+ logging.setLoggerClass(ExplicitlyConfiguredLogger)
66
+ logcontext_debug_logger = logging.getLogger("synapse.logging.context.debug")
67
+ """
68
+ A logger for debugging when the logcontext switches.
69
+
70
+ Because this is very noisy and probably something only developers want to see when
71
+ debugging logcontext problems, we want people to explictly opt-in before seeing anything
72
+ in the logs. Requires explicitly setting `synapse.logging.context.debug` in the logging
73
+ configuration and does not inherit the log level from the parent logger.
74
+ """
75
+ # Restore the original logger class
76
+ logging.setLoggerClass(original_logger_class)
77
+
78
+ try:
79
+ import resource
80
+
81
+ # Python doesn't ship with a definition of RUSAGE_THREAD but it's defined
82
+ # to be 1 on linux so we hard code it.
83
+ RUSAGE_THREAD = 1
84
+
85
+ # If the system doesn't support RUSAGE_THREAD then this should throw an
86
+ # exception.
87
+ resource.getrusage(RUSAGE_THREAD)
88
+
89
+ is_thread_resource_usage_supported = True
90
+
91
+ def get_thread_resource_usage() -> "Optional[resource.struct_rusage]":
92
+ return resource.getrusage(RUSAGE_THREAD)
93
+
94
+ except Exception:
95
+ # If the system doesn't support resource.getrusage(RUSAGE_THREAD) then we
96
+ # won't track resource usage.
97
+ is_thread_resource_usage_supported = False
98
+
99
+ def get_thread_resource_usage() -> "Optional[resource.struct_rusage]":
100
+ return None
101
+
102
+
103
+ # a hook which can be set during testing to assert that we aren't abusing logcontexts.
104
+ def logcontext_error(msg: str) -> None:
105
+ logger.warning(msg)
106
+
107
+
108
+ # get an id for the current thread.
109
+ #
110
+ # threading.get_ident doesn't actually return an OS-level tid, and annoyingly,
111
+ # on Linux it actually returns the same value either side of a fork() call. However
112
+ # we only fork in one place, so it's not worth the hoop-jumping to get a real tid.
113
+ #
114
+ get_thread_id = threading.get_ident
115
+
116
+
117
+ class ContextResourceUsage:
118
+ """Object for tracking the resources used by a log context
119
+
120
+ Attributes:
121
+ ru_utime (float): user CPU time (in seconds)
122
+ ru_stime (float): system CPU time (in seconds)
123
+ db_txn_count (int): number of database transactions done
124
+ db_sched_duration_sec (float): amount of time spent waiting for a
125
+ database connection
126
+ db_txn_duration_sec (float): amount of time spent doing database
127
+ transactions (excluding scheduling time)
128
+ evt_db_fetch_count (int): number of events requested from the database
129
+ """
130
+
131
+ __slots__ = [
132
+ "ru_stime",
133
+ "ru_utime",
134
+ "db_txn_count",
135
+ "db_txn_duration_sec",
136
+ "db_sched_duration_sec",
137
+ "evt_db_fetch_count",
138
+ ]
139
+
140
+ def __init__(self, copy_from: "Optional[ContextResourceUsage]" = None) -> None:
141
+ """Create a new ContextResourceUsage
142
+
143
+ Args:
144
+ copy_from: if not None, an object to copy stats from
145
+ """
146
+ if copy_from is None:
147
+ self.reset()
148
+ else:
149
+ # FIXME: mypy can't infer the types set via reset() above, so specify explicitly for now
150
+ self.ru_utime: float = copy_from.ru_utime
151
+ self.ru_stime: float = copy_from.ru_stime
152
+ self.db_txn_count: int = copy_from.db_txn_count
153
+
154
+ self.db_txn_duration_sec: float = copy_from.db_txn_duration_sec
155
+ self.db_sched_duration_sec: float = copy_from.db_sched_duration_sec
156
+ self.evt_db_fetch_count: int = copy_from.evt_db_fetch_count
157
+
158
+ def copy(self) -> "ContextResourceUsage":
159
+ return ContextResourceUsage(copy_from=self)
160
+
161
+ def reset(self) -> None:
162
+ self.ru_stime = 0.0
163
+ self.ru_utime = 0.0
164
+ self.db_txn_count = 0
165
+
166
+ self.db_txn_duration_sec = 0.0
167
+ self.db_sched_duration_sec = 0.0
168
+ self.evt_db_fetch_count = 0
169
+
170
+ def __repr__(self) -> str:
171
+ return (
172
+ "<ContextResourceUsage ru_stime='%r', ru_utime='%r', "
173
+ "db_txn_count='%r', db_txn_duration_sec='%r', "
174
+ "db_sched_duration_sec='%r', evt_db_fetch_count='%r'>"
175
+ ) % (
176
+ self.ru_stime,
177
+ self.ru_utime,
178
+ self.db_txn_count,
179
+ self.db_txn_duration_sec,
180
+ self.db_sched_duration_sec,
181
+ self.evt_db_fetch_count,
182
+ )
183
+
184
+ def __iadd__(self, other: "ContextResourceUsage") -> "ContextResourceUsage":
185
+ """Add another ContextResourceUsage's stats to this one's.
186
+
187
+ Args:
188
+ other: the other resource usage object
189
+ """
190
+ self.ru_utime += other.ru_utime
191
+ self.ru_stime += other.ru_stime
192
+ self.db_txn_count += other.db_txn_count
193
+ self.db_txn_duration_sec += other.db_txn_duration_sec
194
+ self.db_sched_duration_sec += other.db_sched_duration_sec
195
+ self.evt_db_fetch_count += other.evt_db_fetch_count
196
+ return self
197
+
198
+ def __isub__(self, other: "ContextResourceUsage") -> "ContextResourceUsage":
199
+ self.ru_utime -= other.ru_utime
200
+ self.ru_stime -= other.ru_stime
201
+ self.db_txn_count -= other.db_txn_count
202
+ self.db_txn_duration_sec -= other.db_txn_duration_sec
203
+ self.db_sched_duration_sec -= other.db_sched_duration_sec
204
+ self.evt_db_fetch_count -= other.evt_db_fetch_count
205
+ return self
206
+
207
+ def __add__(self, other: "ContextResourceUsage") -> "ContextResourceUsage":
208
+ res = ContextResourceUsage(copy_from=self)
209
+ res += other
210
+ return res
211
+
212
+ def __sub__(self, other: "ContextResourceUsage") -> "ContextResourceUsage":
213
+ res = ContextResourceUsage(copy_from=self)
214
+ res -= other
215
+ return res
216
+
217
+
218
+ @attr.s(slots=True, auto_attribs=True)
219
+ class ContextRequest:
220
+ """
221
+ A bundle of attributes from the SynapseRequest object.
222
+
223
+ This exists to:
224
+
225
+ * Avoid a cycle between LoggingContext and SynapseRequest.
226
+ * Be a single variable that can be passed from parent LoggingContexts to
227
+ their children.
228
+ """
229
+
230
+ request_id: str
231
+ ip_address: str
232
+ site_tag: str
233
+ requester: Optional[str]
234
+ authenticated_entity: Optional[str]
235
+ method: str
236
+ url: str
237
+ protocol: str
238
+ user_agent: str
239
+
240
+
241
+ LoggingContextOrSentinel = Union["LoggingContext", "_Sentinel"]
242
+
243
+
244
+ class _Sentinel:
245
+ """
246
+ Sentinel to represent the root context
247
+
248
+ This should only be used for tasks outside of Synapse like when we yield control
249
+ back to the Twisted reactor (event loop) so we don't leak the current logging
250
+ context to other tasks that are scheduled next in the event loop.
251
+
252
+ Nothing from the Synapse homeserver should be logged with the sentinel context. i.e.
253
+ we should always know which server the logs are coming from.
254
+ """
255
+
256
+ __slots__ = [
257
+ "previous_context",
258
+ "finished",
259
+ "scope",
260
+ "server_name",
261
+ "request",
262
+ "tag",
263
+ ]
264
+
265
+ def __init__(self) -> None:
266
+ # Minimal set for compatibility with LoggingContext
267
+ self.previous_context = None
268
+ self.finished = False
269
+ self.server_name = "unknown_server_from_sentinel_context"
270
+ self.request = None
271
+ self.scope = None
272
+ self.tag = None
273
+
274
+ def __str__(self) -> str:
275
+ return "sentinel"
276
+
277
+ def start(self, rusage: "Optional[resource.struct_rusage]") -> None:
278
+ pass
279
+
280
+ def stop(self, rusage: "Optional[resource.struct_rusage]") -> None:
281
+ pass
282
+
283
+ def add_database_transaction(self, duration_sec: float) -> None:
284
+ pass
285
+
286
+ def add_database_scheduled(self, sched_sec: float) -> None:
287
+ pass
288
+
289
+ def record_event_fetch(self, event_count: int) -> None:
290
+ pass
291
+
292
+ def __bool__(self) -> Literal[False]:
293
+ return False
294
+
295
+
296
+ SENTINEL_CONTEXT = _Sentinel()
297
+
298
+
299
+ class LoggingContext:
300
+ """Additional context for log formatting. Contexts are scoped within a
301
+ "with" block.
302
+
303
+ If a parent is given when creating a new context, then:
304
+ - logging fields are copied from the parent to the new context on entry
305
+ - when the new context exits, the cpu usage stats are copied from the
306
+ child to the parent
307
+
308
+ Args:
309
+ name: Name for the context for logging.
310
+ server_name: The name of the server this context is associated with
311
+ (`config.server.server_name` or `hs.hostname`)
312
+ parent_context (LoggingContext|None): The parent of the new context
313
+ request: Synapse Request Context object. Useful to associate all the logs
314
+ happening to a given request.
315
+
316
+ """
317
+
318
+ __slots__ = [
319
+ "previous_context",
320
+ "name",
321
+ "server_name",
322
+ "parent_context",
323
+ "_resource_usage",
324
+ "usage_start",
325
+ "main_thread",
326
+ "finished",
327
+ "request",
328
+ "tag",
329
+ "scope",
330
+ ]
331
+
332
+ def __init__(
333
+ self,
334
+ *,
335
+ name: str,
336
+ server_name: str,
337
+ parent_context: "Optional[LoggingContext]" = None,
338
+ request: Optional[ContextRequest] = None,
339
+ ) -> None:
340
+ self.previous_context = current_context()
341
+
342
+ # track the resources used by this context so far
343
+ self._resource_usage = ContextResourceUsage()
344
+
345
+ # The thread resource usage when the logcontext became active. None
346
+ # if the context is not currently active.
347
+ self.usage_start: Optional[resource.struct_rusage] = None
348
+
349
+ self.name = name
350
+ self.server_name = server_name
351
+ self.main_thread = get_thread_id()
352
+ self.request = None
353
+ self.tag = ""
354
+ self.scope: Optional["_LogContextScope"] = None
355
+
356
+ # keep track of whether we have hit the __exit__ block for this context
357
+ # (suggesting that the the thing that created the context thinks it should
358
+ # be finished, and that re-activating it would suggest an error).
359
+ self.finished = False
360
+
361
+ self.parent_context = parent_context
362
+
363
+ # Inherit some fields from the parent context
364
+ if self.parent_context is not None:
365
+ # which request this corresponds to
366
+ self.request = self.parent_context.request
367
+
368
+ # we also track the current scope:
369
+ self.scope = self.parent_context.scope
370
+
371
+ if request is not None:
372
+ # the request param overrides the request from the parent context
373
+ self.request = request
374
+
375
+ def __str__(self) -> str:
376
+ return self.name
377
+
378
+ def __enter__(self) -> "LoggingContext":
379
+ """Enters this logging context into thread local storage"""
380
+ logcontext_debug_logger.debug("LoggingContext(%s).__enter__", self.name)
381
+ old_context = set_current_context(self)
382
+ if self.previous_context != old_context:
383
+ logcontext_error(
384
+ "Expected previous context %r, found %r"
385
+ % (
386
+ self.previous_context,
387
+ old_context,
388
+ )
389
+ )
390
+ return self
391
+
392
+ def __exit__(
393
+ self,
394
+ type: Optional[type[BaseException]],
395
+ value: Optional[BaseException],
396
+ traceback: Optional[TracebackType],
397
+ ) -> None:
398
+ """Restore the logging context in thread local storage to the state it
399
+ was before this context was entered.
400
+ Returns:
401
+ None to avoid suppressing any exceptions that were thrown.
402
+ """
403
+ logcontext_debug_logger.debug(
404
+ "LoggingContext(%s).__exit__ --> %s", self.name, self.previous_context
405
+ )
406
+ current = set_current_context(self.previous_context)
407
+ if current is not self:
408
+ if current is SENTINEL_CONTEXT:
409
+ logcontext_error("Expected logging context %s was lost" % (self,))
410
+ else:
411
+ logcontext_error(
412
+ "Expected logging context %s but found %s" % (self, current)
413
+ )
414
+
415
+ # the fact that we are here suggests that the caller thinks that everything
416
+ # is done and dusted for this logcontext, and further activity will not get
417
+ # recorded against the correct metrics.
418
+ self.finished = True
419
+
420
+ def start(self, rusage: "Optional[resource.struct_rusage]") -> None:
421
+ """
422
+ Record that this logcontext is currently running.
423
+
424
+ This should not be called directly: use set_current_context
425
+
426
+ Args:
427
+ rusage: the resources used by the current thread, at the point of
428
+ switching to this logcontext. May be None if this platform doesn't
429
+ support getrusuage.
430
+ """
431
+ if get_thread_id() != self.main_thread:
432
+ logcontext_error("Started logcontext %s on different thread" % (self,))
433
+ return
434
+
435
+ if self.finished:
436
+ logcontext_error("Re-starting finished log context %s" % (self,))
437
+
438
+ # If we haven't already started record the thread resource usage so
439
+ # far
440
+ if self.usage_start:
441
+ logcontext_error("Re-starting already-active log context %s" % (self,))
442
+ else:
443
+ self.usage_start = rusage
444
+
445
+ def stop(self, rusage: "Optional[resource.struct_rusage]") -> None:
446
+ """
447
+ Record that this logcontext is no longer running.
448
+
449
+ This should not be called directly: use set_current_context
450
+
451
+ Args:
452
+ rusage: the resources used by the current thread, at the point of
453
+ switching away from this logcontext. May be None if this platform
454
+ doesn't support getrusuage.
455
+ """
456
+
457
+ try:
458
+ if get_thread_id() != self.main_thread:
459
+ logcontext_error("Stopped logcontext %s on different thread" % (self,))
460
+ return
461
+
462
+ if not rusage:
463
+ return
464
+
465
+ # Record the cpu used since we started
466
+ if not self.usage_start:
467
+ logcontext_error(
468
+ "Called stop on logcontext %s without recording a start rusage"
469
+ % (self,)
470
+ )
471
+ return
472
+
473
+ utime_delta, stime_delta = self._get_cputime(rusage)
474
+ self.add_cputime(utime_delta, stime_delta)
475
+ finally:
476
+ self.usage_start = None
477
+
478
+ def get_resource_usage(self) -> ContextResourceUsage:
479
+ """Get resources used by this logcontext so far.
480
+
481
+ Returns:
482
+ A *copy* of the object tracking resource usage so far
483
+ """
484
+ # we always return a copy, for consistency
485
+ res = self._resource_usage.copy()
486
+
487
+ # If we are on the correct thread and we're currently running then we
488
+ # can include resource usage so far.
489
+ is_main_thread = get_thread_id() == self.main_thread
490
+ if self.usage_start and is_main_thread:
491
+ rusage = get_thread_resource_usage()
492
+ assert rusage is not None
493
+ utime_delta, stime_delta = self._get_cputime(rusage)
494
+ res.ru_utime += utime_delta
495
+ res.ru_stime += stime_delta
496
+
497
+ return res
498
+
499
+ def _get_cputime(self, current: "resource.struct_rusage") -> tuple[float, float]:
500
+ """Get the cpu usage time between start() and the given rusage
501
+
502
+ Args:
503
+ rusage: the current resource usage
504
+
505
+ Returns: tuple[float, float]: seconds in user mode, seconds in system mode
506
+ """
507
+ assert self.usage_start is not None
508
+
509
+ utime_delta = current.ru_utime - self.usage_start.ru_utime
510
+ stime_delta = current.ru_stime - self.usage_start.ru_stime
511
+
512
+ # sanity check
513
+ if utime_delta < 0:
514
+ logger.error(
515
+ "utime went backwards! %f < %f",
516
+ current.ru_utime,
517
+ self.usage_start.ru_utime,
518
+ )
519
+ utime_delta = 0
520
+
521
+ if stime_delta < 0:
522
+ logger.error(
523
+ "stime went backwards! %f < %f",
524
+ current.ru_stime,
525
+ self.usage_start.ru_stime,
526
+ )
527
+ stime_delta = 0
528
+
529
+ return utime_delta, stime_delta
530
+
531
+ def add_cputime(self, utime_delta: float, stime_delta: float) -> None:
532
+ """Update the CPU time usage of this context (and any parents, recursively).
533
+
534
+ Args:
535
+ utime_delta: additional user time, in seconds, spent in this context.
536
+ stime_delta: additional system time, in seconds, spent in this context.
537
+ """
538
+ self._resource_usage.ru_utime += utime_delta
539
+ self._resource_usage.ru_stime += stime_delta
540
+ if self.parent_context:
541
+ self.parent_context.add_cputime(utime_delta, stime_delta)
542
+
543
+ def add_database_transaction(self, duration_sec: float) -> None:
544
+ """Record the use of a database transaction and the length of time it took.
545
+
546
+ Args:
547
+ duration_sec: The number of seconds the database transaction took.
548
+ """
549
+ if duration_sec < 0:
550
+ raise ValueError("DB txn time can only be non-negative")
551
+ self._resource_usage.db_txn_count += 1
552
+ self._resource_usage.db_txn_duration_sec += duration_sec
553
+ if self.parent_context:
554
+ self.parent_context.add_database_transaction(duration_sec)
555
+
556
+ def add_database_scheduled(self, sched_sec: float) -> None:
557
+ """Record a use of the database pool
558
+
559
+ Args:
560
+ sched_sec: number of seconds it took us to get a connection
561
+ """
562
+ if sched_sec < 0:
563
+ raise ValueError("DB scheduling time can only be non-negative")
564
+ self._resource_usage.db_sched_duration_sec += sched_sec
565
+ if self.parent_context:
566
+ self.parent_context.add_database_scheduled(sched_sec)
567
+
568
+ def record_event_fetch(self, event_count: int) -> None:
569
+ """Record a number of events being fetched from the db
570
+
571
+ Args:
572
+ event_count: number of events being fetched
573
+ """
574
+ self._resource_usage.evt_db_fetch_count += event_count
575
+ if self.parent_context:
576
+ self.parent_context.record_event_fetch(event_count)
577
+
578
+
579
+ class LoggingContextFilter(logging.Filter):
580
+ """Logging filter that adds values from the current logging context to each
581
+ record.
582
+ """
583
+
584
+ def __init__(
585
+ self,
586
+ # `request` is here for backwards compatibility since we previously recommended
587
+ # people manually configure `LoggingContextFilter` like the following.
588
+ #
589
+ # ```yaml
590
+ # filters:
591
+ # context:
592
+ # (): synapse.logging.context.LoggingContextFilter
593
+ # request: ""
594
+ # ```
595
+ #
596
+ # TODO: Since we now configure `LoggingContextFilter` automatically since #8051
597
+ # (2020-08-11), we could consider removing this useless parameter. This would
598
+ # require people to remove their own manual configuration of
599
+ # `LoggingContextFilter` as it would cause `TypeError: Filter.__init__() got an
600
+ # unexpected keyword argument 'request'` -> `ValueError: Unable to configure
601
+ # filter 'context'`
602
+ request: str = "",
603
+ ):
604
+ self._default_request = request
605
+
606
+ def filter(self, record: logging.LogRecord) -> Literal[True]:
607
+ """
608
+ Add each field from the logging context to the record.
609
+
610
+ Please be mindful of 3rd-party code outside of Synapse (like in the case of
611
+ Synapse Pro for small hosts) as this is running as a global log record filter.
612
+ Other code may have set their own attributes on the record and the log record
613
+ may not be relevant to Synapse at all so we should not mangle it.
614
+
615
+ We can have some defaults but we should avoid overwriting existing attributes on
616
+ any log record unless we actually have a Synapse logcontext (not just the
617
+ default sentinel logcontext).
618
+
619
+ Returns:
620
+ True to include the record in the log output.
621
+ """
622
+ context = current_context()
623
+ record.request = self._default_request
624
+
625
+ # Avoid overwriting an existing `server_name` on the record. This is running in
626
+ # the context of a global log record filter so there may be 3rd-party code that
627
+ # adds their own `server_name` and we don't want to interfere with that
628
+ # (clobber).
629
+ if not hasattr(record, "server_name"):
630
+ record.server_name = "unknown_server_from_no_logcontext"
631
+
632
+ # context should never be None, but if it somehow ends up being, then
633
+ # we end up in a death spiral of infinite loops, so let's check, for
634
+ # robustness' sake.
635
+ if context is not None:
636
+
637
+ def safe_set(attr: str, value: Any) -> None:
638
+ """
639
+ Only write the attribute if it hasn't already been set or we actually have
640
+ a Synapse logcontext (indicating that this log record is relevant to
641
+ Synapse).
642
+ """
643
+ if context is not SENTINEL_CONTEXT or not hasattr(record, attr):
644
+ setattr(record, attr, value)
645
+
646
+ safe_set("server_name", context.server_name)
647
+
648
+ # Logging is interested in the request ID. Note that for backwards
649
+ # compatibility this is stored as the "request" on the record.
650
+ safe_set("request", str(context))
651
+
652
+ # Add some data from the HTTP request.
653
+ request = context.request
654
+ # The sentinel logcontext has no request so if we get past this point, we
655
+ # know we have some actual Synapse logcontext and don't need to worry about
656
+ # using `safe_set`. We'll consider this an optimization since this is a
657
+ # pretty hot-path.
658
+ if request is None:
659
+ return True
660
+
661
+ record.ip_address = request.ip_address
662
+ record.site_tag = request.site_tag
663
+ record.requester = request.requester
664
+ record.authenticated_entity = request.authenticated_entity
665
+ record.method = request.method
666
+ record.url = request.url
667
+ record.protocol = request.protocol
668
+ record.user_agent = request.user_agent
669
+
670
+ return True
671
+
672
+
673
+ class PreserveLoggingContext:
674
+ """
675
+ Context manager which replaces the logging context
676
+
677
+ The previous logging context is restored on exit.
678
+
679
+ `make_deferred_yieldable` is pretty equivalent to using `with
680
+ PreserveLoggingContext():` (using the default sentinel context), i.e. it clears the
681
+ logcontext before awaiting (and so before execution passes back to the reactor) and
682
+ restores the old context once the awaitable completes (execution passes from the
683
+ reactor back to the code).
684
+ """
685
+
686
+ __slots__ = ["_old_context", "_new_context", "_instance_id"]
687
+
688
+ def __init__(
689
+ self, new_context: LoggingContextOrSentinel = SENTINEL_CONTEXT
690
+ ) -> None:
691
+ self._new_context = new_context
692
+ self._instance_id = random_string_insecure_fast(5)
693
+
694
+ def __enter__(self) -> None:
695
+ logcontext_debug_logger.debug(
696
+ "PreserveLoggingContext(%s).__enter__ %s --> %s",
697
+ self._instance_id,
698
+ current_context(),
699
+ self._new_context,
700
+ )
701
+ self._old_context = set_current_context(self._new_context)
702
+
703
+ def __exit__(
704
+ self,
705
+ type: Optional[type[BaseException]],
706
+ value: Optional[BaseException],
707
+ traceback: Optional[TracebackType],
708
+ ) -> None:
709
+ logcontext_debug_logger.debug(
710
+ "PreserveLoggingContext(%s).__exit %s --> %s",
711
+ self._instance_id,
712
+ current_context(),
713
+ self._old_context,
714
+ )
715
+ context = set_current_context(self._old_context)
716
+
717
+ if context != self._new_context:
718
+ if not context:
719
+ logcontext_error(
720
+ "Expected logging context %s was lost" % (self._new_context,)
721
+ )
722
+ else:
723
+ logcontext_error(
724
+ "Expected logging context %s but found %s"
725
+ % (
726
+ self._new_context,
727
+ context,
728
+ )
729
+ )
730
+
731
+
732
+ _thread_local = threading.local()
733
+ _thread_local.current_context = SENTINEL_CONTEXT
734
+
735
+
736
+ def current_context() -> LoggingContextOrSentinel:
737
+ """Get the current logging context from thread local storage"""
738
+ return getattr(_thread_local, "current_context", SENTINEL_CONTEXT)
739
+
740
+
741
+ def set_current_context(context: LoggingContextOrSentinel) -> LoggingContextOrSentinel:
742
+ """Set the current logging context in thread local storage
743
+ Args:
744
+ context: The context to activate.
745
+
746
+ Returns:
747
+ The context that was previously active
748
+ """
749
+ # everything blows up if we allow current_context to be set to None, so sanity-check
750
+ # that now.
751
+ if context is None:
752
+ raise TypeError("'context' argument may not be None")
753
+
754
+ current = current_context()
755
+
756
+ if current is not context:
757
+ rusage = get_thread_resource_usage()
758
+ current.stop(rusage)
759
+ _thread_local.current_context = context
760
+ context.start(rusage)
761
+
762
+ return current
763
+
764
+
765
+ def nested_logging_context(suffix: str) -> LoggingContext:
766
+ """Creates a new logging context as a child of another.
767
+
768
+ The nested logging context will have a 'name' made up of the parent context's
769
+ name, plus the given suffix.
770
+
771
+ CPU/db usage stats will be added to the parent context's on exit.
772
+
773
+ Normal usage looks like:
774
+
775
+ with nested_logging_context(suffix):
776
+ # ... do stuff
777
+
778
+ Args:
779
+ suffix: suffix to add to the parent context's 'name'.
780
+
781
+ Returns:
782
+ A new logging context.
783
+ """
784
+ curr_context = current_context()
785
+ if not curr_context:
786
+ logger.warning(
787
+ "Starting nested logging context from sentinel context: metrics will be lost"
788
+ )
789
+ parent_context = None
790
+ server_name = "unknown_server_from_sentinel_context"
791
+ else:
792
+ assert isinstance(curr_context, LoggingContext)
793
+ parent_context = curr_context
794
+ server_name = parent_context.server_name
795
+ prefix = str(curr_context)
796
+ return LoggingContext(
797
+ name=prefix + "-" + suffix,
798
+ server_name=server_name,
799
+ parent_context=parent_context,
800
+ )
801
+
802
+
803
+ P = ParamSpec("P")
804
+ R = TypeVar("R")
805
+
806
+
807
+ async def _unwrap_awaitable(awaitable: Awaitable[R]) -> R:
808
+ """Unwraps an arbitrary awaitable by awaiting it."""
809
+ return await awaitable
810
+
811
+
812
+ @overload
813
+ def preserve_fn(
814
+ f: Callable[P, Awaitable[R]],
815
+ ) -> Callable[P, "defer.Deferred[R]"]:
816
+ # The `type: ignore[misc]` above suppresses
817
+ # "Overloaded function signatures 1 and 2 overlap with incompatible return types"
818
+ ...
819
+
820
+
821
+ @overload
822
+ def preserve_fn(f: Callable[P, R]) -> Callable[P, "defer.Deferred[R]"]: ...
823
+
824
+
825
+ def preserve_fn(
826
+ f: Union[
827
+ Callable[P, R],
828
+ Callable[P, Awaitable[R]],
829
+ ],
830
+ ) -> Callable[P, "defer.Deferred[R]"]:
831
+ """Function decorator which wraps the function with run_in_background"""
832
+
833
+ def g(*args: P.args, **kwargs: P.kwargs) -> "defer.Deferred[R]":
834
+ return run_in_background(f, *args, **kwargs)
835
+
836
+ return g
837
+
838
+
839
+ @overload
840
+ def run_in_background(
841
+ f: Callable[P, Awaitable[R]], *args: P.args, **kwargs: P.kwargs
842
+ ) -> "defer.Deferred[R]":
843
+ # The `type: ignore[misc]` above suppresses
844
+ # "Overloaded function signatures 1 and 2 overlap with incompatible return types"
845
+ ...
846
+
847
+
848
+ @overload
849
+ def run_in_background(
850
+ f: Callable[P, R], *args: P.args, **kwargs: P.kwargs
851
+ ) -> "defer.Deferred[R]": ...
852
+
853
+
854
+ def run_in_background(
855
+ f: Union[
856
+ Callable[P, R],
857
+ Callable[P, Awaitable[R]],
858
+ ],
859
+ *args: P.args,
860
+ **kwargs: P.kwargs,
861
+ ) -> "defer.Deferred[R]":
862
+ """Calls a function, ensuring that the current context is restored after
863
+ return from the function, and that the sentinel context is set once the
864
+ deferred returned by the function completes.
865
+
866
+ To explain how the log contexts work here:
867
+ - When `run_in_background` is called, the calling logcontext is stored
868
+ ("original"), we kick off the background task in the current context, and we
869
+ restore that original context before returning.
870
+ - For a completed deferred, that's the end of the story.
871
+ - For an incomplete deferred, when the background task finishes, we don't want to
872
+ leak our context into the reactor which would erroneously get attached to the
873
+ next operation picked up by the event loop. We add a callback to the deferred
874
+ which will clear the logging context after it finishes and yields control back to
875
+ the reactor.
876
+
877
+ Useful for wrapping functions that return a deferred or coroutine, which you don't
878
+ yield or await on (for instance because you want to pass it to
879
+ deferred.gatherResults()).
880
+
881
+ If f returns a Coroutine object, it will be wrapped into a Deferred (which will have
882
+ the side effect of executing the coroutine).
883
+
884
+ Note that if you completely discard the result, you should make sure that
885
+ `f` doesn't raise any deferred exceptions, otherwise a scary-looking
886
+ CRITICAL error about an unhandled error will be logged without much
887
+ indication about where it came from.
888
+
889
+ Returns:
890
+ Deferred which returns the result of func, or `None` if func raises.
891
+ Note that the returned Deferred does not follow the synapse logcontext
892
+ rules.
893
+ """
894
+ instance_id = random_string_insecure_fast(5)
895
+ calling_context = current_context()
896
+ logcontext_debug_logger.debug(
897
+ "run_in_background(%s): called with logcontext=%s", instance_id, calling_context
898
+ )
899
+ try:
900
+ # (kick off the task in the current context)
901
+ res = f(*args, **kwargs)
902
+ except Exception:
903
+ # the assumption here is that the caller doesn't want to be disturbed
904
+ # by synchronous exceptions, so let's turn them into Failures.
905
+ return defer.fail()
906
+
907
+ # `res` may be a coroutine, `Deferred`, some other kind of awaitable, or a plain
908
+ # value. Convert it to a `Deferred`.
909
+ #
910
+ # Wrapping the value in a deferred has the side effect of executing the coroutine,
911
+ # if it is one. If it's already a deferred, then we can just use that.
912
+ d: "defer.Deferred[R]"
913
+ if isinstance(res, typing.Coroutine):
914
+ # Wrap the coroutine in a `Deferred`.
915
+ d = defer.ensureDeferred(res)
916
+ elif isinstance(res, defer.Deferred):
917
+ d = res
918
+ elif isinstance(res, Awaitable):
919
+ # `res` is probably some kind of completed awaitable, such as a `DoneAwaitable`
920
+ # or `Future` from `make_awaitable`.
921
+ d = defer.ensureDeferred(_unwrap_awaitable(res))
922
+ else:
923
+ # `res` is a plain value. Wrap it in a `Deferred`.
924
+ d = defer.succeed(res)
925
+
926
+ # The deferred has already completed
927
+ if d.called and not d.paused:
928
+ # If the function messes with logcontexts, we can assume it follows the Synapse
929
+ # logcontext rules (Rules for functions returning awaitables: "If the awaitable
930
+ # is already complete, the function returns with the same logcontext it started
931
+ # with."). If the function doesn't touch logcontexts at all, we can also assume
932
+ # the logcontext is unchanged.
933
+ #
934
+ # Either way, the function should have maintained the calling logcontext, so we
935
+ # can avoid messing with it further. Additionally, if the deferred has already
936
+ # completed, then it would be a mistake to then add a deferred callback (below)
937
+ # to reset the logcontext to the sentinel logcontext as that would run
938
+ # immediately (remember our goal is to maintain the calling logcontext when we
939
+ # return).
940
+ if current_context() != calling_context:
941
+ logcontext_error(
942
+ "run_in_background(%s): deferred already completed but the function did not maintain the calling logcontext %s (found %s)"
943
+ % (
944
+ instance_id,
945
+ calling_context,
946
+ current_context(),
947
+ )
948
+ )
949
+ else:
950
+ logcontext_debug_logger.debug(
951
+ "run_in_background(%s): deferred already completed (maintained the calling logcontext %s)",
952
+ instance_id,
953
+ calling_context,
954
+ )
955
+ return d
956
+
957
+ # Since the function we called may follow the Synapse logcontext rules (Rules for
958
+ # functions returning awaitables: "If the awaitable is incomplete, the function
959
+ # clears the logcontext before returning"), the function may have reset the
960
+ # logcontext before returning, so we need to restore the calling logcontext now
961
+ # before we return ourselves.
962
+ #
963
+ # Our goal is to have the caller logcontext unchanged after firing off the
964
+ # background task and returning.
965
+ logcontext_debug_logger.debug(
966
+ "run_in_background(%s): restoring calling logcontext %s",
967
+ instance_id,
968
+ calling_context,
969
+ )
970
+ set_current_context(calling_context)
971
+
972
+ # If the function we called is playing nice and following the Synapse logcontext
973
+ # rules, it will restore original calling logcontext when the deferred completes;
974
+ # but there is nothing waiting for it, so it will get leaked into the reactor (which
975
+ # would then get picked up by the next thing the reactor does). We therefore need to
976
+ # reset the logcontext here (set the `sentinel` logcontext) before yielding control
977
+ # back to the reactor.
978
+ #
979
+ # (If this feels asymmetric, consider it this way: we are
980
+ # effectively forking a new thread of execution. We are
981
+ # probably currently within a ``with LoggingContext()`` block,
982
+ # which is supposed to have a single entry and exit point. But
983
+ # by spawning off another deferred, we are effectively
984
+ # adding a new exit point.)
985
+ if logcontext_debug_logger.isEnabledFor(logging.DEBUG):
986
+
987
+ def _log_set_context_cb(
988
+ result: ResultT, context: LoggingContextOrSentinel
989
+ ) -> ResultT:
990
+ logcontext_debug_logger.debug(
991
+ "run_in_background(%s): resetting logcontext to %s",
992
+ instance_id,
993
+ context,
994
+ )
995
+ set_current_context(context)
996
+ return result
997
+
998
+ d.addBoth(_log_set_context_cb, SENTINEL_CONTEXT)
999
+ else:
1000
+ d.addBoth(_set_context_cb, SENTINEL_CONTEXT)
1001
+
1002
+ return d
1003
+
1004
+
1005
+ def run_coroutine_in_background(
1006
+ coroutine: typing.Coroutine[Any, Any, R],
1007
+ ) -> "defer.Deferred[R]":
1008
+ """Run the coroutine, ensuring that the current context is restored after
1009
+ return from the function, and that the sentinel context is set once the
1010
+ deferred returned by the function completes.
1011
+
1012
+ Useful for wrapping coroutines that you don't yield or await on (for
1013
+ instance because you want to pass it to deferred.gatherResults()).
1014
+
1015
+ This is a special case of `run_in_background` where we can accept a coroutine
1016
+ directly rather than a function. We can do this because coroutines do not continue
1017
+ running once they have yielded.
1018
+
1019
+ This is an ergonomic helper so we can do this:
1020
+ ```python
1021
+ run_coroutine_in_background(func1(arg1))
1022
+ ```
1023
+ Rather than having to do this:
1024
+ ```python
1025
+ run_in_background(lambda: func1(arg1))
1026
+ ```
1027
+ """
1028
+ return run_in_background(lambda: coroutine)
1029
+
1030
+
1031
+ T = TypeVar("T")
1032
+
1033
+
1034
+ def make_deferred_yieldable(deferred: "defer.Deferred[T]") -> "defer.Deferred[T]":
1035
+ """
1036
+ Given a deferred, make it follow the Synapse logcontext rules:
1037
+
1038
+ - If the deferred has completed, essentially does nothing (just returns another
1039
+ completed deferred with the result/failure).
1040
+ - If the deferred has not yet completed, resets the logcontext before returning a
1041
+ incomplete deferred. Then, when the deferred completes, restores the current
1042
+ logcontext before running callbacks/errbacks.
1043
+
1044
+ This means the resultant deferred can be awaited without leaking the current
1045
+ logcontext to the reactor (which would then get erroneously picked up by the next
1046
+ thing the reactor does), and also means that the logcontext is preserved when the
1047
+ deferred completes.
1048
+
1049
+ (This is more-or-less the opposite operation to run_in_background in terms of how it
1050
+ handles log contexts.)
1051
+
1052
+ Pretty much equivalent to using `with PreserveLoggingContext():`, i.e. it clears the
1053
+ logcontext before awaiting (and so before execution passes back to the reactor) and
1054
+ restores the old context once the awaitable completes (execution passes from the
1055
+ reactor back to the code).
1056
+ """
1057
+ instance_id = random_string_insecure_fast(5)
1058
+ logcontext_debug_logger.debug(
1059
+ "make_deferred_yieldable(%s): called with logcontext=%s",
1060
+ instance_id,
1061
+ current_context(),
1062
+ )
1063
+
1064
+ # The deferred has already completed
1065
+ if deferred.called and not deferred.paused:
1066
+ # it looks like this deferred is ready to run any callbacks we give it
1067
+ # immediately. We may as well optimise out the logcontext faffery.
1068
+ logcontext_debug_logger.debug(
1069
+ "make_deferred_yieldable(%s): deferred already completed and the function should have maintained the logcontext",
1070
+ instance_id,
1071
+ )
1072
+ return deferred
1073
+
1074
+ # Our goal is to have the caller logcontext unchanged after they yield/await the
1075
+ # returned deferred.
1076
+ #
1077
+ # When the caller yield/await's the returned deferred, it may yield
1078
+ # control back to the reactor. To avoid leaking the current logcontext to the
1079
+ # reactor (which would then get erroneously picked up by the next thing the reactor
1080
+ # does) while the deferred runs in the reactor event loop, we reset the logcontext
1081
+ # and add a callback to the deferred to restore it so the caller's logcontext is
1082
+ # active when the deferred completes.
1083
+
1084
+ logcontext_debug_logger.debug(
1085
+ "make_deferred_yieldable(%s): resetting logcontext to %s",
1086
+ instance_id,
1087
+ SENTINEL_CONTEXT,
1088
+ )
1089
+ calling_context = set_current_context(SENTINEL_CONTEXT)
1090
+
1091
+ if logcontext_debug_logger.isEnabledFor(logging.DEBUG):
1092
+
1093
+ def _log_set_context_cb(
1094
+ result: ResultT, context: LoggingContextOrSentinel
1095
+ ) -> ResultT:
1096
+ logcontext_debug_logger.debug(
1097
+ "make_deferred_yieldable(%s): restoring calling logcontext to %s",
1098
+ instance_id,
1099
+ context,
1100
+ )
1101
+ set_current_context(context)
1102
+ return result
1103
+
1104
+ deferred.addBoth(_log_set_context_cb, calling_context)
1105
+ else:
1106
+ deferred.addBoth(_set_context_cb, calling_context)
1107
+
1108
+ return deferred
1109
+
1110
+
1111
+ ResultT = TypeVar("ResultT")
1112
+
1113
+
1114
+ def _set_context_cb(result: ResultT, context: LoggingContextOrSentinel) -> ResultT:
1115
+ """A callback function which just sets the logging context"""
1116
+ set_current_context(context)
1117
+ return result
1118
+
1119
+
1120
+ def defer_to_thread(
1121
+ reactor: "ISynapseReactor", f: Callable[P, R], *args: P.args, **kwargs: P.kwargs
1122
+ ) -> "defer.Deferred[R]":
1123
+ """
1124
+ Calls the function `f` using a thread from the reactor's default threadpool and
1125
+ returns the result as a Deferred.
1126
+
1127
+ Creates a new logcontext for `f`, which is created as a child of the current
1128
+ logcontext (so its CPU usage metrics will get attributed to the current
1129
+ logcontext). `f` should preserve the logcontext it is given.
1130
+
1131
+ The result deferred follows the Synapse logcontext rules: you should `yield`
1132
+ on it.
1133
+
1134
+ Args:
1135
+ reactor: The reactor in whose main thread the Deferred will be invoked,
1136
+ and whose threadpool we should use for the function.
1137
+
1138
+ Normally this will be hs.get_reactor().
1139
+
1140
+ f: The function to call.
1141
+
1142
+ args: positional arguments to pass to f.
1143
+
1144
+ kwargs: keyword arguments to pass to f.
1145
+
1146
+ Returns:
1147
+ A Deferred which fires a callback with the result of `f`, or an
1148
+ errback if `f` throws an exception.
1149
+ """
1150
+ return defer_to_threadpool(reactor, reactor.getThreadPool(), f, *args, **kwargs)
1151
+
1152
+
1153
+ def defer_to_threadpool(
1154
+ reactor: "ISynapseReactor",
1155
+ threadpool: ThreadPool,
1156
+ f: Callable[P, R],
1157
+ *args: P.args,
1158
+ **kwargs: P.kwargs,
1159
+ ) -> "defer.Deferred[R]":
1160
+ """
1161
+ A wrapper for twisted.internet.threads.deferToThreadpool, which handles
1162
+ logcontexts correctly.
1163
+
1164
+ Calls the function `f` using a thread from the given threadpool and returns
1165
+ the result as a Deferred.
1166
+
1167
+ Creates a new logcontext for `f`, which is created as a child of the current
1168
+ logcontext (so its CPU usage metrics will get attributed to the current
1169
+ logcontext). `f` should preserve the logcontext it is given.
1170
+
1171
+ The result deferred follows the Synapse logcontext rules: you should `yield`
1172
+ on it.
1173
+
1174
+ Args:
1175
+ reactor: The reactor in whose main thread the Deferred will be invoked.
1176
+ Normally this will be hs.get_reactor().
1177
+
1178
+ threadpool: The threadpool to use for running `f`. Normally this will be
1179
+ hs.get_reactor().getThreadPool().
1180
+
1181
+ f: The function to call.
1182
+
1183
+ args: positional arguments to pass to f.
1184
+
1185
+ kwargs: keyword arguments to pass to f.
1186
+
1187
+ Returns:
1188
+ A Deferred which fires a callback with the result of `f`, or an
1189
+ errback if `f` throws an exception.
1190
+ """
1191
+ curr_context = current_context()
1192
+ if not curr_context:
1193
+ logger.warning(
1194
+ "Calling defer_to_threadpool from sentinel context: metrics will be lost"
1195
+ )
1196
+ parent_context = None
1197
+ server_name = "unknown_server_from_sentinel_context"
1198
+ else:
1199
+ assert isinstance(curr_context, LoggingContext)
1200
+ parent_context = curr_context
1201
+ server_name = parent_context.server_name
1202
+
1203
+ def g() -> R:
1204
+ with LoggingContext(
1205
+ name=str(curr_context),
1206
+ server_name=server_name,
1207
+ parent_context=parent_context,
1208
+ ):
1209
+ return f(*args, **kwargs)
1210
+
1211
+ return make_deferred_yieldable(threads.deferToThreadPool(reactor, threadpool, g))