matrix-synapse 1.143.0rc2__cp310-abi3-manylinux_2_28_aarch64.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- matrix_synapse-1.143.0rc2.dist-info/AUTHORS.rst +51 -0
- matrix_synapse-1.143.0rc2.dist-info/LICENSE-AGPL-3.0 +661 -0
- matrix_synapse-1.143.0rc2.dist-info/LICENSE-COMMERCIAL +6 -0
- matrix_synapse-1.143.0rc2.dist-info/METADATA +385 -0
- matrix_synapse-1.143.0rc2.dist-info/RECORD +1058 -0
- matrix_synapse-1.143.0rc2.dist-info/WHEEL +4 -0
- matrix_synapse-1.143.0rc2.dist-info/entry_points.txt +14 -0
- synapse/__init__.py +97 -0
- synapse/_scripts/__init__.py +0 -0
- synapse/_scripts/export_signing_key.py +109 -0
- synapse/_scripts/generate_config.py +83 -0
- synapse/_scripts/generate_log_config.py +56 -0
- synapse/_scripts/generate_signing_key.py +55 -0
- synapse/_scripts/generate_workers_map.py +318 -0
- synapse/_scripts/hash_password.py +95 -0
- synapse/_scripts/move_remote_media_to_new_store.py +128 -0
- synapse/_scripts/register_new_matrix_user.py +402 -0
- synapse/_scripts/review_recent_signups.py +212 -0
- synapse/_scripts/synapse_port_db.py +1604 -0
- synapse/_scripts/synctl.py +365 -0
- synapse/_scripts/update_synapse_database.py +130 -0
- synapse/api/__init__.py +20 -0
- synapse/api/auth/__init__.py +207 -0
- synapse/api/auth/base.py +406 -0
- synapse/api/auth/internal.py +299 -0
- synapse/api/auth/mas.py +436 -0
- synapse/api/auth/msc3861_delegated.py +617 -0
- synapse/api/auth_blocking.py +144 -0
- synapse/api/constants.py +362 -0
- synapse/api/errors.py +907 -0
- synapse/api/filtering.py +537 -0
- synapse/api/presence.py +102 -0
- synapse/api/ratelimiting.py +480 -0
- synapse/api/room_versions.py +535 -0
- synapse/api/urls.py +118 -0
- synapse/app/__init__.py +60 -0
- synapse/app/_base.py +862 -0
- synapse/app/admin_cmd.py +388 -0
- synapse/app/appservice.py +30 -0
- synapse/app/client_reader.py +30 -0
- synapse/app/complement_fork_starter.py +206 -0
- synapse/app/event_creator.py +29 -0
- synapse/app/federation_reader.py +30 -0
- synapse/app/federation_sender.py +30 -0
- synapse/app/frontend_proxy.py +30 -0
- synapse/app/generic_worker.py +474 -0
- synapse/app/homeserver.py +505 -0
- synapse/app/media_repository.py +30 -0
- synapse/app/phone_stats_home.py +296 -0
- synapse/app/pusher.py +30 -0
- synapse/app/synchrotron.py +30 -0
- synapse/app/user_dir.py +31 -0
- synapse/appservice/__init__.py +458 -0
- synapse/appservice/api.py +567 -0
- synapse/appservice/scheduler.py +564 -0
- synapse/config/__init__.py +27 -0
- synapse/config/__main__.py +62 -0
- synapse/config/_base.py +1106 -0
- synapse/config/_base.pyi +215 -0
- synapse/config/_util.py +99 -0
- synapse/config/account_validity.py +116 -0
- synapse/config/api.py +141 -0
- synapse/config/appservice.py +210 -0
- synapse/config/auth.py +80 -0
- synapse/config/auto_accept_invites.py +43 -0
- synapse/config/background_updates.py +44 -0
- synapse/config/cache.py +231 -0
- synapse/config/captcha.py +90 -0
- synapse/config/cas.py +116 -0
- synapse/config/consent.py +73 -0
- synapse/config/database.py +184 -0
- synapse/config/emailconfig.py +367 -0
- synapse/config/experimental.py +595 -0
- synapse/config/federation.py +114 -0
- synapse/config/homeserver.py +141 -0
- synapse/config/jwt.py +55 -0
- synapse/config/key.py +447 -0
- synapse/config/logger.py +390 -0
- synapse/config/mas.py +192 -0
- synapse/config/matrixrtc.py +66 -0
- synapse/config/metrics.py +84 -0
- synapse/config/modules.py +40 -0
- synapse/config/oembed.py +185 -0
- synapse/config/oidc.py +509 -0
- synapse/config/password_auth_providers.py +82 -0
- synapse/config/push.py +64 -0
- synapse/config/ratelimiting.py +254 -0
- synapse/config/redis.py +74 -0
- synapse/config/registration.py +296 -0
- synapse/config/repository.py +311 -0
- synapse/config/retention.py +162 -0
- synapse/config/room.py +88 -0
- synapse/config/room_directory.py +165 -0
- synapse/config/saml2.py +251 -0
- synapse/config/server.py +1170 -0
- synapse/config/server_notices.py +84 -0
- synapse/config/spam_checker.py +66 -0
- synapse/config/sso.py +121 -0
- synapse/config/stats.py +54 -0
- synapse/config/third_party_event_rules.py +40 -0
- synapse/config/tls.py +192 -0
- synapse/config/tracer.py +71 -0
- synapse/config/user_directory.py +47 -0
- synapse/config/user_types.py +42 -0
- synapse/config/voip.py +59 -0
- synapse/config/workers.py +642 -0
- synapse/crypto/__init__.py +20 -0
- synapse/crypto/context_factory.py +278 -0
- synapse/crypto/event_signing.py +194 -0
- synapse/crypto/keyring.py +931 -0
- synapse/event_auth.py +1266 -0
- synapse/events/__init__.py +667 -0
- synapse/events/auto_accept_invites.py +216 -0
- synapse/events/builder.py +387 -0
- synapse/events/presence_router.py +243 -0
- synapse/events/snapshot.py +559 -0
- synapse/events/utils.py +924 -0
- synapse/events/validator.py +305 -0
- synapse/federation/__init__.py +22 -0
- synapse/federation/federation_base.py +382 -0
- synapse/federation/federation_client.py +2132 -0
- synapse/federation/federation_server.py +1540 -0
- synapse/federation/persistence.py +70 -0
- synapse/federation/send_queue.py +531 -0
- synapse/federation/sender/__init__.py +1164 -0
- synapse/federation/sender/per_destination_queue.py +886 -0
- synapse/federation/sender/transaction_manager.py +210 -0
- synapse/federation/transport/__init__.py +28 -0
- synapse/federation/transport/client.py +1199 -0
- synapse/federation/transport/server/__init__.py +334 -0
- synapse/federation/transport/server/_base.py +429 -0
- synapse/federation/transport/server/federation.py +910 -0
- synapse/federation/units.py +133 -0
- synapse/handlers/__init__.py +20 -0
- synapse/handlers/account.py +162 -0
- synapse/handlers/account_data.py +360 -0
- synapse/handlers/account_validity.py +361 -0
- synapse/handlers/admin.py +615 -0
- synapse/handlers/appservice.py +989 -0
- synapse/handlers/auth.py +2481 -0
- synapse/handlers/cas.py +413 -0
- synapse/handlers/deactivate_account.py +363 -0
- synapse/handlers/delayed_events.py +599 -0
- synapse/handlers/device.py +1870 -0
- synapse/handlers/devicemessage.py +399 -0
- synapse/handlers/directory.py +545 -0
- synapse/handlers/e2e_keys.py +1834 -0
- synapse/handlers/e2e_room_keys.py +455 -0
- synapse/handlers/event_auth.py +390 -0
- synapse/handlers/events.py +201 -0
- synapse/handlers/federation.py +2039 -0
- synapse/handlers/federation_event.py +2419 -0
- synapse/handlers/identity.py +812 -0
- synapse/handlers/initial_sync.py +528 -0
- synapse/handlers/jwt.py +120 -0
- synapse/handlers/message.py +2347 -0
- synapse/handlers/oidc.py +1801 -0
- synapse/handlers/pagination.py +768 -0
- synapse/handlers/password_policy.py +102 -0
- synapse/handlers/presence.py +2633 -0
- synapse/handlers/profile.py +655 -0
- synapse/handlers/push_rules.py +164 -0
- synapse/handlers/read_marker.py +79 -0
- synapse/handlers/receipts.py +351 -0
- synapse/handlers/register.py +1059 -0
- synapse/handlers/relations.py +623 -0
- synapse/handlers/reports.py +98 -0
- synapse/handlers/room.py +2448 -0
- synapse/handlers/room_list.py +632 -0
- synapse/handlers/room_member.py +2365 -0
- synapse/handlers/room_member_worker.py +146 -0
- synapse/handlers/room_policy.py +186 -0
- synapse/handlers/room_summary.py +1057 -0
- synapse/handlers/saml.py +524 -0
- synapse/handlers/search.py +723 -0
- synapse/handlers/send_email.py +209 -0
- synapse/handlers/set_password.py +71 -0
- synapse/handlers/sliding_sync/__init__.py +1701 -0
- synapse/handlers/sliding_sync/extensions.py +969 -0
- synapse/handlers/sliding_sync/room_lists.py +2262 -0
- synapse/handlers/sliding_sync/store.py +128 -0
- synapse/handlers/sso.py +1291 -0
- synapse/handlers/state_deltas.py +82 -0
- synapse/handlers/stats.py +321 -0
- synapse/handlers/sync.py +3106 -0
- synapse/handlers/thread_subscriptions.py +190 -0
- synapse/handlers/typing.py +606 -0
- synapse/handlers/ui_auth/__init__.py +48 -0
- synapse/handlers/ui_auth/checkers.py +332 -0
- synapse/handlers/user_directory.py +783 -0
- synapse/handlers/worker_lock.py +371 -0
- synapse/http/__init__.py +105 -0
- synapse/http/additional_resource.py +62 -0
- synapse/http/client.py +1373 -0
- synapse/http/connectproxyclient.py +316 -0
- synapse/http/federation/__init__.py +19 -0
- synapse/http/federation/matrix_federation_agent.py +490 -0
- synapse/http/federation/srv_resolver.py +196 -0
- synapse/http/federation/well_known_resolver.py +367 -0
- synapse/http/matrixfederationclient.py +1873 -0
- synapse/http/proxy.py +290 -0
- synapse/http/proxyagent.py +497 -0
- synapse/http/replicationagent.py +202 -0
- synapse/http/request_metrics.py +309 -0
- synapse/http/server.py +1110 -0
- synapse/http/servlet.py +1018 -0
- synapse/http/site.py +825 -0
- synapse/http/types.py +27 -0
- synapse/logging/__init__.py +31 -0
- synapse/logging/_remote.py +261 -0
- synapse/logging/_terse_json.py +95 -0
- synapse/logging/context.py +1209 -0
- synapse/logging/formatter.py +62 -0
- synapse/logging/handlers.py +99 -0
- synapse/logging/loggers.py +25 -0
- synapse/logging/opentracing.py +1132 -0
- synapse/logging/scopecontextmanager.py +160 -0
- synapse/media/_base.py +830 -0
- synapse/media/filepath.py +417 -0
- synapse/media/media_repository.py +1580 -0
- synapse/media/media_storage.py +702 -0
- synapse/media/oembed.py +277 -0
- synapse/media/preview_html.py +556 -0
- synapse/media/storage_provider.py +195 -0
- synapse/media/thumbnailer.py +833 -0
- synapse/media/url_previewer.py +875 -0
- synapse/metrics/__init__.py +748 -0
- synapse/metrics/_gc.py +219 -0
- synapse/metrics/_reactor_metrics.py +171 -0
- synapse/metrics/_types.py +38 -0
- synapse/metrics/background_process_metrics.py +555 -0
- synapse/metrics/common_usage_metrics.py +94 -0
- synapse/metrics/jemalloc.py +248 -0
- synapse/module_api/__init__.py +2131 -0
- synapse/module_api/callbacks/__init__.py +50 -0
- synapse/module_api/callbacks/account_validity_callbacks.py +106 -0
- synapse/module_api/callbacks/media_repository_callbacks.py +157 -0
- synapse/module_api/callbacks/ratelimit_callbacks.py +78 -0
- synapse/module_api/callbacks/spamchecker_callbacks.py +991 -0
- synapse/module_api/callbacks/third_party_event_rules_callbacks.py +592 -0
- synapse/module_api/errors.py +42 -0
- synapse/notifier.py +970 -0
- synapse/push/__init__.py +212 -0
- synapse/push/bulk_push_rule_evaluator.py +635 -0
- synapse/push/clientformat.py +126 -0
- synapse/push/emailpusher.py +333 -0
- synapse/push/httppusher.py +564 -0
- synapse/push/mailer.py +1010 -0
- synapse/push/presentable_names.py +216 -0
- synapse/push/push_tools.py +114 -0
- synapse/push/push_types.py +141 -0
- synapse/push/pusher.py +87 -0
- synapse/push/pusherpool.py +501 -0
- synapse/push/rulekinds.py +33 -0
- synapse/py.typed +0 -0
- synapse/replication/__init__.py +20 -0
- synapse/replication/http/__init__.py +68 -0
- synapse/replication/http/_base.py +468 -0
- synapse/replication/http/account_data.py +297 -0
- synapse/replication/http/deactivate_account.py +81 -0
- synapse/replication/http/delayed_events.py +62 -0
- synapse/replication/http/devices.py +254 -0
- synapse/replication/http/federation.py +334 -0
- synapse/replication/http/login.py +106 -0
- synapse/replication/http/membership.py +364 -0
- synapse/replication/http/presence.py +133 -0
- synapse/replication/http/push.py +156 -0
- synapse/replication/http/register.py +172 -0
- synapse/replication/http/send_events.py +182 -0
- synapse/replication/http/state.py +82 -0
- synapse/replication/http/streams.py +101 -0
- synapse/replication/tcp/__init__.py +56 -0
- synapse/replication/tcp/client.py +552 -0
- synapse/replication/tcp/commands.py +569 -0
- synapse/replication/tcp/context.py +41 -0
- synapse/replication/tcp/external_cache.py +156 -0
- synapse/replication/tcp/handler.py +922 -0
- synapse/replication/tcp/protocol.py +608 -0
- synapse/replication/tcp/redis.py +509 -0
- synapse/replication/tcp/resource.py +348 -0
- synapse/replication/tcp/streams/__init__.py +96 -0
- synapse/replication/tcp/streams/_base.py +765 -0
- synapse/replication/tcp/streams/events.py +287 -0
- synapse/replication/tcp/streams/federation.py +92 -0
- synapse/replication/tcp/streams/partial_state.py +80 -0
- synapse/res/providers.json +29 -0
- synapse/res/templates/_base.html +29 -0
- synapse/res/templates/account_previously_renewed.html +6 -0
- synapse/res/templates/account_renewed.html +6 -0
- synapse/res/templates/add_threepid.html +8 -0
- synapse/res/templates/add_threepid.txt +6 -0
- synapse/res/templates/add_threepid_failure.html +7 -0
- synapse/res/templates/add_threepid_success.html +6 -0
- synapse/res/templates/already_in_use.html +12 -0
- synapse/res/templates/already_in_use.txt +10 -0
- synapse/res/templates/auth_success.html +21 -0
- synapse/res/templates/invalid_token.html +6 -0
- synapse/res/templates/mail-Element.css +7 -0
- synapse/res/templates/mail-Vector.css +7 -0
- synapse/res/templates/mail-expiry.css +4 -0
- synapse/res/templates/mail.css +156 -0
- synapse/res/templates/notice_expiry.html +46 -0
- synapse/res/templates/notice_expiry.txt +7 -0
- synapse/res/templates/notif.html +51 -0
- synapse/res/templates/notif.txt +22 -0
- synapse/res/templates/notif_mail.html +59 -0
- synapse/res/templates/notif_mail.txt +10 -0
- synapse/res/templates/password_reset.html +10 -0
- synapse/res/templates/password_reset.txt +7 -0
- synapse/res/templates/password_reset_confirmation.html +15 -0
- synapse/res/templates/password_reset_failure.html +7 -0
- synapse/res/templates/password_reset_success.html +6 -0
- synapse/res/templates/recaptcha.html +42 -0
- synapse/res/templates/registration.html +12 -0
- synapse/res/templates/registration.txt +10 -0
- synapse/res/templates/registration_failure.html +6 -0
- synapse/res/templates/registration_success.html +6 -0
- synapse/res/templates/registration_token.html +18 -0
- synapse/res/templates/room.html +33 -0
- synapse/res/templates/room.txt +9 -0
- synapse/res/templates/sso.css +129 -0
- synapse/res/templates/sso_account_deactivated.html +25 -0
- synapse/res/templates/sso_auth_account_details.html +186 -0
- synapse/res/templates/sso_auth_account_details.js +116 -0
- synapse/res/templates/sso_auth_bad_user.html +26 -0
- synapse/res/templates/sso_auth_confirm.html +27 -0
- synapse/res/templates/sso_auth_success.html +26 -0
- synapse/res/templates/sso_error.html +71 -0
- synapse/res/templates/sso_footer.html +19 -0
- synapse/res/templates/sso_login_idp_picker.html +60 -0
- synapse/res/templates/sso_new_user_consent.html +30 -0
- synapse/res/templates/sso_partial_profile.html +19 -0
- synapse/res/templates/sso_redirect_confirm.html +39 -0
- synapse/res/templates/style.css +33 -0
- synapse/res/templates/terms.html +27 -0
- synapse/rest/__init__.py +197 -0
- synapse/rest/admin/__init__.py +390 -0
- synapse/rest/admin/_base.py +72 -0
- synapse/rest/admin/background_updates.py +171 -0
- synapse/rest/admin/devices.py +221 -0
- synapse/rest/admin/event_reports.py +173 -0
- synapse/rest/admin/events.py +69 -0
- synapse/rest/admin/experimental_features.py +137 -0
- synapse/rest/admin/federation.py +243 -0
- synapse/rest/admin/media.py +540 -0
- synapse/rest/admin/registration_tokens.py +358 -0
- synapse/rest/admin/rooms.py +1061 -0
- synapse/rest/admin/scheduled_tasks.py +70 -0
- synapse/rest/admin/server_notice_servlet.py +132 -0
- synapse/rest/admin/statistics.py +132 -0
- synapse/rest/admin/username_available.py +58 -0
- synapse/rest/admin/users.py +1606 -0
- synapse/rest/client/__init__.py +20 -0
- synapse/rest/client/_base.py +113 -0
- synapse/rest/client/account.py +930 -0
- synapse/rest/client/account_data.py +319 -0
- synapse/rest/client/account_validity.py +103 -0
- synapse/rest/client/appservice_ping.py +125 -0
- synapse/rest/client/auth.py +218 -0
- synapse/rest/client/auth_metadata.py +122 -0
- synapse/rest/client/capabilities.py +121 -0
- synapse/rest/client/delayed_events.py +165 -0
- synapse/rest/client/devices.py +587 -0
- synapse/rest/client/directory.py +211 -0
- synapse/rest/client/events.py +116 -0
- synapse/rest/client/filter.py +112 -0
- synapse/rest/client/initial_sync.py +65 -0
- synapse/rest/client/keys.py +678 -0
- synapse/rest/client/knock.py +104 -0
- synapse/rest/client/login.py +750 -0
- synapse/rest/client/login_token_request.py +127 -0
- synapse/rest/client/logout.py +93 -0
- synapse/rest/client/matrixrtc.py +52 -0
- synapse/rest/client/media.py +285 -0
- synapse/rest/client/mutual_rooms.py +93 -0
- synapse/rest/client/notifications.py +137 -0
- synapse/rest/client/openid.py +109 -0
- synapse/rest/client/password_policy.py +69 -0
- synapse/rest/client/presence.py +131 -0
- synapse/rest/client/profile.py +291 -0
- synapse/rest/client/push_rule.py +331 -0
- synapse/rest/client/pusher.py +181 -0
- synapse/rest/client/read_marker.py +104 -0
- synapse/rest/client/receipts.py +165 -0
- synapse/rest/client/register.py +1067 -0
- synapse/rest/client/relations.py +138 -0
- synapse/rest/client/rendezvous.py +76 -0
- synapse/rest/client/reporting.py +207 -0
- synapse/rest/client/room.py +1669 -0
- synapse/rest/client/room_keys.py +426 -0
- synapse/rest/client/room_upgrade_rest_servlet.py +112 -0
- synapse/rest/client/sendtodevice.py +85 -0
- synapse/rest/client/sync.py +1131 -0
- synapse/rest/client/tags.py +129 -0
- synapse/rest/client/thirdparty.py +130 -0
- synapse/rest/client/thread_subscriptions.py +247 -0
- synapse/rest/client/tokenrefresh.py +52 -0
- synapse/rest/client/transactions.py +149 -0
- synapse/rest/client/user_directory.py +90 -0
- synapse/rest/client/versions.py +191 -0
- synapse/rest/client/voip.py +88 -0
- synapse/rest/consent/__init__.py +0 -0
- synapse/rest/consent/consent_resource.py +210 -0
- synapse/rest/health.py +38 -0
- synapse/rest/key/__init__.py +20 -0
- synapse/rest/key/v2/__init__.py +40 -0
- synapse/rest/key/v2/local_key_resource.py +125 -0
- synapse/rest/key/v2/remote_key_resource.py +302 -0
- synapse/rest/media/__init__.py +0 -0
- synapse/rest/media/config_resource.py +53 -0
- synapse/rest/media/create_resource.py +90 -0
- synapse/rest/media/download_resource.py +110 -0
- synapse/rest/media/media_repository_resource.py +113 -0
- synapse/rest/media/preview_url_resource.py +77 -0
- synapse/rest/media/thumbnail_resource.py +142 -0
- synapse/rest/media/upload_resource.py +187 -0
- synapse/rest/media/v1/__init__.py +39 -0
- synapse/rest/media/v1/_base.py +23 -0
- synapse/rest/media/v1/media_storage.py +23 -0
- synapse/rest/media/v1/storage_provider.py +23 -0
- synapse/rest/synapse/__init__.py +20 -0
- synapse/rest/synapse/client/__init__.py +93 -0
- synapse/rest/synapse/client/federation_whitelist.py +66 -0
- synapse/rest/synapse/client/jwks.py +77 -0
- synapse/rest/synapse/client/new_user_consent.py +115 -0
- synapse/rest/synapse/client/oidc/__init__.py +45 -0
- synapse/rest/synapse/client/oidc/backchannel_logout_resource.py +42 -0
- synapse/rest/synapse/client/oidc/callback_resource.py +48 -0
- synapse/rest/synapse/client/password_reset.py +129 -0
- synapse/rest/synapse/client/pick_idp.py +107 -0
- synapse/rest/synapse/client/pick_username.py +153 -0
- synapse/rest/synapse/client/rendezvous.py +58 -0
- synapse/rest/synapse/client/saml2/__init__.py +42 -0
- synapse/rest/synapse/client/saml2/metadata_resource.py +46 -0
- synapse/rest/synapse/client/saml2/response_resource.py +52 -0
- synapse/rest/synapse/client/sso_register.py +56 -0
- synapse/rest/synapse/client/unsubscribe.py +88 -0
- synapse/rest/synapse/mas/__init__.py +71 -0
- synapse/rest/synapse/mas/_base.py +55 -0
- synapse/rest/synapse/mas/devices.py +239 -0
- synapse/rest/synapse/mas/users.py +469 -0
- synapse/rest/well_known.py +148 -0
- synapse/server.py +1257 -0
- synapse/server_notices/__init__.py +0 -0
- synapse/server_notices/consent_server_notices.py +136 -0
- synapse/server_notices/resource_limits_server_notices.py +215 -0
- synapse/server_notices/server_notices_manager.py +388 -0
- synapse/server_notices/server_notices_sender.py +67 -0
- synapse/server_notices/worker_server_notices_sender.py +46 -0
- synapse/spam_checker_api/__init__.py +31 -0
- synapse/state/__init__.py +1022 -0
- synapse/state/v1.py +369 -0
- synapse/state/v2.py +984 -0
- synapse/static/client/login/index.html +47 -0
- synapse/static/client/login/js/jquery-3.4.1.min.js +2 -0
- synapse/static/client/login/js/login.js +291 -0
- synapse/static/client/login/spinner.gif +0 -0
- synapse/static/client/login/style.css +79 -0
- synapse/static/index.html +63 -0
- synapse/storage/__init__.py +43 -0
- synapse/storage/_base.py +245 -0
- synapse/storage/admin_client_config.py +25 -0
- synapse/storage/background_updates.py +1188 -0
- synapse/storage/controllers/__init__.py +57 -0
- synapse/storage/controllers/persist_events.py +1237 -0
- synapse/storage/controllers/purge_events.py +455 -0
- synapse/storage/controllers/state.py +950 -0
- synapse/storage/controllers/stats.py +119 -0
- synapse/storage/database.py +2719 -0
- synapse/storage/databases/__init__.py +175 -0
- synapse/storage/databases/main/__init__.py +420 -0
- synapse/storage/databases/main/account_data.py +1059 -0
- synapse/storage/databases/main/appservice.py +473 -0
- synapse/storage/databases/main/cache.py +911 -0
- synapse/storage/databases/main/censor_events.py +225 -0
- synapse/storage/databases/main/client_ips.py +815 -0
- synapse/storage/databases/main/delayed_events.py +562 -0
- synapse/storage/databases/main/deviceinbox.py +1271 -0
- synapse/storage/databases/main/devices.py +2578 -0
- synapse/storage/databases/main/directory.py +212 -0
- synapse/storage/databases/main/e2e_room_keys.py +689 -0
- synapse/storage/databases/main/end_to_end_keys.py +1894 -0
- synapse/storage/databases/main/event_federation.py +2508 -0
- synapse/storage/databases/main/event_push_actions.py +1933 -0
- synapse/storage/databases/main/events.py +3765 -0
- synapse/storage/databases/main/events_bg_updates.py +2910 -0
- synapse/storage/databases/main/events_forward_extremities.py +126 -0
- synapse/storage/databases/main/events_worker.py +2786 -0
- synapse/storage/databases/main/experimental_features.py +130 -0
- synapse/storage/databases/main/filtering.py +231 -0
- synapse/storage/databases/main/keys.py +291 -0
- synapse/storage/databases/main/lock.py +553 -0
- synapse/storage/databases/main/media_repository.py +1068 -0
- synapse/storage/databases/main/metrics.py +460 -0
- synapse/storage/databases/main/monthly_active_users.py +443 -0
- synapse/storage/databases/main/openid.py +60 -0
- synapse/storage/databases/main/presence.py +509 -0
- synapse/storage/databases/main/profile.py +539 -0
- synapse/storage/databases/main/purge_events.py +521 -0
- synapse/storage/databases/main/push_rule.py +970 -0
- synapse/storage/databases/main/pusher.py +793 -0
- synapse/storage/databases/main/receipts.py +1341 -0
- synapse/storage/databases/main/registration.py +3072 -0
- synapse/storage/databases/main/rejections.py +37 -0
- synapse/storage/databases/main/relations.py +1116 -0
- synapse/storage/databases/main/room.py +2779 -0
- synapse/storage/databases/main/roommember.py +2110 -0
- synapse/storage/databases/main/search.py +939 -0
- synapse/storage/databases/main/session.py +151 -0
- synapse/storage/databases/main/signatures.py +94 -0
- synapse/storage/databases/main/sliding_sync.py +603 -0
- synapse/storage/databases/main/state.py +1002 -0
- synapse/storage/databases/main/state_deltas.py +329 -0
- synapse/storage/databases/main/stats.py +789 -0
- synapse/storage/databases/main/stream.py +2577 -0
- synapse/storage/databases/main/tags.py +360 -0
- synapse/storage/databases/main/task_scheduler.py +225 -0
- synapse/storage/databases/main/thread_subscriptions.py +589 -0
- synapse/storage/databases/main/transactions.py +675 -0
- synapse/storage/databases/main/ui_auth.py +420 -0
- synapse/storage/databases/main/user_directory.py +1330 -0
- synapse/storage/databases/main/user_erasure_store.py +117 -0
- synapse/storage/databases/state/__init__.py +22 -0
- synapse/storage/databases/state/bg_updates.py +497 -0
- synapse/storage/databases/state/deletion.py +557 -0
- synapse/storage/databases/state/store.py +948 -0
- synapse/storage/engines/__init__.py +70 -0
- synapse/storage/engines/_base.py +154 -0
- synapse/storage/engines/postgres.py +261 -0
- synapse/storage/engines/sqlite.py +199 -0
- synapse/storage/invite_rule.py +112 -0
- synapse/storage/keys.py +40 -0
- synapse/storage/prepare_database.py +730 -0
- synapse/storage/push_rule.py +28 -0
- synapse/storage/roommember.py +88 -0
- synapse/storage/schema/README.md +4 -0
- synapse/storage/schema/__init__.py +186 -0
- synapse/storage/schema/common/delta/25/00background_updates.sql +40 -0
- synapse/storage/schema/common/delta/35/00background_updates_add_col.sql +36 -0
- synapse/storage/schema/common/delta/58/00background_update_ordering.sql +38 -0
- synapse/storage/schema/common/full_schemas/72/full.sql.postgres +8 -0
- synapse/storage/schema/common/full_schemas/72/full.sql.sqlite +6 -0
- synapse/storage/schema/common/schema_version.sql +60 -0
- synapse/storage/schema/main/delta/12/v12.sql +82 -0
- synapse/storage/schema/main/delta/13/v13.sql +38 -0
- synapse/storage/schema/main/delta/14/v14.sql +42 -0
- synapse/storage/schema/main/delta/15/appservice_txns.sql +50 -0
- synapse/storage/schema/main/delta/15/presence_indices.sql +2 -0
- synapse/storage/schema/main/delta/15/v15.sql +24 -0
- synapse/storage/schema/main/delta/16/events_order_index.sql +4 -0
- synapse/storage/schema/main/delta/16/remote_media_cache_index.sql +2 -0
- synapse/storage/schema/main/delta/16/remove_duplicates.sql +9 -0
- synapse/storage/schema/main/delta/16/room_alias_index.sql +3 -0
- synapse/storage/schema/main/delta/16/unique_constraints.sql +72 -0
- synapse/storage/schema/main/delta/16/users.sql +56 -0
- synapse/storage/schema/main/delta/17/drop_indexes.sql +37 -0
- synapse/storage/schema/main/delta/17/server_keys.sql +43 -0
- synapse/storage/schema/main/delta/17/user_threepids.sql +9 -0
- synapse/storage/schema/main/delta/18/server_keys_bigger_ints.sql +51 -0
- synapse/storage/schema/main/delta/19/event_index.sql +38 -0
- synapse/storage/schema/main/delta/20/dummy.sql +1 -0
- synapse/storage/schema/main/delta/20/pushers.py +93 -0
- synapse/storage/schema/main/delta/21/end_to_end_keys.sql +53 -0
- synapse/storage/schema/main/delta/21/receipts.sql +57 -0
- synapse/storage/schema/main/delta/22/receipts_index.sql +41 -0
- synapse/storage/schema/main/delta/22/user_threepids_unique.sql +19 -0
- synapse/storage/schema/main/delta/24/stats_reporting.sql +37 -0
- synapse/storage/schema/main/delta/25/fts.py +81 -0
- synapse/storage/schema/main/delta/25/guest_access.sql +44 -0
- synapse/storage/schema/main/delta/25/history_visibility.sql +44 -0
- synapse/storage/schema/main/delta/25/tags.sql +57 -0
- synapse/storage/schema/main/delta/26/account_data.sql +36 -0
- synapse/storage/schema/main/delta/27/account_data.sql +55 -0
- synapse/storage/schema/main/delta/27/forgotten_memberships.sql +45 -0
- synapse/storage/schema/main/delta/27/ts.py +61 -0
- synapse/storage/schema/main/delta/28/event_push_actions.sql +46 -0
- synapse/storage/schema/main/delta/28/events_room_stream.sql +39 -0
- synapse/storage/schema/main/delta/28/public_roms_index.sql +39 -0
- synapse/storage/schema/main/delta/28/receipts_user_id_index.sql +41 -0
- synapse/storage/schema/main/delta/28/upgrade_times.sql +40 -0
- synapse/storage/schema/main/delta/28/users_is_guest.sql +41 -0
- synapse/storage/schema/main/delta/29/push_actions.sql +54 -0
- synapse/storage/schema/main/delta/30/alias_creator.sql +35 -0
- synapse/storage/schema/main/delta/30/as_users.py +82 -0
- synapse/storage/schema/main/delta/30/deleted_pushers.sql +44 -0
- synapse/storage/schema/main/delta/30/presence_stream.sql +49 -0
- synapse/storage/schema/main/delta/30/public_rooms.sql +42 -0
- synapse/storage/schema/main/delta/30/push_rule_stream.sql +57 -0
- synapse/storage/schema/main/delta/30/threepid_guest_access_tokens.sql +43 -0
- synapse/storage/schema/main/delta/31/invites.sql +61 -0
- synapse/storage/schema/main/delta/31/local_media_repository_url_cache.sql +46 -0
- synapse/storage/schema/main/delta/31/pushers_0.py +92 -0
- synapse/storage/schema/main/delta/31/pushers_index.sql +41 -0
- synapse/storage/schema/main/delta/31/search_update.py +65 -0
- synapse/storage/schema/main/delta/32/events.sql +35 -0
- synapse/storage/schema/main/delta/32/openid.sql +9 -0
- synapse/storage/schema/main/delta/32/pusher_throttle.sql +42 -0
- synapse/storage/schema/main/delta/32/remove_indices.sql +52 -0
- synapse/storage/schema/main/delta/32/reports.sql +44 -0
- synapse/storage/schema/main/delta/33/access_tokens_device_index.sql +36 -0
- synapse/storage/schema/main/delta/33/devices.sql +40 -0
- synapse/storage/schema/main/delta/33/devices_for_e2e_keys.sql +38 -0
- synapse/storage/schema/main/delta/33/devices_for_e2e_keys_clear_unknown_device.sql +39 -0
- synapse/storage/schema/main/delta/33/event_fields.py +61 -0
- synapse/storage/schema/main/delta/33/remote_media_ts.py +43 -0
- synapse/storage/schema/main/delta/33/user_ips_index.sql +36 -0
- synapse/storage/schema/main/delta/34/appservice_stream.sql +42 -0
- synapse/storage/schema/main/delta/34/cache_stream.py +50 -0
- synapse/storage/schema/main/delta/34/device_inbox.sql +43 -0
- synapse/storage/schema/main/delta/34/push_display_name_rename.sql +39 -0
- synapse/storage/schema/main/delta/34/received_txn_purge.py +36 -0
- synapse/storage/schema/main/delta/35/contains_url.sql +36 -0
- synapse/storage/schema/main/delta/35/device_outbox.sql +58 -0
- synapse/storage/schema/main/delta/35/device_stream_id.sql +40 -0
- synapse/storage/schema/main/delta/35/event_push_actions_index.sql +36 -0
- synapse/storage/schema/main/delta/35/public_room_list_change_stream.sql +52 -0
- synapse/storage/schema/main/delta/35/stream_order_to_extrem.sql +56 -0
- synapse/storage/schema/main/delta/36/readd_public_rooms.sql +45 -0
- synapse/storage/schema/main/delta/37/remove_auth_idx.py +89 -0
- synapse/storage/schema/main/delta/37/user_threepids.sql +71 -0
- synapse/storage/schema/main/delta/38/postgres_fts_gist.sql +38 -0
- synapse/storage/schema/main/delta/39/appservice_room_list.sql +48 -0
- synapse/storage/schema/main/delta/39/device_federation_stream_idx.sql +35 -0
- synapse/storage/schema/main/delta/39/event_push_index.sql +36 -0
- synapse/storage/schema/main/delta/39/federation_out_position.sql +41 -0
- synapse/storage/schema/main/delta/39/membership_profile.sql +39 -0
- synapse/storage/schema/main/delta/40/current_state_idx.sql +36 -0
- synapse/storage/schema/main/delta/40/device_inbox.sql +40 -0
- synapse/storage/schema/main/delta/40/device_list_streams.sql +79 -0
- synapse/storage/schema/main/delta/40/event_push_summary.sql +57 -0
- synapse/storage/schema/main/delta/40/pushers.sql +58 -0
- synapse/storage/schema/main/delta/41/device_list_stream_idx.sql +36 -0
- synapse/storage/schema/main/delta/41/device_outbound_index.sql +35 -0
- synapse/storage/schema/main/delta/41/event_search_event_id_idx.sql +36 -0
- synapse/storage/schema/main/delta/41/ratelimit.sql +41 -0
- synapse/storage/schema/main/delta/42/current_state_delta.sql +48 -0
- synapse/storage/schema/main/delta/42/device_list_last_id.sql +52 -0
- synapse/storage/schema/main/delta/42/event_auth_state_only.sql +36 -0
- synapse/storage/schema/main/delta/42/user_dir.py +88 -0
- synapse/storage/schema/main/delta/43/blocked_rooms.sql +40 -0
- synapse/storage/schema/main/delta/43/quarantine_media.sql +36 -0
- synapse/storage/schema/main/delta/43/url_cache.sql +35 -0
- synapse/storage/schema/main/delta/43/user_share.sql +52 -0
- synapse/storage/schema/main/delta/44/expire_url_cache.sql +60 -0
- synapse/storage/schema/main/delta/45/group_server.sql +186 -0
- synapse/storage/schema/main/delta/45/profile_cache.sql +47 -0
- synapse/storage/schema/main/delta/46/drop_refresh_tokens.sql +36 -0
- synapse/storage/schema/main/delta/46/drop_unique_deleted_pushers.sql +54 -0
- synapse/storage/schema/main/delta/46/group_server.sql +51 -0
- synapse/storage/schema/main/delta/46/local_media_repository_url_idx.sql +43 -0
- synapse/storage/schema/main/delta/46/user_dir_null_room_ids.sql +54 -0
- synapse/storage/schema/main/delta/46/user_dir_typos.sql +43 -0
- synapse/storage/schema/main/delta/47/last_access_media.sql +35 -0
- synapse/storage/schema/main/delta/47/postgres_fts_gin.sql +36 -0
- synapse/storage/schema/main/delta/47/push_actions_staging.sql +47 -0
- synapse/storage/schema/main/delta/48/add_user_consent.sql +37 -0
- synapse/storage/schema/main/delta/48/add_user_ips_last_seen_index.sql +36 -0
- synapse/storage/schema/main/delta/48/deactivated_users.sql +44 -0
- synapse/storage/schema/main/delta/48/group_unique_indexes.py +67 -0
- synapse/storage/schema/main/delta/48/groups_joinable.sql +41 -0
- synapse/storage/schema/main/delta/49/add_user_consent_server_notice_sent.sql +39 -0
- synapse/storage/schema/main/delta/49/add_user_daily_visits.sql +40 -0
- synapse/storage/schema/main/delta/49/add_user_ips_last_seen_only_index.sql +36 -0
- synapse/storage/schema/main/delta/50/add_creation_ts_users_index.sql +38 -0
- synapse/storage/schema/main/delta/50/erasure_store.sql +40 -0
- synapse/storage/schema/main/delta/50/make_event_content_nullable.py +102 -0
- synapse/storage/schema/main/delta/51/e2e_room_keys.sql +58 -0
- synapse/storage/schema/main/delta/51/monthly_active_users.sql +46 -0
- synapse/storage/schema/main/delta/52/add_event_to_state_group_index.sql +38 -0
- synapse/storage/schema/main/delta/52/device_list_streams_unique_idx.sql +55 -0
- synapse/storage/schema/main/delta/52/e2e_room_keys.sql +72 -0
- synapse/storage/schema/main/delta/53/add_user_type_to_users.sql +38 -0
- synapse/storage/schema/main/delta/53/drop_sent_transactions.sql +35 -0
- synapse/storage/schema/main/delta/53/event_format_version.sql +35 -0
- synapse/storage/schema/main/delta/53/user_dir_populate.sql +49 -0
- synapse/storage/schema/main/delta/53/user_ips_index.sql +49 -0
- synapse/storage/schema/main/delta/53/user_share.sql +63 -0
- synapse/storage/schema/main/delta/53/user_threepid_id.sql +48 -0
- synapse/storage/schema/main/delta/53/users_in_public_rooms.sql +47 -0
- synapse/storage/schema/main/delta/54/account_validity_with_renewal.sql +49 -0
- synapse/storage/schema/main/delta/54/add_validity_to_server_keys.sql +42 -0
- synapse/storage/schema/main/delta/54/delete_forward_extremities.sql +42 -0
- synapse/storage/schema/main/delta/54/drop_legacy_tables.sql +49 -0
- synapse/storage/schema/main/delta/54/drop_presence_list.sql +35 -0
- synapse/storage/schema/main/delta/54/relations.sql +46 -0
- synapse/storage/schema/main/delta/54/stats.sql +99 -0
- synapse/storage/schema/main/delta/54/stats2.sql +47 -0
- synapse/storage/schema/main/delta/55/access_token_expiry.sql +37 -0
- synapse/storage/schema/main/delta/55/track_threepid_validations.sql +50 -0
- synapse/storage/schema/main/delta/55/users_alter_deactivated.sql +38 -0
- synapse/storage/schema/main/delta/56/add_spans_to_device_lists.sql +39 -0
- synapse/storage/schema/main/delta/56/current_state_events_membership.sql +41 -0
- synapse/storage/schema/main/delta/56/current_state_events_membership_mk2.sql +43 -0
- synapse/storage/schema/main/delta/56/delete_keys_from_deleted_backups.sql +44 -0
- synapse/storage/schema/main/delta/56/destinations_failure_ts.sql +44 -0
- synapse/storage/schema/main/delta/56/destinations_retry_interval_type.sql.postgres +18 -0
- synapse/storage/schema/main/delta/56/device_stream_id_insert.sql +39 -0
- synapse/storage/schema/main/delta/56/devices_last_seen.sql +43 -0
- synapse/storage/schema/main/delta/56/drop_unused_event_tables.sql +39 -0
- synapse/storage/schema/main/delta/56/event_expiry.sql +40 -0
- synapse/storage/schema/main/delta/56/event_labels.sql +49 -0
- synapse/storage/schema/main/delta/56/event_labels_background_update.sql +36 -0
- synapse/storage/schema/main/delta/56/fix_room_keys_index.sql +37 -0
- synapse/storage/schema/main/delta/56/hidden_devices.sql +37 -0
- synapse/storage/schema/main/delta/56/hidden_devices_fix.sql.sqlite +42 -0
- synapse/storage/schema/main/delta/56/nuke_empty_communities_from_db.sql +48 -0
- synapse/storage/schema/main/delta/56/public_room_list_idx.sql +35 -0
- synapse/storage/schema/main/delta/56/redaction_censor.sql +35 -0
- synapse/storage/schema/main/delta/56/redaction_censor2.sql +41 -0
- synapse/storage/schema/main/delta/56/redaction_censor3_fix_update.sql.postgres +25 -0
- synapse/storage/schema/main/delta/56/redaction_censor4.sql +35 -0
- synapse/storage/schema/main/delta/56/remove_tombstoned_rooms_from_directory.sql +38 -0
- synapse/storage/schema/main/delta/56/room_key_etag.sql +36 -0
- synapse/storage/schema/main/delta/56/room_membership_idx.sql +37 -0
- synapse/storage/schema/main/delta/56/room_retention.sql +52 -0
- synapse/storage/schema/main/delta/56/signing_keys.sql +75 -0
- synapse/storage/schema/main/delta/56/signing_keys_nonunique_signatures.sql +41 -0
- synapse/storage/schema/main/delta/56/stats_separated.sql +175 -0
- synapse/storage/schema/main/delta/56/unique_user_filter_index.py +46 -0
- synapse/storage/schema/main/delta/56/user_external_ids.sql +43 -0
- synapse/storage/schema/main/delta/56/users_in_public_rooms_idx.sql +36 -0
- synapse/storage/schema/main/delta/57/delete_old_current_state_events.sql +41 -0
- synapse/storage/schema/main/delta/57/device_list_remote_cache_stale.sql +44 -0
- synapse/storage/schema/main/delta/57/local_current_membership.py +111 -0
- synapse/storage/schema/main/delta/57/remove_sent_outbound_pokes.sql +40 -0
- synapse/storage/schema/main/delta/57/rooms_version_column.sql +43 -0
- synapse/storage/schema/main/delta/57/rooms_version_column_2.sql.postgres +35 -0
- synapse/storage/schema/main/delta/57/rooms_version_column_2.sql.sqlite +22 -0
- synapse/storage/schema/main/delta/57/rooms_version_column_3.sql.postgres +39 -0
- synapse/storage/schema/main/delta/57/rooms_version_column_3.sql.sqlite +23 -0
- synapse/storage/schema/main/delta/58/02remove_dup_outbound_pokes.sql +41 -0
- synapse/storage/schema/main/delta/58/03persist_ui_auth.sql +55 -0
- synapse/storage/schema/main/delta/58/05cache_instance.sql.postgres +30 -0
- synapse/storage/schema/main/delta/58/06dlols_unique_idx.py +83 -0
- synapse/storage/schema/main/delta/58/07add_method_to_thumbnail_constraint.sql.postgres +33 -0
- synapse/storage/schema/main/delta/58/07add_method_to_thumbnail_constraint.sql.sqlite +44 -0
- synapse/storage/schema/main/delta/58/07persist_ui_auth_ips.sql +44 -0
- synapse/storage/schema/main/delta/58/08_media_safe_from_quarantine.sql.postgres +18 -0
- synapse/storage/schema/main/delta/58/08_media_safe_from_quarantine.sql.sqlite +18 -0
- synapse/storage/schema/main/delta/58/09shadow_ban.sql +37 -0
- synapse/storage/schema/main/delta/58/10_pushrules_enabled_delete_obsolete.sql +47 -0
- synapse/storage/schema/main/delta/58/10drop_local_rejections_stream.sql +41 -0
- synapse/storage/schema/main/delta/58/10federation_pos_instance_name.sql +41 -0
- synapse/storage/schema/main/delta/58/11dehydration.sql +39 -0
- synapse/storage/schema/main/delta/58/11fallback.sql +43 -0
- synapse/storage/schema/main/delta/58/11user_id_seq.py +38 -0
- synapse/storage/schema/main/delta/58/12room_stats.sql +51 -0
- synapse/storage/schema/main/delta/58/13remove_presence_allow_inbound.sql +36 -0
- synapse/storage/schema/main/delta/58/14events_instance_name.sql +35 -0
- synapse/storage/schema/main/delta/58/14events_instance_name.sql.postgres +28 -0
- synapse/storage/schema/main/delta/58/15_catchup_destination_rooms.sql +61 -0
- synapse/storage/schema/main/delta/58/15unread_count.sql +45 -0
- synapse/storage/schema/main/delta/58/16populate_stats_process_rooms_fix.sql +41 -0
- synapse/storage/schema/main/delta/58/17_catchup_last_successful.sql +40 -0
- synapse/storage/schema/main/delta/58/18stream_positions.sql +41 -0
- synapse/storage/schema/main/delta/58/19instance_map.sql.postgres +25 -0
- synapse/storage/schema/main/delta/58/19txn_id.sql +59 -0
- synapse/storage/schema/main/delta/58/20instance_name_event_tables.sql +36 -0
- synapse/storage/schema/main/delta/58/20user_daily_visits.sql +37 -0
- synapse/storage/schema/main/delta/58/21as_device_stream.sql +36 -0
- synapse/storage/schema/main/delta/58/21drop_device_max_stream_id.sql +1 -0
- synapse/storage/schema/main/delta/58/22puppet_token.sql +36 -0
- synapse/storage/schema/main/delta/58/22users_have_local_media.sql +2 -0
- synapse/storage/schema/main/delta/58/23e2e_cross_signing_keys_idx.sql +36 -0
- synapse/storage/schema/main/delta/58/24drop_event_json_index.sql +38 -0
- synapse/storage/schema/main/delta/58/25user_external_ids_user_id_idx.sql +36 -0
- synapse/storage/schema/main/delta/58/26access_token_last_validated.sql +37 -0
- synapse/storage/schema/main/delta/58/27local_invites.sql +37 -0
- synapse/storage/schema/main/delta/58/28drop_last_used_column.sql.postgres +16 -0
- synapse/storage/schema/main/delta/58/28drop_last_used_column.sql.sqlite +62 -0
- synapse/storage/schema/main/delta/59/01ignored_user.py +85 -0
- synapse/storage/schema/main/delta/59/02shard_send_to_device.sql +37 -0
- synapse/storage/schema/main/delta/59/03shard_send_to_device_sequence.sql.postgres +25 -0
- synapse/storage/schema/main/delta/59/04_event_auth_chains.sql +71 -0
- synapse/storage/schema/main/delta/59/04_event_auth_chains.sql.postgres +16 -0
- synapse/storage/schema/main/delta/59/04drop_account_data.sql +36 -0
- synapse/storage/schema/main/delta/59/05cache_invalidation.sql +36 -0
- synapse/storage/schema/main/delta/59/06chain_cover_index.sql +36 -0
- synapse/storage/schema/main/delta/59/06shard_account_data.sql +39 -0
- synapse/storage/schema/main/delta/59/06shard_account_data.sql.postgres +32 -0
- synapse/storage/schema/main/delta/59/07shard_account_data_fix.sql +37 -0
- synapse/storage/schema/main/delta/59/08delete_pushers_for_deactivated_accounts.sql +39 -0
- synapse/storage/schema/main/delta/59/08delete_stale_pushers.sql +39 -0
- synapse/storage/schema/main/delta/59/09rejected_events_metadata.sql +45 -0
- synapse/storage/schema/main/delta/59/10delete_purged_chain_cover.sql +36 -0
- synapse/storage/schema/main/delta/59/11add_knock_members_to_stats.sql +39 -0
- synapse/storage/schema/main/delta/59/11drop_thumbnail_constraint.sql.postgres +22 -0
- synapse/storage/schema/main/delta/59/12account_validity_token_used_ts_ms.sql +37 -0
- synapse/storage/schema/main/delta/59/12presence_stream_instance.sql +37 -0
- synapse/storage/schema/main/delta/59/12presence_stream_instance_seq.sql.postgres +20 -0
- synapse/storage/schema/main/delta/59/13users_to_send_full_presence_to.sql +53 -0
- synapse/storage/schema/main/delta/59/14refresh_tokens.sql +53 -0
- synapse/storage/schema/main/delta/59/15locks.sql +56 -0
- synapse/storage/schema/main/delta/59/16federation_inbound_staging.sql +51 -0
- synapse/storage/schema/main/delta/60/01recreate_stream_ordering.sql.postgres +45 -0
- synapse/storage/schema/main/delta/60/02change_stream_ordering_columns.sql.postgres +30 -0
- synapse/storage/schema/main/delta/61/01change_appservices_txns.sql.postgres +23 -0
- synapse/storage/schema/main/delta/61/01insertion_event_lookups.sql +68 -0
- synapse/storage/schema/main/delta/61/02drop_redundant_room_depth_index.sql +37 -0
- synapse/storage/schema/main/delta/61/03recreate_min_depth.py +74 -0
- synapse/storage/schema/main/delta/62/01insertion_event_extremities.sql +43 -0
- synapse/storage/schema/main/delta/63/01create_registration_tokens.sql +42 -0
- synapse/storage/schema/main/delta/63/02delete_unlinked_email_pushers.sql +39 -0
- synapse/storage/schema/main/delta/63/02populate-rooms-creator.sql +36 -0
- synapse/storage/schema/main/delta/63/03session_store.sql +42 -0
- synapse/storage/schema/main/delta/63/04add_presence_stream_not_offline_index.sql +37 -0
- synapse/storage/schema/main/delta/64/01msc2716_chunk_to_batch_rename.sql.postgres +23 -0
- synapse/storage/schema/main/delta/64/01msc2716_chunk_to_batch_rename.sql.sqlite +37 -0
- synapse/storage/schema/main/delta/65/01msc2716_insertion_event_edges.sql +38 -0
- synapse/storage/schema/main/delta/65/03remove_hidden_devices_from_device_inbox.sql +41 -0
- synapse/storage/schema/main/delta/65/04_local_group_updates.sql +37 -0
- synapse/storage/schema/main/delta/65/05_remove_room_stats_historical_and_user_stats_historical.sql +38 -0
- synapse/storage/schema/main/delta/65/06remove_deleted_devices_from_device_inbox.sql +53 -0
- synapse/storage/schema/main/delta/65/07_arbitrary_relations.sql +37 -0
- synapse/storage/schema/main/delta/65/08_device_inbox_background_updates.sql +37 -0
- synapse/storage/schema/main/delta/65/10_expirable_refresh_tokens.sql +47 -0
- synapse/storage/schema/main/delta/65/11_devices_auth_provider_session.sql +46 -0
- synapse/storage/schema/main/delta/67/01drop_public_room_list_stream.sql +37 -0
- synapse/storage/schema/main/delta/68/01event_columns.sql +45 -0
- synapse/storage/schema/main/delta/68/02_msc2409_add_device_id_appservice_stream_type.sql +40 -0
- synapse/storage/schema/main/delta/68/03_delete_account_data_for_deactivated_accounts.sql +39 -0
- synapse/storage/schema/main/delta/68/04_refresh_tokens_index_next_token_id.sql +47 -0
- synapse/storage/schema/main/delta/68/04partial_state_rooms.sql +60 -0
- synapse/storage/schema/main/delta/68/05_delete_non_strings_from_event_search.sql.sqlite +22 -0
- synapse/storage/schema/main/delta/68/05partial_state_rooms_triggers.py +80 -0
- synapse/storage/schema/main/delta/68/06_msc3202_add_device_list_appservice_stream_type.sql +42 -0
- synapse/storage/schema/main/delta/69/01as_txn_seq.py +54 -0
- synapse/storage/schema/main/delta/69/01device_list_oubound_by_room.sql +57 -0
- synapse/storage/schema/main/delta/69/02cache_invalidation_index.sql +37 -0
- synapse/storage/schema/main/delta/70/01clean_table_purged_rooms.sql +39 -0
- synapse/storage/schema/main/delta/71/01rebuild_event_edges.sql.postgres +43 -0
- synapse/storage/schema/main/delta/71/01rebuild_event_edges.sql.sqlite +47 -0
- synapse/storage/schema/main/delta/71/01remove_noop_background_updates.sql +80 -0
- synapse/storage/schema/main/delta/71/02event_push_summary_unique.sql +37 -0
- synapse/storage/schema/main/delta/72/01add_room_type_to_state_stats.sql +38 -0
- synapse/storage/schema/main/delta/72/01event_push_summary_receipt.sql +54 -0
- synapse/storage/schema/main/delta/72/02event_push_actions_index.sql +38 -0
- synapse/storage/schema/main/delta/72/03bg_populate_events_columns.py +57 -0
- synapse/storage/schema/main/delta/72/03drop_event_reference_hashes.sql +36 -0
- synapse/storage/schema/main/delta/72/03remove_groups.sql +50 -0
- synapse/storage/schema/main/delta/72/04drop_column_application_services_state_last_txn.sql.postgres +17 -0
- synapse/storage/schema/main/delta/72/04drop_column_application_services_state_last_txn.sql.sqlite +40 -0
- synapse/storage/schema/main/delta/72/05receipts_event_stream_ordering.sql +38 -0
- synapse/storage/schema/main/delta/72/05remove_unstable_private_read_receipts.sql +38 -0
- synapse/storage/schema/main/delta/72/06add_consent_ts_to_users.sql +35 -0
- synapse/storage/schema/main/delta/72/06thread_notifications.sql +49 -0
- synapse/storage/schema/main/delta/72/07force_update_current_state_events_membership.py +67 -0
- synapse/storage/schema/main/delta/72/07thread_receipts.sql.postgres +30 -0
- synapse/storage/schema/main/delta/72/07thread_receipts.sql.sqlite +70 -0
- synapse/storage/schema/main/delta/72/08begin_cache_invalidation_seq_at_2.sql.postgres +23 -0
- synapse/storage/schema/main/delta/72/08thread_receipts.sql +39 -0
- synapse/storage/schema/main/delta/72/09partial_indices.sql.sqlite +56 -0
- synapse/storage/schema/main/delta/73/01event_failed_pull_attempts.sql +48 -0
- synapse/storage/schema/main/delta/73/02add_pusher_enabled.sql +35 -0
- synapse/storage/schema/main/delta/73/02room_id_indexes_for_purging.sql +41 -0
- synapse/storage/schema/main/delta/73/03pusher_device_id.sql +39 -0
- synapse/storage/schema/main/delta/73/03users_approved_column.sql +39 -0
- synapse/storage/schema/main/delta/73/04partial_join_details.sql +42 -0
- synapse/storage/schema/main/delta/73/04pending_device_list_updates.sql +47 -0
- synapse/storage/schema/main/delta/73/05old_push_actions.sql.postgres +22 -0
- synapse/storage/schema/main/delta/73/05old_push_actions.sql.sqlite +24 -0
- synapse/storage/schema/main/delta/73/06thread_notifications_thread_id_idx.sql +42 -0
- synapse/storage/schema/main/delta/73/08thread_receipts_non_null.sql.postgres +23 -0
- synapse/storage/schema/main/delta/73/08thread_receipts_non_null.sql.sqlite +76 -0
- synapse/storage/schema/main/delta/73/09partial_joined_via_destination.sql +37 -0
- synapse/storage/schema/main/delta/73/09threads_table.sql +49 -0
- synapse/storage/schema/main/delta/73/10_update_sqlite_fts4_tokenizer.py +71 -0
- synapse/storage/schema/main/delta/73/10login_tokens.sql +54 -0
- synapse/storage/schema/main/delta/73/11event_search_room_id_n_distinct.sql.postgres +33 -0
- synapse/storage/schema/main/delta/73/12refactor_device_list_outbound_pokes.sql +72 -0
- synapse/storage/schema/main/delta/73/13add_device_lists_index.sql +39 -0
- synapse/storage/schema/main/delta/73/20_un_partial_stated_room_stream.sql +51 -0
- synapse/storage/schema/main/delta/73/21_un_partial_stated_room_stream_seq.sql.postgres +20 -0
- synapse/storage/schema/main/delta/73/22_rebuild_user_dir_stats.sql +48 -0
- synapse/storage/schema/main/delta/73/22_un_partial_stated_event_stream.sql +53 -0
- synapse/storage/schema/main/delta/73/23_fix_thread_index.sql +52 -0
- synapse/storage/schema/main/delta/73/23_un_partial_stated_room_stream_seq.sql.postgres +20 -0
- synapse/storage/schema/main/delta/73/24_events_jump_to_date_index.sql +36 -0
- synapse/storage/schema/main/delta/73/25drop_presence.sql +36 -0
- synapse/storage/schema/main/delta/74/01_user_directory_stale_remote_users.sql +58 -0
- synapse/storage/schema/main/delta/74/02_set_device_id_for_pushers_bg_update.sql +38 -0
- synapse/storage/schema/main/delta/74/03_membership_tables_event_stream_ordering.sql.postgres +29 -0
- synapse/storage/schema/main/delta/74/03_membership_tables_event_stream_ordering.sql.sqlite +23 -0
- synapse/storage/schema/main/delta/74/03_room_membership_index.sql +38 -0
- synapse/storage/schema/main/delta/74/04_delete_e2e_backup_keys_for_deactivated_users.sql +36 -0
- synapse/storage/schema/main/delta/74/04_membership_tables_event_stream_ordering_triggers.py +87 -0
- synapse/storage/schema/main/delta/74/05_events_txn_id_device_id.sql +72 -0
- synapse/storage/schema/main/delta/74/90COMMENTS_destinations.sql.postgres +52 -0
- synapse/storage/schema/main/delta/76/01_add_profiles_full_user_id_column.sql +39 -0
- synapse/storage/schema/main/delta/76/02_add_user_filters_full_user_id_column.sql +39 -0
- synapse/storage/schema/main/delta/76/03_per_user_experimental_features.sql +46 -0
- synapse/storage/schema/main/delta/76/04_add_room_forgetter.sql +43 -0
- synapse/storage/schema/main/delta/77/01_add_profiles_not_valid_check.sql.postgres +16 -0
- synapse/storage/schema/main/delta/77/02_add_user_filters_not_valid_check.sql.postgres +16 -0
- synapse/storage/schema/main/delta/77/03bg_populate_full_user_id_profiles.sql +35 -0
- synapse/storage/schema/main/delta/77/04bg_populate_full_user_id_user_filters.sql +35 -0
- synapse/storage/schema/main/delta/77/05thread_notifications_backfill.sql +67 -0
- synapse/storage/schema/main/delta/77/06thread_notifications_not_null.sql.sqlite +102 -0
- synapse/storage/schema/main/delta/77/06thread_notifications_not_null_event_push_actions.sql.postgres +27 -0
- synapse/storage/schema/main/delta/77/06thread_notifications_not_null_event_push_actions_staging.sql.postgres +27 -0
- synapse/storage/schema/main/delta/77/06thread_notifications_not_null_event_push_summary.sql.postgres +29 -0
- synapse/storage/schema/main/delta/77/14bg_indices_event_stream_ordering.sql +39 -0
- synapse/storage/schema/main/delta/78/01_validate_and_update_profiles.py +99 -0
- synapse/storage/schema/main/delta/78/02_validate_and_update_user_filters.py +100 -0
- synapse/storage/schema/main/delta/78/03_remove_unused_indexes_user_filters.py +72 -0
- synapse/storage/schema/main/delta/78/03event_extremities_constraints.py +65 -0
- synapse/storage/schema/main/delta/78/04_add_full_user_id_index_user_filters.py +32 -0
- synapse/storage/schema/main/delta/79/03_read_write_locks_triggers.sql.postgres +102 -0
- synapse/storage/schema/main/delta/79/03_read_write_locks_triggers.sql.sqlite +72 -0
- synapse/storage/schema/main/delta/79/04_mitigate_stream_ordering_update_race.py +70 -0
- synapse/storage/schema/main/delta/79/05_read_write_locks_triggers.sql.postgres +69 -0
- synapse/storage/schema/main/delta/79/05_read_write_locks_triggers.sql.sqlite +65 -0
- synapse/storage/schema/main/delta/80/01_users_alter_locked.sql +35 -0
- synapse/storage/schema/main/delta/80/02_read_write_locks_unlogged.sql.postgres +30 -0
- synapse/storage/schema/main/delta/80/02_scheduled_tasks.sql +47 -0
- synapse/storage/schema/main/delta/80/03_read_write_locks_triggers.sql.postgres +37 -0
- synapse/storage/schema/main/delta/80/04_read_write_locks_deadlock.sql.postgres +71 -0
- synapse/storage/schema/main/delta/82/02_scheduled_tasks_index.sql +35 -0
- synapse/storage/schema/main/delta/82/04_add_indices_for_purging_rooms.sql +39 -0
- synapse/storage/schema/main/delta/82/05gaps.sql +44 -0
- synapse/storage/schema/main/delta/83/01_drop_old_tables.sql +43 -0
- synapse/storage/schema/main/delta/83/03_instance_name_receipts.sql.sqlite +17 -0
- synapse/storage/schema/main/delta/83/05_cross_signing_key_update_grant.sql +34 -0
- synapse/storage/schema/main/delta/83/06_event_push_summary_room.sql +36 -0
- synapse/storage/schema/main/delta/84/01_auth_links_stats.sql.postgres +20 -0
- synapse/storage/schema/main/delta/84/02_auth_links_index.sql +16 -0
- synapse/storage/schema/main/delta/84/03_auth_links_analyze.sql.postgres +16 -0
- synapse/storage/schema/main/delta/84/04_access_token_index.sql +15 -0
- synapse/storage/schema/main/delta/85/01_add_suspended.sql +14 -0
- synapse/storage/schema/main/delta/85/02_add_instance_names.sql +27 -0
- synapse/storage/schema/main/delta/85/03_new_sequences.sql.postgres +54 -0
- synapse/storage/schema/main/delta/85/04_cleanup_device_federation_outbox.sql +15 -0
- synapse/storage/schema/main/delta/85/05_add_instance_names_converted_pos.sql +16 -0
- synapse/storage/schema/main/delta/85/06_add_room_reports.sql +20 -0
- synapse/storage/schema/main/delta/86/01_authenticate_media.sql +15 -0
- synapse/storage/schema/main/delta/86/02_receipts_event_id_index.sql +15 -0
- synapse/storage/schema/main/delta/87/01_sliding_sync_memberships.sql +169 -0
- synapse/storage/schema/main/delta/87/02_per_connection_state.sql +81 -0
- synapse/storage/schema/main/delta/87/03_current_state_index.sql +19 -0
- synapse/storage/schema/main/delta/88/01_add_delayed_events.sql +43 -0
- synapse/storage/schema/main/delta/88/01_custom_profile_fields.sql +15 -0
- synapse/storage/schema/main/delta/88/02_fix_sliding_sync_membership_snapshots_forgotten_column.sql +21 -0
- synapse/storage/schema/main/delta/88/03_add_otk_ts_added_index.sql +18 -0
- synapse/storage/schema/main/delta/88/04_current_state_delta_index.sql +18 -0
- synapse/storage/schema/main/delta/88/05_drop_old_otks.sql.postgres +19 -0
- synapse/storage/schema/main/delta/88/05_drop_old_otks.sql.sqlite +19 -0
- synapse/storage/schema/main/delta/88/05_sliding_sync_room_config_index.sql +20 -0
- synapse/storage/schema/main/delta/88/06_events_received_ts_index.sql +17 -0
- synapse/storage/schema/main/delta/89/01_sliding_sync_membership_snapshot_index.sql +15 -0
- synapse/storage/schema/main/delta/90/01_add_column_participant_room_memberships_table.sql +16 -0
- synapse/storage/schema/main/delta/91/01_media_hash.sql +28 -0
- synapse/storage/schema/main/delta/92/01_remove_trigger.sql.postgres +16 -0
- synapse/storage/schema/main/delta/92/01_remove_trigger.sql.sqlite +16 -0
- synapse/storage/schema/main/delta/92/02_remove_populate_participant_bg_update.sql +17 -0
- synapse/storage/schema/main/delta/92/04_ss_membership_snapshot_idx.sql +16 -0
- synapse/storage/schema/main/delta/92/04_thread_subscriptions.sql +59 -0
- synapse/storage/schema/main/delta/92/04_thread_subscriptions_seq.sql.postgres +19 -0
- synapse/storage/schema/main/delta/92/05_fixup_max_depth_cap.sql +17 -0
- synapse/storage/schema/main/delta/92/05_thread_subscriptions_comments.sql.postgres +18 -0
- synapse/storage/schema/main/delta/92/06_device_federation_inbox_index.sql +16 -0
- synapse/storage/schema/main/delta/92/06_threads_last_sent_stream_ordering_comments.sql.postgres +24 -0
- synapse/storage/schema/main/delta/92/07_add_user_reports.sql +22 -0
- synapse/storage/schema/main/delta/92/07_event_txn_id_device_id_txn_id2.sql +15 -0
- synapse/storage/schema/main/delta/92/08_room_ban_redactions.sql +21 -0
- synapse/storage/schema/main/delta/92/08_thread_subscriptions_seq_fixup.sql.postgres +19 -0
- synapse/storage/schema/main/delta/92/09_thread_subscriptions_update.sql +20 -0
- synapse/storage/schema/main/delta/92/09_thread_subscriptions_update.sql.postgres +18 -0
- synapse/storage/schema/main/delta/93/01_add_delayed_events.sql +15 -0
- synapse/storage/schema/main/full_schemas/72/full.sql.postgres +1344 -0
- synapse/storage/schema/main/full_schemas/72/full.sql.sqlite +646 -0
- synapse/storage/schema/state/delta/23/drop_state_index.sql +35 -0
- synapse/storage/schema/state/delta/32/remove_state_indices.sql +38 -0
- synapse/storage/schema/state/delta/35/add_state_index.sql +36 -0
- synapse/storage/schema/state/delta/35/state.sql +41 -0
- synapse/storage/schema/state/delta/35/state_dedupe.sql +36 -0
- synapse/storage/schema/state/delta/47/state_group_seq.py +38 -0
- synapse/storage/schema/state/delta/56/state_group_room_idx.sql +36 -0
- synapse/storage/schema/state/delta/61/02state_groups_state_n_distinct.sql.postgres +34 -0
- synapse/storage/schema/state/delta/70/08_state_group_edges_unique.sql +36 -0
- synapse/storage/schema/state/delta/89/01_state_groups_deletion.sql +39 -0
- synapse/storage/schema/state/delta/90/02_delete_unreferenced_state_groups.sql +16 -0
- synapse/storage/schema/state/delta/90/03_remove_old_deletion_bg_update.sql +15 -0
- synapse/storage/schema/state/full_schemas/72/full.sql.postgres +30 -0
- synapse/storage/schema/state/full_schemas/72/full.sql.sqlite +20 -0
- synapse/storage/types.py +183 -0
- synapse/storage/util/__init__.py +20 -0
- synapse/storage/util/id_generators.py +928 -0
- synapse/storage/util/partial_state_events_tracker.py +194 -0
- synapse/storage/util/sequence.py +315 -0
- synapse/streams/__init__.py +43 -0
- synapse/streams/config.py +91 -0
- synapse/streams/events.py +203 -0
- synapse/synapse_rust/__init__.pyi +3 -0
- synapse/synapse_rust/acl.pyi +20 -0
- synapse/synapse_rust/events.pyi +136 -0
- synapse/synapse_rust/http_client.pyi +32 -0
- synapse/synapse_rust/push.pyi +86 -0
- synapse/synapse_rust/rendezvous.pyi +30 -0
- synapse/synapse_rust/segmenter.pyi +1 -0
- synapse/synapse_rust.abi3.so +0 -0
- synapse/types/__init__.py +1600 -0
- synapse/types/handlers/__init__.py +93 -0
- synapse/types/handlers/policy_server.py +16 -0
- synapse/types/handlers/sliding_sync.py +908 -0
- synapse/types/rest/__init__.py +25 -0
- synapse/types/rest/client/__init__.py +413 -0
- synapse/types/state.py +634 -0
- synapse/types/storage/__init__.py +66 -0
- synapse/util/__init__.py +169 -0
- synapse/util/async_helpers.py +1045 -0
- synapse/util/background_queue.py +142 -0
- synapse/util/batching_queue.py +202 -0
- synapse/util/caches/__init__.py +300 -0
- synapse/util/caches/cached_call.py +143 -0
- synapse/util/caches/deferred_cache.py +530 -0
- synapse/util/caches/descriptors.py +692 -0
- synapse/util/caches/dictionary_cache.py +346 -0
- synapse/util/caches/expiringcache.py +249 -0
- synapse/util/caches/lrucache.py +975 -0
- synapse/util/caches/response_cache.py +322 -0
- synapse/util/caches/stream_change_cache.py +370 -0
- synapse/util/caches/treecache.py +189 -0
- synapse/util/caches/ttlcache.py +197 -0
- synapse/util/cancellation.py +63 -0
- synapse/util/check_dependencies.py +335 -0
- synapse/util/clock.py +567 -0
- synapse/util/constants.py +22 -0
- synapse/util/daemonize.py +165 -0
- synapse/util/distributor.py +157 -0
- synapse/util/events.py +134 -0
- synapse/util/file_consumer.py +164 -0
- synapse/util/frozenutils.py +57 -0
- synapse/util/gai_resolver.py +178 -0
- synapse/util/hash.py +38 -0
- synapse/util/httpresourcetree.py +108 -0
- synapse/util/iterutils.py +189 -0
- synapse/util/json.py +56 -0
- synapse/util/linked_list.py +156 -0
- synapse/util/logcontext.py +46 -0
- synapse/util/logformatter.py +28 -0
- synapse/util/macaroons.py +325 -0
- synapse/util/manhole.py +191 -0
- synapse/util/metrics.py +339 -0
- synapse/util/module_loader.py +116 -0
- synapse/util/msisdn.py +51 -0
- synapse/util/patch_inline_callbacks.py +250 -0
- synapse/util/pydantic_models.py +63 -0
- synapse/util/ratelimitutils.py +419 -0
- synapse/util/retryutils.py +339 -0
- synapse/util/rlimit.py +42 -0
- synapse/util/rust.py +133 -0
- synapse/util/sentinel.py +21 -0
- synapse/util/stringutils.py +293 -0
- synapse/util/task_scheduler.py +493 -0
- synapse/util/templates.py +126 -0
- synapse/util/threepids.py +123 -0
- synapse/util/wheel_timer.py +112 -0
- synapse/visibility.py +835 -0
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
--
|
|
2
|
+
-- This file is licensed under the Affero General Public License (AGPL) version 3.
|
|
3
|
+
--
|
|
4
|
+
-- Copyright (C) 2024 New Vector, Ltd
|
|
5
|
+
--
|
|
6
|
+
-- This program is free software: you can redistribute it and/or modify
|
|
7
|
+
-- it under the terms of the GNU Affero General Public License as
|
|
8
|
+
-- published by the Free Software Foundation, either version 3 of the
|
|
9
|
+
-- License, or (at your option) any later version.
|
|
10
|
+
--
|
|
11
|
+
-- See the GNU Affero General Public License for more details:
|
|
12
|
+
-- <https://www.gnu.org/licenses/agpl-3.0.html>.
|
|
13
|
+
|
|
14
|
+
-- Add squences for stream tables to allow them to be used with
|
|
15
|
+
-- `MultiWriterIdGenerator`
|
|
16
|
+
CREATE SEQUENCE IF NOT EXISTS device_lists_sequence;
|
|
17
|
+
|
|
18
|
+
-- We need to take the max across all the device lists tables as they share the
|
|
19
|
+
-- ID generator
|
|
20
|
+
SELECT setval('device_lists_sequence', (
|
|
21
|
+
SELECT GREATEST(
|
|
22
|
+
(SELECT COALESCE(MAX(stream_id), 1) FROM device_lists_stream),
|
|
23
|
+
(SELECT COALESCE(MAX(stream_id), 1) FROM user_signature_stream),
|
|
24
|
+
(SELECT COALESCE(MAX(stream_id), 1) FROM device_lists_outbound_pokes),
|
|
25
|
+
(SELECT COALESCE(MAX(stream_id), 1) FROM device_lists_changes_in_room),
|
|
26
|
+
(SELECT COALESCE(MAX(stream_id), 1) FROM device_lists_remote_pending),
|
|
27
|
+
(SELECT COALESCE(MAX(stream_id), 1) FROM device_lists_changes_converted_stream_position)
|
|
28
|
+
)
|
|
29
|
+
));
|
|
30
|
+
|
|
31
|
+
CREATE SEQUENCE IF NOT EXISTS e2e_cross_signing_keys_sequence;
|
|
32
|
+
|
|
33
|
+
SELECT setval('e2e_cross_signing_keys_sequence', (
|
|
34
|
+
SELECT COALESCE(MAX(stream_id), 1) FROM e2e_cross_signing_keys
|
|
35
|
+
));
|
|
36
|
+
|
|
37
|
+
|
|
38
|
+
CREATE SEQUENCE IF NOT EXISTS push_rules_stream_sequence;
|
|
39
|
+
|
|
40
|
+
SELECT setval('push_rules_stream_sequence', (
|
|
41
|
+
SELECT COALESCE(MAX(stream_id), 1) FROM push_rules_stream
|
|
42
|
+
));
|
|
43
|
+
|
|
44
|
+
|
|
45
|
+
CREATE SEQUENCE IF NOT EXISTS pushers_sequence;
|
|
46
|
+
|
|
47
|
+
-- We need to take the max across all the pusher tables as they share the
|
|
48
|
+
-- ID generator
|
|
49
|
+
SELECT setval('pushers_sequence', (
|
|
50
|
+
SELECT GREATEST(
|
|
51
|
+
(SELECT COALESCE(MAX(id), 1) FROM pushers),
|
|
52
|
+
(SELECT COALESCE(MAX(stream_id), 1) FROM deleted_pushers)
|
|
53
|
+
)
|
|
54
|
+
));
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
--
|
|
2
|
+
-- This file is licensed under the Affero General Public License (AGPL) version 3.
|
|
3
|
+
--
|
|
4
|
+
-- Copyright (C) 2024 New Vector, Ltd
|
|
5
|
+
--
|
|
6
|
+
-- This program is free software: you can redistribute it and/or modify
|
|
7
|
+
-- it under the terms of the GNU Affero General Public License as
|
|
8
|
+
-- published by the Free Software Foundation, either version 3 of the
|
|
9
|
+
-- License, or (at your option) any later version.
|
|
10
|
+
--
|
|
11
|
+
-- See the GNU Affero General Public License for more details:
|
|
12
|
+
-- <https://www.gnu.org/licenses/agpl-3.0.html>.
|
|
13
|
+
|
|
14
|
+
INSERT INTO background_updates (ordering, update_name, progress_json) VALUES
|
|
15
|
+
(8504, 'cleanup_device_federation_outbox', '{}');
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
--
|
|
2
|
+
-- This file is licensed under the Affero General Public License (AGPL) version 3.
|
|
3
|
+
--
|
|
4
|
+
-- Copyright (C) 2024 New Vector, Ltd
|
|
5
|
+
--
|
|
6
|
+
-- This program is free software: you can redistribute it and/or modify
|
|
7
|
+
-- it under the terms of the GNU Affero General Public License as
|
|
8
|
+
-- published by the Free Software Foundation, either version 3 of the
|
|
9
|
+
-- License, or (at your option) any later version.
|
|
10
|
+
--
|
|
11
|
+
-- See the GNU Affero General Public License for more details:
|
|
12
|
+
-- <https://www.gnu.org/licenses/agpl-3.0.html>.
|
|
13
|
+
|
|
14
|
+
-- Add `instance_name` columns to stream tables to allow them to be used with
|
|
15
|
+
-- `MultiWriterIdGenerator`
|
|
16
|
+
ALTER TABLE device_lists_changes_converted_stream_position ADD COLUMN instance_name TEXT;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
--
|
|
2
|
+
-- This file is licensed under the Affero General Public License (AGPL) version 3.
|
|
3
|
+
--
|
|
4
|
+
-- Copyright (C) 2024 New Vector, Ltd
|
|
5
|
+
--
|
|
6
|
+
-- This program is free software: you can redistribute it and/or modify
|
|
7
|
+
-- it under the terms of the GNU Affero General Public License as
|
|
8
|
+
-- published by the Free Software Foundation, either version 3 of the
|
|
9
|
+
-- License, or (at your option) any later version.
|
|
10
|
+
--
|
|
11
|
+
-- See the GNU Affero General Public License for more details:
|
|
12
|
+
-- <https://www.gnu.org/licenses/agpl-3.0.html>.
|
|
13
|
+
|
|
14
|
+
CREATE TABLE room_reports (
|
|
15
|
+
id BIGINT NOT NULL PRIMARY KEY,
|
|
16
|
+
received_ts BIGINT NOT NULL,
|
|
17
|
+
room_id TEXT NOT NULL,
|
|
18
|
+
user_id TEXT NOT NULL,
|
|
19
|
+
reason TEXT NOT NULL
|
|
20
|
+
);
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
--
|
|
2
|
+
-- This file is licensed under the Affero General Public License (AGPL) version 3.
|
|
3
|
+
--
|
|
4
|
+
-- Copyright (C) 2024 New Vector, Ltd
|
|
5
|
+
--
|
|
6
|
+
-- This program is free software: you can redistribute it and/or modify
|
|
7
|
+
-- it under the terms of the GNU Affero General Public License as
|
|
8
|
+
-- published by the Free Software Foundation, either version 3 of the
|
|
9
|
+
-- License, or (at your option) any later version.
|
|
10
|
+
--
|
|
11
|
+
-- See the GNU Affero General Public License for more details:
|
|
12
|
+
-- <https://www.gnu.org/licenses/agpl-3.0.html>.
|
|
13
|
+
|
|
14
|
+
ALTER TABLE remote_media_cache ADD COLUMN authenticated BOOLEAN DEFAULT FALSE NOT NULL;
|
|
15
|
+
ALTER TABLE local_media_repository ADD COLUMN authenticated BOOLEAN DEFAULT FALSE NOT NULL;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
--
|
|
2
|
+
-- This file is licensed under the Affero General Public License (AGPL) version 3.
|
|
3
|
+
--
|
|
4
|
+
-- Copyright (C) 2024 New Vector, Ltd
|
|
5
|
+
--
|
|
6
|
+
-- This program is free software: you can redistribute it and/or modify
|
|
7
|
+
-- it under the terms of the GNU Affero General Public License as
|
|
8
|
+
-- published by the Free Software Foundation, either version 3 of the
|
|
9
|
+
-- License, or (at your option) any later version.
|
|
10
|
+
--
|
|
11
|
+
-- See the GNU Affero General Public License for more details:
|
|
12
|
+
-- <https://www.gnu.org/licenses/agpl-3.0.html>.
|
|
13
|
+
|
|
14
|
+
INSERT INTO background_updates (ordering, update_name, progress_json) VALUES
|
|
15
|
+
(8602, 'receipts_room_id_event_id_index', '{}');
|
|
@@ -0,0 +1,169 @@
|
|
|
1
|
+
--
|
|
2
|
+
-- This file is licensed under the Affero General Public License (AGPL) version 3.
|
|
3
|
+
--
|
|
4
|
+
-- Copyright (C) 2024 New Vector, Ltd
|
|
5
|
+
--
|
|
6
|
+
-- This program is free software: you can redistribute it and/or modify
|
|
7
|
+
-- it under the terms of the GNU Affero General Public License as
|
|
8
|
+
-- published by the Free Software Foundation, either version 3 of the
|
|
9
|
+
-- License, or (at your option) any later version.
|
|
10
|
+
--
|
|
11
|
+
-- See the GNU Affero General Public License for more details:
|
|
12
|
+
-- <https://www.gnu.org/licenses/agpl-3.0.html>.
|
|
13
|
+
|
|
14
|
+
-- This table is a list/queue used to keep track of which rooms need to be inserted into
|
|
15
|
+
-- `sliding_sync_joined_rooms`. We do this to avoid reading from `current_state_events`
|
|
16
|
+
-- during the background update to populate `sliding_sync_joined_rooms` which works but
|
|
17
|
+
-- it takes a lot of work for the database to grab `DISTINCT` room_ids given how many
|
|
18
|
+
-- state events there are for each room.
|
|
19
|
+
--
|
|
20
|
+
-- This table is prefilled with every room in the `rooms` table (see the
|
|
21
|
+
-- `sliding_sync_prefill_joined_rooms_to_recalculate_table_bg_update` background
|
|
22
|
+
-- update). This table is also updated whenever we come across stale data so that we can
|
|
23
|
+
-- catch-up with all of the new data if Synapse was downgraded (see
|
|
24
|
+
-- `_resolve_stale_data_in_sliding_sync_tables`).
|
|
25
|
+
--
|
|
26
|
+
-- FIXME: This can be removed once we bump `SCHEMA_COMPAT_VERSION` and run the
|
|
27
|
+
-- foreground update for
|
|
28
|
+
-- `sliding_sync_joined_rooms`/`sliding_sync_membership_snapshots` (tracked by
|
|
29
|
+
-- https://github.com/element-hq/synapse/issues/17623)
|
|
30
|
+
CREATE TABLE IF NOT EXISTS sliding_sync_joined_rooms_to_recalculate(
|
|
31
|
+
room_id TEXT NOT NULL REFERENCES rooms(room_id),
|
|
32
|
+
PRIMARY KEY (room_id)
|
|
33
|
+
);
|
|
34
|
+
|
|
35
|
+
-- A table for storing room meta data (current state relevant to sliding sync) that the
|
|
36
|
+
-- local server is still participating in (someone local is joined to the room).
|
|
37
|
+
--
|
|
38
|
+
-- We store the joined rooms in separate table from `sliding_sync_membership_snapshots`
|
|
39
|
+
-- because we need up-to-date information for joined rooms and it can be shared across
|
|
40
|
+
-- everyone who is joined.
|
|
41
|
+
--
|
|
42
|
+
-- This table is kept in sync with `current_state_events` which means if the server is
|
|
43
|
+
-- no longer participating in a room, the row will be deleted.
|
|
44
|
+
CREATE TABLE IF NOT EXISTS sliding_sync_joined_rooms(
|
|
45
|
+
room_id TEXT NOT NULL REFERENCES rooms(room_id),
|
|
46
|
+
-- The `stream_ordering` of the most-recent/latest event in the room
|
|
47
|
+
event_stream_ordering BIGINT NOT NULL REFERENCES events(stream_ordering),
|
|
48
|
+
-- The `stream_ordering` of the last event according to the `bump_event_types`
|
|
49
|
+
bump_stamp BIGINT,
|
|
50
|
+
-- `m.room.create` -> `content.type` (current state)
|
|
51
|
+
--
|
|
52
|
+
-- Useful for the `spaces`/`not_spaces` filter in the Sliding Sync API
|
|
53
|
+
room_type TEXT,
|
|
54
|
+
-- `m.room.name` -> `content.name` (current state)
|
|
55
|
+
--
|
|
56
|
+
-- Useful for the room meta data and `room_name_like` filter in the Sliding Sync API
|
|
57
|
+
room_name TEXT,
|
|
58
|
+
-- `m.room.encryption` -> `content.algorithm` (current state)
|
|
59
|
+
--
|
|
60
|
+
-- Useful for the `is_encrypted` filter in the Sliding Sync API
|
|
61
|
+
is_encrypted BOOLEAN DEFAULT FALSE NOT NULL,
|
|
62
|
+
-- `m.room.tombstone` -> `content.replacement_room` (according to the current state at the
|
|
63
|
+
-- time of the membership).
|
|
64
|
+
--
|
|
65
|
+
-- Useful for the `include_old_rooms` functionality in the Sliding Sync API
|
|
66
|
+
tombstone_successor_room_id TEXT,
|
|
67
|
+
PRIMARY KEY (room_id)
|
|
68
|
+
);
|
|
69
|
+
|
|
70
|
+
-- So we can purge rooms easily.
|
|
71
|
+
--
|
|
72
|
+
-- The primary key is already `room_id`
|
|
73
|
+
|
|
74
|
+
-- So we can sort by `stream_ordering
|
|
75
|
+
CREATE UNIQUE INDEX IF NOT EXISTS sliding_sync_joined_rooms_event_stream_ordering ON sliding_sync_joined_rooms(event_stream_ordering);
|
|
76
|
+
|
|
77
|
+
-- A table for storing a snapshot of room meta data (historical current state relevant
|
|
78
|
+
-- for sliding sync) at the time of a local user's membership. Only has rows for the
|
|
79
|
+
-- latest membership event for a given local user in a room which matches
|
|
80
|
+
-- `local_current_membership` .
|
|
81
|
+
--
|
|
82
|
+
-- We store all memberships including joins. This makes it easy to reference this table
|
|
83
|
+
-- to find all membership for a given user and shares the same semantics as
|
|
84
|
+
-- `local_current_membership`. And we get to avoid some table maintenance; if we only
|
|
85
|
+
-- stored non-joins, we would have to delete the row for the user when the user joins
|
|
86
|
+
-- the room. Stripped state doesn't include the `m.room.tombstone` event, so we just
|
|
87
|
+
-- assume that the room doesn't have a tombstone.
|
|
88
|
+
--
|
|
89
|
+
-- For remote invite/knocks where the server is not participating in the room, we will
|
|
90
|
+
-- use stripped state events to populate this table. We assume that if any stripped
|
|
91
|
+
-- state is given, it will include all possible stripped state events types. For
|
|
92
|
+
-- example, if stripped state is given but `m.room.encryption` isn't included, we will
|
|
93
|
+
-- assume that the room is not encrypted.
|
|
94
|
+
--
|
|
95
|
+
-- We don't include `bump_stamp` here because we can just use the `stream_ordering` from
|
|
96
|
+
-- the membership event itself as the `bump_stamp`.
|
|
97
|
+
CREATE TABLE IF NOT EXISTS sliding_sync_membership_snapshots(
|
|
98
|
+
room_id TEXT NOT NULL REFERENCES rooms(room_id),
|
|
99
|
+
user_id TEXT NOT NULL,
|
|
100
|
+
-- Useful to be able to tell leaves from kicks (where the `user_id` is different from the `sender`)
|
|
101
|
+
sender TEXT NOT NULL,
|
|
102
|
+
membership_event_id TEXT NOT NULL REFERENCES events(event_id),
|
|
103
|
+
membership TEXT NOT NULL,
|
|
104
|
+
-- This is an integer just to match `room_memberships` and also means we don't need
|
|
105
|
+
-- to do any casting.
|
|
106
|
+
forgotten INTEGER DEFAULT 0 NOT NULL,
|
|
107
|
+
-- `stream_ordering` of the `membership_event_id`
|
|
108
|
+
event_stream_ordering BIGINT NOT NULL REFERENCES events(stream_ordering),
|
|
109
|
+
-- `instance_name` of the worker that persisted the `membership_event_id`.
|
|
110
|
+
-- Useful for crafting `PersistedEventPosition(...)`
|
|
111
|
+
event_instance_name TEXT NOT NULL,
|
|
112
|
+
-- For remote invites/knocks that don't include any stripped state, we want to be
|
|
113
|
+
-- able to distinguish between a room with `None` as valid value for some state and
|
|
114
|
+
-- room where the state is completely unknown. Basically, this should be True unless
|
|
115
|
+
-- no stripped state was provided for a remote invite/knock (False).
|
|
116
|
+
has_known_state BOOLEAN DEFAULT FALSE NOT NULL,
|
|
117
|
+
-- `m.room.create` -> `content.type` (according to the current state at the time of
|
|
118
|
+
-- the membership).
|
|
119
|
+
--
|
|
120
|
+
-- Useful for the `spaces`/`not_spaces` filter in the Sliding Sync API
|
|
121
|
+
room_type TEXT,
|
|
122
|
+
-- `m.room.name` -> `content.name` (according to the current state at the time of
|
|
123
|
+
-- the membership).
|
|
124
|
+
--
|
|
125
|
+
-- Useful for the room meta data and `room_name_like` filter in the Sliding Sync API
|
|
126
|
+
room_name TEXT,
|
|
127
|
+
-- `m.room.encryption` -> `content.algorithm` (according to the current state at the
|
|
128
|
+
-- time of the membership).
|
|
129
|
+
--
|
|
130
|
+
-- Useful for the `is_encrypted` filter in the Sliding Sync API
|
|
131
|
+
is_encrypted BOOLEAN DEFAULT FALSE NOT NULL,
|
|
132
|
+
-- `m.room.tombstone` -> `content.replacement_room` (according to the current state at the
|
|
133
|
+
-- time of the membership).
|
|
134
|
+
--
|
|
135
|
+
-- Useful for the `include_old_rooms` functionality in the Sliding Sync API
|
|
136
|
+
tombstone_successor_room_id TEXT,
|
|
137
|
+
PRIMARY KEY (room_id, user_id)
|
|
138
|
+
);
|
|
139
|
+
|
|
140
|
+
-- So we can purge rooms easily.
|
|
141
|
+
--
|
|
142
|
+
-- Since we're using a multi-column index as the primary key (room_id, user_id), the
|
|
143
|
+
-- first index column (room_id) is always usable for searching so we don't need to
|
|
144
|
+
-- create a separate index for it.
|
|
145
|
+
--
|
|
146
|
+
-- CREATE INDEX IF NOT EXISTS sliding_sync_membership_snapshots_room_id ON sliding_sync_membership_snapshots(room_id);
|
|
147
|
+
|
|
148
|
+
-- So we can fetch all rooms for a given user
|
|
149
|
+
CREATE INDEX IF NOT EXISTS sliding_sync_membership_snapshots_user_id ON sliding_sync_membership_snapshots(user_id);
|
|
150
|
+
-- So we can sort by `stream_ordering
|
|
151
|
+
CREATE UNIQUE INDEX IF NOT EXISTS sliding_sync_membership_snapshots_event_stream_ordering ON sliding_sync_membership_snapshots(event_stream_ordering);
|
|
152
|
+
|
|
153
|
+
|
|
154
|
+
-- Add a series of background updates to populate the new `sliding_sync_joined_rooms` table:
|
|
155
|
+
--
|
|
156
|
+
-- 1. Add a background update to prefill `sliding_sync_joined_rooms_to_recalculate`.
|
|
157
|
+
-- We do a one-shot bulk insert from the `rooms` table to prefill.
|
|
158
|
+
-- 2. Add a background update to populate the new `sliding_sync_joined_rooms` table
|
|
159
|
+
-- based on the rooms listed in the `sliding_sync_joined_rooms_to_recalculate`
|
|
160
|
+
-- table.
|
|
161
|
+
--
|
|
162
|
+
INSERT INTO background_updates (ordering, update_name, progress_json) VALUES
|
|
163
|
+
(8701, 'sliding_sync_prefill_joined_rooms_to_recalculate_table_bg_update', '{}');
|
|
164
|
+
INSERT INTO background_updates (ordering, update_name, progress_json, depends_on) VALUES
|
|
165
|
+
(8701, 'sliding_sync_joined_rooms_bg_update', '{}', 'sliding_sync_prefill_joined_rooms_to_recalculate_table_bg_update');
|
|
166
|
+
|
|
167
|
+
-- Add a background updates to populate the new `sliding_sync_membership_snapshots` table
|
|
168
|
+
INSERT INTO background_updates (ordering, update_name, progress_json) VALUES
|
|
169
|
+
(8701, 'sliding_sync_membership_snapshots_bg_update', '{}');
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
--
|
|
2
|
+
-- This file is licensed under the Affero General Public License (AGPL) version 3.
|
|
3
|
+
--
|
|
4
|
+
-- Copyright (C) 2024 New Vector, Ltd
|
|
5
|
+
--
|
|
6
|
+
-- This program is free software: you can redistribute it and/or modify
|
|
7
|
+
-- it under the terms of the GNU Affero General Public License as
|
|
8
|
+
-- published by the Free Software Foundation, either version 3 of the
|
|
9
|
+
-- License, or (at your option) any later version.
|
|
10
|
+
--
|
|
11
|
+
-- See the GNU Affero General Public License for more details:
|
|
12
|
+
-- <https://www.gnu.org/licenses/agpl-3.0.html>.
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
-- Table to track active sliding sync connections.
|
|
16
|
+
--
|
|
17
|
+
-- A new connection will be created for every sliding sync request without a
|
|
18
|
+
-- `since` token for a given `conn_id` for a device.#
|
|
19
|
+
--
|
|
20
|
+
-- Once a new connection is created and used we delete all other connections for
|
|
21
|
+
-- the `conn_id`.
|
|
22
|
+
CREATE TABLE sliding_sync_connections(
|
|
23
|
+
connection_key $%AUTO_INCREMENT_PRIMARY_KEY%$,
|
|
24
|
+
user_id TEXT NOT NULL,
|
|
25
|
+
-- Generally the device ID, but may be something else for e.g. puppeted accounts.
|
|
26
|
+
effective_device_id TEXT NOT NULL,
|
|
27
|
+
conn_id TEXT NOT NULL,
|
|
28
|
+
created_ts BIGINT NOT NULL
|
|
29
|
+
);
|
|
30
|
+
|
|
31
|
+
CREATE INDEX sliding_sync_connections_idx ON sliding_sync_connections(user_id, effective_device_id, conn_id);
|
|
32
|
+
CREATE INDEX sliding_sync_connections_ts_idx ON sliding_sync_connections(created_ts);
|
|
33
|
+
|
|
34
|
+
-- We track per-connection state by associating changes to the state with
|
|
35
|
+
-- connection positions. This ensures that we correctly track state even if we
|
|
36
|
+
-- see retries of requests.
|
|
37
|
+
--
|
|
38
|
+
-- If the client starts a "new" connection (by not specifying a since token),
|
|
39
|
+
-- we'll clear out the other connections (to ensure that we don't end up with
|
|
40
|
+
-- lots of connection keys).
|
|
41
|
+
CREATE TABLE sliding_sync_connection_positions(
|
|
42
|
+
connection_position $%AUTO_INCREMENT_PRIMARY_KEY%$,
|
|
43
|
+
connection_key BIGINT NOT NULL REFERENCES sliding_sync_connections(connection_key) ON DELETE CASCADE,
|
|
44
|
+
created_ts BIGINT NOT NULL
|
|
45
|
+
);
|
|
46
|
+
|
|
47
|
+
CREATE INDEX sliding_sync_connection_positions_key ON sliding_sync_connection_positions(connection_key);
|
|
48
|
+
CREATE INDEX sliding_sync_connection_positions_ts_idx ON sliding_sync_connection_positions(created_ts);
|
|
49
|
+
|
|
50
|
+
|
|
51
|
+
-- To save space we deduplicate the `required_state` json by assigning IDs to
|
|
52
|
+
-- different values.
|
|
53
|
+
CREATE TABLE sliding_sync_connection_required_state(
|
|
54
|
+
required_state_id $%AUTO_INCREMENT_PRIMARY_KEY%$,
|
|
55
|
+
connection_key BIGINT NOT NULL REFERENCES sliding_sync_connections(connection_key) ON DELETE CASCADE,
|
|
56
|
+
required_state TEXT NOT NULL -- We store this as a json list of event type / state key tuples.
|
|
57
|
+
);
|
|
58
|
+
|
|
59
|
+
CREATE INDEX sliding_sync_connection_required_state_conn_pos ON sliding_sync_connection_required_state(connection_key);
|
|
60
|
+
|
|
61
|
+
|
|
62
|
+
-- Stores the room configs we have seen for rooms in a connection.
|
|
63
|
+
CREATE TABLE sliding_sync_connection_room_configs(
|
|
64
|
+
connection_position BIGINT NOT NULL REFERENCES sliding_sync_connection_positions(connection_position) ON DELETE CASCADE,
|
|
65
|
+
room_id TEXT NOT NULL,
|
|
66
|
+
timeline_limit BIGINT NOT NULL,
|
|
67
|
+
required_state_id BIGINT NOT NULL REFERENCES sliding_sync_connection_required_state(required_state_id)
|
|
68
|
+
);
|
|
69
|
+
|
|
70
|
+
CREATE UNIQUE INDEX sliding_sync_connection_room_configs_idx ON sliding_sync_connection_room_configs(connection_position, room_id);
|
|
71
|
+
|
|
72
|
+
-- Stores what data we have sent for given streams down given connections.
|
|
73
|
+
CREATE TABLE sliding_sync_connection_streams(
|
|
74
|
+
connection_position BIGINT NOT NULL REFERENCES sliding_sync_connection_positions(connection_position) ON DELETE CASCADE,
|
|
75
|
+
stream TEXT NOT NULL, -- e.g. "events" or "receipts"
|
|
76
|
+
room_id TEXT NOT NULL,
|
|
77
|
+
room_status TEXT NOT NULL, -- "live" or "previously", i.e. the `HaveSentRoomFlag` value
|
|
78
|
+
last_token TEXT -- For "previously" the token for the stream we have sent up to.
|
|
79
|
+
);
|
|
80
|
+
|
|
81
|
+
CREATE UNIQUE INDEX sliding_sync_connection_streams_idx ON sliding_sync_connection_streams(connection_position, room_id, stream);
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
--
|
|
2
|
+
-- This file is licensed under the Affero General Public License (AGPL) version 3.
|
|
3
|
+
--
|
|
4
|
+
-- Copyright (C) 2024 New Vector, Ltd
|
|
5
|
+
--
|
|
6
|
+
-- This program is free software: you can redistribute it and/or modify
|
|
7
|
+
-- it under the terms of the GNU Affero General Public License as
|
|
8
|
+
-- published by the Free Software Foundation, either version 3 of the
|
|
9
|
+
-- License, or (at your option) any later version.
|
|
10
|
+
--
|
|
11
|
+
-- See the GNU Affero General Public License for more details:
|
|
12
|
+
-- <https://www.gnu.org/licenses/agpl-3.0.html>.
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
-- Add a background updates to add a new index:
|
|
16
|
+
-- `current_state_events(room_id, membership) WHERE type = 'm.room.member'
|
|
17
|
+
-- This makes counting membership in rooms (for syncs) much faster
|
|
18
|
+
INSERT INTO background_updates (ordering, update_name, progress_json) VALUES
|
|
19
|
+
(8701, 'current_state_events_members_room_index', '{}');
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
--
|
|
2
|
+
-- This file is licensed under the Affero General Public License (AGPL) version 3.
|
|
3
|
+
--
|
|
4
|
+
-- Copyright (C) 2024 New Vector, Ltd
|
|
5
|
+
--
|
|
6
|
+
-- This program is free software: you can redistribute it and/or modify
|
|
7
|
+
-- it under the terms of the GNU Affero General Public License as
|
|
8
|
+
-- published by the Free Software Foundation, either version 3 of the
|
|
9
|
+
-- License, or (at your option) any later version.
|
|
10
|
+
--
|
|
11
|
+
-- See the GNU Affero General Public License for more details:
|
|
12
|
+
-- <https://www.gnu.org/licenses/agpl-3.0.html>.
|
|
13
|
+
|
|
14
|
+
CREATE TABLE delayed_events (
|
|
15
|
+
delay_id TEXT NOT NULL,
|
|
16
|
+
user_localpart TEXT NOT NULL,
|
|
17
|
+
device_id TEXT,
|
|
18
|
+
delay BIGINT NOT NULL,
|
|
19
|
+
send_ts BIGINT NOT NULL,
|
|
20
|
+
room_id TEXT NOT NULL,
|
|
21
|
+
event_type TEXT NOT NULL,
|
|
22
|
+
state_key TEXT,
|
|
23
|
+
origin_server_ts BIGINT,
|
|
24
|
+
content bytea NOT NULL,
|
|
25
|
+
is_processed BOOLEAN NOT NULL DEFAULT FALSE,
|
|
26
|
+
PRIMARY KEY (user_localpart, delay_id)
|
|
27
|
+
);
|
|
28
|
+
|
|
29
|
+
CREATE INDEX delayed_events_send_ts ON delayed_events (send_ts);
|
|
30
|
+
CREATE INDEX delayed_events_is_processed ON delayed_events (is_processed);
|
|
31
|
+
CREATE INDEX delayed_events_room_state_event_idx ON delayed_events (room_id, event_type, state_key) WHERE state_key IS NOT NULL;
|
|
32
|
+
|
|
33
|
+
CREATE TABLE delayed_events_stream_pos (
|
|
34
|
+
Lock CHAR(1) NOT NULL DEFAULT 'X' UNIQUE, -- Makes sure this table only has one row.
|
|
35
|
+
stream_id BIGINT NOT NULL,
|
|
36
|
+
CHECK (Lock='X')
|
|
37
|
+
);
|
|
38
|
+
|
|
39
|
+
-- Start processing events from the point this migration was run, rather
|
|
40
|
+
-- than the beginning of time.
|
|
41
|
+
INSERT INTO delayed_events_stream_pos (
|
|
42
|
+
stream_id
|
|
43
|
+
) SELECT COALESCE(MAX(stream_ordering), 0) from events;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
--
|
|
2
|
+
-- This file is licensed under the Affero General Public License (AGPL) version 3.
|
|
3
|
+
--
|
|
4
|
+
-- Copyright (C) 2024 Patrick Cloke
|
|
5
|
+
--
|
|
6
|
+
-- This program is free software: you can redistribute it and/or modify
|
|
7
|
+
-- it under the terms of the GNU Affero General Public License as
|
|
8
|
+
-- published by the Free Software Foundation, either version 3 of the
|
|
9
|
+
-- License, or (at your option) any later version.
|
|
10
|
+
--
|
|
11
|
+
-- See the GNU Affero General Public License for more details:
|
|
12
|
+
-- <https://www.gnu.org/licenses/agpl-3.0.html>.
|
|
13
|
+
|
|
14
|
+
-- Custom profile fields.
|
|
15
|
+
ALTER TABLE profiles ADD COLUMN fields JSONB;
|
synapse/storage/schema/main/delta/88/02_fix_sliding_sync_membership_snapshots_forgotten_column.sql
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
--
|
|
2
|
+
-- This file is licensed under the Affero General Public License (AGPL) version 3.
|
|
3
|
+
--
|
|
4
|
+
-- Copyright (C) 2024 New Vector, Ltd
|
|
5
|
+
--
|
|
6
|
+
-- This program is free software: you can redistribute it and/or modify
|
|
7
|
+
-- it under the terms of the GNU Affero General Public License as
|
|
8
|
+
-- published by the Free Software Foundation, either version 3 of the
|
|
9
|
+
-- License, or (at your option) any later version.
|
|
10
|
+
--
|
|
11
|
+
-- See the GNU Affero General Public License for more details:
|
|
12
|
+
-- <https://www.gnu.org/licenses/agpl-3.0.html>.
|
|
13
|
+
|
|
14
|
+
-- Add a background update to update the `sliding_sync_membership_snapshots` ->
|
|
15
|
+
-- `forgotten` column to be in sync with the `room_memberships` table.
|
|
16
|
+
--
|
|
17
|
+
-- For any room that someone has forgotten and subsequently re-joined or had any new
|
|
18
|
+
-- membership on, we need to go and update the column to match the `room_memberships`
|
|
19
|
+
-- table as it has fallen out of sync.
|
|
20
|
+
INSERT INTO background_updates (ordering, update_name, progress_json) VALUES
|
|
21
|
+
(8802, 'sliding_sync_membership_snapshots_fix_forgotten_column_bg_update', '{}');
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
--
|
|
2
|
+
-- This file is licensed under the Affero General Public License (AGPL) version 3.
|
|
3
|
+
--
|
|
4
|
+
-- Copyright (C) 2024 New Vector, Ltd
|
|
5
|
+
--
|
|
6
|
+
-- This program is free software: you can redistribute it and/or modify
|
|
7
|
+
-- it under the terms of the GNU Affero General Public License as
|
|
8
|
+
-- published by the Free Software Foundation, either version 3 of the
|
|
9
|
+
-- License, or (at your option) any later version.
|
|
10
|
+
--
|
|
11
|
+
-- See the GNU Affero General Public License for more details:
|
|
12
|
+
-- <https://www.gnu.org/licenses/agpl-3.0.html>.
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
-- Add an index on (user_id, device_id, algorithm, ts_added_ms) on e2e_one_time_keys_json, so that OTKs can
|
|
16
|
+
-- efficiently be issued in the same order they were uploaded.
|
|
17
|
+
INSERT INTO background_updates (ordering, update_name, progress_json) VALUES
|
|
18
|
+
(8803, 'add_otk_ts_added_index', '{}');
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
--
|
|
2
|
+
-- This file is licensed under the Affero General Public License (AGPL) version 3.
|
|
3
|
+
--
|
|
4
|
+
-- Copyright (C) 2024 New Vector, Ltd
|
|
5
|
+
--
|
|
6
|
+
-- This program is free software: you can redistribute it and/or modify
|
|
7
|
+
-- it under the terms of the GNU Affero General Public License as
|
|
8
|
+
-- published by the Free Software Foundation, either version 3 of the
|
|
9
|
+
-- License, or (at your option) any later version.
|
|
10
|
+
--
|
|
11
|
+
-- See the GNU Affero General Public License for more details:
|
|
12
|
+
-- <https://www.gnu.org/licenses/agpl-3.0.html>.
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
-- Add an index on `current_state_delta_stream(room_id, stream_id)` to allow
|
|
16
|
+
-- efficient per-room lookups.
|
|
17
|
+
INSERT INTO background_updates (ordering, update_name, progress_json) VALUES
|
|
18
|
+
(8804, 'current_state_delta_stream_room_index', '{}');
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
--
|
|
2
|
+
-- This file is licensed under the Affero General Public License (AGPL) version 3.
|
|
3
|
+
--
|
|
4
|
+
-- Copyright (C) 2024 New Vector, Ltd
|
|
5
|
+
--
|
|
6
|
+
-- This program is free software: you can redistribute it and/or modify
|
|
7
|
+
-- it under the terms of the GNU Affero General Public License as
|
|
8
|
+
-- published by the Free Software Foundation, either version 3 of the
|
|
9
|
+
-- License, or (at your option) any later version.
|
|
10
|
+
--
|
|
11
|
+
-- See the GNU Affero General Public License for more details:
|
|
12
|
+
-- <https://www.gnu.org/licenses/agpl-3.0.html>.
|
|
13
|
+
|
|
14
|
+
-- Until Synapse 1.119, Synapse used to issue one-time-keys in a random order, leading to the possibility
|
|
15
|
+
-- that it could still have old OTKs that the client has dropped.
|
|
16
|
+
--
|
|
17
|
+
-- We create a scheduled task which will drop old OTKs, to flush them out.
|
|
18
|
+
INSERT INTO scheduled_tasks(id, action, status, timestamp)
|
|
19
|
+
VALUES ('delete_old_otks_task', 'delete_old_otks', 'scheduled', extract(epoch from current_timestamp) * 1000);
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
--
|
|
2
|
+
-- This file is licensed under the Affero General Public License (AGPL) version 3.
|
|
3
|
+
--
|
|
4
|
+
-- Copyright (C) 2024 New Vector, Ltd
|
|
5
|
+
--
|
|
6
|
+
-- This program is free software: you can redistribute it and/or modify
|
|
7
|
+
-- it under the terms of the GNU Affero General Public License as
|
|
8
|
+
-- published by the Free Software Foundation, either version 3 of the
|
|
9
|
+
-- License, or (at your option) any later version.
|
|
10
|
+
--
|
|
11
|
+
-- See the GNU Affero General Public License for more details:
|
|
12
|
+
-- <https://www.gnu.org/licenses/agpl-3.0.html>.
|
|
13
|
+
|
|
14
|
+
-- Until Synapse 1.119, Synapse used to issue one-time-keys in a random order, leading to the possibility
|
|
15
|
+
-- that it could still have old OTKs that the client has dropped.
|
|
16
|
+
--
|
|
17
|
+
-- We create a scheduled task which will drop old OTKs, to flush them out.
|
|
18
|
+
INSERT INTO scheduled_tasks(id, action, status, timestamp)
|
|
19
|
+
VALUES ('delete_old_otks_task', 'delete_old_otks', 'scheduled', strftime('%s', 'now') * 1000);
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
--
|
|
2
|
+
-- This file is licensed under the Affero General Public License (AGPL) version 3.
|
|
3
|
+
--
|
|
4
|
+
-- Copyright (C) 2024 New Vector, Ltd
|
|
5
|
+
--
|
|
6
|
+
-- This program is free software: you can redistribute it and/or modify
|
|
7
|
+
-- it under the terms of the GNU Affero General Public License as
|
|
8
|
+
-- published by the Free Software Foundation, either version 3 of the
|
|
9
|
+
-- License, or (at your option) any later version.
|
|
10
|
+
--
|
|
11
|
+
-- See the GNU Affero General Public License for more details:
|
|
12
|
+
-- <https://www.gnu.org/licenses/agpl-3.0.html>.
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
-- Add an index on sliding_sync_connection_room_configs(required_state_id), so
|
|
16
|
+
-- that when we delete entries in `sliding_sync_connection_required_state` it's
|
|
17
|
+
-- efficient for Postgres to check they've been deleted from
|
|
18
|
+
-- `sliding_sync_connection_room_configs` too
|
|
19
|
+
INSERT INTO background_updates (ordering, update_name, progress_json) VALUES
|
|
20
|
+
(8805, 'sliding_sync_connection_room_configs_required_state_id_idx', '{}');
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
--
|
|
2
|
+
-- This file is licensed under the Affero General Public License (AGPL) version 3.
|
|
3
|
+
--
|
|
4
|
+
-- Copyright (C) 2024 New Vector, Ltd
|
|
5
|
+
--
|
|
6
|
+
-- This program is free software: you can redistribute it and/or modify
|
|
7
|
+
-- it under the terms of the GNU Affero General Public License as
|
|
8
|
+
-- published by the Free Software Foundation, either version 3 of the
|
|
9
|
+
-- License, or (at your option) any later version.
|
|
10
|
+
--
|
|
11
|
+
-- See the GNU Affero General Public License for more details:
|
|
12
|
+
-- <https://www.gnu.org/licenses/agpl-3.0.html>.
|
|
13
|
+
|
|
14
|
+
-- Add an index on `events.received_ts` for `m.room.member` events to allow for
|
|
15
|
+
-- efficient lookup of events by timestamp in some Admin API's
|
|
16
|
+
INSERT INTO background_updates (ordering, update_name, progress_json) VALUES
|
|
17
|
+
(8806, 'events_received_ts_index', '{}');
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
--
|
|
2
|
+
-- This file is licensed under the Affero General Public License (AGPL) version 3.
|
|
3
|
+
--
|
|
4
|
+
-- Copyright (C) 2025 New Vector, Ltd
|
|
5
|
+
--
|
|
6
|
+
-- This program is free software: you can redistribute it and/or modify
|
|
7
|
+
-- it under the terms of the GNU Affero General Public License as
|
|
8
|
+
-- published by the Free Software Foundation, either version 3 of the
|
|
9
|
+
-- License, or (at your option) any later version.
|
|
10
|
+
--
|
|
11
|
+
-- See the GNU Affero General Public License for more details:
|
|
12
|
+
-- <https://www.gnu.org/licenses/agpl-3.0.html>.
|
|
13
|
+
|
|
14
|
+
INSERT INTO background_updates (ordering, update_name, progress_json) VALUES
|
|
15
|
+
(8901, 'sliding_sync_membership_snapshots_membership_event_id_idx', '{}');
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
--
|
|
2
|
+
-- This file is licensed under the Affero General Public License (AGPL) version 3.
|
|
3
|
+
--
|
|
4
|
+
-- Copyright (C) 2025 New Vector, Ltd
|
|
5
|
+
--
|
|
6
|
+
-- This program is free software: you can redistribute it and/or modify
|
|
7
|
+
-- it under the terms of the GNU Affero General Public License as
|
|
8
|
+
-- published by the Free Software Foundation, either version 3 of the
|
|
9
|
+
-- License, or (at your option) any later version.
|
|
10
|
+
--
|
|
11
|
+
-- See the GNU Affero General Public License for more details:
|
|
12
|
+
-- <https://www.gnu.org/licenses/agpl-3.0.html>.
|
|
13
|
+
|
|
14
|
+
-- Add a column `participant` to `room_memberships` table to track whether a room member has sent
|
|
15
|
+
-- a `m.room.message` or `m.room.encrypted` event into a room they are a member of
|
|
16
|
+
ALTER TABLE room_memberships ADD COLUMN participant BOOLEAN DEFAULT FALSE;
|