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