matrix-synapse 1.145.0rc2__cp310-abi3-manylinux_2_28_x86_64.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 (1636) hide show
  1. AUTHORS.rst +51 -0
  2. CHANGES.md +1732 -0
  3. CONTRIBUTING.md +3 -0
  4. Cargo.lock +1923 -0
  5. Cargo.toml +6 -0
  6. INSTALL.md +7 -0
  7. LICENSE-AGPL-3.0 +661 -0
  8. LICENSE-COMMERCIAL +6 -0
  9. UPGRADE.rst +7 -0
  10. book.toml +47 -0
  11. changelog.d/.gitignore +1 -0
  12. demo/.gitignore +4 -0
  13. demo/clean.sh +22 -0
  14. demo/start.sh +173 -0
  15. demo/stop.sh +14 -0
  16. docs/.sample_config_header.yaml +12 -0
  17. docs/CAPTCHA_SETUP.md +37 -0
  18. docs/README.md +86 -0
  19. docs/SUMMARY.md +126 -0
  20. docs/admin_api/README.rst +13 -0
  21. docs/admin_api/account_validity.md +47 -0
  22. docs/admin_api/client_server_api_extensions.md +67 -0
  23. docs/admin_api/event_reports.md +185 -0
  24. docs/admin_api/experimental_features.md +52 -0
  25. docs/admin_api/fetch_event.md +53 -0
  26. docs/admin_api/media_admin_api.md +372 -0
  27. docs/admin_api/purge_history_api.md +77 -0
  28. docs/admin_api/register_api.md +92 -0
  29. docs/admin_api/room_membership.md +35 -0
  30. docs/admin_api/rooms.md +1190 -0
  31. docs/admin_api/scheduled_tasks.md +54 -0
  32. docs/admin_api/server_notices.md +48 -0
  33. docs/admin_api/statistics.md +132 -0
  34. docs/admin_api/user_admin_api.md +1602 -0
  35. docs/admin_api/version_api.md +23 -0
  36. docs/ancient_architecture_notes.md +81 -0
  37. docs/application_services.md +36 -0
  38. docs/architecture.md +65 -0
  39. docs/auth_chain_diff.dot +32 -0
  40. docs/auth_chain_diff.dot.png +0 -0
  41. docs/auth_chain_difference_algorithm.md +141 -0
  42. docs/changelogs/CHANGES-2019.md +1039 -0
  43. docs/changelogs/CHANGES-2020.md +2145 -0
  44. docs/changelogs/CHANGES-2021.md +2573 -0
  45. docs/changelogs/CHANGES-2022.md +2766 -0
  46. docs/changelogs/CHANGES-2023.md +2202 -0
  47. docs/changelogs/CHANGES-2024.md +1586 -0
  48. docs/changelogs/CHANGES-pre-1.0.md +3641 -0
  49. docs/changelogs/README.md +1 -0
  50. docs/code_style.md +119 -0
  51. docs/consent_tracking.md +197 -0
  52. docs/delegate.md +111 -0
  53. docs/deprecation_policy.md +89 -0
  54. docs/development/cas.md +64 -0
  55. docs/development/contributing_guide.md +554 -0
  56. docs/development/database_schema.md +404 -0
  57. docs/development/demo.md +42 -0
  58. docs/development/dependencies.md +326 -0
  59. docs/development/experimental_features.md +37 -0
  60. docs/development/git.md +148 -0
  61. docs/development/img/git/branches.jpg +0 -0
  62. docs/development/img/git/clean.png +0 -0
  63. docs/development/img/git/squash.png +0 -0
  64. docs/development/internal_documentation/README.md +12 -0
  65. docs/development/internal_documentation/release_notes_review_checklist.md +12 -0
  66. docs/development/releases.md +37 -0
  67. docs/development/reviews.md +41 -0
  68. docs/development/room-dag-concepts.md +115 -0
  69. docs/development/saml.md +40 -0
  70. docs/development/synapse_architecture/cancellation.md +392 -0
  71. docs/development/synapse_architecture/faster_joins.md +375 -0
  72. docs/development/synapse_architecture/streams.md +198 -0
  73. docs/element_logo_white_bg.svg +94 -0
  74. docs/favicon.png +0 -0
  75. docs/favicon.svg +58 -0
  76. docs/federate.md +67 -0
  77. docs/jwt.md +105 -0
  78. docs/log_contexts.md +566 -0
  79. docs/manhole.md +101 -0
  80. docs/media_repository.md +78 -0
  81. docs/message_retention_policies.md +207 -0
  82. docs/metrics-howto.md +315 -0
  83. docs/modules/account_data_callbacks.md +106 -0
  84. docs/modules/account_validity_callbacks.md +57 -0
  85. docs/modules/add_extra_fields_to_client_events_unsigned.md +32 -0
  86. docs/modules/background_update_controller_callbacks.md +71 -0
  87. docs/modules/index.md +53 -0
  88. docs/modules/media_repository_callbacks.md +131 -0
  89. docs/modules/password_auth_provider_callbacks.md +270 -0
  90. docs/modules/porting_legacy_module.md +20 -0
  91. docs/modules/presence_router_callbacks.md +112 -0
  92. docs/modules/ratelimit_callbacks.md +43 -0
  93. docs/modules/spam_checker_callbacks.md +517 -0
  94. docs/modules/third_party_rules_callbacks.md +350 -0
  95. docs/modules/writing_a_module.md +141 -0
  96. docs/openid.md +783 -0
  97. docs/opentracing.md +99 -0
  98. docs/other/running_synapse_on_single_board_computers.md +75 -0
  99. docs/password_auth_providers.md +129 -0
  100. docs/postgres.md +269 -0
  101. docs/presence_router_module.md +247 -0
  102. docs/privacy_policy_templates/en/1.0.html +26 -0
  103. docs/privacy_policy_templates/en/success.html +11 -0
  104. docs/replication.md +36 -0
  105. docs/reverse_proxy.md +327 -0
  106. docs/room_and_user_statistics.md +22 -0
  107. docs/sample_config.yaml +47 -0
  108. docs/sample_log_config.yaml +75 -0
  109. docs/server_notices.md +66 -0
  110. docs/setup/forward_proxy.md +89 -0
  111. docs/setup/installation.md +656 -0
  112. docs/setup/security.md +41 -0
  113. docs/setup/turn/coturn.md +197 -0
  114. docs/setup/turn/eturnal.md +170 -0
  115. docs/spam_checker.md +122 -0
  116. docs/sso_mapping_providers.md +208 -0
  117. docs/structured_logging.md +80 -0
  118. docs/synctl_workers.md +36 -0
  119. docs/systemd-with-workers/README.md +101 -0
  120. docs/systemd-with-workers/system/matrix-synapse-worker@.service +26 -0
  121. docs/systemd-with-workers/system/matrix-synapse.service +23 -0
  122. docs/systemd-with-workers/system/matrix-synapse.target +6 -0
  123. docs/systemd-with-workers/workers/background_worker.yaml +4 -0
  124. docs/systemd-with-workers/workers/event_persister.yaml +20 -0
  125. docs/systemd-with-workers/workers/federation_sender.yaml +4 -0
  126. docs/systemd-with-workers/workers/generic_worker.yaml +11 -0
  127. docs/systemd-with-workers/workers/media_worker.yaml +11 -0
  128. docs/systemd-with-workers/workers/pusher_worker.yaml +4 -0
  129. docs/tcp_replication.md +258 -0
  130. docs/templates.md +254 -0
  131. docs/turn-howto.md +168 -0
  132. docs/upgrade.md +2876 -0
  133. docs/usage/administration/README.md +7 -0
  134. docs/usage/administration/admin_api/README.md +47 -0
  135. docs/usage/administration/admin_api/background_updates.md +109 -0
  136. docs/usage/administration/admin_api/federation.md +212 -0
  137. docs/usage/administration/admin_api/registration_tokens.md +298 -0
  138. docs/usage/administration/admin_faq.md +294 -0
  139. docs/usage/administration/backups.md +125 -0
  140. docs/usage/administration/database_maintenance_tools.md +18 -0
  141. docs/usage/administration/monitoring/reporting_homeserver_usage_statistics.md +77 -0
  142. docs/usage/administration/monthly_active_users.md +84 -0
  143. docs/usage/administration/request_log.md +44 -0
  144. docs/usage/administration/state_groups.md +25 -0
  145. docs/usage/administration/understanding_synapse_through_grafana_graphs.md +83 -0
  146. docs/usage/administration/useful_sql_for_admins.md +216 -0
  147. docs/usage/configuration/README.md +4 -0
  148. docs/usage/configuration/config_documentation.md +4768 -0
  149. docs/usage/configuration/homeserver_sample_config.md +17 -0
  150. docs/usage/configuration/logging_sample_config.md +19 -0
  151. docs/usage/configuration/user_authentication/README.md +15 -0
  152. docs/usage/configuration/user_authentication/refresh_tokens.md +139 -0
  153. docs/usage/configuration/user_authentication/single_sign_on/README.md +5 -0
  154. docs/usage/configuration/user_authentication/single_sign_on/cas.md +8 -0
  155. docs/usage/configuration/user_authentication/single_sign_on/saml.md +8 -0
  156. docs/user_directory.md +130 -0
  157. docs/website_files/README.md +35 -0
  158. docs/website_files/indent-section-headers.css +7 -0
  159. docs/website_files/remove-nav-buttons.css +8 -0
  160. docs/website_files/table-of-contents.css +47 -0
  161. docs/website_files/table-of-contents.js +148 -0
  162. docs/website_files/theme/index.hbs +324 -0
  163. docs/website_files/version-picker.css +78 -0
  164. docs/website_files/version-picker.js +147 -0
  165. docs/website_files/version.js +1 -0
  166. docs/welcome_and_overview.md +67 -0
  167. docs/workers.md +897 -0
  168. matrix_synapse-1.145.0rc2.dist-info/METADATA +260 -0
  169. matrix_synapse-1.145.0rc2.dist-info/RECORD +1636 -0
  170. matrix_synapse-1.145.0rc2.dist-info/WHEEL +5 -0
  171. matrix_synapse-1.145.0rc2.dist-info/entry_points.txt +13 -0
  172. matrix_synapse-1.145.0rc2.dist-info/licenses/AUTHORS.rst +51 -0
  173. matrix_synapse-1.145.0rc2.dist-info/licenses/LICENSE-AGPL-3.0 +661 -0
  174. matrix_synapse-1.145.0rc2.dist-info/licenses/LICENSE-COMMERCIAL +6 -0
  175. mypy.ini +115 -0
  176. rust/Cargo.toml +63 -0
  177. rust/build.rs +45 -0
  178. scripts-dev/build_debian_packages.py +228 -0
  179. scripts-dev/check-newsfragment.sh +62 -0
  180. scripts-dev/check_line_terminators.sh +29 -0
  181. scripts-dev/check_locked_deps_have_sdists.py +64 -0
  182. scripts-dev/check_schema_delta.py +240 -0
  183. scripts-dev/complement.sh +332 -0
  184. scripts-dev/config-lint.sh +15 -0
  185. scripts-dev/database-save.sh +15 -0
  186. scripts-dev/docker_update_debian_changelog.sh +70 -0
  187. scripts-dev/dump_macaroon.py +25 -0
  188. scripts-dev/federation_client.py +428 -0
  189. scripts-dev/gen_config_documentation.py +510 -0
  190. scripts-dev/generate_sample_config.sh +28 -0
  191. scripts-dev/lint.sh +141 -0
  192. scripts-dev/make_full_schema.sh +310 -0
  193. scripts-dev/mypy_synapse_plugin.py +918 -0
  194. scripts-dev/next_github_number.sh +9 -0
  195. scripts-dev/release.py +986 -0
  196. scripts-dev/schema_versions.py +182 -0
  197. scripts-dev/sign_json.py +172 -0
  198. synapse/__init__.py +97 -0
  199. synapse/_scripts/__init__.py +0 -0
  200. synapse/_scripts/export_signing_key.py +109 -0
  201. synapse/_scripts/generate_config.py +83 -0
  202. synapse/_scripts/generate_log_config.py +56 -0
  203. synapse/_scripts/generate_signing_key.py +55 -0
  204. synapse/_scripts/generate_workers_map.py +318 -0
  205. synapse/_scripts/hash_password.py +95 -0
  206. synapse/_scripts/move_remote_media_to_new_store.py +128 -0
  207. synapse/_scripts/register_new_matrix_user.py +402 -0
  208. synapse/_scripts/review_recent_signups.py +212 -0
  209. synapse/_scripts/synapse_port_db.py +1604 -0
  210. synapse/_scripts/synctl.py +365 -0
  211. synapse/_scripts/update_synapse_database.py +130 -0
  212. synapse/api/__init__.py +20 -0
  213. synapse/api/auth/__init__.py +207 -0
  214. synapse/api/auth/base.py +406 -0
  215. synapse/api/auth/internal.py +299 -0
  216. synapse/api/auth/mas.py +436 -0
  217. synapse/api/auth/msc3861_delegated.py +617 -0
  218. synapse/api/auth_blocking.py +144 -0
  219. synapse/api/constants.py +379 -0
  220. synapse/api/errors.py +913 -0
  221. synapse/api/filtering.py +537 -0
  222. synapse/api/presence.py +102 -0
  223. synapse/api/ratelimiting.py +481 -0
  224. synapse/api/room_versions.py +535 -0
  225. synapse/api/urls.py +118 -0
  226. synapse/app/__init__.py +62 -0
  227. synapse/app/_base.py +906 -0
  228. synapse/app/admin_cmd.py +388 -0
  229. synapse/app/appservice.py +30 -0
  230. synapse/app/client_reader.py +30 -0
  231. synapse/app/complement_fork_starter.py +206 -0
  232. synapse/app/event_creator.py +29 -0
  233. synapse/app/federation_reader.py +30 -0
  234. synapse/app/federation_sender.py +30 -0
  235. synapse/app/frontend_proxy.py +30 -0
  236. synapse/app/generic_worker.py +475 -0
  237. synapse/app/homeserver.py +505 -0
  238. synapse/app/media_repository.py +30 -0
  239. synapse/app/phone_stats_home.py +292 -0
  240. synapse/app/pusher.py +30 -0
  241. synapse/app/synchrotron.py +30 -0
  242. synapse/app/user_dir.py +31 -0
  243. synapse/appservice/__init__.py +458 -0
  244. synapse/appservice/api.py +567 -0
  245. synapse/appservice/scheduler.py +565 -0
  246. synapse/config/__init__.py +27 -0
  247. synapse/config/__main__.py +62 -0
  248. synapse/config/_base.py +1154 -0
  249. synapse/config/_base.pyi +216 -0
  250. synapse/config/_util.py +99 -0
  251. synapse/config/account_validity.py +116 -0
  252. synapse/config/api.py +141 -0
  253. synapse/config/appservice.py +210 -0
  254. synapse/config/auth.py +80 -0
  255. synapse/config/auto_accept_invites.py +43 -0
  256. synapse/config/background_updates.py +44 -0
  257. synapse/config/cache.py +231 -0
  258. synapse/config/captcha.py +90 -0
  259. synapse/config/cas.py +116 -0
  260. synapse/config/consent.py +73 -0
  261. synapse/config/database.py +184 -0
  262. synapse/config/emailconfig.py +367 -0
  263. synapse/config/experimental.py +601 -0
  264. synapse/config/federation.py +114 -0
  265. synapse/config/homeserver.py +141 -0
  266. synapse/config/jwt.py +55 -0
  267. synapse/config/key.py +447 -0
  268. synapse/config/logger.py +390 -0
  269. synapse/config/mas.py +192 -0
  270. synapse/config/matrixrtc.py +66 -0
  271. synapse/config/metrics.py +93 -0
  272. synapse/config/modules.py +40 -0
  273. synapse/config/oembed.py +185 -0
  274. synapse/config/oidc.py +509 -0
  275. synapse/config/password_auth_providers.py +82 -0
  276. synapse/config/push.py +64 -0
  277. synapse/config/ratelimiting.py +260 -0
  278. synapse/config/redis.py +74 -0
  279. synapse/config/registration.py +296 -0
  280. synapse/config/repository.py +311 -0
  281. synapse/config/retention.py +162 -0
  282. synapse/config/room.py +88 -0
  283. synapse/config/room_directory.py +165 -0
  284. synapse/config/saml2.py +251 -0
  285. synapse/config/server.py +1139 -0
  286. synapse/config/server_notices.py +84 -0
  287. synapse/config/spam_checker.py +66 -0
  288. synapse/config/sso.py +121 -0
  289. synapse/config/stats.py +54 -0
  290. synapse/config/third_party_event_rules.py +40 -0
  291. synapse/config/tls.py +192 -0
  292. synapse/config/tracer.py +71 -0
  293. synapse/config/user_directory.py +47 -0
  294. synapse/config/user_types.py +42 -0
  295. synapse/config/voip.py +59 -0
  296. synapse/config/workers.py +642 -0
  297. synapse/crypto/__init__.py +20 -0
  298. synapse/crypto/context_factory.py +278 -0
  299. synapse/crypto/event_signing.py +194 -0
  300. synapse/crypto/keyring.py +980 -0
  301. synapse/event_auth.py +1266 -0
  302. synapse/events/__init__.py +667 -0
  303. synapse/events/auto_accept_invites.py +216 -0
  304. synapse/events/builder.py +387 -0
  305. synapse/events/presence_router.py +243 -0
  306. synapse/events/snapshot.py +559 -0
  307. synapse/events/utils.py +924 -0
  308. synapse/events/validator.py +305 -0
  309. synapse/federation/__init__.py +22 -0
  310. synapse/federation/federation_base.py +382 -0
  311. synapse/federation/federation_client.py +2133 -0
  312. synapse/federation/federation_server.py +1543 -0
  313. synapse/federation/persistence.py +70 -0
  314. synapse/federation/send_queue.py +532 -0
  315. synapse/federation/sender/__init__.py +1165 -0
  316. synapse/federation/sender/per_destination_queue.py +886 -0
  317. synapse/federation/sender/transaction_manager.py +210 -0
  318. synapse/federation/transport/__init__.py +28 -0
  319. synapse/federation/transport/client.py +1199 -0
  320. synapse/federation/transport/server/__init__.py +334 -0
  321. synapse/federation/transport/server/_base.py +429 -0
  322. synapse/federation/transport/server/federation.py +910 -0
  323. synapse/federation/units.py +133 -0
  324. synapse/handlers/__init__.py +20 -0
  325. synapse/handlers/account.py +162 -0
  326. synapse/handlers/account_data.py +360 -0
  327. synapse/handlers/account_validity.py +362 -0
  328. synapse/handlers/admin.py +615 -0
  329. synapse/handlers/appservice.py +989 -0
  330. synapse/handlers/auth.py +2482 -0
  331. synapse/handlers/cas.py +413 -0
  332. synapse/handlers/deactivate_account.py +363 -0
  333. synapse/handlers/delayed_events.py +607 -0
  334. synapse/handlers/device.py +1869 -0
  335. synapse/handlers/devicemessage.py +399 -0
  336. synapse/handlers/directory.py +545 -0
  337. synapse/handlers/e2e_keys.py +1835 -0
  338. synapse/handlers/e2e_room_keys.py +455 -0
  339. synapse/handlers/event_auth.py +390 -0
  340. synapse/handlers/events.py +203 -0
  341. synapse/handlers/federation.py +2042 -0
  342. synapse/handlers/federation_event.py +2420 -0
  343. synapse/handlers/identity.py +812 -0
  344. synapse/handlers/initial_sync.py +528 -0
  345. synapse/handlers/jwt.py +120 -0
  346. synapse/handlers/message.py +2357 -0
  347. synapse/handlers/oidc.py +1801 -0
  348. synapse/handlers/pagination.py +811 -0
  349. synapse/handlers/password_policy.py +102 -0
  350. synapse/handlers/presence.py +2634 -0
  351. synapse/handlers/profile.py +656 -0
  352. synapse/handlers/push_rules.py +164 -0
  353. synapse/handlers/read_marker.py +79 -0
  354. synapse/handlers/receipts.py +351 -0
  355. synapse/handlers/register.py +1059 -0
  356. synapse/handlers/relations.py +623 -0
  357. synapse/handlers/reports.py +98 -0
  358. synapse/handlers/room.py +2449 -0
  359. synapse/handlers/room_list.py +632 -0
  360. synapse/handlers/room_member.py +2366 -0
  361. synapse/handlers/room_member_worker.py +146 -0
  362. synapse/handlers/room_policy.py +186 -0
  363. synapse/handlers/room_summary.py +1057 -0
  364. synapse/handlers/saml.py +524 -0
  365. synapse/handlers/search.py +723 -0
  366. synapse/handlers/send_email.py +209 -0
  367. synapse/handlers/set_password.py +71 -0
  368. synapse/handlers/sliding_sync/__init__.py +1961 -0
  369. synapse/handlers/sliding_sync/extensions.py +969 -0
  370. synapse/handlers/sliding_sync/room_lists.py +2317 -0
  371. synapse/handlers/sliding_sync/store.py +126 -0
  372. synapse/handlers/sso.py +1291 -0
  373. synapse/handlers/state_deltas.py +82 -0
  374. synapse/handlers/stats.py +322 -0
  375. synapse/handlers/sync.py +3096 -0
  376. synapse/handlers/thread_subscriptions.py +190 -0
  377. synapse/handlers/typing.py +612 -0
  378. synapse/handlers/ui_auth/__init__.py +48 -0
  379. synapse/handlers/ui_auth/checkers.py +332 -0
  380. synapse/handlers/user_directory.py +786 -0
  381. synapse/handlers/worker_lock.py +371 -0
  382. synapse/http/__init__.py +105 -0
  383. synapse/http/additional_resource.py +62 -0
  384. synapse/http/client.py +1377 -0
  385. synapse/http/connectproxyclient.py +316 -0
  386. synapse/http/federation/__init__.py +19 -0
  387. synapse/http/federation/matrix_federation_agent.py +490 -0
  388. synapse/http/federation/srv_resolver.py +196 -0
  389. synapse/http/federation/well_known_resolver.py +368 -0
  390. synapse/http/matrixfederationclient.py +1874 -0
  391. synapse/http/proxy.py +290 -0
  392. synapse/http/proxyagent.py +497 -0
  393. synapse/http/replicationagent.py +203 -0
  394. synapse/http/request_metrics.py +309 -0
  395. synapse/http/server.py +1111 -0
  396. synapse/http/servlet.py +1018 -0
  397. synapse/http/site.py +952 -0
  398. synapse/http/types.py +27 -0
  399. synapse/logging/__init__.py +31 -0
  400. synapse/logging/_remote.py +261 -0
  401. synapse/logging/_terse_json.py +95 -0
  402. synapse/logging/context.py +1209 -0
  403. synapse/logging/formatter.py +62 -0
  404. synapse/logging/handlers.py +99 -0
  405. synapse/logging/loggers.py +25 -0
  406. synapse/logging/opentracing.py +1132 -0
  407. synapse/logging/scopecontextmanager.py +160 -0
  408. synapse/media/_base.py +831 -0
  409. synapse/media/filepath.py +417 -0
  410. synapse/media/media_repository.py +1595 -0
  411. synapse/media/media_storage.py +703 -0
  412. synapse/media/oembed.py +277 -0
  413. synapse/media/preview_html.py +556 -0
  414. synapse/media/storage_provider.py +195 -0
  415. synapse/media/thumbnailer.py +833 -0
  416. synapse/media/url_previewer.py +884 -0
  417. synapse/metrics/__init__.py +748 -0
  418. synapse/metrics/_gc.py +219 -0
  419. synapse/metrics/_reactor_metrics.py +171 -0
  420. synapse/metrics/_types.py +38 -0
  421. synapse/metrics/background_process_metrics.py +555 -0
  422. synapse/metrics/common_usage_metrics.py +95 -0
  423. synapse/metrics/jemalloc.py +248 -0
  424. synapse/module_api/__init__.py +2131 -0
  425. synapse/module_api/callbacks/__init__.py +50 -0
  426. synapse/module_api/callbacks/account_validity_callbacks.py +106 -0
  427. synapse/module_api/callbacks/media_repository_callbacks.py +157 -0
  428. synapse/module_api/callbacks/ratelimit_callbacks.py +78 -0
  429. synapse/module_api/callbacks/spamchecker_callbacks.py +991 -0
  430. synapse/module_api/callbacks/third_party_event_rules_callbacks.py +592 -0
  431. synapse/module_api/errors.py +42 -0
  432. synapse/notifier.py +969 -0
  433. synapse/push/__init__.py +212 -0
  434. synapse/push/bulk_push_rule_evaluator.py +635 -0
  435. synapse/push/clientformat.py +126 -0
  436. synapse/push/emailpusher.py +334 -0
  437. synapse/push/httppusher.py +565 -0
  438. synapse/push/mailer.py +1009 -0
  439. synapse/push/presentable_names.py +216 -0
  440. synapse/push/push_tools.py +114 -0
  441. synapse/push/push_types.py +141 -0
  442. synapse/push/pusher.py +87 -0
  443. synapse/push/pusherpool.py +501 -0
  444. synapse/push/rulekinds.py +33 -0
  445. synapse/py.typed +0 -0
  446. synapse/replication/__init__.py +20 -0
  447. synapse/replication/http/__init__.py +68 -0
  448. synapse/replication/http/_base.py +469 -0
  449. synapse/replication/http/account_data.py +297 -0
  450. synapse/replication/http/deactivate_account.py +81 -0
  451. synapse/replication/http/delayed_events.py +62 -0
  452. synapse/replication/http/devices.py +254 -0
  453. synapse/replication/http/federation.py +334 -0
  454. synapse/replication/http/login.py +106 -0
  455. synapse/replication/http/membership.py +364 -0
  456. synapse/replication/http/presence.py +133 -0
  457. synapse/replication/http/push.py +156 -0
  458. synapse/replication/http/register.py +172 -0
  459. synapse/replication/http/send_events.py +182 -0
  460. synapse/replication/http/state.py +82 -0
  461. synapse/replication/http/streams.py +101 -0
  462. synapse/replication/tcp/__init__.py +56 -0
  463. synapse/replication/tcp/client.py +553 -0
  464. synapse/replication/tcp/commands.py +569 -0
  465. synapse/replication/tcp/context.py +41 -0
  466. synapse/replication/tcp/external_cache.py +156 -0
  467. synapse/replication/tcp/handler.py +922 -0
  468. synapse/replication/tcp/protocol.py +611 -0
  469. synapse/replication/tcp/redis.py +510 -0
  470. synapse/replication/tcp/resource.py +349 -0
  471. synapse/replication/tcp/streams/__init__.py +96 -0
  472. synapse/replication/tcp/streams/_base.py +765 -0
  473. synapse/replication/tcp/streams/events.py +287 -0
  474. synapse/replication/tcp/streams/federation.py +92 -0
  475. synapse/replication/tcp/streams/partial_state.py +80 -0
  476. synapse/res/providers.json +29 -0
  477. synapse/res/templates/_base.html +29 -0
  478. synapse/res/templates/account_previously_renewed.html +6 -0
  479. synapse/res/templates/account_renewed.html +6 -0
  480. synapse/res/templates/add_threepid.html +8 -0
  481. synapse/res/templates/add_threepid.txt +6 -0
  482. synapse/res/templates/add_threepid_failure.html +7 -0
  483. synapse/res/templates/add_threepid_success.html +6 -0
  484. synapse/res/templates/already_in_use.html +12 -0
  485. synapse/res/templates/already_in_use.txt +10 -0
  486. synapse/res/templates/auth_success.html +21 -0
  487. synapse/res/templates/invalid_token.html +6 -0
  488. synapse/res/templates/mail-Element.css +7 -0
  489. synapse/res/templates/mail-Vector.css +7 -0
  490. synapse/res/templates/mail-expiry.css +4 -0
  491. synapse/res/templates/mail.css +156 -0
  492. synapse/res/templates/notice_expiry.html +46 -0
  493. synapse/res/templates/notice_expiry.txt +7 -0
  494. synapse/res/templates/notif.html +51 -0
  495. synapse/res/templates/notif.txt +22 -0
  496. synapse/res/templates/notif_mail.html +59 -0
  497. synapse/res/templates/notif_mail.txt +10 -0
  498. synapse/res/templates/password_reset.html +10 -0
  499. synapse/res/templates/password_reset.txt +7 -0
  500. synapse/res/templates/password_reset_confirmation.html +15 -0
  501. synapse/res/templates/password_reset_failure.html +7 -0
  502. synapse/res/templates/password_reset_success.html +6 -0
  503. synapse/res/templates/recaptcha.html +42 -0
  504. synapse/res/templates/registration.html +12 -0
  505. synapse/res/templates/registration.txt +10 -0
  506. synapse/res/templates/registration_failure.html +6 -0
  507. synapse/res/templates/registration_success.html +6 -0
  508. synapse/res/templates/registration_token.html +18 -0
  509. synapse/res/templates/room.html +33 -0
  510. synapse/res/templates/room.txt +9 -0
  511. synapse/res/templates/sso.css +129 -0
  512. synapse/res/templates/sso_account_deactivated.html +25 -0
  513. synapse/res/templates/sso_auth_account_details.html +186 -0
  514. synapse/res/templates/sso_auth_account_details.js +116 -0
  515. synapse/res/templates/sso_auth_bad_user.html +26 -0
  516. synapse/res/templates/sso_auth_confirm.html +27 -0
  517. synapse/res/templates/sso_auth_success.html +26 -0
  518. synapse/res/templates/sso_error.html +71 -0
  519. synapse/res/templates/sso_footer.html +19 -0
  520. synapse/res/templates/sso_login_idp_picker.html +60 -0
  521. synapse/res/templates/sso_new_user_consent.html +30 -0
  522. synapse/res/templates/sso_partial_profile.html +19 -0
  523. synapse/res/templates/sso_redirect_confirm.html +39 -0
  524. synapse/res/templates/style.css +33 -0
  525. synapse/res/templates/terms.html +27 -0
  526. synapse/rest/__init__.py +197 -0
  527. synapse/rest/admin/__init__.py +395 -0
  528. synapse/rest/admin/_base.py +72 -0
  529. synapse/rest/admin/background_updates.py +171 -0
  530. synapse/rest/admin/devices.py +221 -0
  531. synapse/rest/admin/event_reports.py +173 -0
  532. synapse/rest/admin/events.py +69 -0
  533. synapse/rest/admin/experimental_features.py +137 -0
  534. synapse/rest/admin/federation.py +243 -0
  535. synapse/rest/admin/media.py +540 -0
  536. synapse/rest/admin/registration_tokens.py +358 -0
  537. synapse/rest/admin/rooms.py +1092 -0
  538. synapse/rest/admin/scheduled_tasks.py +70 -0
  539. synapse/rest/admin/server_notice_servlet.py +132 -0
  540. synapse/rest/admin/statistics.py +132 -0
  541. synapse/rest/admin/username_available.py +58 -0
  542. synapse/rest/admin/users.py +1634 -0
  543. synapse/rest/client/__init__.py +20 -0
  544. synapse/rest/client/_base.py +113 -0
  545. synapse/rest/client/account.py +937 -0
  546. synapse/rest/client/account_data.py +319 -0
  547. synapse/rest/client/account_validity.py +103 -0
  548. synapse/rest/client/appservice_ping.py +125 -0
  549. synapse/rest/client/auth.py +218 -0
  550. synapse/rest/client/auth_metadata.py +122 -0
  551. synapse/rest/client/capabilities.py +121 -0
  552. synapse/rest/client/delayed_events.py +165 -0
  553. synapse/rest/client/devices.py +587 -0
  554. synapse/rest/client/directory.py +211 -0
  555. synapse/rest/client/events.py +116 -0
  556. synapse/rest/client/filter.py +112 -0
  557. synapse/rest/client/initial_sync.py +65 -0
  558. synapse/rest/client/keys.py +678 -0
  559. synapse/rest/client/knock.py +104 -0
  560. synapse/rest/client/login.py +750 -0
  561. synapse/rest/client/login_token_request.py +127 -0
  562. synapse/rest/client/logout.py +93 -0
  563. synapse/rest/client/matrixrtc.py +52 -0
  564. synapse/rest/client/media.py +307 -0
  565. synapse/rest/client/mutual_rooms.py +145 -0
  566. synapse/rest/client/notifications.py +137 -0
  567. synapse/rest/client/openid.py +109 -0
  568. synapse/rest/client/password_policy.py +69 -0
  569. synapse/rest/client/presence.py +131 -0
  570. synapse/rest/client/profile.py +291 -0
  571. synapse/rest/client/push_rule.py +331 -0
  572. synapse/rest/client/pusher.py +181 -0
  573. synapse/rest/client/read_marker.py +104 -0
  574. synapse/rest/client/receipts.py +165 -0
  575. synapse/rest/client/register.py +1072 -0
  576. synapse/rest/client/relations.py +138 -0
  577. synapse/rest/client/rendezvous.py +76 -0
  578. synapse/rest/client/reporting.py +207 -0
  579. synapse/rest/client/room.py +1763 -0
  580. synapse/rest/client/room_keys.py +426 -0
  581. synapse/rest/client/room_upgrade_rest_servlet.py +112 -0
  582. synapse/rest/client/sendtodevice.py +85 -0
  583. synapse/rest/client/sync.py +1131 -0
  584. synapse/rest/client/tags.py +129 -0
  585. synapse/rest/client/thirdparty.py +130 -0
  586. synapse/rest/client/thread_subscriptions.py +247 -0
  587. synapse/rest/client/tokenrefresh.py +52 -0
  588. synapse/rest/client/transactions.py +150 -0
  589. synapse/rest/client/user_directory.py +99 -0
  590. synapse/rest/client/versions.py +193 -0
  591. synapse/rest/client/voip.py +88 -0
  592. synapse/rest/consent/__init__.py +0 -0
  593. synapse/rest/consent/consent_resource.py +210 -0
  594. synapse/rest/health.py +38 -0
  595. synapse/rest/key/__init__.py +20 -0
  596. synapse/rest/key/v2/__init__.py +40 -0
  597. synapse/rest/key/v2/local_key_resource.py +125 -0
  598. synapse/rest/key/v2/remote_key_resource.py +302 -0
  599. synapse/rest/media/__init__.py +0 -0
  600. synapse/rest/media/config_resource.py +53 -0
  601. synapse/rest/media/create_resource.py +90 -0
  602. synapse/rest/media/download_resource.py +110 -0
  603. synapse/rest/media/media_repository_resource.py +113 -0
  604. synapse/rest/media/preview_url_resource.py +77 -0
  605. synapse/rest/media/thumbnail_resource.py +142 -0
  606. synapse/rest/media/upload_resource.py +187 -0
  607. synapse/rest/media/v1/__init__.py +39 -0
  608. synapse/rest/media/v1/_base.py +23 -0
  609. synapse/rest/media/v1/media_storage.py +23 -0
  610. synapse/rest/media/v1/storage_provider.py +23 -0
  611. synapse/rest/synapse/__init__.py +20 -0
  612. synapse/rest/synapse/client/__init__.py +93 -0
  613. synapse/rest/synapse/client/federation_whitelist.py +66 -0
  614. synapse/rest/synapse/client/jwks.py +77 -0
  615. synapse/rest/synapse/client/new_user_consent.py +115 -0
  616. synapse/rest/synapse/client/oidc/__init__.py +45 -0
  617. synapse/rest/synapse/client/oidc/backchannel_logout_resource.py +42 -0
  618. synapse/rest/synapse/client/oidc/callback_resource.py +48 -0
  619. synapse/rest/synapse/client/password_reset.py +129 -0
  620. synapse/rest/synapse/client/pick_idp.py +107 -0
  621. synapse/rest/synapse/client/pick_username.py +153 -0
  622. synapse/rest/synapse/client/rendezvous.py +58 -0
  623. synapse/rest/synapse/client/saml2/__init__.py +42 -0
  624. synapse/rest/synapse/client/saml2/metadata_resource.py +46 -0
  625. synapse/rest/synapse/client/saml2/response_resource.py +52 -0
  626. synapse/rest/synapse/client/sso_register.py +56 -0
  627. synapse/rest/synapse/client/unsubscribe.py +88 -0
  628. synapse/rest/synapse/mas/__init__.py +71 -0
  629. synapse/rest/synapse/mas/_base.py +55 -0
  630. synapse/rest/synapse/mas/devices.py +239 -0
  631. synapse/rest/synapse/mas/users.py +469 -0
  632. synapse/rest/well_known.py +148 -0
  633. synapse/server.py +1279 -0
  634. synapse/server_notices/__init__.py +0 -0
  635. synapse/server_notices/consent_server_notices.py +136 -0
  636. synapse/server_notices/resource_limits_server_notices.py +215 -0
  637. synapse/server_notices/server_notices_manager.py +388 -0
  638. synapse/server_notices/server_notices_sender.py +67 -0
  639. synapse/server_notices/worker_server_notices_sender.py +46 -0
  640. synapse/spam_checker_api/__init__.py +31 -0
  641. synapse/state/__init__.py +1023 -0
  642. synapse/state/v1.py +369 -0
  643. synapse/state/v2.py +985 -0
  644. synapse/static/client/login/index.html +47 -0
  645. synapse/static/client/login/js/jquery-3.4.1.min.js +2 -0
  646. synapse/static/client/login/js/login.js +291 -0
  647. synapse/static/client/login/spinner.gif +0 -0
  648. synapse/static/client/login/style.css +79 -0
  649. synapse/static/index.html +63 -0
  650. synapse/storage/__init__.py +43 -0
  651. synapse/storage/_base.py +245 -0
  652. synapse/storage/admin_client_config.py +25 -0
  653. synapse/storage/background_updates.py +1189 -0
  654. synapse/storage/controllers/__init__.py +57 -0
  655. synapse/storage/controllers/persist_events.py +1237 -0
  656. synapse/storage/controllers/purge_events.py +456 -0
  657. synapse/storage/controllers/state.py +950 -0
  658. synapse/storage/controllers/stats.py +119 -0
  659. synapse/storage/database.py +2720 -0
  660. synapse/storage/databases/__init__.py +175 -0
  661. synapse/storage/databases/main/__init__.py +420 -0
  662. synapse/storage/databases/main/account_data.py +1073 -0
  663. synapse/storage/databases/main/appservice.py +473 -0
  664. synapse/storage/databases/main/cache.py +912 -0
  665. synapse/storage/databases/main/censor_events.py +226 -0
  666. synapse/storage/databases/main/client_ips.py +816 -0
  667. synapse/storage/databases/main/delayed_events.py +577 -0
  668. synapse/storage/databases/main/deviceinbox.py +1272 -0
  669. synapse/storage/databases/main/devices.py +2579 -0
  670. synapse/storage/databases/main/directory.py +212 -0
  671. synapse/storage/databases/main/e2e_room_keys.py +689 -0
  672. synapse/storage/databases/main/end_to_end_keys.py +1894 -0
  673. synapse/storage/databases/main/event_federation.py +2511 -0
  674. synapse/storage/databases/main/event_push_actions.py +1936 -0
  675. synapse/storage/databases/main/events.py +3765 -0
  676. synapse/storage/databases/main/events_bg_updates.py +2910 -0
  677. synapse/storage/databases/main/events_forward_extremities.py +126 -0
  678. synapse/storage/databases/main/events_worker.py +2787 -0
  679. synapse/storage/databases/main/experimental_features.py +130 -0
  680. synapse/storage/databases/main/filtering.py +231 -0
  681. synapse/storage/databases/main/keys.py +291 -0
  682. synapse/storage/databases/main/lock.py +554 -0
  683. synapse/storage/databases/main/media_repository.py +1068 -0
  684. synapse/storage/databases/main/metrics.py +461 -0
  685. synapse/storage/databases/main/monthly_active_users.py +443 -0
  686. synapse/storage/databases/main/openid.py +60 -0
  687. synapse/storage/databases/main/presence.py +509 -0
  688. synapse/storage/databases/main/profile.py +539 -0
  689. synapse/storage/databases/main/purge_events.py +521 -0
  690. synapse/storage/databases/main/push_rule.py +970 -0
  691. synapse/storage/databases/main/pusher.py +793 -0
  692. synapse/storage/databases/main/receipts.py +1341 -0
  693. synapse/storage/databases/main/registration.py +3071 -0
  694. synapse/storage/databases/main/rejections.py +37 -0
  695. synapse/storage/databases/main/relations.py +1116 -0
  696. synapse/storage/databases/main/room.py +2779 -0
  697. synapse/storage/databases/main/roommember.py +2132 -0
  698. synapse/storage/databases/main/search.py +939 -0
  699. synapse/storage/databases/main/session.py +152 -0
  700. synapse/storage/databases/main/signatures.py +94 -0
  701. synapse/storage/databases/main/sliding_sync.py +842 -0
  702. synapse/storage/databases/main/state.py +1002 -0
  703. synapse/storage/databases/main/state_deltas.py +360 -0
  704. synapse/storage/databases/main/stats.py +789 -0
  705. synapse/storage/databases/main/stream.py +2589 -0
  706. synapse/storage/databases/main/tags.py +360 -0
  707. synapse/storage/databases/main/task_scheduler.py +225 -0
  708. synapse/storage/databases/main/thread_subscriptions.py +589 -0
  709. synapse/storage/databases/main/transactions.py +676 -0
  710. synapse/storage/databases/main/ui_auth.py +420 -0
  711. synapse/storage/databases/main/user_directory.py +1330 -0
  712. synapse/storage/databases/main/user_erasure_store.py +117 -0
  713. synapse/storage/databases/state/__init__.py +22 -0
  714. synapse/storage/databases/state/bg_updates.py +497 -0
  715. synapse/storage/databases/state/deletion.py +557 -0
  716. synapse/storage/databases/state/store.py +948 -0
  717. synapse/storage/engines/__init__.py +70 -0
  718. synapse/storage/engines/_base.py +154 -0
  719. synapse/storage/engines/postgres.py +261 -0
  720. synapse/storage/engines/sqlite.py +199 -0
  721. synapse/storage/invite_rule.py +152 -0
  722. synapse/storage/keys.py +40 -0
  723. synapse/storage/prepare_database.py +730 -0
  724. synapse/storage/push_rule.py +28 -0
  725. synapse/storage/roommember.py +88 -0
  726. synapse/storage/schema/README.md +4 -0
  727. synapse/storage/schema/__init__.py +186 -0
  728. synapse/storage/schema/common/delta/25/00background_updates.sql +40 -0
  729. synapse/storage/schema/common/delta/35/00background_updates_add_col.sql +36 -0
  730. synapse/storage/schema/common/delta/58/00background_update_ordering.sql +38 -0
  731. synapse/storage/schema/common/full_schemas/72/full.sql.postgres +8 -0
  732. synapse/storage/schema/common/full_schemas/72/full.sql.sqlite +6 -0
  733. synapse/storage/schema/common/schema_version.sql +60 -0
  734. synapse/storage/schema/main/delta/12/v12.sql +82 -0
  735. synapse/storage/schema/main/delta/13/v13.sql +38 -0
  736. synapse/storage/schema/main/delta/14/v14.sql +42 -0
  737. synapse/storage/schema/main/delta/15/appservice_txns.sql +50 -0
  738. synapse/storage/schema/main/delta/15/presence_indices.sql +2 -0
  739. synapse/storage/schema/main/delta/15/v15.sql +24 -0
  740. synapse/storage/schema/main/delta/16/events_order_index.sql +4 -0
  741. synapse/storage/schema/main/delta/16/remote_media_cache_index.sql +2 -0
  742. synapse/storage/schema/main/delta/16/remove_duplicates.sql +9 -0
  743. synapse/storage/schema/main/delta/16/room_alias_index.sql +3 -0
  744. synapse/storage/schema/main/delta/16/unique_constraints.sql +72 -0
  745. synapse/storage/schema/main/delta/16/users.sql +56 -0
  746. synapse/storage/schema/main/delta/17/drop_indexes.sql +37 -0
  747. synapse/storage/schema/main/delta/17/server_keys.sql +43 -0
  748. synapse/storage/schema/main/delta/17/user_threepids.sql +9 -0
  749. synapse/storage/schema/main/delta/18/server_keys_bigger_ints.sql +51 -0
  750. synapse/storage/schema/main/delta/19/event_index.sql +38 -0
  751. synapse/storage/schema/main/delta/20/dummy.sql +1 -0
  752. synapse/storage/schema/main/delta/20/pushers.py +93 -0
  753. synapse/storage/schema/main/delta/21/end_to_end_keys.sql +53 -0
  754. synapse/storage/schema/main/delta/21/receipts.sql +57 -0
  755. synapse/storage/schema/main/delta/22/receipts_index.sql +41 -0
  756. synapse/storage/schema/main/delta/22/user_threepids_unique.sql +19 -0
  757. synapse/storage/schema/main/delta/24/stats_reporting.sql +37 -0
  758. synapse/storage/schema/main/delta/25/fts.py +81 -0
  759. synapse/storage/schema/main/delta/25/guest_access.sql +44 -0
  760. synapse/storage/schema/main/delta/25/history_visibility.sql +44 -0
  761. synapse/storage/schema/main/delta/25/tags.sql +57 -0
  762. synapse/storage/schema/main/delta/26/account_data.sql +36 -0
  763. synapse/storage/schema/main/delta/27/account_data.sql +55 -0
  764. synapse/storage/schema/main/delta/27/forgotten_memberships.sql +45 -0
  765. synapse/storage/schema/main/delta/27/ts.py +61 -0
  766. synapse/storage/schema/main/delta/28/event_push_actions.sql +46 -0
  767. synapse/storage/schema/main/delta/28/events_room_stream.sql +39 -0
  768. synapse/storage/schema/main/delta/28/public_roms_index.sql +39 -0
  769. synapse/storage/schema/main/delta/28/receipts_user_id_index.sql +41 -0
  770. synapse/storage/schema/main/delta/28/upgrade_times.sql +40 -0
  771. synapse/storage/schema/main/delta/28/users_is_guest.sql +41 -0
  772. synapse/storage/schema/main/delta/29/push_actions.sql +54 -0
  773. synapse/storage/schema/main/delta/30/alias_creator.sql +35 -0
  774. synapse/storage/schema/main/delta/30/as_users.py +82 -0
  775. synapse/storage/schema/main/delta/30/deleted_pushers.sql +44 -0
  776. synapse/storage/schema/main/delta/30/presence_stream.sql +49 -0
  777. synapse/storage/schema/main/delta/30/public_rooms.sql +42 -0
  778. synapse/storage/schema/main/delta/30/push_rule_stream.sql +57 -0
  779. synapse/storage/schema/main/delta/30/threepid_guest_access_tokens.sql +43 -0
  780. synapse/storage/schema/main/delta/31/invites.sql +61 -0
  781. synapse/storage/schema/main/delta/31/local_media_repository_url_cache.sql +46 -0
  782. synapse/storage/schema/main/delta/31/pushers_0.py +92 -0
  783. synapse/storage/schema/main/delta/31/pushers_index.sql +41 -0
  784. synapse/storage/schema/main/delta/31/search_update.py +65 -0
  785. synapse/storage/schema/main/delta/32/events.sql +35 -0
  786. synapse/storage/schema/main/delta/32/openid.sql +9 -0
  787. synapse/storage/schema/main/delta/32/pusher_throttle.sql +42 -0
  788. synapse/storage/schema/main/delta/32/remove_indices.sql +52 -0
  789. synapse/storage/schema/main/delta/32/reports.sql +44 -0
  790. synapse/storage/schema/main/delta/33/access_tokens_device_index.sql +36 -0
  791. synapse/storage/schema/main/delta/33/devices.sql +40 -0
  792. synapse/storage/schema/main/delta/33/devices_for_e2e_keys.sql +38 -0
  793. synapse/storage/schema/main/delta/33/devices_for_e2e_keys_clear_unknown_device.sql +39 -0
  794. synapse/storage/schema/main/delta/33/event_fields.py +61 -0
  795. synapse/storage/schema/main/delta/33/remote_media_ts.py +43 -0
  796. synapse/storage/schema/main/delta/33/user_ips_index.sql +36 -0
  797. synapse/storage/schema/main/delta/34/appservice_stream.sql +42 -0
  798. synapse/storage/schema/main/delta/34/cache_stream.py +50 -0
  799. synapse/storage/schema/main/delta/34/device_inbox.sql +43 -0
  800. synapse/storage/schema/main/delta/34/push_display_name_rename.sql +39 -0
  801. synapse/storage/schema/main/delta/34/received_txn_purge.py +36 -0
  802. synapse/storage/schema/main/delta/35/contains_url.sql +36 -0
  803. synapse/storage/schema/main/delta/35/device_outbox.sql +58 -0
  804. synapse/storage/schema/main/delta/35/device_stream_id.sql +40 -0
  805. synapse/storage/schema/main/delta/35/event_push_actions_index.sql +36 -0
  806. synapse/storage/schema/main/delta/35/public_room_list_change_stream.sql +52 -0
  807. synapse/storage/schema/main/delta/35/stream_order_to_extrem.sql +56 -0
  808. synapse/storage/schema/main/delta/36/readd_public_rooms.sql +45 -0
  809. synapse/storage/schema/main/delta/37/remove_auth_idx.py +89 -0
  810. synapse/storage/schema/main/delta/37/user_threepids.sql +71 -0
  811. synapse/storage/schema/main/delta/38/postgres_fts_gist.sql +38 -0
  812. synapse/storage/schema/main/delta/39/appservice_room_list.sql +48 -0
  813. synapse/storage/schema/main/delta/39/device_federation_stream_idx.sql +35 -0
  814. synapse/storage/schema/main/delta/39/event_push_index.sql +36 -0
  815. synapse/storage/schema/main/delta/39/federation_out_position.sql +41 -0
  816. synapse/storage/schema/main/delta/39/membership_profile.sql +39 -0
  817. synapse/storage/schema/main/delta/40/current_state_idx.sql +36 -0
  818. synapse/storage/schema/main/delta/40/device_inbox.sql +40 -0
  819. synapse/storage/schema/main/delta/40/device_list_streams.sql +79 -0
  820. synapse/storage/schema/main/delta/40/event_push_summary.sql +57 -0
  821. synapse/storage/schema/main/delta/40/pushers.sql +58 -0
  822. synapse/storage/schema/main/delta/41/device_list_stream_idx.sql +36 -0
  823. synapse/storage/schema/main/delta/41/device_outbound_index.sql +35 -0
  824. synapse/storage/schema/main/delta/41/event_search_event_id_idx.sql +36 -0
  825. synapse/storage/schema/main/delta/41/ratelimit.sql +41 -0
  826. synapse/storage/schema/main/delta/42/current_state_delta.sql +48 -0
  827. synapse/storage/schema/main/delta/42/device_list_last_id.sql +52 -0
  828. synapse/storage/schema/main/delta/42/event_auth_state_only.sql +36 -0
  829. synapse/storage/schema/main/delta/42/user_dir.py +88 -0
  830. synapse/storage/schema/main/delta/43/blocked_rooms.sql +40 -0
  831. synapse/storage/schema/main/delta/43/quarantine_media.sql +36 -0
  832. synapse/storage/schema/main/delta/43/url_cache.sql +35 -0
  833. synapse/storage/schema/main/delta/43/user_share.sql +52 -0
  834. synapse/storage/schema/main/delta/44/expire_url_cache.sql +60 -0
  835. synapse/storage/schema/main/delta/45/group_server.sql +186 -0
  836. synapse/storage/schema/main/delta/45/profile_cache.sql +47 -0
  837. synapse/storage/schema/main/delta/46/drop_refresh_tokens.sql +36 -0
  838. synapse/storage/schema/main/delta/46/drop_unique_deleted_pushers.sql +54 -0
  839. synapse/storage/schema/main/delta/46/group_server.sql +51 -0
  840. synapse/storage/schema/main/delta/46/local_media_repository_url_idx.sql +43 -0
  841. synapse/storage/schema/main/delta/46/user_dir_null_room_ids.sql +54 -0
  842. synapse/storage/schema/main/delta/46/user_dir_typos.sql +43 -0
  843. synapse/storage/schema/main/delta/47/last_access_media.sql +35 -0
  844. synapse/storage/schema/main/delta/47/postgres_fts_gin.sql +36 -0
  845. synapse/storage/schema/main/delta/47/push_actions_staging.sql +47 -0
  846. synapse/storage/schema/main/delta/48/add_user_consent.sql +37 -0
  847. synapse/storage/schema/main/delta/48/add_user_ips_last_seen_index.sql +36 -0
  848. synapse/storage/schema/main/delta/48/deactivated_users.sql +44 -0
  849. synapse/storage/schema/main/delta/48/group_unique_indexes.py +67 -0
  850. synapse/storage/schema/main/delta/48/groups_joinable.sql +41 -0
  851. synapse/storage/schema/main/delta/49/add_user_consent_server_notice_sent.sql +39 -0
  852. synapse/storage/schema/main/delta/49/add_user_daily_visits.sql +40 -0
  853. synapse/storage/schema/main/delta/49/add_user_ips_last_seen_only_index.sql +36 -0
  854. synapse/storage/schema/main/delta/50/add_creation_ts_users_index.sql +38 -0
  855. synapse/storage/schema/main/delta/50/erasure_store.sql +40 -0
  856. synapse/storage/schema/main/delta/50/make_event_content_nullable.py +102 -0
  857. synapse/storage/schema/main/delta/51/e2e_room_keys.sql +58 -0
  858. synapse/storage/schema/main/delta/51/monthly_active_users.sql +46 -0
  859. synapse/storage/schema/main/delta/52/add_event_to_state_group_index.sql +38 -0
  860. synapse/storage/schema/main/delta/52/device_list_streams_unique_idx.sql +55 -0
  861. synapse/storage/schema/main/delta/52/e2e_room_keys.sql +72 -0
  862. synapse/storage/schema/main/delta/53/add_user_type_to_users.sql +38 -0
  863. synapse/storage/schema/main/delta/53/drop_sent_transactions.sql +35 -0
  864. synapse/storage/schema/main/delta/53/event_format_version.sql +35 -0
  865. synapse/storage/schema/main/delta/53/user_dir_populate.sql +49 -0
  866. synapse/storage/schema/main/delta/53/user_ips_index.sql +49 -0
  867. synapse/storage/schema/main/delta/53/user_share.sql +63 -0
  868. synapse/storage/schema/main/delta/53/user_threepid_id.sql +48 -0
  869. synapse/storage/schema/main/delta/53/users_in_public_rooms.sql +47 -0
  870. synapse/storage/schema/main/delta/54/account_validity_with_renewal.sql +49 -0
  871. synapse/storage/schema/main/delta/54/add_validity_to_server_keys.sql +42 -0
  872. synapse/storage/schema/main/delta/54/delete_forward_extremities.sql +42 -0
  873. synapse/storage/schema/main/delta/54/drop_legacy_tables.sql +49 -0
  874. synapse/storage/schema/main/delta/54/drop_presence_list.sql +35 -0
  875. synapse/storage/schema/main/delta/54/relations.sql +46 -0
  876. synapse/storage/schema/main/delta/54/stats.sql +99 -0
  877. synapse/storage/schema/main/delta/54/stats2.sql +47 -0
  878. synapse/storage/schema/main/delta/55/access_token_expiry.sql +37 -0
  879. synapse/storage/schema/main/delta/55/track_threepid_validations.sql +50 -0
  880. synapse/storage/schema/main/delta/55/users_alter_deactivated.sql +38 -0
  881. synapse/storage/schema/main/delta/56/add_spans_to_device_lists.sql +39 -0
  882. synapse/storage/schema/main/delta/56/current_state_events_membership.sql +41 -0
  883. synapse/storage/schema/main/delta/56/current_state_events_membership_mk2.sql +43 -0
  884. synapse/storage/schema/main/delta/56/delete_keys_from_deleted_backups.sql +44 -0
  885. synapse/storage/schema/main/delta/56/destinations_failure_ts.sql +44 -0
  886. synapse/storage/schema/main/delta/56/destinations_retry_interval_type.sql.postgres +18 -0
  887. synapse/storage/schema/main/delta/56/device_stream_id_insert.sql +39 -0
  888. synapse/storage/schema/main/delta/56/devices_last_seen.sql +43 -0
  889. synapse/storage/schema/main/delta/56/drop_unused_event_tables.sql +39 -0
  890. synapse/storage/schema/main/delta/56/event_expiry.sql +40 -0
  891. synapse/storage/schema/main/delta/56/event_labels.sql +49 -0
  892. synapse/storage/schema/main/delta/56/event_labels_background_update.sql +36 -0
  893. synapse/storage/schema/main/delta/56/fix_room_keys_index.sql +37 -0
  894. synapse/storage/schema/main/delta/56/hidden_devices.sql +37 -0
  895. synapse/storage/schema/main/delta/56/hidden_devices_fix.sql.sqlite +42 -0
  896. synapse/storage/schema/main/delta/56/nuke_empty_communities_from_db.sql +48 -0
  897. synapse/storage/schema/main/delta/56/public_room_list_idx.sql +35 -0
  898. synapse/storage/schema/main/delta/56/redaction_censor.sql +35 -0
  899. synapse/storage/schema/main/delta/56/redaction_censor2.sql +41 -0
  900. synapse/storage/schema/main/delta/56/redaction_censor3_fix_update.sql.postgres +25 -0
  901. synapse/storage/schema/main/delta/56/redaction_censor4.sql +35 -0
  902. synapse/storage/schema/main/delta/56/remove_tombstoned_rooms_from_directory.sql +38 -0
  903. synapse/storage/schema/main/delta/56/room_key_etag.sql +36 -0
  904. synapse/storage/schema/main/delta/56/room_membership_idx.sql +37 -0
  905. synapse/storage/schema/main/delta/56/room_retention.sql +52 -0
  906. synapse/storage/schema/main/delta/56/signing_keys.sql +75 -0
  907. synapse/storage/schema/main/delta/56/signing_keys_nonunique_signatures.sql +41 -0
  908. synapse/storage/schema/main/delta/56/stats_separated.sql +175 -0
  909. synapse/storage/schema/main/delta/56/unique_user_filter_index.py +46 -0
  910. synapse/storage/schema/main/delta/56/user_external_ids.sql +43 -0
  911. synapse/storage/schema/main/delta/56/users_in_public_rooms_idx.sql +36 -0
  912. synapse/storage/schema/main/delta/57/delete_old_current_state_events.sql +41 -0
  913. synapse/storage/schema/main/delta/57/device_list_remote_cache_stale.sql +44 -0
  914. synapse/storage/schema/main/delta/57/local_current_membership.py +111 -0
  915. synapse/storage/schema/main/delta/57/remove_sent_outbound_pokes.sql +40 -0
  916. synapse/storage/schema/main/delta/57/rooms_version_column.sql +43 -0
  917. synapse/storage/schema/main/delta/57/rooms_version_column_2.sql.postgres +35 -0
  918. synapse/storage/schema/main/delta/57/rooms_version_column_2.sql.sqlite +22 -0
  919. synapse/storage/schema/main/delta/57/rooms_version_column_3.sql.postgres +39 -0
  920. synapse/storage/schema/main/delta/57/rooms_version_column_3.sql.sqlite +23 -0
  921. synapse/storage/schema/main/delta/58/02remove_dup_outbound_pokes.sql +41 -0
  922. synapse/storage/schema/main/delta/58/03persist_ui_auth.sql +55 -0
  923. synapse/storage/schema/main/delta/58/05cache_instance.sql.postgres +30 -0
  924. synapse/storage/schema/main/delta/58/06dlols_unique_idx.py +83 -0
  925. synapse/storage/schema/main/delta/58/07add_method_to_thumbnail_constraint.sql.postgres +33 -0
  926. synapse/storage/schema/main/delta/58/07add_method_to_thumbnail_constraint.sql.sqlite +44 -0
  927. synapse/storage/schema/main/delta/58/07persist_ui_auth_ips.sql +44 -0
  928. synapse/storage/schema/main/delta/58/08_media_safe_from_quarantine.sql.postgres +18 -0
  929. synapse/storage/schema/main/delta/58/08_media_safe_from_quarantine.sql.sqlite +18 -0
  930. synapse/storage/schema/main/delta/58/09shadow_ban.sql +37 -0
  931. synapse/storage/schema/main/delta/58/10_pushrules_enabled_delete_obsolete.sql +47 -0
  932. synapse/storage/schema/main/delta/58/10drop_local_rejections_stream.sql +41 -0
  933. synapse/storage/schema/main/delta/58/10federation_pos_instance_name.sql +41 -0
  934. synapse/storage/schema/main/delta/58/11dehydration.sql +39 -0
  935. synapse/storage/schema/main/delta/58/11fallback.sql +43 -0
  936. synapse/storage/schema/main/delta/58/11user_id_seq.py +38 -0
  937. synapse/storage/schema/main/delta/58/12room_stats.sql +51 -0
  938. synapse/storage/schema/main/delta/58/13remove_presence_allow_inbound.sql +36 -0
  939. synapse/storage/schema/main/delta/58/14events_instance_name.sql +35 -0
  940. synapse/storage/schema/main/delta/58/14events_instance_name.sql.postgres +28 -0
  941. synapse/storage/schema/main/delta/58/15_catchup_destination_rooms.sql +61 -0
  942. synapse/storage/schema/main/delta/58/15unread_count.sql +45 -0
  943. synapse/storage/schema/main/delta/58/16populate_stats_process_rooms_fix.sql +41 -0
  944. synapse/storage/schema/main/delta/58/17_catchup_last_successful.sql +40 -0
  945. synapse/storage/schema/main/delta/58/18stream_positions.sql +41 -0
  946. synapse/storage/schema/main/delta/58/19instance_map.sql.postgres +25 -0
  947. synapse/storage/schema/main/delta/58/19txn_id.sql +59 -0
  948. synapse/storage/schema/main/delta/58/20instance_name_event_tables.sql +36 -0
  949. synapse/storage/schema/main/delta/58/20user_daily_visits.sql +37 -0
  950. synapse/storage/schema/main/delta/58/21as_device_stream.sql +36 -0
  951. synapse/storage/schema/main/delta/58/21drop_device_max_stream_id.sql +1 -0
  952. synapse/storage/schema/main/delta/58/22puppet_token.sql +36 -0
  953. synapse/storage/schema/main/delta/58/22users_have_local_media.sql +2 -0
  954. synapse/storage/schema/main/delta/58/23e2e_cross_signing_keys_idx.sql +36 -0
  955. synapse/storage/schema/main/delta/58/24drop_event_json_index.sql +38 -0
  956. synapse/storage/schema/main/delta/58/25user_external_ids_user_id_idx.sql +36 -0
  957. synapse/storage/schema/main/delta/58/26access_token_last_validated.sql +37 -0
  958. synapse/storage/schema/main/delta/58/27local_invites.sql +37 -0
  959. synapse/storage/schema/main/delta/58/28drop_last_used_column.sql.postgres +16 -0
  960. synapse/storage/schema/main/delta/58/28drop_last_used_column.sql.sqlite +62 -0
  961. synapse/storage/schema/main/delta/59/01ignored_user.py +85 -0
  962. synapse/storage/schema/main/delta/59/02shard_send_to_device.sql +37 -0
  963. synapse/storage/schema/main/delta/59/03shard_send_to_device_sequence.sql.postgres +25 -0
  964. synapse/storage/schema/main/delta/59/04_event_auth_chains.sql +71 -0
  965. synapse/storage/schema/main/delta/59/04_event_auth_chains.sql.postgres +16 -0
  966. synapse/storage/schema/main/delta/59/04drop_account_data.sql +36 -0
  967. synapse/storage/schema/main/delta/59/05cache_invalidation.sql +36 -0
  968. synapse/storage/schema/main/delta/59/06chain_cover_index.sql +36 -0
  969. synapse/storage/schema/main/delta/59/06shard_account_data.sql +39 -0
  970. synapse/storage/schema/main/delta/59/06shard_account_data.sql.postgres +32 -0
  971. synapse/storage/schema/main/delta/59/07shard_account_data_fix.sql +37 -0
  972. synapse/storage/schema/main/delta/59/08delete_pushers_for_deactivated_accounts.sql +39 -0
  973. synapse/storage/schema/main/delta/59/08delete_stale_pushers.sql +39 -0
  974. synapse/storage/schema/main/delta/59/09rejected_events_metadata.sql +45 -0
  975. synapse/storage/schema/main/delta/59/10delete_purged_chain_cover.sql +36 -0
  976. synapse/storage/schema/main/delta/59/11add_knock_members_to_stats.sql +39 -0
  977. synapse/storage/schema/main/delta/59/11drop_thumbnail_constraint.sql.postgres +22 -0
  978. synapse/storage/schema/main/delta/59/12account_validity_token_used_ts_ms.sql +37 -0
  979. synapse/storage/schema/main/delta/59/12presence_stream_instance.sql +37 -0
  980. synapse/storage/schema/main/delta/59/12presence_stream_instance_seq.sql.postgres +20 -0
  981. synapse/storage/schema/main/delta/59/13users_to_send_full_presence_to.sql +53 -0
  982. synapse/storage/schema/main/delta/59/14refresh_tokens.sql +53 -0
  983. synapse/storage/schema/main/delta/59/15locks.sql +56 -0
  984. synapse/storage/schema/main/delta/59/16federation_inbound_staging.sql +51 -0
  985. synapse/storage/schema/main/delta/60/01recreate_stream_ordering.sql.postgres +45 -0
  986. synapse/storage/schema/main/delta/60/02change_stream_ordering_columns.sql.postgres +30 -0
  987. synapse/storage/schema/main/delta/61/01change_appservices_txns.sql.postgres +23 -0
  988. synapse/storage/schema/main/delta/61/01insertion_event_lookups.sql +68 -0
  989. synapse/storage/schema/main/delta/61/02drop_redundant_room_depth_index.sql +37 -0
  990. synapse/storage/schema/main/delta/61/03recreate_min_depth.py +74 -0
  991. synapse/storage/schema/main/delta/62/01insertion_event_extremities.sql +43 -0
  992. synapse/storage/schema/main/delta/63/01create_registration_tokens.sql +42 -0
  993. synapse/storage/schema/main/delta/63/02delete_unlinked_email_pushers.sql +39 -0
  994. synapse/storage/schema/main/delta/63/02populate-rooms-creator.sql +36 -0
  995. synapse/storage/schema/main/delta/63/03session_store.sql +42 -0
  996. synapse/storage/schema/main/delta/63/04add_presence_stream_not_offline_index.sql +37 -0
  997. synapse/storage/schema/main/delta/64/01msc2716_chunk_to_batch_rename.sql.postgres +23 -0
  998. synapse/storage/schema/main/delta/64/01msc2716_chunk_to_batch_rename.sql.sqlite +37 -0
  999. synapse/storage/schema/main/delta/65/01msc2716_insertion_event_edges.sql +38 -0
  1000. synapse/storage/schema/main/delta/65/03remove_hidden_devices_from_device_inbox.sql +41 -0
  1001. synapse/storage/schema/main/delta/65/04_local_group_updates.sql +37 -0
  1002. synapse/storage/schema/main/delta/65/05_remove_room_stats_historical_and_user_stats_historical.sql +38 -0
  1003. synapse/storage/schema/main/delta/65/06remove_deleted_devices_from_device_inbox.sql +53 -0
  1004. synapse/storage/schema/main/delta/65/07_arbitrary_relations.sql +37 -0
  1005. synapse/storage/schema/main/delta/65/08_device_inbox_background_updates.sql +37 -0
  1006. synapse/storage/schema/main/delta/65/10_expirable_refresh_tokens.sql +47 -0
  1007. synapse/storage/schema/main/delta/65/11_devices_auth_provider_session.sql +46 -0
  1008. synapse/storage/schema/main/delta/67/01drop_public_room_list_stream.sql +37 -0
  1009. synapse/storage/schema/main/delta/68/01event_columns.sql +45 -0
  1010. synapse/storage/schema/main/delta/68/02_msc2409_add_device_id_appservice_stream_type.sql +40 -0
  1011. synapse/storage/schema/main/delta/68/03_delete_account_data_for_deactivated_accounts.sql +39 -0
  1012. synapse/storage/schema/main/delta/68/04_refresh_tokens_index_next_token_id.sql +47 -0
  1013. synapse/storage/schema/main/delta/68/04partial_state_rooms.sql +60 -0
  1014. synapse/storage/schema/main/delta/68/05_delete_non_strings_from_event_search.sql.sqlite +22 -0
  1015. synapse/storage/schema/main/delta/68/05partial_state_rooms_triggers.py +80 -0
  1016. synapse/storage/schema/main/delta/68/06_msc3202_add_device_list_appservice_stream_type.sql +42 -0
  1017. synapse/storage/schema/main/delta/69/01as_txn_seq.py +54 -0
  1018. synapse/storage/schema/main/delta/69/01device_list_oubound_by_room.sql +57 -0
  1019. synapse/storage/schema/main/delta/69/02cache_invalidation_index.sql +37 -0
  1020. synapse/storage/schema/main/delta/70/01clean_table_purged_rooms.sql +39 -0
  1021. synapse/storage/schema/main/delta/71/01rebuild_event_edges.sql.postgres +43 -0
  1022. synapse/storage/schema/main/delta/71/01rebuild_event_edges.sql.sqlite +47 -0
  1023. synapse/storage/schema/main/delta/71/01remove_noop_background_updates.sql +80 -0
  1024. synapse/storage/schema/main/delta/71/02event_push_summary_unique.sql +37 -0
  1025. synapse/storage/schema/main/delta/72/01add_room_type_to_state_stats.sql +38 -0
  1026. synapse/storage/schema/main/delta/72/01event_push_summary_receipt.sql +54 -0
  1027. synapse/storage/schema/main/delta/72/02event_push_actions_index.sql +38 -0
  1028. synapse/storage/schema/main/delta/72/03bg_populate_events_columns.py +57 -0
  1029. synapse/storage/schema/main/delta/72/03drop_event_reference_hashes.sql +36 -0
  1030. synapse/storage/schema/main/delta/72/03remove_groups.sql +50 -0
  1031. synapse/storage/schema/main/delta/72/04drop_column_application_services_state_last_txn.sql.postgres +17 -0
  1032. synapse/storage/schema/main/delta/72/04drop_column_application_services_state_last_txn.sql.sqlite +40 -0
  1033. synapse/storage/schema/main/delta/72/05receipts_event_stream_ordering.sql +38 -0
  1034. synapse/storage/schema/main/delta/72/05remove_unstable_private_read_receipts.sql +38 -0
  1035. synapse/storage/schema/main/delta/72/06add_consent_ts_to_users.sql +35 -0
  1036. synapse/storage/schema/main/delta/72/06thread_notifications.sql +49 -0
  1037. synapse/storage/schema/main/delta/72/07force_update_current_state_events_membership.py +67 -0
  1038. synapse/storage/schema/main/delta/72/07thread_receipts.sql.postgres +30 -0
  1039. synapse/storage/schema/main/delta/72/07thread_receipts.sql.sqlite +70 -0
  1040. synapse/storage/schema/main/delta/72/08begin_cache_invalidation_seq_at_2.sql.postgres +23 -0
  1041. synapse/storage/schema/main/delta/72/08thread_receipts.sql +39 -0
  1042. synapse/storage/schema/main/delta/72/09partial_indices.sql.sqlite +56 -0
  1043. synapse/storage/schema/main/delta/73/01event_failed_pull_attempts.sql +48 -0
  1044. synapse/storage/schema/main/delta/73/02add_pusher_enabled.sql +35 -0
  1045. synapse/storage/schema/main/delta/73/02room_id_indexes_for_purging.sql +41 -0
  1046. synapse/storage/schema/main/delta/73/03pusher_device_id.sql +39 -0
  1047. synapse/storage/schema/main/delta/73/03users_approved_column.sql +39 -0
  1048. synapse/storage/schema/main/delta/73/04partial_join_details.sql +42 -0
  1049. synapse/storage/schema/main/delta/73/04pending_device_list_updates.sql +47 -0
  1050. synapse/storage/schema/main/delta/73/05old_push_actions.sql.postgres +22 -0
  1051. synapse/storage/schema/main/delta/73/05old_push_actions.sql.sqlite +24 -0
  1052. synapse/storage/schema/main/delta/73/06thread_notifications_thread_id_idx.sql +42 -0
  1053. synapse/storage/schema/main/delta/73/08thread_receipts_non_null.sql.postgres +23 -0
  1054. synapse/storage/schema/main/delta/73/08thread_receipts_non_null.sql.sqlite +76 -0
  1055. synapse/storage/schema/main/delta/73/09partial_joined_via_destination.sql +37 -0
  1056. synapse/storage/schema/main/delta/73/09threads_table.sql +49 -0
  1057. synapse/storage/schema/main/delta/73/10_update_sqlite_fts4_tokenizer.py +71 -0
  1058. synapse/storage/schema/main/delta/73/10login_tokens.sql +54 -0
  1059. synapse/storage/schema/main/delta/73/11event_search_room_id_n_distinct.sql.postgres +33 -0
  1060. synapse/storage/schema/main/delta/73/12refactor_device_list_outbound_pokes.sql +72 -0
  1061. synapse/storage/schema/main/delta/73/13add_device_lists_index.sql +39 -0
  1062. synapse/storage/schema/main/delta/73/20_un_partial_stated_room_stream.sql +51 -0
  1063. synapse/storage/schema/main/delta/73/21_un_partial_stated_room_stream_seq.sql.postgres +20 -0
  1064. synapse/storage/schema/main/delta/73/22_rebuild_user_dir_stats.sql +48 -0
  1065. synapse/storage/schema/main/delta/73/22_un_partial_stated_event_stream.sql +53 -0
  1066. synapse/storage/schema/main/delta/73/23_fix_thread_index.sql +52 -0
  1067. synapse/storage/schema/main/delta/73/23_un_partial_stated_room_stream_seq.sql.postgres +20 -0
  1068. synapse/storage/schema/main/delta/73/24_events_jump_to_date_index.sql +36 -0
  1069. synapse/storage/schema/main/delta/73/25drop_presence.sql +36 -0
  1070. synapse/storage/schema/main/delta/74/01_user_directory_stale_remote_users.sql +58 -0
  1071. synapse/storage/schema/main/delta/74/02_set_device_id_for_pushers_bg_update.sql +38 -0
  1072. synapse/storage/schema/main/delta/74/03_membership_tables_event_stream_ordering.sql.postgres +29 -0
  1073. synapse/storage/schema/main/delta/74/03_membership_tables_event_stream_ordering.sql.sqlite +23 -0
  1074. synapse/storage/schema/main/delta/74/03_room_membership_index.sql +38 -0
  1075. synapse/storage/schema/main/delta/74/04_delete_e2e_backup_keys_for_deactivated_users.sql +36 -0
  1076. synapse/storage/schema/main/delta/74/04_membership_tables_event_stream_ordering_triggers.py +87 -0
  1077. synapse/storage/schema/main/delta/74/05_events_txn_id_device_id.sql +72 -0
  1078. synapse/storage/schema/main/delta/74/90COMMENTS_destinations.sql.postgres +52 -0
  1079. synapse/storage/schema/main/delta/76/01_add_profiles_full_user_id_column.sql +39 -0
  1080. synapse/storage/schema/main/delta/76/02_add_user_filters_full_user_id_column.sql +39 -0
  1081. synapse/storage/schema/main/delta/76/03_per_user_experimental_features.sql +46 -0
  1082. synapse/storage/schema/main/delta/76/04_add_room_forgetter.sql +43 -0
  1083. synapse/storage/schema/main/delta/77/01_add_profiles_not_valid_check.sql.postgres +16 -0
  1084. synapse/storage/schema/main/delta/77/02_add_user_filters_not_valid_check.sql.postgres +16 -0
  1085. synapse/storage/schema/main/delta/77/03bg_populate_full_user_id_profiles.sql +35 -0
  1086. synapse/storage/schema/main/delta/77/04bg_populate_full_user_id_user_filters.sql +35 -0
  1087. synapse/storage/schema/main/delta/77/05thread_notifications_backfill.sql +67 -0
  1088. synapse/storage/schema/main/delta/77/06thread_notifications_not_null.sql.sqlite +102 -0
  1089. synapse/storage/schema/main/delta/77/06thread_notifications_not_null_event_push_actions.sql.postgres +27 -0
  1090. synapse/storage/schema/main/delta/77/06thread_notifications_not_null_event_push_actions_staging.sql.postgres +27 -0
  1091. synapse/storage/schema/main/delta/77/06thread_notifications_not_null_event_push_summary.sql.postgres +29 -0
  1092. synapse/storage/schema/main/delta/77/14bg_indices_event_stream_ordering.sql +39 -0
  1093. synapse/storage/schema/main/delta/78/01_validate_and_update_profiles.py +99 -0
  1094. synapse/storage/schema/main/delta/78/02_validate_and_update_user_filters.py +100 -0
  1095. synapse/storage/schema/main/delta/78/03_remove_unused_indexes_user_filters.py +72 -0
  1096. synapse/storage/schema/main/delta/78/03event_extremities_constraints.py +65 -0
  1097. synapse/storage/schema/main/delta/78/04_add_full_user_id_index_user_filters.py +32 -0
  1098. synapse/storage/schema/main/delta/79/03_read_write_locks_triggers.sql.postgres +102 -0
  1099. synapse/storage/schema/main/delta/79/03_read_write_locks_triggers.sql.sqlite +72 -0
  1100. synapse/storage/schema/main/delta/79/04_mitigate_stream_ordering_update_race.py +70 -0
  1101. synapse/storage/schema/main/delta/79/05_read_write_locks_triggers.sql.postgres +69 -0
  1102. synapse/storage/schema/main/delta/79/05_read_write_locks_triggers.sql.sqlite +65 -0
  1103. synapse/storage/schema/main/delta/80/01_users_alter_locked.sql +35 -0
  1104. synapse/storage/schema/main/delta/80/02_read_write_locks_unlogged.sql.postgres +30 -0
  1105. synapse/storage/schema/main/delta/80/02_scheduled_tasks.sql +47 -0
  1106. synapse/storage/schema/main/delta/80/03_read_write_locks_triggers.sql.postgres +37 -0
  1107. synapse/storage/schema/main/delta/80/04_read_write_locks_deadlock.sql.postgres +71 -0
  1108. synapse/storage/schema/main/delta/82/02_scheduled_tasks_index.sql +35 -0
  1109. synapse/storage/schema/main/delta/82/04_add_indices_for_purging_rooms.sql +39 -0
  1110. synapse/storage/schema/main/delta/82/05gaps.sql +44 -0
  1111. synapse/storage/schema/main/delta/83/01_drop_old_tables.sql +43 -0
  1112. synapse/storage/schema/main/delta/83/03_instance_name_receipts.sql.sqlite +17 -0
  1113. synapse/storage/schema/main/delta/83/05_cross_signing_key_update_grant.sql +34 -0
  1114. synapse/storage/schema/main/delta/83/06_event_push_summary_room.sql +36 -0
  1115. synapse/storage/schema/main/delta/84/01_auth_links_stats.sql.postgres +20 -0
  1116. synapse/storage/schema/main/delta/84/02_auth_links_index.sql +16 -0
  1117. synapse/storage/schema/main/delta/84/03_auth_links_analyze.sql.postgres +16 -0
  1118. synapse/storage/schema/main/delta/84/04_access_token_index.sql +15 -0
  1119. synapse/storage/schema/main/delta/85/01_add_suspended.sql +14 -0
  1120. synapse/storage/schema/main/delta/85/02_add_instance_names.sql +27 -0
  1121. synapse/storage/schema/main/delta/85/03_new_sequences.sql.postgres +54 -0
  1122. synapse/storage/schema/main/delta/85/04_cleanup_device_federation_outbox.sql +15 -0
  1123. synapse/storage/schema/main/delta/85/05_add_instance_names_converted_pos.sql +16 -0
  1124. synapse/storage/schema/main/delta/85/06_add_room_reports.sql +20 -0
  1125. synapse/storage/schema/main/delta/86/01_authenticate_media.sql +15 -0
  1126. synapse/storage/schema/main/delta/86/02_receipts_event_id_index.sql +15 -0
  1127. synapse/storage/schema/main/delta/87/01_sliding_sync_memberships.sql +169 -0
  1128. synapse/storage/schema/main/delta/87/02_per_connection_state.sql +81 -0
  1129. synapse/storage/schema/main/delta/87/03_current_state_index.sql +19 -0
  1130. synapse/storage/schema/main/delta/88/01_add_delayed_events.sql +43 -0
  1131. synapse/storage/schema/main/delta/88/01_custom_profile_fields.sql +15 -0
  1132. synapse/storage/schema/main/delta/88/02_fix_sliding_sync_membership_snapshots_forgotten_column.sql +21 -0
  1133. synapse/storage/schema/main/delta/88/03_add_otk_ts_added_index.sql +18 -0
  1134. synapse/storage/schema/main/delta/88/04_current_state_delta_index.sql +18 -0
  1135. synapse/storage/schema/main/delta/88/05_drop_old_otks.sql.postgres +19 -0
  1136. synapse/storage/schema/main/delta/88/05_drop_old_otks.sql.sqlite +19 -0
  1137. synapse/storage/schema/main/delta/88/05_sliding_sync_room_config_index.sql +20 -0
  1138. synapse/storage/schema/main/delta/88/06_events_received_ts_index.sql +17 -0
  1139. synapse/storage/schema/main/delta/89/01_sliding_sync_membership_snapshot_index.sql +15 -0
  1140. synapse/storage/schema/main/delta/90/01_add_column_participant_room_memberships_table.sql +16 -0
  1141. synapse/storage/schema/main/delta/91/01_media_hash.sql +28 -0
  1142. synapse/storage/schema/main/delta/92/01_remove_trigger.sql.postgres +16 -0
  1143. synapse/storage/schema/main/delta/92/01_remove_trigger.sql.sqlite +16 -0
  1144. synapse/storage/schema/main/delta/92/02_remove_populate_participant_bg_update.sql +17 -0
  1145. synapse/storage/schema/main/delta/92/04_ss_membership_snapshot_idx.sql +16 -0
  1146. synapse/storage/schema/main/delta/92/04_thread_subscriptions.sql +59 -0
  1147. synapse/storage/schema/main/delta/92/04_thread_subscriptions_seq.sql.postgres +19 -0
  1148. synapse/storage/schema/main/delta/92/05_fixup_max_depth_cap.sql +17 -0
  1149. synapse/storage/schema/main/delta/92/05_thread_subscriptions_comments.sql.postgres +18 -0
  1150. synapse/storage/schema/main/delta/92/06_device_federation_inbox_index.sql +16 -0
  1151. synapse/storage/schema/main/delta/92/06_threads_last_sent_stream_ordering_comments.sql.postgres +24 -0
  1152. synapse/storage/schema/main/delta/92/07_add_user_reports.sql +22 -0
  1153. synapse/storage/schema/main/delta/92/07_event_txn_id_device_id_txn_id2.sql +15 -0
  1154. synapse/storage/schema/main/delta/92/08_room_ban_redactions.sql +21 -0
  1155. synapse/storage/schema/main/delta/92/08_thread_subscriptions_seq_fixup.sql.postgres +19 -0
  1156. synapse/storage/schema/main/delta/92/09_thread_subscriptions_update.sql +20 -0
  1157. synapse/storage/schema/main/delta/92/09_thread_subscriptions_update.sql.postgres +18 -0
  1158. synapse/storage/schema/main/delta/93/01_add_delayed_events.sql +15 -0
  1159. synapse/storage/schema/main/delta/93/02_sliding_sync_members.sql +60 -0
  1160. synapse/storage/schema/main/delta/93/03_sss_pos_last_used.sql +27 -0
  1161. synapse/storage/schema/main/full_schemas/72/full.sql.postgres +1344 -0
  1162. synapse/storage/schema/main/full_schemas/72/full.sql.sqlite +646 -0
  1163. synapse/storage/schema/state/delta/23/drop_state_index.sql +35 -0
  1164. synapse/storage/schema/state/delta/32/remove_state_indices.sql +38 -0
  1165. synapse/storage/schema/state/delta/35/add_state_index.sql +36 -0
  1166. synapse/storage/schema/state/delta/35/state.sql +41 -0
  1167. synapse/storage/schema/state/delta/35/state_dedupe.sql +36 -0
  1168. synapse/storage/schema/state/delta/47/state_group_seq.py +38 -0
  1169. synapse/storage/schema/state/delta/56/state_group_room_idx.sql +36 -0
  1170. synapse/storage/schema/state/delta/61/02state_groups_state_n_distinct.sql.postgres +34 -0
  1171. synapse/storage/schema/state/delta/70/08_state_group_edges_unique.sql +36 -0
  1172. synapse/storage/schema/state/delta/89/01_state_groups_deletion.sql +39 -0
  1173. synapse/storage/schema/state/delta/90/02_delete_unreferenced_state_groups.sql +16 -0
  1174. synapse/storage/schema/state/delta/90/03_remove_old_deletion_bg_update.sql +15 -0
  1175. synapse/storage/schema/state/full_schemas/72/full.sql.postgres +30 -0
  1176. synapse/storage/schema/state/full_schemas/72/full.sql.sqlite +20 -0
  1177. synapse/storage/types.py +183 -0
  1178. synapse/storage/util/__init__.py +20 -0
  1179. synapse/storage/util/id_generators.py +928 -0
  1180. synapse/storage/util/partial_state_events_tracker.py +194 -0
  1181. synapse/storage/util/sequence.py +315 -0
  1182. synapse/streams/__init__.py +43 -0
  1183. synapse/streams/config.py +91 -0
  1184. synapse/streams/events.py +203 -0
  1185. synapse/synapse_rust/__init__.pyi +3 -0
  1186. synapse/synapse_rust/acl.pyi +20 -0
  1187. synapse/synapse_rust/events.pyi +136 -0
  1188. synapse/synapse_rust/http_client.pyi +32 -0
  1189. synapse/synapse_rust/push.pyi +86 -0
  1190. synapse/synapse_rust/rendezvous.pyi +30 -0
  1191. synapse/synapse_rust/segmenter.pyi +1 -0
  1192. synapse/synapse_rust.abi3.so +0 -0
  1193. synapse/types/__init__.py +1600 -0
  1194. synapse/types/handlers/__init__.py +93 -0
  1195. synapse/types/handlers/policy_server.py +16 -0
  1196. synapse/types/handlers/sliding_sync.py +1004 -0
  1197. synapse/types/rest/__init__.py +25 -0
  1198. synapse/types/rest/client/__init__.py +413 -0
  1199. synapse/types/state.py +634 -0
  1200. synapse/types/storage/__init__.py +66 -0
  1201. synapse/util/__init__.py +160 -0
  1202. synapse/util/async_helpers.py +1048 -0
  1203. synapse/util/background_queue.py +142 -0
  1204. synapse/util/batching_queue.py +203 -0
  1205. synapse/util/caches/__init__.py +300 -0
  1206. synapse/util/caches/cached_call.py +143 -0
  1207. synapse/util/caches/deferred_cache.py +530 -0
  1208. synapse/util/caches/descriptors.py +692 -0
  1209. synapse/util/caches/dictionary_cache.py +346 -0
  1210. synapse/util/caches/expiringcache.py +250 -0
  1211. synapse/util/caches/lrucache.py +976 -0
  1212. synapse/util/caches/response_cache.py +323 -0
  1213. synapse/util/caches/stream_change_cache.py +370 -0
  1214. synapse/util/caches/treecache.py +189 -0
  1215. synapse/util/caches/ttlcache.py +197 -0
  1216. synapse/util/cancellation.py +63 -0
  1217. synapse/util/check_dependencies.py +335 -0
  1218. synapse/util/clock.py +592 -0
  1219. synapse/util/daemonize.py +165 -0
  1220. synapse/util/distributor.py +157 -0
  1221. synapse/util/duration.py +117 -0
  1222. synapse/util/events.py +134 -0
  1223. synapse/util/file_consumer.py +164 -0
  1224. synapse/util/frozenutils.py +57 -0
  1225. synapse/util/gai_resolver.py +178 -0
  1226. synapse/util/hash.py +38 -0
  1227. synapse/util/httpresourcetree.py +108 -0
  1228. synapse/util/iterutils.py +190 -0
  1229. synapse/util/json.py +56 -0
  1230. synapse/util/linked_list.py +156 -0
  1231. synapse/util/logcontext.py +46 -0
  1232. synapse/util/logformatter.py +28 -0
  1233. synapse/util/macaroons.py +325 -0
  1234. synapse/util/manhole.py +191 -0
  1235. synapse/util/metrics.py +339 -0
  1236. synapse/util/module_loader.py +116 -0
  1237. synapse/util/msisdn.py +51 -0
  1238. synapse/util/patch_inline_callbacks.py +250 -0
  1239. synapse/util/pydantic_models.py +63 -0
  1240. synapse/util/ratelimitutils.py +422 -0
  1241. synapse/util/retryutils.py +339 -0
  1242. synapse/util/rlimit.py +42 -0
  1243. synapse/util/rust.py +164 -0
  1244. synapse/util/sentinel.py +21 -0
  1245. synapse/util/stringutils.py +293 -0
  1246. synapse/util/task_scheduler.py +494 -0
  1247. synapse/util/templates.py +126 -0
  1248. synapse/util/threepids.py +123 -0
  1249. synapse/util/wheel_timer.py +112 -0
  1250. synapse/visibility.py +869 -0
  1251. synmark/__init__.py +47 -0
  1252. synmark/__main__.py +128 -0
  1253. synmark/suites/__init__.py +9 -0
  1254. synmark/suites/logging.py +154 -0
  1255. synmark/suites/lrucache.py +48 -0
  1256. synmark/suites/lrucache_evict.py +49 -0
  1257. sytest-blacklist +33 -0
  1258. tests/__init__.py +29 -0
  1259. tests/api/__init__.py +0 -0
  1260. tests/api/test_auth.py +548 -0
  1261. tests/api/test_errors.py +46 -0
  1262. tests/api/test_filtering.py +622 -0
  1263. tests/api/test_ratelimiting.py +505 -0
  1264. tests/api/test_urls.py +81 -0
  1265. tests/app/__init__.py +0 -0
  1266. tests/app/test_homeserver_shutdown.py +271 -0
  1267. tests/app/test_homeserver_start.py +49 -0
  1268. tests/app/test_openid_listener.py +139 -0
  1269. tests/app/test_phone_stats_home.py +248 -0
  1270. tests/appservice/__init__.py +20 -0
  1271. tests/appservice/test_api.py +253 -0
  1272. tests/appservice/test_appservice.py +259 -0
  1273. tests/appservice/test_scheduler.py +477 -0
  1274. tests/config/__init__.py +20 -0
  1275. tests/config/test___main__.py +38 -0
  1276. tests/config/test_api.py +146 -0
  1277. tests/config/test_appservice.py +48 -0
  1278. tests/config/test_background_update.py +65 -0
  1279. tests/config/test_base.py +151 -0
  1280. tests/config/test_cache.py +193 -0
  1281. tests/config/test_database.py +42 -0
  1282. tests/config/test_generate.py +72 -0
  1283. tests/config/test_load.py +322 -0
  1284. tests/config/test_oauth_delegation.py +454 -0
  1285. tests/config/test_ratelimiting.py +77 -0
  1286. tests/config/test_registration_config.py +203 -0
  1287. tests/config/test_room_directory.py +203 -0
  1288. tests/config/test_server.py +248 -0
  1289. tests/config/test_tls.py +209 -0
  1290. tests/config/test_util.py +59 -0
  1291. tests/config/test_workers.py +332 -0
  1292. tests/config/utils.py +66 -0
  1293. tests/crypto/__init__.py +20 -0
  1294. tests/crypto/test_event_signing.py +109 -0
  1295. tests/crypto/test_keyring.py +737 -0
  1296. tests/events/__init__.py +0 -0
  1297. tests/events/test_auto_accept_invites.py +827 -0
  1298. tests/events/test_presence_router.py +540 -0
  1299. tests/events/test_snapshot.py +121 -0
  1300. tests/events/test_utils.py +986 -0
  1301. tests/federation/__init__.py +0 -0
  1302. tests/federation/test_complexity.py +257 -0
  1303. tests/federation/test_federation_catch_up.py +585 -0
  1304. tests/federation/test_federation_client.py +316 -0
  1305. tests/federation/test_federation_devices.py +161 -0
  1306. tests/federation/test_federation_media.py +295 -0
  1307. tests/federation/test_federation_out_of_band_membership.py +671 -0
  1308. tests/federation/test_federation_sender.py +956 -0
  1309. tests/federation/test_federation_server.py +631 -0
  1310. tests/federation/transport/__init__.py +0 -0
  1311. tests/federation/transport/server/__init__.py +20 -0
  1312. tests/federation/transport/server/test__base.py +156 -0
  1313. tests/federation/transport/test_client.py +157 -0
  1314. tests/federation/transport/test_knocking.py +323 -0
  1315. tests/federation/transport/test_server.py +74 -0
  1316. tests/handlers/__init__.py +0 -0
  1317. tests/handlers/oidc_test_key.p8 +5 -0
  1318. tests/handlers/oidc_test_key.pub.pem +4 -0
  1319. tests/handlers/test_admin.py +361 -0
  1320. tests/handlers/test_appservice.py +1336 -0
  1321. tests/handlers/test_auth.py +248 -0
  1322. tests/handlers/test_cas.py +239 -0
  1323. tests/handlers/test_deactivate_account.py +485 -0
  1324. tests/handlers/test_device.py +665 -0
  1325. tests/handlers/test_directory.py +613 -0
  1326. tests/handlers/test_e2e_keys.py +2025 -0
  1327. tests/handlers/test_e2e_room_keys.py +569 -0
  1328. tests/handlers/test_federation.py +794 -0
  1329. tests/handlers/test_federation_event.py +1181 -0
  1330. tests/handlers/test_message.py +322 -0
  1331. tests/handlers/test_oauth_delegation.py +1314 -0
  1332. tests/handlers/test_oidc.py +1688 -0
  1333. tests/handlers/test_password_providers.py +987 -0
  1334. tests/handlers/test_presence.py +2144 -0
  1335. tests/handlers/test_profile.py +401 -0
  1336. tests/handlers/test_receipts.py +342 -0
  1337. tests/handlers/test_register.py +880 -0
  1338. tests/handlers/test_room.py +108 -0
  1339. tests/handlers/test_room_list.py +93 -0
  1340. tests/handlers/test_room_member.py +764 -0
  1341. tests/handlers/test_room_policy.py +468 -0
  1342. tests/handlers/test_room_summary.py +1248 -0
  1343. tests/handlers/test_saml.py +427 -0
  1344. tests/handlers/test_send_email.py +230 -0
  1345. tests/handlers/test_sliding_sync.py +5065 -0
  1346. tests/handlers/test_sso.py +152 -0
  1347. tests/handlers/test_stats.py +594 -0
  1348. tests/handlers/test_sync.py +1275 -0
  1349. tests/handlers/test_typing.py +557 -0
  1350. tests/handlers/test_user_directory.py +1435 -0
  1351. tests/handlers/test_worker_lock.py +126 -0
  1352. tests/http/__init__.py +196 -0
  1353. tests/http/ca.crt +19 -0
  1354. tests/http/ca.key +27 -0
  1355. tests/http/federation/__init__.py +19 -0
  1356. tests/http/federation/test_matrix_federation_agent.py +1855 -0
  1357. tests/http/federation/test_srv_resolver.py +220 -0
  1358. tests/http/server/__init__.py +20 -0
  1359. tests/http/server/_base.py +621 -0
  1360. tests/http/server.key +27 -0
  1361. tests/http/test_additional_resource.py +76 -0
  1362. tests/http/test_client.py +422 -0
  1363. tests/http/test_endpoint.py +62 -0
  1364. tests/http/test_matrixfederationclient.py +1092 -0
  1365. tests/http/test_proxy.py +75 -0
  1366. tests/http/test_proxyagent.py +1008 -0
  1367. tests/http/test_servlet.py +145 -0
  1368. tests/http/test_simple_client.py +188 -0
  1369. tests/http/test_site.py +247 -0
  1370. tests/logging/__init__.py +42 -0
  1371. tests/logging/test_loggers.py +127 -0
  1372. tests/logging/test_opentracing.py +524 -0
  1373. tests/logging/test_remote_handler.py +184 -0
  1374. tests/logging/test_terse_json.py +253 -0
  1375. tests/media/__init__.py +20 -0
  1376. tests/media/test_base.py +88 -0
  1377. tests/media/test_filepath.py +602 -0
  1378. tests/media/test_html_preview.py +565 -0
  1379. tests/media/test_media_retention.py +299 -0
  1380. tests/media/test_media_storage.py +1401 -0
  1381. tests/media/test_oembed.py +172 -0
  1382. tests/media/test_url_previewer.py +120 -0
  1383. tests/metrics/__init__.py +0 -0
  1384. tests/metrics/test_background_process_metrics.py +21 -0
  1385. tests/metrics/test_metrics.py +407 -0
  1386. tests/metrics/test_phone_home_stats.py +263 -0
  1387. tests/module_api/__init__.py +0 -0
  1388. tests/module_api/test_account_data_manager.py +171 -0
  1389. tests/module_api/test_api.py +1035 -0
  1390. tests/module_api/test_event_unsigned_addition.py +66 -0
  1391. tests/module_api/test_spamchecker.py +286 -0
  1392. tests/push/__init__.py +0 -0
  1393. tests/push/test_bulk_push_rule_evaluator.py +652 -0
  1394. tests/push/test_email.py +570 -0
  1395. tests/push/test_http.py +1247 -0
  1396. tests/push/test_presentable_names.py +238 -0
  1397. tests/push/test_push_rule_evaluator.py +1069 -0
  1398. tests/replication/__init__.py +20 -0
  1399. tests/replication/_base.py +619 -0
  1400. tests/replication/http/__init__.py +20 -0
  1401. tests/replication/http/test__base.py +113 -0
  1402. tests/replication/storage/__init__.py +20 -0
  1403. tests/replication/storage/_base.py +85 -0
  1404. tests/replication/storage/test_events.py +299 -0
  1405. tests/replication/tcp/__init__.py +19 -0
  1406. tests/replication/tcp/streams/__init__.py +19 -0
  1407. tests/replication/tcp/streams/test_account_data.py +133 -0
  1408. tests/replication/tcp/streams/test_events.py +565 -0
  1409. tests/replication/tcp/streams/test_federation.py +117 -0
  1410. tests/replication/tcp/streams/test_partial_state.py +72 -0
  1411. tests/replication/tcp/streams/test_receipts.py +110 -0
  1412. tests/replication/tcp/streams/test_thread_subscriptions.py +157 -0
  1413. tests/replication/tcp/streams/test_to_device.py +112 -0
  1414. tests/replication/tcp/streams/test_typing.py +223 -0
  1415. tests/replication/tcp/test_commands.py +50 -0
  1416. tests/replication/tcp/test_handler.py +211 -0
  1417. tests/replication/test_auth.py +120 -0
  1418. tests/replication/test_client_reader_shard.py +101 -0
  1419. tests/replication/test_federation_ack.py +88 -0
  1420. tests/replication/test_federation_sender_shard.py +352 -0
  1421. tests/replication/test_module_cache_invalidation.py +89 -0
  1422. tests/replication/test_multi_media_repo.py +496 -0
  1423. tests/replication/test_pusher_shard.py +192 -0
  1424. tests/replication/test_sharded_event_persister.py +332 -0
  1425. tests/replication/test_sharded_receipts.py +250 -0
  1426. tests/rest/__init__.py +20 -0
  1427. tests/rest/admin/__init__.py +19 -0
  1428. tests/rest/admin/test_admin.py +614 -0
  1429. tests/rest/admin/test_background_updates.py +375 -0
  1430. tests/rest/admin/test_device.py +600 -0
  1431. tests/rest/admin/test_event.py +74 -0
  1432. tests/rest/admin/test_event_reports.py +781 -0
  1433. tests/rest/admin/test_federation.py +863 -0
  1434. tests/rest/admin/test_jwks.py +106 -0
  1435. tests/rest/admin/test_media.py +1091 -0
  1436. tests/rest/admin/test_registration_tokens.py +729 -0
  1437. tests/rest/admin/test_room.py +3626 -0
  1438. tests/rest/admin/test_scheduled_tasks.py +192 -0
  1439. tests/rest/admin/test_server_notice.py +753 -0
  1440. tests/rest/admin/test_statistics.py +523 -0
  1441. tests/rest/admin/test_user.py +6061 -0
  1442. tests/rest/admin/test_username_available.py +82 -0
  1443. tests/rest/client/__init__.py +20 -0
  1444. tests/rest/client/sliding_sync/__init__.py +13 -0
  1445. tests/rest/client/sliding_sync/test_connection_tracking.py +505 -0
  1446. tests/rest/client/sliding_sync/test_extension_account_data.py +1056 -0
  1447. tests/rest/client/sliding_sync/test_extension_e2ee.py +459 -0
  1448. tests/rest/client/sliding_sync/test_extension_receipts.py +934 -0
  1449. tests/rest/client/sliding_sync/test_extension_thread_subscriptions.py +497 -0
  1450. tests/rest/client/sliding_sync/test_extension_to_device.py +294 -0
  1451. tests/rest/client/sliding_sync/test_extension_typing.py +500 -0
  1452. tests/rest/client/sliding_sync/test_extensions.py +306 -0
  1453. tests/rest/client/sliding_sync/test_lists_filters.py +1975 -0
  1454. tests/rest/client/sliding_sync/test_room_subscriptions.py +303 -0
  1455. tests/rest/client/sliding_sync/test_rooms_invites.py +528 -0
  1456. tests/rest/client/sliding_sync/test_rooms_meta.py +1338 -0
  1457. tests/rest/client/sliding_sync/test_rooms_required_state.py +2247 -0
  1458. tests/rest/client/sliding_sync/test_rooms_timeline.py +718 -0
  1459. tests/rest/client/sliding_sync/test_sliding_sync.py +1688 -0
  1460. tests/rest/client/test_account.py +1543 -0
  1461. tests/rest/client/test_account_data.py +81 -0
  1462. tests/rest/client/test_auth.py +1508 -0
  1463. tests/rest/client/test_auth_metadata.py +145 -0
  1464. tests/rest/client/test_capabilities.py +318 -0
  1465. tests/rest/client/test_consent.py +138 -0
  1466. tests/rest/client/test_delayed_events.py +553 -0
  1467. tests/rest/client/test_devices.py +634 -0
  1468. tests/rest/client/test_directory.py +249 -0
  1469. tests/rest/client/test_ephemeral_message.py +113 -0
  1470. tests/rest/client/test_events.py +165 -0
  1471. tests/rest/client/test_filter.py +124 -0
  1472. tests/rest/client/test_identity.py +67 -0
  1473. tests/rest/client/test_keys.py +516 -0
  1474. tests/rest/client/test_login.py +1881 -0
  1475. tests/rest/client/test_login_token_request.py +175 -0
  1476. tests/rest/client/test_matrixrtc.py +105 -0
  1477. tests/rest/client/test_media.py +3156 -0
  1478. tests/rest/client/test_models.py +83 -0
  1479. tests/rest/client/test_mutual_rooms.py +235 -0
  1480. tests/rest/client/test_notifications.py +231 -0
  1481. tests/rest/client/test_owned_state.py +308 -0
  1482. tests/rest/client/test_password_policy.py +186 -0
  1483. tests/rest/client/test_power_levels.py +295 -0
  1484. tests/rest/client/test_presence.py +149 -0
  1485. tests/rest/client/test_profile.py +925 -0
  1486. tests/rest/client/test_push_rule_attrs.py +510 -0
  1487. tests/rest/client/test_read_marker.py +151 -0
  1488. tests/rest/client/test_receipts.py +287 -0
  1489. tests/rest/client/test_redactions.py +657 -0
  1490. tests/rest/client/test_register.py +1314 -0
  1491. tests/rest/client/test_relations.py +1954 -0
  1492. tests/rest/client/test_rendezvous.py +468 -0
  1493. tests/rest/client/test_reporting.py +324 -0
  1494. tests/rest/client/test_retention.py +389 -0
  1495. tests/rest/client/test_rooms.py +5486 -0
  1496. tests/rest/client/test_sendtodevice.py +271 -0
  1497. tests/rest/client/test_shadow_banned.py +335 -0
  1498. tests/rest/client/test_sync.py +1147 -0
  1499. tests/rest/client/test_tags.py +161 -0
  1500. tests/rest/client/test_third_party_rules.py +1076 -0
  1501. tests/rest/client/test_thread_subscriptions.py +351 -0
  1502. tests/rest/client/test_transactions.py +204 -0
  1503. tests/rest/client/test_typing.py +114 -0
  1504. tests/rest/client/test_upgrade_room.py +433 -0
  1505. tests/rest/client/utils.py +985 -0
  1506. tests/rest/key/__init__.py +0 -0
  1507. tests/rest/key/v2/__init__.py +0 -0
  1508. tests/rest/key/v2/test_remote_key_resource.py +282 -0
  1509. tests/rest/media/__init__.py +19 -0
  1510. tests/rest/media/test_domain_blocking.py +148 -0
  1511. tests/rest/media/test_url_preview.py +1445 -0
  1512. tests/rest/synapse/__init__.py +12 -0
  1513. tests/rest/synapse/client/__init__.py +12 -0
  1514. tests/rest/synapse/client/test_federation_whitelist.py +118 -0
  1515. tests/rest/synapse/mas/__init__.py +12 -0
  1516. tests/rest/synapse/mas/_base.py +43 -0
  1517. tests/rest/synapse/mas/test_devices.py +693 -0
  1518. tests/rest/synapse/mas/test_users.py +1399 -0
  1519. tests/rest/test_health.py +35 -0
  1520. tests/rest/test_well_known.py +155 -0
  1521. tests/scripts/__init__.py +0 -0
  1522. tests/scripts/test_new_matrix_user.py +172 -0
  1523. tests/server.py +1374 -0
  1524. tests/server_notices/__init__.py +241 -0
  1525. tests/server_notices/test_consent.py +111 -0
  1526. tests/server_notices/test_resource_limits_server_notices.py +409 -0
  1527. tests/state/__init__.py +0 -0
  1528. tests/state/test_v2.py +1096 -0
  1529. tests/state/test_v21.py +506 -0
  1530. tests/storage/__init__.py +0 -0
  1531. tests/storage/databases/__init__.py +20 -0
  1532. tests/storage/databases/main/__init__.py +20 -0
  1533. tests/storage/databases/main/test_cache.py +124 -0
  1534. tests/storage/databases/main/test_deviceinbox.py +323 -0
  1535. tests/storage/databases/main/test_end_to_end_keys.py +127 -0
  1536. tests/storage/databases/main/test_events_worker.py +594 -0
  1537. tests/storage/databases/main/test_lock.py +499 -0
  1538. tests/storage/databases/main/test_metrics.py +88 -0
  1539. tests/storage/databases/main/test_receipts.py +218 -0
  1540. tests/storage/databases/main/test_room.py +192 -0
  1541. tests/storage/test__base.py +178 -0
  1542. tests/storage/test_account_data.py +186 -0
  1543. tests/storage/test_appservice.py +568 -0
  1544. tests/storage/test_background_update.py +671 -0
  1545. tests/storage/test_base.py +813 -0
  1546. tests/storage/test_cleanup_extrems.py +396 -0
  1547. tests/storage/test_client_ips.py +788 -0
  1548. tests/storage/test_database.py +288 -0
  1549. tests/storage/test_devices.py +353 -0
  1550. tests/storage/test_directory.py +74 -0
  1551. tests/storage/test_e2e_room_keys.py +87 -0
  1552. tests/storage/test_end_to_end_keys.py +120 -0
  1553. tests/storage/test_event_chain.py +826 -0
  1554. tests/storage/test_event_federation.py +1433 -0
  1555. tests/storage/test_event_push_actions.py +809 -0
  1556. tests/storage/test_events.py +591 -0
  1557. tests/storage/test_events_bg_updates.py +156 -0
  1558. tests/storage/test_id_generators.py +791 -0
  1559. tests/storage/test_invite_rule.py +171 -0
  1560. tests/storage/test_main.py +56 -0
  1561. tests/storage/test_monthly_active_users.py +500 -0
  1562. tests/storage/test_profile.py +134 -0
  1563. tests/storage/test_purge.py +459 -0
  1564. tests/storage/test_receipts.py +309 -0
  1565. tests/storage/test_redaction.py +462 -0
  1566. tests/storage/test_registration.py +277 -0
  1567. tests/storage/test_relations.py +118 -0
  1568. tests/storage/test_rollback_worker.py +132 -0
  1569. tests/storage/test_room.py +69 -0
  1570. tests/storage/test_room_search.py +383 -0
  1571. tests/storage/test_roommember.py +812 -0
  1572. tests/storage/test_sliding_sync_tables.py +5187 -0
  1573. tests/storage/test_state.py +959 -0
  1574. tests/storage/test_state_deletion.py +475 -0
  1575. tests/storage/test_stream.py +1533 -0
  1576. tests/storage/test_thread_subscriptions.py +369 -0
  1577. tests/storage/test_transactions.py +77 -0
  1578. tests/storage/test_txn_limit.py +49 -0
  1579. tests/storage/test_unsafe_locale.py +67 -0
  1580. tests/storage/test_user_directory.py +691 -0
  1581. tests/storage/test_user_filters.py +101 -0
  1582. tests/storage/util/__init__.py +20 -0
  1583. tests/storage/util/test_partial_state_events_tracker.py +181 -0
  1584. tests/synapse_rust/__init__.py +11 -0
  1585. tests/synapse_rust/test_http_client.py +225 -0
  1586. tests/test_distributor.py +74 -0
  1587. tests/test_event_auth.py +921 -0
  1588. tests/test_mau.py +347 -0
  1589. tests/test_phone_home.py +102 -0
  1590. tests/test_rust.py +11 -0
  1591. tests/test_server.py +557 -0
  1592. tests/test_state.py +902 -0
  1593. tests/test_terms_auth.py +128 -0
  1594. tests/test_types.py +201 -0
  1595. tests/test_utils/__init__.py +161 -0
  1596. tests/test_utils/event_injection.py +150 -0
  1597. tests/test_utils/html_parsers.py +59 -0
  1598. tests/test_utils/logging_setup.py +74 -0
  1599. tests/test_utils/oidc.py +370 -0
  1600. tests/test_visibility.py +712 -0
  1601. tests/types/__init__.py +0 -0
  1602. tests/types/test_init.py +51 -0
  1603. tests/types/test_state.py +627 -0
  1604. tests/unittest.py +1108 -0
  1605. tests/util/__init__.py +20 -0
  1606. tests/util/caches/__init__.py +20 -0
  1607. tests/util/caches/test_cached_call.py +168 -0
  1608. tests/util/caches/test_deferred_cache.py +317 -0
  1609. tests/util/caches/test_descriptors.py +1110 -0
  1610. tests/util/caches/test_response_cache.py +225 -0
  1611. tests/util/caches/test_ttlcache.py +90 -0
  1612. tests/util/test_async_helpers.py +808 -0
  1613. tests/util/test_background_queue.py +117 -0
  1614. tests/util/test_batching_queue.py +252 -0
  1615. tests/util/test_check_dependencies.py +243 -0
  1616. tests/util/test_dict_cache.py +130 -0
  1617. tests/util/test_events.py +118 -0
  1618. tests/util/test_expiring_cache.py +113 -0
  1619. tests/util/test_file_consumer.py +199 -0
  1620. tests/util/test_itertools.py +190 -0
  1621. tests/util/test_linearizer.py +264 -0
  1622. tests/util/test_logcontext.py +715 -0
  1623. tests/util/test_logformatter.py +44 -0
  1624. tests/util/test_lrucache.py +479 -0
  1625. tests/util/test_macaroons.py +126 -0
  1626. tests/util/test_mutable_overlay_mapping.py +189 -0
  1627. tests/util/test_ratelimitutils.py +146 -0
  1628. tests/util/test_retryutils.py +314 -0
  1629. tests/util/test_rwlock.py +401 -0
  1630. tests/util/test_stream_change_cache.py +304 -0
  1631. tests/util/test_stringutils.py +86 -0
  1632. tests/util/test_task_scheduler.py +227 -0
  1633. tests/util/test_threepids.py +55 -0
  1634. tests/util/test_treecache.py +93 -0
  1635. tests/util/test_wheel_timer.py +82 -0
  1636. tests/utils.py +342 -0
@@ -0,0 +1,2025 @@
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 2016 OpenMarket Ltd
6
+ # Copyright (C) 2023 New Vector, Ltd
7
+ #
8
+ # This program is free software: you can redistribute it and/or modify
9
+ # it under the terms of the GNU Affero General Public License as
10
+ # published by the Free Software Foundation, either version 3 of the
11
+ # License, or (at your option) any later version.
12
+ #
13
+ # See the GNU Affero General Public License for more details:
14
+ # <https://www.gnu.org/licenses/agpl-3.0.html>.
15
+ #
16
+ # Originally licensed under the Apache License, Version 2.0:
17
+ # <http://www.apache.org/licenses/LICENSE-2.0>.
18
+ #
19
+ # [This file includes modifications made by New Vector Limited]
20
+ #
21
+ #
22
+ import time
23
+ from typing import Iterable
24
+ from unittest import mock
25
+
26
+ from parameterized import parameterized
27
+ from signedjson import key as key, sign as sign
28
+
29
+ from twisted.internet.testing import MemoryReactor
30
+
31
+ from synapse.api.constants import RoomEncryptionAlgorithms
32
+ from synapse.api.errors import Codes, SynapseError
33
+ from synapse.appservice import ApplicationService
34
+ from synapse.handlers.device import DeviceWriterHandler
35
+ from synapse.server import HomeServer
36
+ from synapse.storage.databases.main.appservice import _make_exclusive_regex
37
+ from synapse.types import JsonDict, UserID
38
+ from synapse.util.clock import Clock
39
+
40
+ from tests import unittest
41
+ from tests.unittest import override_config
42
+
43
+
44
+ class E2eKeysHandlerTestCase(unittest.HomeserverTestCase):
45
+ def make_homeserver(self, reactor: MemoryReactor, clock: Clock) -> HomeServer:
46
+ self.appservice_api = mock.AsyncMock()
47
+ return self.setup_test_homeserver(application_service_api=self.appservice_api)
48
+
49
+ def prepare(self, reactor: MemoryReactor, clock: Clock, hs: HomeServer) -> None:
50
+ self.handler = hs.get_e2e_keys_handler()
51
+ self.store = self.hs.get_datastores().main
52
+ self.requester = UserID.from_string(f"@test_requester:{self.hs.hostname}")
53
+
54
+ def test_query_local_devices_no_devices(self) -> None:
55
+ """If the user has no devices, we expect an empty list."""
56
+ local_user = "@boris:" + self.hs.hostname
57
+ res = self.get_success(self.handler.query_local_devices({local_user: None}))
58
+ self.assertDictEqual(res, {local_user: {}})
59
+
60
+ def test_reupload_one_time_keys(self) -> None:
61
+ """we should be able to re-upload the same keys"""
62
+ local_user = "@boris:" + self.hs.hostname
63
+ device_id = "xyz"
64
+ keys: JsonDict = {
65
+ "alg1:k1": "key1",
66
+ "alg2:k2": {"key": "key2", "signatures": {"k1": "sig1"}},
67
+ "alg2:k3": {"key": "key3"},
68
+ }
69
+
70
+ # Note that "signed_curve25519" is always returned in key count responses. This is necessary until
71
+ # https://github.com/matrix-org/matrix-doc/issues/3298 is fixed.
72
+ res = self.get_success(
73
+ self.handler.upload_keys_for_user(
74
+ local_user, device_id, {"one_time_keys": keys}
75
+ )
76
+ )
77
+ self.assertDictEqual(
78
+ res, {"one_time_key_counts": {"alg1": 1, "alg2": 2, "signed_curve25519": 0}}
79
+ )
80
+
81
+ # we should be able to change the signature without a problem
82
+ keys["alg2:k2"]["signatures"]["k1"] = "sig2"
83
+ res = self.get_success(
84
+ self.handler.upload_keys_for_user(
85
+ local_user, device_id, {"one_time_keys": keys}
86
+ )
87
+ )
88
+ self.assertDictEqual(
89
+ res, {"one_time_key_counts": {"alg1": 1, "alg2": 2, "signed_curve25519": 0}}
90
+ )
91
+
92
+ def test_change_one_time_keys(self) -> None:
93
+ """attempts to change one-time-keys should be rejected"""
94
+
95
+ local_user = "@boris:" + self.hs.hostname
96
+ device_id = "xyz"
97
+ keys = {
98
+ "alg1:k1": "key1",
99
+ "alg2:k2": {"key": "key2", "signatures": {"k1": "sig1"}},
100
+ "alg2:k3": {"key": "key3"},
101
+ }
102
+
103
+ res = self.get_success(
104
+ self.handler.upload_keys_for_user(
105
+ local_user, device_id, {"one_time_keys": keys}
106
+ )
107
+ )
108
+ self.assertDictEqual(
109
+ res, {"one_time_key_counts": {"alg1": 1, "alg2": 2, "signed_curve25519": 0}}
110
+ )
111
+
112
+ # Error when changing string key
113
+ self.get_failure(
114
+ self.handler.upload_keys_for_user(
115
+ local_user, device_id, {"one_time_keys": {"alg1:k1": "key2"}}
116
+ ),
117
+ SynapseError,
118
+ )
119
+
120
+ # Error when replacing dict key with string
121
+ self.get_failure(
122
+ self.handler.upload_keys_for_user(
123
+ local_user, device_id, {"one_time_keys": {"alg2:k3": "key2"}}
124
+ ),
125
+ SynapseError,
126
+ )
127
+
128
+ # Error when replacing string key with dict
129
+ self.get_failure(
130
+ self.handler.upload_keys_for_user(
131
+ local_user,
132
+ device_id,
133
+ {"one_time_keys": {"alg1:k1": {"key": "key"}}},
134
+ ),
135
+ SynapseError,
136
+ )
137
+
138
+ # Error when replacing dict key
139
+ self.get_failure(
140
+ self.handler.upload_keys_for_user(
141
+ local_user,
142
+ device_id,
143
+ {
144
+ "one_time_keys": {
145
+ "alg2:k2": {"key": "key3", "signatures": {"k1": "sig1"}}
146
+ }
147
+ },
148
+ ),
149
+ SynapseError,
150
+ )
151
+
152
+ def test_claim_one_time_key(self) -> None:
153
+ local_user = "@boris:" + self.hs.hostname
154
+ device_id = "xyz"
155
+ res = self.get_success(
156
+ self.handler.upload_keys_for_user(
157
+ local_user, device_id, {"one_time_keys": {"alg1:k1": "key1"}}
158
+ )
159
+ )
160
+ self.assertDictEqual(
161
+ res, {"one_time_key_counts": {"alg1": 1, "signed_curve25519": 0}}
162
+ )
163
+
164
+ # Keys should be returned in the order they were uploaded. To test, advance time
165
+ # a little, then upload a second key with an earlier key ID; it should get
166
+ # returned second.
167
+ self.reactor.advance(1)
168
+ res = self.get_success(
169
+ self.handler.upload_keys_for_user(
170
+ local_user, device_id, {"one_time_keys": {"alg1:k0": "key0"}}
171
+ )
172
+ )
173
+ self.assertDictEqual(
174
+ res, {"one_time_key_counts": {"alg1": 2, "signed_curve25519": 0}}
175
+ )
176
+
177
+ # now claim both keys back. They should be in the same order
178
+ res = self.get_success(
179
+ self.handler.claim_one_time_keys(
180
+ {local_user: {device_id: {"alg1": 1}}},
181
+ self.requester,
182
+ timeout=None,
183
+ always_include_fallback_keys=False,
184
+ )
185
+ )
186
+ self.assertEqual(
187
+ res,
188
+ {
189
+ "failures": {},
190
+ "one_time_keys": {local_user: {device_id: {"alg1:k1": "key1"}}},
191
+ },
192
+ )
193
+ res = self.get_success(
194
+ self.handler.claim_one_time_keys(
195
+ {local_user: {device_id: {"alg1": 1}}},
196
+ self.requester,
197
+ timeout=None,
198
+ always_include_fallback_keys=False,
199
+ )
200
+ )
201
+ self.assertEqual(
202
+ res,
203
+ {
204
+ "failures": {},
205
+ "one_time_keys": {local_user: {device_id: {"alg1:k0": "key0"}}},
206
+ },
207
+ )
208
+
209
+ def test_claim_one_time_key_bulk(self) -> None:
210
+ """Like test_claim_one_time_key but claims multiple keys in one handler call."""
211
+ # Apologies to the reader. This test is a little too verbose. It is particularly
212
+ # tricky to make assertions neatly with all these nested dictionaries in play.
213
+
214
+ # Three users with two devices each. Each device uses two algorithms.
215
+ # Each algorithm is invoked with two keys.
216
+ alice = f"@alice:{self.hs.hostname}"
217
+ brian = f"@brian:{self.hs.hostname}"
218
+ chris = f"@chris:{self.hs.hostname}"
219
+ one_time_keys = {
220
+ alice: {
221
+ "alice_dev_1": {
222
+ "alg1:k1": {"dummy_id": 1},
223
+ "alg1:k2": {"dummy_id": 2},
224
+ "alg2:k3": {"dummy_id": 3},
225
+ "alg2:k4": {"dummy_id": 4},
226
+ },
227
+ "alice_dev_2": {
228
+ "alg1:k5": {"dummy_id": 5},
229
+ "alg1:k6": {"dummy_id": 6},
230
+ "alg2:k7": {"dummy_id": 7},
231
+ "alg2:k8": {"dummy_id": 8},
232
+ },
233
+ },
234
+ brian: {
235
+ "brian_dev_1": {
236
+ "alg1:k9": {"dummy_id": 9},
237
+ "alg1:k10": {"dummy_id": 10},
238
+ "alg2:k11": {"dummy_id": 11},
239
+ "alg2:k12": {"dummy_id": 12},
240
+ },
241
+ "brian_dev_2": {
242
+ "alg1:k13": {"dummy_id": 13},
243
+ "alg1:k14": {"dummy_id": 14},
244
+ "alg2:k15": {"dummy_id": 15},
245
+ "alg2:k16": {"dummy_id": 16},
246
+ },
247
+ },
248
+ chris: {
249
+ "chris_dev_1": {
250
+ "alg1:k17": {"dummy_id": 17},
251
+ "alg1:k18": {"dummy_id": 18},
252
+ "alg2:k19": {"dummy_id": 19},
253
+ "alg2:k20": {"dummy_id": 20},
254
+ },
255
+ "chris_dev_2": {
256
+ "alg1:k21": {"dummy_id": 21},
257
+ "alg1:k22": {"dummy_id": 22},
258
+ "alg2:k23": {"dummy_id": 23},
259
+ "alg2:k24": {"dummy_id": 24},
260
+ },
261
+ },
262
+ }
263
+ for user_id, devices in one_time_keys.items():
264
+ for device_id, keys_dict in devices.items():
265
+ counts = self.get_success(
266
+ self.handler.upload_keys_for_user(
267
+ user_id,
268
+ device_id,
269
+ {"one_time_keys": keys_dict},
270
+ )
271
+ )
272
+ # The upload should report 2 keys per algorithm.
273
+ expected_counts = {
274
+ "one_time_key_counts": {
275
+ # See count_e2e_one_time_keys for why this is hardcoded.
276
+ "signed_curve25519": 0,
277
+ "alg1": 2,
278
+ "alg2": 2,
279
+ },
280
+ }
281
+ self.assertEqual(counts, expected_counts)
282
+
283
+ # Claim a variety of keys.
284
+ # Raw format, easier to make test assertions about.
285
+ claims_to_make = {
286
+ (alice, "alice_dev_1", "alg1"): 1,
287
+ (alice, "alice_dev_1", "alg2"): 2,
288
+ (alice, "alice_dev_2", "alg2"): 1,
289
+ (brian, "brian_dev_1", "alg1"): 2,
290
+ (brian, "brian_dev_2", "alg2"): 9001,
291
+ (chris, "chris_dev_2", "alg2"): 1,
292
+ }
293
+ # Convert to the format the handler wants.
294
+ query: dict[str, dict[str, dict[str, int]]] = {}
295
+ for (user_id, device_id, algorithm), count in claims_to_make.items():
296
+ query.setdefault(user_id, {}).setdefault(device_id, {})[algorithm] = count
297
+ claim_res = self.get_success(
298
+ self.handler.claim_one_time_keys(
299
+ query,
300
+ self.requester,
301
+ timeout=None,
302
+ always_include_fallback_keys=False,
303
+ )
304
+ )
305
+
306
+ # No failures, please!
307
+ self.assertEqual(claim_res["failures"], {})
308
+
309
+ # Check that we get exactly the (user, device, algorithm)s we asked for.
310
+ got_otks = claim_res["one_time_keys"]
311
+ claimed_user_device_algorithms = {
312
+ (user_id, device_id, alg_key_id.split(":")[0])
313
+ for user_id, devices in got_otks.items()
314
+ for device_id, key_dict in devices.items()
315
+ for alg_key_id in key_dict
316
+ }
317
+ self.assertEqual(claimed_user_device_algorithms, set(claims_to_make))
318
+
319
+ # Now check the keys we got are what we expected.
320
+ def assertExactlyOneOtk(
321
+ user_id: str, device_id: str, *alg_key_pairs: str
322
+ ) -> None:
323
+ key_dict = got_otks[user_id][device_id]
324
+ found = 0
325
+ for alg_key in alg_key_pairs:
326
+ if alg_key in key_dict:
327
+ expected_key_json = one_time_keys[user_id][device_id][alg_key]
328
+ self.assertEqual(key_dict[alg_key], expected_key_json)
329
+ found += 1
330
+ self.assertEqual(found, 1)
331
+
332
+ def assertAllOtks(user_id: str, device_id: str, *alg_key_pairs: str) -> None:
333
+ key_dict = got_otks[user_id][device_id]
334
+ for alg_key in alg_key_pairs:
335
+ expected_key_json = one_time_keys[user_id][device_id][alg_key]
336
+ self.assertEqual(key_dict[alg_key], expected_key_json)
337
+
338
+ # Expect a single arbitrary key to be returned.
339
+ assertExactlyOneOtk(alice, "alice_dev_1", "alg1:k1", "alg1:k2")
340
+ assertExactlyOneOtk(alice, "alice_dev_2", "alg2:k7", "alg2:k8")
341
+ assertExactlyOneOtk(chris, "chris_dev_2", "alg2:k23", "alg2:k24")
342
+
343
+ assertAllOtks(alice, "alice_dev_1", "alg2:k3", "alg2:k4")
344
+ assertAllOtks(brian, "brian_dev_1", "alg1:k9", "alg1:k10")
345
+ assertAllOtks(brian, "brian_dev_2", "alg2:k15", "alg2:k16")
346
+
347
+ # Now check the unused key counts.
348
+ for user_id, devices in one_time_keys.items():
349
+ for device_id in devices:
350
+ counts_by_alg = self.get_success(
351
+ self.store.count_e2e_one_time_keys(user_id, device_id)
352
+ )
353
+ # Somewhat fiddley to compute the expected count dict.
354
+ expected_counts_by_alg = {
355
+ "signed_curve25519": 0,
356
+ }
357
+ for alg in ["alg1", "alg2"]:
358
+ claim_count = claims_to_make.get((user_id, device_id, alg), 0)
359
+ remaining_count = max(0, 2 - claim_count)
360
+ if remaining_count > 0:
361
+ expected_counts_by_alg[alg] = remaining_count
362
+
363
+ self.assertEqual(
364
+ counts_by_alg, expected_counts_by_alg, f"{user_id}:{device_id}"
365
+ )
366
+
367
+ def test_claim_one_time_key_bulk_ordering(self) -> None:
368
+ """Keys returned by the bulk claim call should be returned in the correct order"""
369
+
370
+ # Alice has lots of keys, uploaded in a specific order
371
+ alice = f"@alice:{self.hs.hostname}"
372
+ alice_dev = "alice_dev_1"
373
+
374
+ self.get_success(
375
+ self.handler.upload_keys_for_user(
376
+ alice,
377
+ alice_dev,
378
+ {"one_time_keys": {"alg1:k20": 20, "alg1:k21": 21, "alg1:k22": 22}},
379
+ )
380
+ )
381
+ # Advance time by 1s, to ensure that there is a difference in upload time.
382
+ self.reactor.advance(1)
383
+ self.get_success(
384
+ self.handler.upload_keys_for_user(
385
+ alice,
386
+ alice_dev,
387
+ {"one_time_keys": {"alg1:k10": 10, "alg1:k11": 11, "alg1:k12": 12}},
388
+ )
389
+ )
390
+
391
+ # Now claim some, and check we get the right ones.
392
+ claim_res = self.get_success(
393
+ self.handler.claim_one_time_keys(
394
+ {alice: {alice_dev: {"alg1": 2}}},
395
+ self.requester,
396
+ timeout=None,
397
+ always_include_fallback_keys=False,
398
+ )
399
+ )
400
+ # We should get the first-uploaded keys, even though they have later key ids.
401
+ # We should get a random set of two of k20, k21, k22.
402
+ self.assertEqual(claim_res["failures"], {})
403
+ claimed_keys = claim_res["one_time_keys"]["@alice:test"]["alice_dev_1"]
404
+ self.assertEqual(len(claimed_keys), 2)
405
+ for key_id in claimed_keys.keys():
406
+ self.assertIn(key_id, ["alg1:k20", "alg1:k21", "alg1:k22"])
407
+
408
+ def test_fallback_key(self) -> None:
409
+ local_user = "@boris:" + self.hs.hostname
410
+ device_id = "xyz"
411
+ fallback_key = {"alg1:k1": "fallback_key1"}
412
+ fallback_key2 = {"alg1:k2": "fallback_key2"}
413
+ otk = {"alg1:k2": "key2"}
414
+
415
+ # we shouldn't have any unused fallback keys yet
416
+ res = self.get_success(
417
+ self.store.get_e2e_unused_fallback_key_types(local_user, device_id)
418
+ )
419
+ self.assertEqual(res, [])
420
+
421
+ self.get_success(
422
+ self.handler.upload_keys_for_user(
423
+ local_user,
424
+ device_id,
425
+ {"fallback_keys": fallback_key},
426
+ )
427
+ )
428
+
429
+ # we should now have an unused alg1 key
430
+ fallback_res = self.get_success(
431
+ self.store.get_e2e_unused_fallback_key_types(local_user, device_id)
432
+ )
433
+ self.assertEqual(fallback_res, ["alg1"])
434
+
435
+ # claiming an OTK when no OTKs are available should return the fallback
436
+ # key
437
+ claim_res = self.get_success(
438
+ self.handler.claim_one_time_keys(
439
+ {local_user: {device_id: {"alg1": 1}}},
440
+ self.requester,
441
+ timeout=None,
442
+ always_include_fallback_keys=False,
443
+ )
444
+ )
445
+ self.assertEqual(
446
+ claim_res,
447
+ {"failures": {}, "one_time_keys": {local_user: {device_id: fallback_key}}},
448
+ )
449
+
450
+ # we shouldn't have any unused fallback keys again
451
+ unused_res = self.get_success(
452
+ self.store.get_e2e_unused_fallback_key_types(local_user, device_id)
453
+ )
454
+ self.assertEqual(unused_res, [])
455
+
456
+ # claiming an OTK again should return the same fallback key
457
+ claim_res = self.get_success(
458
+ self.handler.claim_one_time_keys(
459
+ {local_user: {device_id: {"alg1": 1}}},
460
+ self.requester,
461
+ timeout=None,
462
+ always_include_fallback_keys=False,
463
+ )
464
+ )
465
+ self.assertEqual(
466
+ claim_res,
467
+ {"failures": {}, "one_time_keys": {local_user: {device_id: fallback_key}}},
468
+ )
469
+
470
+ # re-uploading the same fallback key should still result in no unused fallback
471
+ # keys
472
+ self.get_success(
473
+ self.handler.upload_keys_for_user(
474
+ local_user,
475
+ device_id,
476
+ {"fallback_keys": fallback_key},
477
+ )
478
+ )
479
+
480
+ unused_res = self.get_success(
481
+ self.store.get_e2e_unused_fallback_key_types(local_user, device_id)
482
+ )
483
+ self.assertEqual(unused_res, [])
484
+
485
+ # uploading a new fallback key should result in an unused fallback key
486
+ self.get_success(
487
+ self.handler.upload_keys_for_user(
488
+ local_user,
489
+ device_id,
490
+ {"fallback_keys": fallback_key2},
491
+ )
492
+ )
493
+
494
+ unused_res = self.get_success(
495
+ self.store.get_e2e_unused_fallback_key_types(local_user, device_id)
496
+ )
497
+ self.assertEqual(unused_res, ["alg1"])
498
+
499
+ # if the user uploads a one-time key, the next claim should fetch the
500
+ # one-time key, and then go back to the fallback
501
+ self.get_success(
502
+ self.handler.upload_keys_for_user(
503
+ local_user, device_id, {"one_time_keys": otk}
504
+ )
505
+ )
506
+
507
+ claim_res = self.get_success(
508
+ self.handler.claim_one_time_keys(
509
+ {local_user: {device_id: {"alg1": 1}}},
510
+ self.requester,
511
+ timeout=None,
512
+ always_include_fallback_keys=False,
513
+ )
514
+ )
515
+ self.assertEqual(
516
+ claim_res,
517
+ {"failures": {}, "one_time_keys": {local_user: {device_id: otk}}},
518
+ )
519
+
520
+ claim_res = self.get_success(
521
+ self.handler.claim_one_time_keys(
522
+ {local_user: {device_id: {"alg1": 1}}},
523
+ self.requester,
524
+ timeout=None,
525
+ always_include_fallback_keys=False,
526
+ )
527
+ )
528
+ self.assertEqual(
529
+ claim_res,
530
+ {"failures": {}, "one_time_keys": {local_user: {device_id: fallback_key2}}},
531
+ )
532
+
533
+ def test_fallback_key_bulk(self) -> None:
534
+ """Like test_fallback_key, but claims multiple keys in one handler call."""
535
+ alice = f"@alice:{self.hs.hostname}"
536
+ brian = f"@brian:{self.hs.hostname}"
537
+ chris = f"@chris:{self.hs.hostname}"
538
+
539
+ # Have three users upload fallback keys for two devices.
540
+ fallback_keys = {
541
+ alice: {
542
+ "alice_dev_1": {"alg1:k1": "fallback_key1"},
543
+ "alice_dev_2": {"alg2:k2": "fallback_key2"},
544
+ },
545
+ brian: {
546
+ "brian_dev_1": {"alg1:k3": "fallback_key3"},
547
+ "brian_dev_2": {"alg2:k4": "fallback_key4"},
548
+ },
549
+ chris: {
550
+ "chris_dev_1": {"alg1:k5": "fallback_key5"},
551
+ "chris_dev_2": {"alg2:k6": "fallback_key6"},
552
+ },
553
+ }
554
+
555
+ for user_id, devices in fallback_keys.items():
556
+ for device_id, key_dict in devices.items():
557
+ self.get_success(
558
+ self.handler.upload_keys_for_user(
559
+ user_id,
560
+ device_id,
561
+ {"fallback_keys": key_dict},
562
+ )
563
+ )
564
+
565
+ # Each device should have an unused fallback key.
566
+ for user_id, devices in fallback_keys.items():
567
+ for device_id in devices:
568
+ fallback_res = self.get_success(
569
+ self.store.get_e2e_unused_fallback_key_types(user_id, device_id)
570
+ )
571
+ expected_algorithm_name = f"alg{device_id[-1]}"
572
+ self.assertEqual(fallback_res, [expected_algorithm_name])
573
+
574
+ # Claim the fallback key for one device per user.
575
+ claim_res = self.get_success(
576
+ self.handler.claim_one_time_keys(
577
+ {
578
+ alice: {"alice_dev_1": {"alg1": 1}},
579
+ brian: {"brian_dev_2": {"alg2": 1}},
580
+ chris: {"chris_dev_2": {"alg2": 1}},
581
+ },
582
+ self.requester,
583
+ timeout=None,
584
+ always_include_fallback_keys=False,
585
+ )
586
+ )
587
+ expected_claims = {
588
+ alice: {"alice_dev_1": {"alg1:k1": "fallback_key1"}},
589
+ brian: {"brian_dev_2": {"alg2:k4": "fallback_key4"}},
590
+ chris: {"chris_dev_2": {"alg2:k6": "fallback_key6"}},
591
+ }
592
+ self.assertEqual(
593
+ claim_res,
594
+ {"failures": {}, "one_time_keys": expected_claims},
595
+ )
596
+
597
+ for user_id, devices in fallback_keys.items():
598
+ for device_id in devices:
599
+ fallback_res = self.get_success(
600
+ self.store.get_e2e_unused_fallback_key_types(user_id, device_id)
601
+ )
602
+ # Claimed fallback keys should no longer show up as unused.
603
+ # Unclaimed fallback keys should still be unused.
604
+ if device_id in expected_claims[user_id]:
605
+ self.assertEqual(fallback_res, [])
606
+ else:
607
+ expected_algorithm_name = f"alg{device_id[-1]}"
608
+ self.assertEqual(fallback_res, [expected_algorithm_name])
609
+
610
+ def test_fallback_key_always_returned(self) -> None:
611
+ local_user = "@boris:" + self.hs.hostname
612
+ device_id = "xyz"
613
+ fallback_key = {"alg1:k1": "fallback_key1"}
614
+ otk = {"alg1:k2": "key2"}
615
+
616
+ # we shouldn't have any unused fallback keys yet
617
+ res = self.get_success(
618
+ self.store.get_e2e_unused_fallback_key_types(local_user, device_id)
619
+ )
620
+ self.assertEqual(res, [])
621
+
622
+ # Upload a OTK & fallback key.
623
+ self.get_success(
624
+ self.handler.upload_keys_for_user(
625
+ local_user,
626
+ device_id,
627
+ {"one_time_keys": otk, "fallback_keys": fallback_key},
628
+ )
629
+ )
630
+
631
+ # we should now have an unused alg1 key
632
+ fallback_res = self.get_success(
633
+ self.store.get_e2e_unused_fallback_key_types(local_user, device_id)
634
+ )
635
+ self.assertEqual(fallback_res, ["alg1"])
636
+
637
+ # Claiming an OTK and requesting to always return the fallback key should
638
+ # return both.
639
+ claim_res = self.get_success(
640
+ self.handler.claim_one_time_keys(
641
+ {local_user: {device_id: {"alg1": 1}}},
642
+ self.requester,
643
+ timeout=None,
644
+ always_include_fallback_keys=True,
645
+ )
646
+ )
647
+ self.assertEqual(
648
+ claim_res,
649
+ {
650
+ "failures": {},
651
+ "one_time_keys": {local_user: {device_id: {**fallback_key, **otk}}},
652
+ },
653
+ )
654
+
655
+ # This should not mark the key as used.
656
+ fallback_res = self.get_success(
657
+ self.store.get_e2e_unused_fallback_key_types(local_user, device_id)
658
+ )
659
+ self.assertEqual(fallback_res, ["alg1"])
660
+
661
+ # Claiming an OTK again should return only the fallback key.
662
+ claim_res = self.get_success(
663
+ self.handler.claim_one_time_keys(
664
+ {local_user: {device_id: {"alg1": 1}}},
665
+ self.requester,
666
+ timeout=None,
667
+ always_include_fallback_keys=True,
668
+ )
669
+ )
670
+ self.assertEqual(
671
+ claim_res,
672
+ {"failures": {}, "one_time_keys": {local_user: {device_id: fallback_key}}},
673
+ )
674
+
675
+ # And mark it as used.
676
+ fallback_res = self.get_success(
677
+ self.store.get_e2e_unused_fallback_key_types(local_user, device_id)
678
+ )
679
+ self.assertEqual(fallback_res, [])
680
+
681
+ def test_replace_master_key(self) -> None:
682
+ """uploading a new signing key should make the old signing key unavailable"""
683
+ local_user = "@boris:" + self.hs.hostname
684
+ keys1 = {
685
+ "master_key": {
686
+ # private key: 2lonYOM6xYKdEsO+6KrC766xBcHnYnim1x/4LFGF8B0
687
+ "user_id": local_user,
688
+ "usage": ["master"],
689
+ "keys": {
690
+ "ed25519:nqOvzeuGWT/sRx3h7+MHoInYj3Uk2LD/unI9kDYcHwk": "nqOvzeuGWT/sRx3h7+MHoInYj3Uk2LD/unI9kDYcHwk"
691
+ },
692
+ }
693
+ }
694
+ self.get_success(self.handler.upload_signing_keys_for_user(local_user, keys1))
695
+
696
+ keys2 = {
697
+ "master_key": {
698
+ # private key: 4TL4AjRYwDVwD3pqQzcor+ez/euOB1/q78aTJ+czDNs
699
+ "user_id": local_user,
700
+ "usage": ["master"],
701
+ "keys": {
702
+ "ed25519:Hq6gL+utB4ET+UvD5ci0kgAwsX6qP/zvf8v6OInU5iw": "Hq6gL+utB4ET+UvD5ci0kgAwsX6qP/zvf8v6OInU5iw"
703
+ },
704
+ }
705
+ }
706
+ self.get_success(self.handler.upload_signing_keys_for_user(local_user, keys2))
707
+
708
+ devices = self.get_success(
709
+ self.handler.query_devices(
710
+ {"device_keys": {local_user: []}}, 0, local_user, "device123"
711
+ )
712
+ )
713
+ self.assertDictEqual(devices["master_keys"], {local_user: keys2["master_key"]})
714
+
715
+ def test_reupload_signatures(self) -> None:
716
+ """re-uploading a signature should not fail"""
717
+ local_user = "@boris:" + self.hs.hostname
718
+ keys1 = {
719
+ "master_key": {
720
+ # private key: HvQBbU+hc2Zr+JP1sE0XwBe1pfZZEYtJNPJLZJtS+F8
721
+ "user_id": local_user,
722
+ "usage": ["master"],
723
+ "keys": {
724
+ "ed25519:EmkqvokUn8p+vQAGZitOk4PWjp7Ukp3txV2TbMPEiBQ": "EmkqvokUn8p+vQAGZitOk4PWjp7Ukp3txV2TbMPEiBQ"
725
+ },
726
+ },
727
+ "self_signing_key": {
728
+ # private key: 2lonYOM6xYKdEsO+6KrC766xBcHnYnim1x/4LFGF8B0
729
+ "user_id": local_user,
730
+ "usage": ["self_signing"],
731
+ "keys": {
732
+ "ed25519:nqOvzeuGWT/sRx3h7+MHoInYj3Uk2LD/unI9kDYcHwk": "nqOvzeuGWT/sRx3h7+MHoInYj3Uk2LD/unI9kDYcHwk"
733
+ },
734
+ },
735
+ }
736
+ master_signing_key = key.decode_signing_key_base64(
737
+ "ed25519",
738
+ "EmkqvokUn8p+vQAGZitOk4PWjp7Ukp3txV2TbMPEiBQ",
739
+ "HvQBbU+hc2Zr+JP1sE0XwBe1pfZZEYtJNPJLZJtS+F8",
740
+ )
741
+ sign.sign_json(keys1["self_signing_key"], local_user, master_signing_key)
742
+ signing_key = key.decode_signing_key_base64(
743
+ "ed25519",
744
+ "nqOvzeuGWT/sRx3h7+MHoInYj3Uk2LD/unI9kDYcHwk",
745
+ "2lonYOM6xYKdEsO+6KrC766xBcHnYnim1x/4LFGF8B0",
746
+ )
747
+ self.get_success(self.handler.upload_signing_keys_for_user(local_user, keys1))
748
+
749
+ # upload two device keys, which will be signed later by the self-signing key
750
+ device_key_1: JsonDict = {
751
+ "user_id": local_user,
752
+ "device_id": "abc",
753
+ "algorithms": [
754
+ "m.olm.curve25519-aes-sha2",
755
+ RoomEncryptionAlgorithms.MEGOLM_V1_AES_SHA2,
756
+ ],
757
+ "keys": {
758
+ "ed25519:abc": "base64+ed25519+key",
759
+ "curve25519:abc": "base64+curve25519+key",
760
+ },
761
+ "signatures": {local_user: {"ed25519:abc": "base64+signature"}},
762
+ }
763
+ device_key_2: JsonDict = {
764
+ "user_id": local_user,
765
+ "device_id": "def",
766
+ "algorithms": [
767
+ "m.olm.curve25519-aes-sha2",
768
+ RoomEncryptionAlgorithms.MEGOLM_V1_AES_SHA2,
769
+ ],
770
+ "keys": {
771
+ "ed25519:def": "base64+ed25519+key",
772
+ "curve25519:def": "base64+curve25519+key",
773
+ },
774
+ "signatures": {local_user: {"ed25519:def": "base64+signature"}},
775
+ }
776
+
777
+ self.get_success(
778
+ self.handler.upload_keys_for_user(
779
+ local_user, "abc", {"device_keys": device_key_1}
780
+ )
781
+ )
782
+ self.get_success(
783
+ self.handler.upload_keys_for_user(
784
+ local_user, "def", {"device_keys": device_key_2}
785
+ )
786
+ )
787
+
788
+ # sign the first device key and upload it
789
+ del device_key_1["signatures"]
790
+ sign.sign_json(device_key_1, local_user, signing_key)
791
+ self.get_success(
792
+ self.handler.upload_signatures_for_device_keys(
793
+ local_user, {local_user: {"abc": device_key_1}}
794
+ )
795
+ )
796
+
797
+ # sign the second device key and upload both device keys. The server
798
+ # should ignore the first device key since it already has a valid
799
+ # signature for it
800
+ del device_key_2["signatures"]
801
+ sign.sign_json(device_key_2, local_user, signing_key)
802
+ self.get_success(
803
+ self.handler.upload_signatures_for_device_keys(
804
+ local_user, {local_user: {"abc": device_key_1, "def": device_key_2}}
805
+ )
806
+ )
807
+
808
+ device_key_1["signatures"][local_user]["ed25519:abc"] = "base64+signature"
809
+ device_key_2["signatures"][local_user]["ed25519:def"] = "base64+signature"
810
+ devices = self.get_success(
811
+ self.handler.query_devices(
812
+ {"device_keys": {local_user: []}}, 0, local_user, "device123"
813
+ )
814
+ )
815
+ del devices["device_keys"][local_user]["abc"]["unsigned"]
816
+ del devices["device_keys"][local_user]["def"]["unsigned"]
817
+ self.assertDictEqual(devices["device_keys"][local_user]["abc"], device_key_1)
818
+ self.assertDictEqual(devices["device_keys"][local_user]["def"], device_key_2)
819
+
820
+ def test_self_signing_key_doesnt_show_up_as_device(self) -> None:
821
+ """signing keys should be hidden when fetching a user's devices"""
822
+ local_user = "@boris:" + self.hs.hostname
823
+ keys1 = {
824
+ "master_key": {
825
+ # private key: 2lonYOM6xYKdEsO+6KrC766xBcHnYnim1x/4LFGF8B0
826
+ "user_id": local_user,
827
+ "usage": ["master"],
828
+ "keys": {
829
+ "ed25519:nqOvzeuGWT/sRx3h7+MHoInYj3Uk2LD/unI9kDYcHwk": "nqOvzeuGWT/sRx3h7+MHoInYj3Uk2LD/unI9kDYcHwk"
830
+ },
831
+ }
832
+ }
833
+ self.get_success(self.handler.upload_signing_keys_for_user(local_user, keys1))
834
+
835
+ device_handler = self.hs.get_device_handler()
836
+ assert isinstance(device_handler, DeviceWriterHandler)
837
+ e = self.get_failure(
838
+ device_handler.check_device_registered(
839
+ user_id=local_user,
840
+ device_id="nqOvzeuGWT/sRx3h7+MHoInYj3Uk2LD/unI9kDYcHwk",
841
+ initial_device_display_name="new display name",
842
+ ),
843
+ SynapseError,
844
+ )
845
+ res = e.value.code
846
+ self.assertEqual(res, 400)
847
+
848
+ query_res = self.get_success(
849
+ self.handler.query_local_devices({local_user: None})
850
+ )
851
+ self.assertDictEqual(query_res, {local_user: {}})
852
+
853
+ def test_upload_signatures(self) -> None:
854
+ """should check signatures that are uploaded"""
855
+ # set up a user with cross-signing keys and a device. This user will
856
+ # try uploading signatures
857
+ local_user = "@boris:" + self.hs.hostname
858
+ device_id = "xyz"
859
+ # private key: OMkooTr76ega06xNvXIGPbgvvxAOzmQncN8VObS7aBA
860
+ device_pubkey = "NnHhnqiMFQkq969szYkooLaBAXW244ZOxgukCvm2ZeY"
861
+ device_key: JsonDict = {
862
+ "user_id": local_user,
863
+ "device_id": device_id,
864
+ "algorithms": [
865
+ "m.olm.curve25519-aes-sha2",
866
+ RoomEncryptionAlgorithms.MEGOLM_V1_AES_SHA2,
867
+ ],
868
+ "keys": {"curve25519:xyz": "curve25519+key", "ed25519:xyz": device_pubkey},
869
+ "signatures": {local_user: {"ed25519:xyz": "something"}},
870
+ }
871
+ device_signing_key = key.decode_signing_key_base64(
872
+ "ed25519", "xyz", "OMkooTr76ega06xNvXIGPbgvvxAOzmQncN8VObS7aBA"
873
+ )
874
+
875
+ self.get_success(
876
+ self.handler.upload_keys_for_user(
877
+ local_user, device_id, {"device_keys": device_key}
878
+ )
879
+ )
880
+
881
+ # private key: 2lonYOM6xYKdEsO+6KrC766xBcHnYnim1x/4LFGF8B0
882
+ master_pubkey = "nqOvzeuGWT/sRx3h7+MHoInYj3Uk2LD/unI9kDYcHwk"
883
+ master_key: JsonDict = {
884
+ "user_id": local_user,
885
+ "usage": ["master"],
886
+ "keys": {"ed25519:" + master_pubkey: master_pubkey},
887
+ }
888
+ master_signing_key = key.decode_signing_key_base64(
889
+ "ed25519", master_pubkey, "2lonYOM6xYKdEsO+6KrC766xBcHnYnim1x/4LFGF8B0"
890
+ )
891
+ usersigning_pubkey = "Hq6gL+utB4ET+UvD5ci0kgAwsX6qP/zvf8v6OInU5iw"
892
+ usersigning_key = {
893
+ # private key: 4TL4AjRYwDVwD3pqQzcor+ez/euOB1/q78aTJ+czDNs
894
+ "user_id": local_user,
895
+ "usage": ["user_signing"],
896
+ "keys": {"ed25519:" + usersigning_pubkey: usersigning_pubkey},
897
+ }
898
+ usersigning_signing_key = key.decode_signing_key_base64(
899
+ "ed25519", usersigning_pubkey, "4TL4AjRYwDVwD3pqQzcor+ez/euOB1/q78aTJ+czDNs"
900
+ )
901
+ sign.sign_json(usersigning_key, local_user, master_signing_key)
902
+ # private key: HvQBbU+hc2Zr+JP1sE0XwBe1pfZZEYtJNPJLZJtS+F8
903
+ selfsigning_pubkey = "EmkqvokUn8p+vQAGZitOk4PWjp7Ukp3txV2TbMPEiBQ"
904
+ selfsigning_key = {
905
+ "user_id": local_user,
906
+ "usage": ["self_signing"],
907
+ "keys": {"ed25519:" + selfsigning_pubkey: selfsigning_pubkey},
908
+ }
909
+ selfsigning_signing_key = key.decode_signing_key_base64(
910
+ "ed25519", selfsigning_pubkey, "HvQBbU+hc2Zr+JP1sE0XwBe1pfZZEYtJNPJLZJtS+F8"
911
+ )
912
+ sign.sign_json(selfsigning_key, local_user, master_signing_key)
913
+ cross_signing_keys = {
914
+ "master_key": master_key,
915
+ "user_signing_key": usersigning_key,
916
+ "self_signing_key": selfsigning_key,
917
+ }
918
+ self.get_success(
919
+ self.handler.upload_signing_keys_for_user(local_user, cross_signing_keys)
920
+ )
921
+
922
+ # set up another user with a master key. This user will be signed by
923
+ # the first user
924
+ other_user = "@otherboris:" + self.hs.hostname
925
+ other_master_pubkey = "fHZ3NPiKxoLQm5OoZbKa99SYxprOjNs4TwJUKP+twCM"
926
+ other_master_key: JsonDict = {
927
+ # private key: oyw2ZUx0O4GifbfFYM0nQvj9CL0b8B7cyN4FprtK8OI
928
+ "user_id": other_user,
929
+ "usage": ["master"],
930
+ "keys": {"ed25519:" + other_master_pubkey: other_master_pubkey},
931
+ }
932
+ self.get_success(
933
+ self.handler.upload_signing_keys_for_user(
934
+ other_user, {"master_key": other_master_key}
935
+ )
936
+ )
937
+
938
+ # test various signature failures (see below)
939
+ ret = self.get_success(
940
+ self.handler.upload_signatures_for_device_keys(
941
+ local_user,
942
+ {
943
+ local_user: {
944
+ # fails because the signature is invalid
945
+ # should fail with INVALID_SIGNATURE
946
+ device_id: {
947
+ "user_id": local_user,
948
+ "device_id": device_id,
949
+ "algorithms": [
950
+ "m.olm.curve25519-aes-sha2",
951
+ RoomEncryptionAlgorithms.MEGOLM_V1_AES_SHA2,
952
+ ],
953
+ "keys": {
954
+ "curve25519:xyz": "curve25519+key",
955
+ # private key: OMkooTr76ega06xNvXIGPbgvvxAOzmQncN8VObS7aBA
956
+ "ed25519:xyz": device_pubkey,
957
+ },
958
+ "signatures": {
959
+ local_user: {
960
+ "ed25519:" + selfsigning_pubkey: "something"
961
+ }
962
+ },
963
+ },
964
+ # fails because device is unknown
965
+ # should fail with NOT_FOUND
966
+ "unknown": {
967
+ "user_id": local_user,
968
+ "device_id": "unknown",
969
+ "signatures": {
970
+ local_user: {
971
+ "ed25519:" + selfsigning_pubkey: "something"
972
+ }
973
+ },
974
+ },
975
+ # fails because the signature is invalid
976
+ # should fail with INVALID_SIGNATURE
977
+ master_pubkey: {
978
+ "user_id": local_user,
979
+ "usage": ["master"],
980
+ "keys": {"ed25519:" + master_pubkey: master_pubkey},
981
+ "signatures": {
982
+ local_user: {"ed25519:" + device_pubkey: "something"}
983
+ },
984
+ },
985
+ },
986
+ other_user: {
987
+ # fails because the device is not the user's master-signing key
988
+ # should fail with NOT_FOUND
989
+ "unknown": {
990
+ "user_id": other_user,
991
+ "device_id": "unknown",
992
+ "signatures": {
993
+ local_user: {
994
+ "ed25519:" + usersigning_pubkey: "something"
995
+ }
996
+ },
997
+ },
998
+ other_master_pubkey: {
999
+ # fails because the key doesn't match what the server has
1000
+ # should fail with UNKNOWN
1001
+ "user_id": other_user,
1002
+ "usage": ["master"],
1003
+ "keys": {
1004
+ "ed25519:" + other_master_pubkey: other_master_pubkey
1005
+ },
1006
+ "something": "random",
1007
+ "signatures": {
1008
+ local_user: {
1009
+ "ed25519:" + usersigning_pubkey: "something"
1010
+ }
1011
+ },
1012
+ },
1013
+ },
1014
+ },
1015
+ )
1016
+ )
1017
+
1018
+ user_failures = ret["failures"][local_user]
1019
+ self.assertEqual(user_failures[device_id]["errcode"], Codes.INVALID_SIGNATURE)
1020
+ self.assertEqual(
1021
+ user_failures[master_pubkey]["errcode"], Codes.INVALID_SIGNATURE
1022
+ )
1023
+ self.assertEqual(user_failures["unknown"]["errcode"], Codes.NOT_FOUND)
1024
+
1025
+ other_user_failures = ret["failures"][other_user]
1026
+ self.assertEqual(other_user_failures["unknown"]["errcode"], Codes.NOT_FOUND)
1027
+ self.assertEqual(
1028
+ other_user_failures[other_master_pubkey]["errcode"], Codes.UNKNOWN
1029
+ )
1030
+
1031
+ # test successful signatures
1032
+ del device_key["signatures"]
1033
+ sign.sign_json(device_key, local_user, selfsigning_signing_key)
1034
+ sign.sign_json(master_key, local_user, device_signing_key)
1035
+ sign.sign_json(other_master_key, local_user, usersigning_signing_key)
1036
+ ret = self.get_success(
1037
+ self.handler.upload_signatures_for_device_keys(
1038
+ local_user,
1039
+ {
1040
+ local_user: {device_id: device_key, master_pubkey: master_key},
1041
+ other_user: {other_master_pubkey: other_master_key},
1042
+ },
1043
+ )
1044
+ )
1045
+
1046
+ self.assertEqual(ret["failures"], {})
1047
+
1048
+ # fetch the signed keys/devices and make sure that the signatures are there
1049
+ ret = self.get_success(
1050
+ self.handler.query_devices(
1051
+ {"device_keys": {local_user: [], other_user: []}},
1052
+ 0,
1053
+ local_user,
1054
+ "device123",
1055
+ )
1056
+ )
1057
+
1058
+ self.assertEqual(
1059
+ ret["device_keys"][local_user]["xyz"]["signatures"][local_user][
1060
+ "ed25519:" + selfsigning_pubkey
1061
+ ],
1062
+ device_key["signatures"][local_user]["ed25519:" + selfsigning_pubkey],
1063
+ )
1064
+ self.assertEqual(
1065
+ ret["master_keys"][local_user]["signatures"][local_user][
1066
+ "ed25519:" + device_id
1067
+ ],
1068
+ master_key["signatures"][local_user]["ed25519:" + device_id],
1069
+ )
1070
+ self.assertEqual(
1071
+ ret["master_keys"][other_user]["signatures"][local_user][
1072
+ "ed25519:" + usersigning_pubkey
1073
+ ],
1074
+ other_master_key["signatures"][local_user]["ed25519:" + usersigning_pubkey],
1075
+ )
1076
+
1077
+ def test_query_devices_remote_no_sync(self) -> None:
1078
+ """Tests that querying keys for a remote user that we don't share a room
1079
+ with returns the cross signing keys correctly.
1080
+ """
1081
+
1082
+ remote_user_id = "@test:other"
1083
+ local_user_id = "@test:test"
1084
+
1085
+ remote_master_key = "85T7JXPFBAySB/jwby4S3lBPTqY3+Zg53nYuGmu1ggY"
1086
+ remote_self_signing_key = "QeIiFEjluPBtI7WQdG365QKZcFs9kqmHir6RBD0//nQ"
1087
+
1088
+ self.hs.get_federation_client().query_client_keys = mock.AsyncMock( # type: ignore[method-assign]
1089
+ return_value={
1090
+ "device_keys": {remote_user_id: {}},
1091
+ "master_keys": {
1092
+ remote_user_id: {
1093
+ "user_id": remote_user_id,
1094
+ "usage": ["master"],
1095
+ "keys": {"ed25519:" + remote_master_key: remote_master_key},
1096
+ },
1097
+ },
1098
+ "self_signing_keys": {
1099
+ remote_user_id: {
1100
+ "user_id": remote_user_id,
1101
+ "usage": ["self_signing"],
1102
+ "keys": {
1103
+ "ed25519:"
1104
+ + remote_self_signing_key: remote_self_signing_key
1105
+ },
1106
+ }
1107
+ },
1108
+ }
1109
+ )
1110
+
1111
+ e2e_handler = self.hs.get_e2e_keys_handler()
1112
+
1113
+ query_result = self.get_success(
1114
+ e2e_handler.query_devices(
1115
+ {
1116
+ "device_keys": {remote_user_id: []},
1117
+ },
1118
+ timeout=10,
1119
+ from_user_id=local_user_id,
1120
+ from_device_id="some_device_id",
1121
+ )
1122
+ )
1123
+
1124
+ self.assertEqual(query_result["failures"], {})
1125
+ self.assertEqual(
1126
+ query_result["master_keys"],
1127
+ {
1128
+ remote_user_id: {
1129
+ "user_id": remote_user_id,
1130
+ "usage": ["master"],
1131
+ "keys": {"ed25519:" + remote_master_key: remote_master_key},
1132
+ },
1133
+ },
1134
+ )
1135
+ self.assertEqual(
1136
+ query_result["self_signing_keys"],
1137
+ {
1138
+ remote_user_id: {
1139
+ "user_id": remote_user_id,
1140
+ "usage": ["self_signing"],
1141
+ "keys": {
1142
+ "ed25519:" + remote_self_signing_key: remote_self_signing_key
1143
+ },
1144
+ }
1145
+ },
1146
+ )
1147
+
1148
+ def test_has_different_keys(self) -> None:
1149
+ """check that has_different_keys returns True when the keys provided are different to what
1150
+ is in the database."""
1151
+ local_user = "@boris:" + self.hs.hostname
1152
+ keys1 = {
1153
+ "master_key": {
1154
+ # private key: 2lonYOM6xYKdEsO+6KrC766xBcHnYnim1x/4LFGF8B0
1155
+ "user_id": local_user,
1156
+ "usage": ["master"],
1157
+ "keys": {
1158
+ "ed25519:nqOvzeuGWT/sRx3h7+MHoInYj3Uk2LD/unI9kDYcHwk": "nqOvzeuGWT/sRx3h7+MHoInYj3Uk2LD/unI9kDYcHwk"
1159
+ },
1160
+ }
1161
+ }
1162
+ self.get_success(self.handler.upload_signing_keys_for_user(local_user, keys1))
1163
+ is_different = self.get_success(
1164
+ self.handler.has_different_keys(
1165
+ local_user,
1166
+ {
1167
+ "master_key": keys1["master_key"],
1168
+ },
1169
+ )
1170
+ )
1171
+ self.assertEqual(is_different, False)
1172
+ # change the usage => different keys
1173
+ keys1["master_key"]["usage"] = ["develop"]
1174
+ is_different = self.get_success(
1175
+ self.handler.has_different_keys(
1176
+ local_user,
1177
+ {
1178
+ "master_key": keys1["master_key"],
1179
+ },
1180
+ )
1181
+ )
1182
+ self.assertEqual(is_different, True)
1183
+ keys1["master_key"]["usage"] = ["master"] # reset
1184
+ # change the key => different keys
1185
+ keys1["master_key"]["keys"] = {
1186
+ "ed25519:nqOvzeuGWT/sRx3h7+MHoInYj3Uk2LD/unIc0rncs": "nqOvzeuGWT/sRx3h7+MHoInYj3Uk2LD/unIc0rncs"
1187
+ }
1188
+ is_different = self.get_success(
1189
+ self.handler.has_different_keys(
1190
+ local_user,
1191
+ {
1192
+ "master_key": keys1["master_key"],
1193
+ },
1194
+ )
1195
+ )
1196
+ self.assertEqual(is_different, True)
1197
+
1198
+ def test_query_devices_remote_sync(self) -> None:
1199
+ """Tests that querying keys for a remote user that we share a room with,
1200
+ but haven't yet fetched the keys for, returns the cross signing keys
1201
+ correctly.
1202
+ """
1203
+
1204
+ remote_user_id = "@test:other"
1205
+ local_user_id = "@test:test"
1206
+
1207
+ # Pretend we're sharing a room with the user we're querying. If not,
1208
+ # `_query_devices_for_destination` will return early.
1209
+ self.store.get_rooms_for_user = mock.AsyncMock(return_value={"some_room_id"})
1210
+
1211
+ remote_master_key = "85T7JXPFBAySB/jwby4S3lBPTqY3+Zg53nYuGmu1ggY"
1212
+ remote_self_signing_key = "QeIiFEjluPBtI7WQdG365QKZcFs9kqmHir6RBD0//nQ"
1213
+
1214
+ self.hs.get_federation_client().query_user_devices = mock.AsyncMock( # type: ignore[method-assign]
1215
+ return_value={
1216
+ "user_id": remote_user_id,
1217
+ "stream_id": 1,
1218
+ "devices": [],
1219
+ "master_key": {
1220
+ "user_id": remote_user_id,
1221
+ "usage": ["master"],
1222
+ "keys": {"ed25519:" + remote_master_key: remote_master_key},
1223
+ },
1224
+ "self_signing_key": {
1225
+ "user_id": remote_user_id,
1226
+ "usage": ["self_signing"],
1227
+ "keys": {
1228
+ "ed25519:" + remote_self_signing_key: remote_self_signing_key
1229
+ },
1230
+ },
1231
+ }
1232
+ )
1233
+
1234
+ e2e_handler = self.hs.get_e2e_keys_handler()
1235
+
1236
+ query_result = self.get_success(
1237
+ e2e_handler.query_devices(
1238
+ {
1239
+ "device_keys": {remote_user_id: []},
1240
+ },
1241
+ timeout=10,
1242
+ from_user_id=local_user_id,
1243
+ from_device_id="some_device_id",
1244
+ )
1245
+ )
1246
+
1247
+ self.assertEqual(query_result["failures"], {})
1248
+ self.assertEqual(
1249
+ query_result["master_keys"],
1250
+ {
1251
+ remote_user_id: {
1252
+ "user_id": remote_user_id,
1253
+ "usage": ["master"],
1254
+ "keys": {"ed25519:" + remote_master_key: remote_master_key},
1255
+ }
1256
+ },
1257
+ )
1258
+ self.assertEqual(
1259
+ query_result["self_signing_keys"],
1260
+ {
1261
+ remote_user_id: {
1262
+ "user_id": remote_user_id,
1263
+ "usage": ["self_signing"],
1264
+ "keys": {
1265
+ "ed25519:" + remote_self_signing_key: remote_self_signing_key
1266
+ },
1267
+ }
1268
+ },
1269
+ )
1270
+
1271
+ def test_query_devices_remote_down(self) -> None:
1272
+ """Tests that querying keys for a remote user on an unreachable server returns
1273
+ results in the "failures" property
1274
+ """
1275
+
1276
+ remote_user_id = "@test:other"
1277
+ local_user_id = "@test:test"
1278
+
1279
+ # The backoff code treats time zero as special
1280
+ self.reactor.advance(5)
1281
+
1282
+ self.hs.get_federation_http_client().agent.request = mock.AsyncMock( # type: ignore[method-assign]
1283
+ side_effect=Exception("boop")
1284
+ )
1285
+
1286
+ e2e_handler = self.hs.get_e2e_keys_handler()
1287
+
1288
+ query_result = self.get_success(
1289
+ e2e_handler.query_devices(
1290
+ {
1291
+ "device_keys": {remote_user_id: []},
1292
+ },
1293
+ timeout=10,
1294
+ from_user_id=local_user_id,
1295
+ from_device_id="some_device_id",
1296
+ )
1297
+ )
1298
+
1299
+ self.assertEqual(
1300
+ query_result["failures"],
1301
+ {
1302
+ "other": {
1303
+ "message": "Failed to send request: Exception: boop",
1304
+ "status": 503,
1305
+ }
1306
+ },
1307
+ )
1308
+
1309
+ # Do it again: we should hit the backoff
1310
+ query_result = self.get_success(
1311
+ e2e_handler.query_devices(
1312
+ {
1313
+ "device_keys": {remote_user_id: []},
1314
+ },
1315
+ timeout=10,
1316
+ from_user_id=local_user_id,
1317
+ from_device_id="some_device_id",
1318
+ )
1319
+ )
1320
+
1321
+ self.assertEqual(
1322
+ query_result["failures"],
1323
+ {"other": {"message": "Not ready for retry", "status": 503}},
1324
+ )
1325
+
1326
+ @parameterized.expand(
1327
+ [
1328
+ # The remote homeserver's response indicates that this user has 0/1/2 devices.
1329
+ ([],),
1330
+ (["device_1"],),
1331
+ (["device_1", "device_2"],),
1332
+ ]
1333
+ )
1334
+ def test_query_all_devices_caches_result(self, device_ids: Iterable[str]) -> None:
1335
+ """Test that requests for all of a remote user's devices are cached.
1336
+
1337
+ We do this by asserting that only one call over federation was made, and that
1338
+ the two queries to the local homeserver produce the same response.
1339
+ """
1340
+ local_user_id = "@test:test"
1341
+ remote_user_id = "@test:other"
1342
+ request_body: JsonDict = {"device_keys": {remote_user_id: []}}
1343
+
1344
+ response_devices = [
1345
+ {
1346
+ "device_id": device_id,
1347
+ "keys": {
1348
+ "algorithms": ["dummy"],
1349
+ "device_id": device_id,
1350
+ "keys": {f"dummy:{device_id}": "dummy"},
1351
+ "signatures": {device_id: {f"dummy:{device_id}": "dummy"}},
1352
+ "unsigned": {},
1353
+ "user_id": "@test:other",
1354
+ },
1355
+ }
1356
+ for device_id in device_ids
1357
+ ]
1358
+
1359
+ response_body = {
1360
+ "devices": response_devices,
1361
+ "user_id": remote_user_id,
1362
+ "stream_id": 12345, # an integer, according to the spec
1363
+ }
1364
+
1365
+ e2e_handler = self.hs.get_e2e_keys_handler()
1366
+
1367
+ # Pretend we're sharing a room with the user we're querying. If not,
1368
+ # `_query_devices_for_destination` will return early.
1369
+ mock_get_rooms = mock.patch.object(
1370
+ self.store,
1371
+ "get_rooms_for_user",
1372
+ new_callable=mock.AsyncMock,
1373
+ return_value=["some_room_id"],
1374
+ )
1375
+ mock_get_users = mock.patch.object(
1376
+ self.store,
1377
+ "get_users_server_still_shares_room_with",
1378
+ new_callable=mock.AsyncMock,
1379
+ return_value={remote_user_id},
1380
+ )
1381
+ mock_request = mock.patch.object(
1382
+ self.hs.get_federation_client(),
1383
+ "query_user_devices",
1384
+ new_callable=mock.AsyncMock,
1385
+ return_value=response_body,
1386
+ )
1387
+
1388
+ with mock_get_rooms, mock_get_users, mock_request as mocked_federation_request:
1389
+ # Make the first query and sanity check it succeeds.
1390
+ response_1 = self.get_success(
1391
+ e2e_handler.query_devices(
1392
+ request_body,
1393
+ timeout=10,
1394
+ from_user_id=local_user_id,
1395
+ from_device_id="some_device_id",
1396
+ )
1397
+ )
1398
+ self.assertEqual(response_1["failures"], {})
1399
+
1400
+ # We should have made a federation request to do so.
1401
+ mocked_federation_request.assert_called_once()
1402
+
1403
+ # Reset the mock so we can prove we don't make a second federation request.
1404
+ mocked_federation_request.reset_mock()
1405
+
1406
+ # Repeat the query.
1407
+ response_2 = self.get_success(
1408
+ e2e_handler.query_devices(
1409
+ request_body,
1410
+ timeout=10,
1411
+ from_user_id=local_user_id,
1412
+ from_device_id="some_device_id",
1413
+ )
1414
+ )
1415
+ self.assertEqual(response_2["failures"], {})
1416
+
1417
+ # We should not have made a second federation request.
1418
+ mocked_federation_request.assert_not_called()
1419
+
1420
+ # The two requests to the local homeserver should be identical.
1421
+ self.assertEqual(response_1, response_2)
1422
+
1423
+ @override_config({"experimental_features": {"msc3983_appservice_otk_claims": True}})
1424
+ def test_query_appservice(self) -> None:
1425
+ local_user = "@boris:" + self.hs.hostname
1426
+ device_id_1 = "xyz"
1427
+ fallback_key = {"alg1:k1": "fallback_key1"}
1428
+ device_id_2 = "abc"
1429
+ otk = {"alg1:k2": "key2"}
1430
+
1431
+ # Inject an appservice interested in this user.
1432
+ appservice = ApplicationService(
1433
+ token="i_am_an_app_service",
1434
+ id="1234",
1435
+ namespaces={"users": [{"regex": r"@boris:.+", "exclusive": True}]},
1436
+ # Note: this user does not have to match the regex above
1437
+ sender=UserID.from_string("@as_main:test"),
1438
+ )
1439
+ self.hs.get_datastores().main.services_cache = [appservice]
1440
+ self.hs.get_datastores().main.exclusive_user_regex = _make_exclusive_regex(
1441
+ [appservice]
1442
+ )
1443
+
1444
+ # Setup a response, but only for device 2.
1445
+ self.appservice_api.claim_client_keys.return_value = (
1446
+ {local_user: {device_id_2: otk}},
1447
+ [(local_user, device_id_1, "alg1", 1)],
1448
+ )
1449
+
1450
+ # we shouldn't have any unused fallback keys yet
1451
+ res = self.get_success(
1452
+ self.store.get_e2e_unused_fallback_key_types(local_user, device_id_1)
1453
+ )
1454
+ self.assertEqual(res, [])
1455
+
1456
+ self.get_success(
1457
+ self.handler.upload_keys_for_user(
1458
+ local_user,
1459
+ device_id_1,
1460
+ {"fallback_keys": fallback_key},
1461
+ )
1462
+ )
1463
+
1464
+ # we should now have an unused alg1 key
1465
+ fallback_res = self.get_success(
1466
+ self.store.get_e2e_unused_fallback_key_types(local_user, device_id_1)
1467
+ )
1468
+ self.assertEqual(fallback_res, ["alg1"])
1469
+
1470
+ # claiming an OTK when no OTKs are available should ask the appservice, then
1471
+ # query the fallback keys.
1472
+ claim_res = self.get_success(
1473
+ self.handler.claim_one_time_keys(
1474
+ {local_user: {device_id_1: {"alg1": 1}, device_id_2: {"alg1": 1}}},
1475
+ self.requester,
1476
+ timeout=None,
1477
+ always_include_fallback_keys=False,
1478
+ )
1479
+ )
1480
+ self.assertEqual(
1481
+ claim_res,
1482
+ {
1483
+ "failures": {},
1484
+ "one_time_keys": {
1485
+ local_user: {device_id_1: fallback_key, device_id_2: otk}
1486
+ },
1487
+ },
1488
+ )
1489
+
1490
+ @override_config({"experimental_features": {"msc3983_appservice_otk_claims": True}})
1491
+ def test_query_appservice_with_fallback(self) -> None:
1492
+ local_user = "@boris:" + self.hs.hostname
1493
+ device_id_1 = "xyz"
1494
+ fallback_key = {"alg1:k1": {"desc": "fallback_key1", "fallback": True}}
1495
+ otk = {"alg1:k2": {"desc": "key2"}}
1496
+ as_fallback_key = {"alg1:k3": {"desc": "fallback_key3", "fallback": True}}
1497
+ as_otk = {"alg1:k4": {"desc": "key4"}}
1498
+
1499
+ # Inject an appservice interested in this user.
1500
+ appservice = ApplicationService(
1501
+ token="i_am_an_app_service",
1502
+ id="1234",
1503
+ namespaces={"users": [{"regex": r"@boris:.+", "exclusive": True}]},
1504
+ # Note: this user does not have to match the regex above
1505
+ sender=UserID.from_string("@as_main:test"),
1506
+ )
1507
+ self.hs.get_datastores().main.services_cache = [appservice]
1508
+ self.hs.get_datastores().main.exclusive_user_regex = _make_exclusive_regex(
1509
+ [appservice]
1510
+ )
1511
+
1512
+ # Setup a response.
1513
+ response: dict[str, dict[str, dict[str, JsonDict]]] = {
1514
+ local_user: {device_id_1: {**as_otk, **as_fallback_key}}
1515
+ }
1516
+ self.appservice_api.claim_client_keys.return_value = (response, [])
1517
+
1518
+ # Claim OTKs, which will ask the appservice and do nothing else.
1519
+ claim_res = self.get_success(
1520
+ self.handler.claim_one_time_keys(
1521
+ {local_user: {device_id_1: {"alg1": 1}}},
1522
+ self.requester,
1523
+ timeout=None,
1524
+ always_include_fallback_keys=True,
1525
+ )
1526
+ )
1527
+ self.assertEqual(
1528
+ claim_res,
1529
+ {
1530
+ "failures": {},
1531
+ "one_time_keys": {
1532
+ local_user: {device_id_1: {**as_otk, **as_fallback_key}}
1533
+ },
1534
+ },
1535
+ )
1536
+
1537
+ # Now upload a fallback key.
1538
+ res = self.get_success(
1539
+ self.store.get_e2e_unused_fallback_key_types(local_user, device_id_1)
1540
+ )
1541
+ self.assertEqual(res, [])
1542
+
1543
+ self.get_success(
1544
+ self.handler.upload_keys_for_user(
1545
+ local_user,
1546
+ device_id_1,
1547
+ {"fallback_keys": fallback_key},
1548
+ )
1549
+ )
1550
+
1551
+ # we should now have an unused alg1 key
1552
+ fallback_res = self.get_success(
1553
+ self.store.get_e2e_unused_fallback_key_types(local_user, device_id_1)
1554
+ )
1555
+ self.assertEqual(fallback_res, ["alg1"])
1556
+
1557
+ # The appservice will return only the OTK.
1558
+ self.appservice_api.claim_client_keys.return_value = (
1559
+ {local_user: {device_id_1: as_otk}},
1560
+ [],
1561
+ )
1562
+
1563
+ # Claim OTKs, which should return the OTK from the appservice and the
1564
+ # uploaded fallback key.
1565
+ claim_res = self.get_success(
1566
+ self.handler.claim_one_time_keys(
1567
+ {local_user: {device_id_1: {"alg1": 1}}},
1568
+ self.requester,
1569
+ timeout=None,
1570
+ always_include_fallback_keys=True,
1571
+ )
1572
+ )
1573
+ self.assertEqual(
1574
+ claim_res,
1575
+ {
1576
+ "failures": {},
1577
+ "one_time_keys": {
1578
+ local_user: {device_id_1: {**as_otk, **fallback_key}}
1579
+ },
1580
+ },
1581
+ )
1582
+
1583
+ # But the fallback key should not be marked as used.
1584
+ fallback_res = self.get_success(
1585
+ self.store.get_e2e_unused_fallback_key_types(local_user, device_id_1)
1586
+ )
1587
+ self.assertEqual(fallback_res, ["alg1"])
1588
+
1589
+ # Now upload a OTK.
1590
+ self.get_success(
1591
+ self.handler.upload_keys_for_user(
1592
+ local_user,
1593
+ device_id_1,
1594
+ {"one_time_keys": otk},
1595
+ )
1596
+ )
1597
+
1598
+ # Claim OTKs, which will return information only from the database.
1599
+ claim_res = self.get_success(
1600
+ self.handler.claim_one_time_keys(
1601
+ {local_user: {device_id_1: {"alg1": 1}}},
1602
+ self.requester,
1603
+ timeout=None,
1604
+ always_include_fallback_keys=True,
1605
+ )
1606
+ )
1607
+ self.assertEqual(
1608
+ claim_res,
1609
+ {
1610
+ "failures": {},
1611
+ "one_time_keys": {local_user: {device_id_1: {**otk, **fallback_key}}},
1612
+ },
1613
+ )
1614
+
1615
+ # But the fallback key should not be marked as used.
1616
+ fallback_res = self.get_success(
1617
+ self.store.get_e2e_unused_fallback_key_types(local_user, device_id_1)
1618
+ )
1619
+ self.assertEqual(fallback_res, ["alg1"])
1620
+
1621
+ # Finally, return only the fallback key from the appservice.
1622
+ self.appservice_api.claim_client_keys.return_value = (
1623
+ {local_user: {device_id_1: as_fallback_key}},
1624
+ [],
1625
+ )
1626
+
1627
+ # Claim OTKs, which will return only the fallback key from the database.
1628
+ claim_res = self.get_success(
1629
+ self.handler.claim_one_time_keys(
1630
+ {local_user: {device_id_1: {"alg1": 1}}},
1631
+ self.requester,
1632
+ timeout=None,
1633
+ always_include_fallback_keys=True,
1634
+ )
1635
+ )
1636
+ self.assertEqual(
1637
+ claim_res,
1638
+ {
1639
+ "failures": {},
1640
+ "one_time_keys": {local_user: {device_id_1: as_fallback_key}},
1641
+ },
1642
+ )
1643
+
1644
+ @override_config({"experimental_features": {"msc3984_appservice_key_query": True}})
1645
+ def test_query_local_devices_appservice(self) -> None:
1646
+ """Test that querying of appservices for keys overrides responses from the database."""
1647
+ local_user = "@boris:" + self.hs.hostname
1648
+ device_1 = "abc"
1649
+ device_2 = "def"
1650
+ device_3 = "ghi"
1651
+
1652
+ # There are 3 devices:
1653
+ #
1654
+ # 1. One which is uploaded to the homeserver.
1655
+ # 2. One which is uploaded to the homeserver, but a newer copy is returned
1656
+ # by the appservice.
1657
+ # 3. One which is only returned by the appservice.
1658
+ device_key_1: JsonDict = {
1659
+ "user_id": local_user,
1660
+ "device_id": device_1,
1661
+ "algorithms": [
1662
+ "m.olm.curve25519-aes-sha2",
1663
+ RoomEncryptionAlgorithms.MEGOLM_V1_AES_SHA2,
1664
+ ],
1665
+ "keys": {
1666
+ "ed25519:abc": "base64+ed25519+key",
1667
+ "curve25519:abc": "base64+curve25519+key",
1668
+ },
1669
+ "signatures": {local_user: {"ed25519:abc": "base64+signature"}},
1670
+ }
1671
+ device_key_2a: JsonDict = {
1672
+ "user_id": local_user,
1673
+ "device_id": device_2,
1674
+ "algorithms": [
1675
+ "m.olm.curve25519-aes-sha2",
1676
+ RoomEncryptionAlgorithms.MEGOLM_V1_AES_SHA2,
1677
+ ],
1678
+ "keys": {
1679
+ "ed25519:def": "base64+ed25519+key",
1680
+ "curve25519:def": "base64+curve25519+key",
1681
+ },
1682
+ "signatures": {local_user: {"ed25519:def": "base64+signature"}},
1683
+ }
1684
+
1685
+ device_key_2b: JsonDict = {
1686
+ "user_id": local_user,
1687
+ "device_id": device_2,
1688
+ "algorithms": [
1689
+ "m.olm.curve25519-aes-sha2",
1690
+ RoomEncryptionAlgorithms.MEGOLM_V1_AES_SHA2,
1691
+ ],
1692
+ # The device ID is the same (above), but the keys are different.
1693
+ "keys": {
1694
+ "ed25519:xyz": "base64+ed25519+key",
1695
+ "curve25519:xyz": "base64+curve25519+key",
1696
+ },
1697
+ "signatures": {local_user: {"ed25519:xyz": "base64+signature"}},
1698
+ }
1699
+ device_key_3: JsonDict = {
1700
+ "user_id": local_user,
1701
+ "device_id": device_3,
1702
+ "algorithms": [
1703
+ "m.olm.curve25519-aes-sha2",
1704
+ RoomEncryptionAlgorithms.MEGOLM_V1_AES_SHA2,
1705
+ ],
1706
+ "keys": {
1707
+ "ed25519:jkl": "base64+ed25519+key",
1708
+ "curve25519:jkl": "base64+curve25519+key",
1709
+ },
1710
+ "signatures": {local_user: {"ed25519:jkl": "base64+signature"}},
1711
+ }
1712
+
1713
+ # Upload keys for devices 1 & 2a.
1714
+ self.get_success(
1715
+ self.handler.upload_keys_for_user(
1716
+ local_user, device_1, {"device_keys": device_key_1}
1717
+ )
1718
+ )
1719
+ self.get_success(
1720
+ self.handler.upload_keys_for_user(
1721
+ local_user, device_2, {"device_keys": device_key_2a}
1722
+ )
1723
+ )
1724
+
1725
+ # Inject an appservice interested in this user.
1726
+ appservice = ApplicationService(
1727
+ token="i_am_an_app_service",
1728
+ id="1234",
1729
+ namespaces={"users": [{"regex": r"@boris:.+", "exclusive": True}]},
1730
+ # Note: this user does not have to match the regex above
1731
+ sender=UserID.from_string("@as_main:test"),
1732
+ )
1733
+ self.hs.get_datastores().main.services_cache = [appservice]
1734
+ self.hs.get_datastores().main.exclusive_user_regex = _make_exclusive_regex(
1735
+ [appservice]
1736
+ )
1737
+
1738
+ # Setup a response.
1739
+ self.appservice_api.query_keys.return_value = {
1740
+ "device_keys": {
1741
+ local_user: {device_2: device_key_2b, device_3: device_key_3}
1742
+ }
1743
+ }
1744
+
1745
+ # Request all devices.
1746
+ res = self.get_success(self.handler.query_local_devices({local_user: None}))
1747
+ self.assertIn(local_user, res)
1748
+ for res_key in res[local_user].values():
1749
+ res_key.pop("unsigned", None)
1750
+ self.assertDictEqual(
1751
+ res,
1752
+ {
1753
+ local_user: {
1754
+ device_1: device_key_1,
1755
+ device_2: device_key_2b,
1756
+ device_3: device_key_3,
1757
+ }
1758
+ },
1759
+ )
1760
+
1761
+ def test_check_cross_signing_setup(self) -> None:
1762
+ # First check what happens with no master key.
1763
+ alice = "@alice:test"
1764
+ exists, replaceable_without_uia = self.get_success(
1765
+ self.handler.check_cross_signing_setup(alice)
1766
+ )
1767
+ self.assertIs(exists, False)
1768
+ self.assertIs(replaceable_without_uia, False)
1769
+
1770
+ # Upload a master key but don't specify a replacement timestamp.
1771
+ dummy_key = {"keys": {"a": "b"}}
1772
+ self.get_success(
1773
+ self.store.set_e2e_cross_signing_key("@alice:test", "master", dummy_key)
1774
+ )
1775
+
1776
+ # Should now find the key exists.
1777
+ exists, replaceable_without_uia = self.get_success(
1778
+ self.handler.check_cross_signing_setup(alice)
1779
+ )
1780
+ self.assertIs(exists, True)
1781
+ self.assertIs(replaceable_without_uia, False)
1782
+
1783
+ # Set an expiry timestamp in the future.
1784
+ self.get_success(
1785
+ self.store.allow_master_cross_signing_key_replacement_without_uia(
1786
+ alice,
1787
+ 1000,
1788
+ )
1789
+ )
1790
+
1791
+ # Should now be allowed to replace the key without UIA.
1792
+ exists, replaceable_without_uia = self.get_success(
1793
+ self.handler.check_cross_signing_setup(alice)
1794
+ )
1795
+ self.assertIs(exists, True)
1796
+ self.assertIs(replaceable_without_uia, True)
1797
+
1798
+ # Wait 2 seconds, so that the timestamp is in the past.
1799
+ self.reactor.advance(2.0)
1800
+
1801
+ # Should no longer be allowed to replace the key without UIA.
1802
+ exists, replaceable_without_uia = self.get_success(
1803
+ self.handler.check_cross_signing_setup(alice)
1804
+ )
1805
+ self.assertIs(exists, True)
1806
+ self.assertIs(replaceable_without_uia, False)
1807
+
1808
+ def test_delete_old_one_time_keys(self) -> None:
1809
+ """Test the db migration that clears out old OTKs"""
1810
+
1811
+ # We upload two sets of keys, one just over a week ago, and one just less than
1812
+ # a week ago. Each batch contains some keys that match the deletion pattern
1813
+ # (key IDs of 6 chars), and some that do not.
1814
+ #
1815
+ # Finally, set the scheduled task going, and check what gets deleted.
1816
+
1817
+ user_id = "@user000:" + self.hs.hostname
1818
+ device_id = "xyz"
1819
+
1820
+ # The scheduled task should be for "now" in real, wallclock time, so
1821
+ # set the test reactor to just over a week ago.
1822
+ self.reactor.advance(time.time() - 7.5 * 24 * 3600)
1823
+
1824
+ # Upload some keys
1825
+ self.get_success(
1826
+ self.handler.upload_keys_for_user(
1827
+ user_id,
1828
+ device_id,
1829
+ {
1830
+ "one_time_keys": {
1831
+ # some keys to delete
1832
+ "alg1:AAAAAA": "key1",
1833
+ "alg2:AAAAAB": {"key": "key2", "signatures": {"k1": "sig1"}},
1834
+ # A key to *not* delete
1835
+ "alg2:AAAAAAAAAA": {"key": "key3"},
1836
+ }
1837
+ },
1838
+ )
1839
+ )
1840
+
1841
+ # A day passes
1842
+ self.reactor.advance(24 * 3600)
1843
+
1844
+ # Upload some more keys
1845
+ self.get_success(
1846
+ self.handler.upload_keys_for_user(
1847
+ user_id,
1848
+ device_id,
1849
+ {
1850
+ "one_time_keys": {
1851
+ # some keys which match the pattern
1852
+ "alg1:BAAAAA": "key1",
1853
+ "alg2:BAAAAB": {"key": "key2", "signatures": {"k1": "sig1"}},
1854
+ # A key to *not* delete
1855
+ "alg2:BAAAAAAAAA": {"key": "key3"},
1856
+ }
1857
+ },
1858
+ )
1859
+ )
1860
+
1861
+ # The rest of the week passes, which should set the scheduled task going.
1862
+ self.reactor.advance(6.5 * 24 * 3600)
1863
+
1864
+ # Check what we're left with in the database
1865
+ remaining_key_ids = {
1866
+ row[0]
1867
+ for row in self.get_success(
1868
+ self.handler.store.db_pool.simple_select_list(
1869
+ "e2e_one_time_keys_json", None, ["key_id"]
1870
+ )
1871
+ )
1872
+ }
1873
+ self.assertEqual(
1874
+ remaining_key_ids, {"AAAAAAAAAA", "BAAAAA", "BAAAAB", "BAAAAAAAAA"}
1875
+ )
1876
+
1877
+ @override_config(
1878
+ {
1879
+ "experimental_features": {
1880
+ "msc4263_limit_key_queries_to_users_who_share_rooms": True
1881
+ }
1882
+ }
1883
+ )
1884
+ def test_query_devices_remote_restricted_not_in_shared_room(self) -> None:
1885
+ """Tests that querying keys for a remote user that we don't share a room
1886
+ with returns nothing.
1887
+ """
1888
+
1889
+ remote_user_id = "@test:other"
1890
+ local_user_id = "@test:test"
1891
+
1892
+ # Do *not* pretend we're sharing a room with the user we're querying.
1893
+
1894
+ remote_master_key = "85T7JXPFBAySB/jwby4S3lBPTqY3+Zg53nYuGmu1ggY"
1895
+ remote_self_signing_key = "QeIiFEjluPBtI7WQdG365QKZcFs9kqmHir6RBD0//nQ"
1896
+
1897
+ self.hs.get_federation_client().query_client_keys = mock.AsyncMock( # type: ignore[method-assign]
1898
+ return_value={
1899
+ "device_keys": {remote_user_id: {}},
1900
+ "master_keys": {
1901
+ remote_user_id: {
1902
+ "user_id": remote_user_id,
1903
+ "usage": ["master"],
1904
+ "keys": {"ed25519:" + remote_master_key: remote_master_key},
1905
+ },
1906
+ },
1907
+ "self_signing_keys": {
1908
+ remote_user_id: {
1909
+ "user_id": remote_user_id,
1910
+ "usage": ["self_signing"],
1911
+ "keys": {
1912
+ "ed25519:"
1913
+ + remote_self_signing_key: remote_self_signing_key
1914
+ },
1915
+ }
1916
+ },
1917
+ }
1918
+ )
1919
+
1920
+ e2e_handler = self.hs.get_e2e_keys_handler()
1921
+
1922
+ query_result = self.get_success(
1923
+ e2e_handler.query_devices(
1924
+ {
1925
+ "device_keys": {remote_user_id: []},
1926
+ },
1927
+ timeout=10,
1928
+ from_user_id=local_user_id,
1929
+ from_device_id="some_device_id",
1930
+ )
1931
+ )
1932
+
1933
+ self.assertEqual(
1934
+ query_result,
1935
+ {
1936
+ "device_keys": {},
1937
+ "failures": {},
1938
+ "master_keys": {},
1939
+ "self_signing_keys": {},
1940
+ "user_signing_keys": {},
1941
+ },
1942
+ )
1943
+
1944
+ @override_config(
1945
+ {
1946
+ "experimental_features": {
1947
+ "msc4263_limit_key_queries_to_users_who_share_rooms": True
1948
+ }
1949
+ }
1950
+ )
1951
+ def test_query_devices_remote_restricted_in_shared_room(self) -> None:
1952
+ """Tests that querying keys for a remote user that we share a room
1953
+ with returns the cross signing keys correctly.
1954
+ """
1955
+
1956
+ remote_user_id = "@test:other"
1957
+ local_user_id = "@test:test"
1958
+
1959
+ # Pretend we're sharing a room with the user we're querying. If not,
1960
+ # `query_devices` will filter out the user ID and `_query_devices_for_destination`
1961
+ # will return early.
1962
+ self.store.do_users_share_a_room_joined_or_invited = mock.AsyncMock( # type: ignore[method-assign]
1963
+ return_value=[remote_user_id]
1964
+ )
1965
+ self.store.get_rooms_for_user = mock.AsyncMock(return_value={"some_room_id"})
1966
+
1967
+ remote_master_key = "85T7JXPFBAySB/jwby4S3lBPTqY3+Zg53nYuGmu1ggY"
1968
+ remote_self_signing_key = "QeIiFEjluPBtI7WQdG365QKZcFs9kqmHir6RBD0//nQ"
1969
+
1970
+ self.hs.get_federation_client().query_user_devices = mock.AsyncMock( # type: ignore[method-assign]
1971
+ return_value={
1972
+ "user_id": remote_user_id,
1973
+ "stream_id": 1,
1974
+ "devices": [],
1975
+ "master_key": {
1976
+ "user_id": remote_user_id,
1977
+ "usage": ["master"],
1978
+ "keys": {"ed25519:" + remote_master_key: remote_master_key},
1979
+ },
1980
+ "self_signing_key": {
1981
+ "user_id": remote_user_id,
1982
+ "usage": ["self_signing"],
1983
+ "keys": {
1984
+ "ed25519:" + remote_self_signing_key: remote_self_signing_key
1985
+ },
1986
+ },
1987
+ }
1988
+ )
1989
+
1990
+ e2e_handler = self.hs.get_e2e_keys_handler()
1991
+
1992
+ query_result = self.get_success(
1993
+ e2e_handler.query_devices(
1994
+ {
1995
+ "device_keys": {remote_user_id: []},
1996
+ },
1997
+ timeout=10,
1998
+ from_user_id=local_user_id,
1999
+ from_device_id="some_device_id",
2000
+ )
2001
+ )
2002
+
2003
+ self.assertEqual(query_result["failures"], {})
2004
+ self.assertEqual(
2005
+ query_result["master_keys"],
2006
+ {
2007
+ remote_user_id: {
2008
+ "user_id": remote_user_id,
2009
+ "usage": ["master"],
2010
+ "keys": {"ed25519:" + remote_master_key: remote_master_key},
2011
+ }
2012
+ },
2013
+ )
2014
+ self.assertEqual(
2015
+ query_result["self_signing_keys"],
2016
+ {
2017
+ remote_user_id: {
2018
+ "user_id": remote_user_id,
2019
+ "usage": ["self_signing"],
2020
+ "keys": {
2021
+ "ed25519:" + remote_self_signing_key: remote_self_signing_key
2022
+ },
2023
+ }
2024
+ },
2025
+ )