From 849a9b184d301576e302faafca01b210fb453bf1 Mon Sep 17 00:00:00 2001 From: Action Bot Date: Mon, 11 Dec 2023 14:54:15 +0000 Subject: [PATCH] Version picker deployed for v1.84 docs to Github Pages --- v1.84/.nojekyll | 1 - v1.84/.sample_config_header.yaml | 12 -- v1.84/404.html | 17 ++- v1.84/CAPTCHA_SETUP.html | 17 ++- v1.84/admin_api/account_validity.html | 17 ++- v1.84/admin_api/event_reports.html | 17 ++- v1.84/admin_api/experimental_features.html | 17 ++- v1.84/admin_api/media_admin_api.html | 17 ++- v1.84/admin_api/purge_history_api.html | 17 ++- v1.84/admin_api/register_api.html | 17 ++- v1.84/admin_api/room_membership.html | 17 ++- v1.84/admin_api/rooms.html | 17 ++- v1.84/admin_api/server_notices.html | 17 ++- v1.84/admin_api/statistics.html | 17 ++- v1.84/admin_api/user_admin_api.html | 17 ++- v1.84/admin_api/version_api.html | 17 ++- v1.84/application_services.html | 17 ++- v1.84/auth_chain_difference_algorithm.html | 17 ++- v1.84/code_style.html | 17 ++- v1.84/consent_tracking.html | 17 ++- v1.84/delegate.html | 17 ++- v1.84/deprecation_policy.html | 17 ++- v1.84/development/cas.html | 17 ++- v1.84/development/contributing_guide.html | 17 ++- v1.84/development/database_schema.html | 17 ++- v1.84/development/demo.html | 17 ++- v1.84/development/dependencies.html | 17 ++- v1.84/development/experimental_features.html | 17 ++- v1.84/development/git.html | 17 ++- .../internal_documentation/index.html | 17 ++- v1.84/development/releases.html | 17 ++- v1.84/development/reviews.html | 17 ++- v1.84/development/room-dag-concepts.html | 17 ++- v1.84/development/saml.html | 17 ++- .../synapse_architecture/cancellation.html | 17 ++- .../synapse_architecture/faster_joins.html | 17 ++- v1.84/docs/website_files/version-picker.css | 78 +++++++++++ v1.84/docs/website_files/version-picker.js | 127 ++++++++++++++++++ v1.84/docs/website_files/version.js | 1 + v1.84/federate.html | 17 ++- v1.84/index.html | 17 ++- v1.84/jwt.html | 17 ++- v1.84/log_contexts.html | 17 ++- v1.84/manhole.html | 17 ++- v1.84/media_repository.html | 17 ++- v1.84/message_retention_policies.html | 17 ++- v1.84/metrics-howto.html | 17 ++- v1.84/modules/account_data_callbacks.html | 17 ++- v1.84/modules/account_validity_callbacks.html | 17 ++- ...ackground_update_controller_callbacks.html | 17 ++- v1.84/modules/index.html | 17 ++- .../password_auth_provider_callbacks.html | 17 ++- v1.84/modules/porting_legacy_module.html | 17 ++- v1.84/modules/presence_router_callbacks.html | 17 ++- v1.84/modules/spam_checker_callbacks.html | 17 ++- .../modules/third_party_rules_callbacks.html | 17 ++- v1.84/modules/writing_a_module.html | 17 ++- v1.84/openid.html | 17 ++- v1.84/opentracing.html | 17 ++- ...ing_synapse_on_single_board_computers.html | 17 ++- v1.84/password_auth_providers.html | 17 ++- v1.84/postgres.html | 17 ++- v1.84/print.html | 17 ++- v1.84/replication.html | 17 ++- v1.84/reverse_proxy.html | 17 ++- v1.84/room_and_user_statistics.html | 17 ++- v1.84/server_notices.html | 17 ++- v1.84/setup/forward_proxy.html | 17 ++- v1.84/setup/installation.html | 17 ++- v1.84/setup/turn/coturn.html | 17 ++- v1.84/setup/turn/eturnal.html | 17 ++- v1.84/sso_mapping_providers.html | 17 ++- v1.84/structured_logging.html | 17 ++- v1.84/synctl_workers.html | 17 ++- v1.84/systemd-with-workers/index.html | 17 ++- v1.84/tcp_replication.html | 17 ++- v1.84/templates.html | 17 ++- v1.84/turn-howto.html | 17 ++- v1.84/upgrade.html | 17 ++- .../admin_api/background_updates.html | 17 ++- .../administration/admin_api/federation.html | 17 ++- .../usage/administration/admin_api/index.html | 17 ++- .../admin_api/registration_tokens.html | 17 ++- v1.84/usage/administration/admin_faq.html | 17 ++- .../database_maintenance_tools.html | 17 ++- v1.84/usage/administration/index.html | 17 ++- ...reporting_homeserver_usage_statistics.html | 17 ++- .../administration/monthly_active_users.html | 17 ++- v1.84/usage/administration/request_log.html | 17 ++- v1.84/usage/administration/state_groups.html | 17 ++- ...anding_synapse_through_grafana_graphs.html | 17 ++- .../administration/useful_sql_for_admins.html | 17 ++- .../configuration/config_documentation.html | 17 ++- .../homeserver_sample_config.html | 17 ++- v1.84/usage/configuration/index.html | 17 ++- .../configuration/logging_sample_config.html | 17 ++- .../user_authentication/index.html | 17 ++- .../user_authentication/refresh_tokens.html | 17 ++- .../single_sign_on/cas.html | 17 ++- .../single_sign_on/index.html | 17 ++- .../single_sign_on/saml.html | 17 ++- v1.84/user_directory.html | 17 ++- v1.84/website_files/theme/index.hbs | 14 +- v1.84/website_files/version-picker.css | 78 +++++++++++ v1.84/website_files/version-picker.js | 127 ++++++++++++++++++ v1.84/website_files/version.js | 1 + v1.84/welcome_and_overview.html | 17 ++- v1.84/workers.html | 17 ++- 108 files changed, 2009 insertions(+), 113 deletions(-) delete mode 100644 v1.84/.nojekyll delete mode 100644 v1.84/.sample_config_header.yaml create mode 100644 v1.84/docs/website_files/version-picker.css create mode 100644 v1.84/docs/website_files/version-picker.js create mode 100644 v1.84/docs/website_files/version.js create mode 100644 v1.84/website_files/version-picker.css create mode 100644 v1.84/website_files/version-picker.js create mode 100644 v1.84/website_files/version.js diff --git a/v1.84/.nojekyll b/v1.84/.nojekyll deleted file mode 100644 index f17311098f..0000000000 --- a/v1.84/.nojekyll +++ /dev/null @@ -1 +0,0 @@ -This file makes sure that Github Pages doesn't process mdBook's output. diff --git a/v1.84/.sample_config_header.yaml b/v1.84/.sample_config_header.yaml deleted file mode 100644 index 2355337e6d..0000000000 --- a/v1.84/.sample_config_header.yaml +++ /dev/null @@ -1,12 +0,0 @@ -# This file is maintained as an up-to-date snapshot of the default -# homeserver.yaml configuration generated by Synapse. You can find a -# complete accounting of possible configuration options at -# https://matrix-org.github.io/synapse/latest/usage/configuration/config_documentation.html -# -# It is *not* intended to be copied and used as the basis for a real -# homeserver.yaml. Instead, if you are starting from scratch, please generate -# a fresh config using Synapse by following the instructions in -# https://matrix-org.github.io/synapse/latest/setup/installation.html. -# -################################################################################ - diff --git a/v1.84/404.html b/v1.84/404.html index e4cdd912a2..58cdfd04d6 100644 --- a/v1.84/404.html +++ b/v1.84/404.html @@ -29,6 +29,7 @@ + @@ -104,6 +105,18 @@ +
+ +

Synapse

@@ -173,5 +186,7 @@ + + - \ No newline at end of file + diff --git a/v1.84/CAPTCHA_SETUP.html b/v1.84/CAPTCHA_SETUP.html index ed7e8c4ffc..f137d3a16c 100644 --- a/v1.84/CAPTCHA_SETUP.html +++ b/v1.84/CAPTCHA_SETUP.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -220,5 +233,7 @@ listeners section of the homeserver.yaml configuration file.

+ + - \ No newline at end of file + diff --git a/v1.84/admin_api/account_validity.html b/v1.84/admin_api/account_validity.html index 8c73efd2bf..ac7724c2c1 100644 --- a/v1.84/admin_api/account_validity.html +++ b/v1.84/admin_api/account_validity.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -214,5 +227,7 @@ milliseconds since epoch:

+ + - \ No newline at end of file + diff --git a/v1.84/admin_api/event_reports.html b/v1.84/admin_api/event_reports.html index 79bf44a935..321767503f 100644 --- a/v1.84/admin_api/event_reports.html +++ b/v1.84/admin_api/event_reports.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -348,5 +361,7 @@ will be an empty JSON object.

+ + - \ No newline at end of file + diff --git a/v1.84/admin_api/experimental_features.html b/v1.84/admin_api/experimental_features.html index 046c6874da..fe68b1a8cc 100644 --- a/v1.84/admin_api/experimental_features.html +++ b/v1.84/admin_api/experimental_features.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -226,5 +239,7 @@ user like so:

+ + - \ No newline at end of file + diff --git a/v1.84/admin_api/media_admin_api.html b/v1.84/admin_api/media_admin_api.html index e26846a1f3..21dec5e570 100644 --- a/v1.84/admin_api/media_admin_api.html +++ b/v1.84/admin_api/media_admin_api.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -403,5 +416,7 @@ from the originating server.

+ + - \ No newline at end of file + diff --git a/v1.84/admin_api/purge_history_api.html b/v1.84/admin_api/purge_history_api.html index 28f693ec4f..75fe38c6aa 100644 --- a/v1.84/admin_api/purge_history_api.html +++ b/v1.84/admin_api/purge_history_api.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -234,5 +247,7 @@ a purge id:

+ + - \ No newline at end of file + diff --git a/v1.84/admin_api/register_api.html b/v1.84/admin_api/register_api.html index f1407aa8d6..e26485575b 100644 --- a/v1.84/admin_api/register_api.html +++ b/v1.84/admin_api/register_api.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -259,5 +272,7 @@ def generate_mac(nonce, user, password, admin=False, user_type=None): + + - \ No newline at end of file + diff --git a/v1.84/admin_api/room_membership.html b/v1.84/admin_api/room_membership.html index e79f987e7d..15ad8b6ac9 100644 --- a/v1.84/admin_api/room_membership.html +++ b/v1.84/admin_api/room_membership.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -211,5 +224,7 @@ for a server admin: see Admin API + + - \ No newline at end of file + diff --git a/v1.84/admin_api/rooms.html b/v1.84/admin_api/rooms.html index b4583c8936..da552617c5 100644 --- a/v1.84/admin_api/rooms.html +++ b/v1.84/admin_api/rooms.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -1138,5 +1151,7 @@ that were deleted.

+ + - \ No newline at end of file + diff --git a/v1.84/admin_api/server_notices.html b/v1.84/admin_api/server_notices.html index c895b5f65d..bb154b804b 100644 --- a/v1.84/admin_api/server_notices.html +++ b/v1.84/admin_api/server_notices.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -216,5 +229,7 @@ can be used. See
the server notices documentati + + - \ No newline at end of file + diff --git a/v1.84/admin_api/statistics.html b/v1.84/admin_api/statistics.html index 4bf39652a8..801fccbae1 100644 --- a/v1.84/admin_api/statistics.html +++ b/v1.84/admin_api/statistics.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -295,5 +308,7 @@ in the database. + + - \ No newline at end of file + diff --git a/v1.84/admin_api/user_admin_api.html b/v1.84/admin_api/user_admin_api.html index 55af2cadb6..512a995027 100644 --- a/v1.84/admin_api/user_admin_api.html +++ b/v1.84/admin_api/user_admin_api.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -1258,5 +1271,7 @@ for more information.

+ + - \ No newline at end of file + diff --git a/v1.84/admin_api/version_api.html b/v1.84/admin_api/version_api.html index 5b708befc3..6ded142ed6 100644 --- a/v1.84/admin_api/version_api.html +++ b/v1.84/admin_api/version_api.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -199,5 +212,7 @@ contains Synapse version information).

+ + - \ No newline at end of file + diff --git a/v1.84/application_services.html b/v1.84/application_services.html index d710b93369..3c54beb8e7 100644 --- a/v1.84/application_services.html +++ b/v1.84/application_services.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -212,5 +225,7 @@ namespaces: + + - \ No newline at end of file + diff --git a/v1.84/auth_chain_difference_algorithm.html b/v1.84/auth_chain_difference_algorithm.html index c7fe5ab185..be93cbe4fe 100644 --- a/v1.84/auth_chain_difference_algorithm.html +++ b/v1.84/auth_chain_difference_algorithm.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -306,5 +319,7 @@ level). + + - \ No newline at end of file + diff --git a/v1.84/code_style.html b/v1.84/code_style.html index 004a191579..ff5b5de488 100644 --- a/v1.84/code_style.html +++ b/v1.84/code_style.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -304,5 +317,7 @@ is left as an exercise for the reader!

+ + - \ No newline at end of file + diff --git a/v1.84/consent_tracking.html b/v1.84/consent_tracking.html index 573b5603ad..11a49a17d1 100644 --- a/v1.84/consent_tracking.html +++ b/v1.84/consent_tracking.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -346,5 +359,7 @@ URI that clients use to connect to the server. (It is used to construct + + - \ No newline at end of file + diff --git a/v1.84/delegate.html b/v1.84/delegate.html index bc8d358910..781d6874b8 100644 --- a/v1.84/delegate.html +++ b/v1.84/delegate.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -265,5 +278,7 @@ reverse proxy.

+ + - \ No newline at end of file + diff --git a/v1.84/deprecation_policy.html b/v1.84/deprecation_policy.html index b03a66c973..31829e301c 100644 --- a/v1.84/deprecation_policy.html +++ b/v1.84/deprecation_policy.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -223,5 +236,7 @@ and is consistent with the .deb packages released by Matrix.org.

+ + - \ No newline at end of file + diff --git a/v1.84/development/cas.html b/v1.84/development/cas.html index 193205b1d6..f79041784d 100644 --- a/v1.84/development/cas.html +++ b/v1.84/development/cas.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -247,5 +260,7 @@ and that the CAS server is on port 8000, both on localhost.

+ + - \ No newline at end of file + diff --git a/v1.84/development/contributing_guide.html b/v1.84/development/contributing_guide.html index 290b37bcee..bc8d73ad45 100644 --- a/v1.84/development/contributing_guide.html +++ b/v1.84/development/contributing_guide.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -620,5 +633,7 @@ do!

+ + - \ No newline at end of file + diff --git a/v1.84/development/database_schema.html b/v1.84/development/database_schema.html index fe1e178fb5..f2e6a4558f 100644 --- a/v1.84/development/database_schema.html +++ b/v1.84/development/database_schema.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -334,5 +347,7 @@ will never happen (SHA256 has a massive big key space).

+ + - \ No newline at end of file + diff --git a/v1.84/development/demo.html b/v1.84/development/demo.html index 11d7469f70..2ea7487f5b 100644 --- a/v1.84/development/demo.html +++ b/v1.84/development/demo.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -220,5 +233,7 @@ name.

+ + - \ No newline at end of file + diff --git a/v1.84/development/dependencies.html b/v1.84/development/dependencies.html index 8435095574..7d8f0b6707 100644 --- a/v1.84/development/dependencies.html +++ b/v1.84/development/dependencies.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -401,5 +414,7 @@ letting Poetry do the right thing.

+ + - \ No newline at end of file + diff --git a/v1.84/development/experimental_features.html b/v1.84/development/experimental_features.html index f077a2a1af..26ccd2942e 100644 --- a/v1.84/development/experimental_features.html +++ b/v1.84/development/experimental_features.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -218,5 +231,7 @@ configuration key (see the synapse.config.experimental file) and ei + + - \ No newline at end of file + diff --git a/v1.84/development/git.html b/v1.84/development/git.html index dfbb987e67..94eb9c0b41 100644 --- a/v1.84/development/git.html +++ b/v1.84/development/git.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -306,5 +319,7 @@ the history of Synapse), we've had two releases in flight at once. Obviously, + + - \ No newline at end of file + diff --git a/v1.84/development/internal_documentation/index.html b/v1.84/development/internal_documentation/index.html index 1f1015dbed..d509a7ff33 100644 --- a/v1.84/development/internal_documentation/index.html +++ b/v1.84/development/internal_documentation/index.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -194,5 +207,7 @@ under the Usage section of the documentation.

+ + - \ No newline at end of file + diff --git a/v1.84/development/releases.html b/v1.84/development/releases.html index 83330e341d..82db96b8cd 100644 --- a/v1.84/development/releases.html +++ b/v1.84/development/releases.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -215,5 +228,7 @@ found in the
security catego + + - \ No newline at end of file + diff --git a/v1.84/development/reviews.html b/v1.84/development/reviews.html index 26e589db32..280ba9fb27 100644 --- a/v1.84/development/reviews.html +++ b/v1.84/development/reviews.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -218,5 +231,7 @@ with the rationale on why you're putting it back in the queue.

+ + - \ No newline at end of file + diff --git a/v1.84/development/room-dag-concepts.html b/v1.84/development/room-dag-concepts.html index b61d197b36..d71ad32bdd 100644 --- a/v1.84/development/room-dag-concepts.html +++ b/v1.84/development/room-dag-concepts.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -274,5 +287,7 @@ notes from @Azrenbeth, https://pastebin.com/seUGVGeT

+ + - \ No newline at end of file + diff --git a/v1.84/development/saml.html b/v1.84/development/saml.html index 1a989d6454..475b1eb4b4 100644 --- a/v1.84/development/saml.html +++ b/v1.84/development/saml.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -223,5 +236,7 @@ samling page and clear the site data. In Chrome, this will be a button on the Ap + + - \ No newline at end of file + diff --git a/v1.84/development/synapse_architecture/cancellation.html b/v1.84/development/synapse_architecture/cancellation.html index b2c1680ed5..f6f1d98e92 100644 --- a/v1.84/development/synapse_architecture/cancellation.html +++ b/v1.84/development/synapse_architecture/cancellation.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -532,5 +545,7 @@ with LoggingContext("request-1"): + + - \ No newline at end of file + diff --git a/v1.84/development/synapse_architecture/faster_joins.html b/v1.84/development/synapse_architecture/faster_joins.html index 925ba53fe7..d9d9282db0 100644 --- a/v1.84/development/synapse_architecture/faster_joins.html +++ b/v1.84/development/synapse_architecture/faster_joins.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
+ +

Synapse

@@ -526,5 +539,7 @@ work?

+ + - \ No newline at end of file + diff --git a/v1.84/docs/website_files/version-picker.css b/v1.84/docs/website_files/version-picker.css new file mode 100644 index 0000000000..28e5d5219a --- /dev/null +++ b/v1.84/docs/website_files/version-picker.css @@ -0,0 +1,78 @@ +.version-picker { + display: flex; + align-items: center; +} + +.version-picker .dropdown { + width: 130px; + max-height: 29px; + margin-left: 10px; + display: inline-block; + border-radius: 4px; + border: 1px solid var(--theme-popup-border); + position: relative; + font-size: 13px; + color: var(--fg); + height: 100%; + text-align: left; +} +.version-picker .dropdown .select { + cursor: pointer; + display: block; + padding: 5px 2px 5px 15px; +} +.version-picker .dropdown .select > i { + font-size: 10px; + color: var(--fg); + cursor: pointer; + float: right; + line-height: 20px !important; +} +.version-picker .dropdown:hover { + border: 1px solid var(--theme-popup-border); +} +.version-picker .dropdown:active { + background-color: var(--theme-popup-bg); +} +.version-picker .dropdown.active:hover, +.version-picker .dropdown.active { + border: 1px solid var(--theme-popup-border); + border-radius: 2px 2px 0 0; + background-color: var(--theme-popup-bg); +} +.version-picker .dropdown.active .select > i { + transform: rotate(-180deg); +} +.version-picker .dropdown .dropdown-menu { + position: absolute; + background-color: var(--theme-popup-bg); + width: 100%; + left: -1px; + right: 1px; + margin-top: 1px; + border: 1px solid var(--theme-popup-border); + border-radius: 0 0 4px 4px; + overflow: hidden; + display: none; + max-height: 300px; + overflow-y: auto; + z-index: 9; +} +.version-picker .dropdown .dropdown-menu li { + font-size: 12px; + padding: 6px 20px; + cursor: pointer; +} +.version-picker .dropdown .dropdown-menu { + padding: 0; + list-style: none; +} +.version-picker .dropdown .dropdown-menu li:hover { + background-color: var(--theme-hover); +} +.version-picker .dropdown .dropdown-menu li.active::before { + display: inline-block; + content: "✓"; + margin-inline-start: -14px; + width: 14px; +} \ No newline at end of file diff --git a/v1.84/docs/website_files/version-picker.js b/v1.84/docs/website_files/version-picker.js new file mode 100644 index 0000000000..bb35a7d896 --- /dev/null +++ b/v1.84/docs/website_files/version-picker.js @@ -0,0 +1,127 @@ + +const dropdown = document.querySelector('.version-picker .dropdown'); +const dropdownMenu = dropdown.querySelector('.dropdown-menu'); + +fetchVersions(dropdown, dropdownMenu).then(() => { + initializeVersionDropdown(dropdown, dropdownMenu); +}); + +/** + * Initialize the dropdown functionality for version selection. + * + * @param {Element} dropdown - The dropdown element. + * @param {Element} dropdownMenu - The dropdown menu element. + */ +function initializeVersionDropdown(dropdown, dropdownMenu) { + // Toggle the dropdown menu on click + dropdown.addEventListener('click', function () { + this.setAttribute('tabindex', 1); + this.classList.toggle('active'); + dropdownMenu.style.display = (dropdownMenu.style.display === 'block') ? 'none' : 'block'; + }); + + // Remove the 'active' class and hide the dropdown menu on focusout + dropdown.addEventListener('focusout', function () { + this.classList.remove('active'); + dropdownMenu.style.display = 'none'; + }); + + // Handle item selection within the dropdown menu + const dropdownMenuItems = dropdownMenu.querySelectorAll('li'); + dropdownMenuItems.forEach(function (item) { + item.addEventListener('click', function () { + dropdownMenuItems.forEach(function (item) { + item.classList.remove('active'); + }); + this.classList.add('active'); + dropdown.querySelector('span').textContent = this.textContent; + dropdown.querySelector('input').value = this.getAttribute('id'); + + window.location.href = changeVersion(window.location.href, this.textContent); + }); + }); +}; + +/** + * This function fetches the available versions from a GitHub repository + * and inserts them into the version picker. + * + * @param {Element} dropdown - The dropdown element. + * @param {Element} dropdownMenu - The dropdown menu element. + * @returns {Promise>} A promise that resolves with an array of available versions. + */ +function fetchVersions(dropdown, dropdownMenu) { + return new Promise((resolve, reject) => { + window.addEventListener("load", () => { + + fetch("https://api.github.com/repos/matrix-org/synapse/git/trees/gh-pages", { + cache: "force-cache", + }).then(res => + res.json() + ).then(resObject => { + const excluded = ['dev-docs', 'v1.91.0', 'v1.80.0', 'v1.69.0']; + const tree = resObject.tree.filter(item => item.type === "tree" && !excluded.includes(item.path)); + const versions = tree.map(item => item.path).sort(sortVersions); + + // Create a list of
  • items for versions + versions.forEach((version) => { + const li = document.createElement("li"); + li.textContent = version; + li.id = version; + + if (window.SYNAPSE_VERSION === version) { + li.classList.add('active'); + dropdown.querySelector('span').textContent = version; + dropdown.querySelector('input').value = version; + } + + dropdownMenu.appendChild(li); + }); + + resolve(versions); + + }).catch(ex => { + console.error("Failed to fetch version data", ex); + reject(ex); + }) + }); + }); +} + +/** + * Custom sorting function to sort an array of version strings. + * + * @param {string} a - The first version string to compare. + * @param {string} b - The second version string to compare. + * @returns {number} - A negative number if a should come before b, a positive number if b should come before a, or 0 if they are equal. + */ +function sortVersions(a, b) { + // Put 'develop' and 'latest' at the top + if (a === 'develop' || a === 'latest') return -1; + if (b === 'develop' || b === 'latest') return 1; + + const versionA = (a.match(/v\d+(\.\d+)+/) || [])[0]; + const versionB = (b.match(/v\d+(\.\d+)+/) || [])[0]; + + return versionB.localeCompare(versionA); +} + +/** + * Change the version in a URL path. + * + * @param {string} url - The original URL to be modified. + * @param {string} newVersion - The new version to replace the existing version in the URL. + * @returns {string} The updated URL with the new version. + */ +function changeVersion(url, newVersion) { + const parsedURL = new URL(url); + const pathSegments = parsedURL.pathname.split('/'); + + // Modify the version + pathSegments[2] = newVersion; + + // Reconstruct the URL + parsedURL.pathname = pathSegments.join('/'); + + return parsedURL.href; +} \ No newline at end of file diff --git a/v1.84/docs/website_files/version.js b/v1.84/docs/website_files/version.js new file mode 100644 index 0000000000..cd39e869c8 --- /dev/null +++ b/v1.84/docs/website_files/version.js @@ -0,0 +1 @@ +window.SYNAPSE_VERSION = 'v1.84'; diff --git a/v1.84/federate.html b/v1.84/federate.html index f96c47cbcf..3f650c364d 100644 --- a/v1.84/federate.html +++ b/v1.84/federate.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -238,5 +251,7 @@ useful just for development purposes. See + + - \ No newline at end of file + diff --git a/v1.84/index.html b/v1.84/index.html index a52dd12d95..76f290c703 100644 --- a/v1.84/index.html +++ b/v1.84/index.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -264,5 +277,7 @@ Policy
    . Thank you!

    + + - \ No newline at end of file + diff --git a/v1.84/jwt.html b/v1.84/jwt.html index d739c35e4d..0523615d22 100644 --- a/v1.84/jwt.html +++ b/v1.84/jwt.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -281,5 +294,7 @@ print(result.decode("ascii")) + + - \ No newline at end of file + diff --git a/v1.84/log_contexts.html b/v1.84/log_contexts.html index 9f5ac779b1..05b6d2fa1a 100644 --- a/v1.84/log_contexts.html +++ b/v1.84/log_contexts.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -481,5 +494,7 @@ lead to leaked logcontexts which are incredibly hard to track down.

    + + - \ No newline at end of file + diff --git a/v1.84/manhole.html b/v1.84/manhole.html index 2b44f9d8f9..9bbbc730ef 100644 --- a/v1.84/manhole.html +++ b/v1.84/manhole.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -254,5 +267,7 @@ parts of the process.

    + + - \ No newline at end of file + diff --git a/v1.84/media_repository.html b/v1.84/media_repository.html index 7e26d76bab..3287589a44 100644 --- a/v1.84/media_repository.html +++ b/v1.84/media_repository.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -245,5 +258,7 @@ url_cache_thumbnails/yyyy-mm-dd/aaaaaaaaaaaaaaaa/128-96-image-jpeg-scale + + - \ No newline at end of file + diff --git a/v1.84/message_retention_policies.html b/v1.84/message_retention_policies.html index e8fbed4611..c0af4a3daa 100644 --- a/v1.84/message_retention_policies.html +++ b/v1.84/message_retention_policies.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -342,5 +355,7 @@ operating system, the server admin needs to run VACUUM FULL; (or + + - \ No newline at end of file + diff --git a/v1.84/metrics-howto.html b/v1.84/metrics-howto.html index b53377c476..797ec387c0 100644 --- a/v1.84/metrics-howto.html +++ b/v1.84/metrics-howto.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -458,5 +471,7 @@ renamed.

    + + - \ No newline at end of file + diff --git a/v1.84/modules/account_data_callbacks.html b/v1.84/modules/account_data_callbacks.html index 6e45ffcf38..bd18ad186f 100644 --- a/v1.84/modules/account_data_callbacks.html +++ b/v1.84/modules/account_data_callbacks.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -276,5 +289,7 @@ class CustomAccountDataModule: + + - \ No newline at end of file + diff --git a/v1.84/modules/account_validity_callbacks.html b/v1.84/modules/account_validity_callbacks.html index a61463342f..63428bb8f6 100644 --- a/v1.84/modules/account_validity_callbacks.html +++ b/v1.84/modules/account_validity_callbacks.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -214,5 +227,7 @@ represented by their Matrix user ID.

    + + - \ No newline at end of file + diff --git a/v1.84/modules/background_update_controller_callbacks.html b/v1.84/modules/background_update_controller_callbacks.html index e954537ec7..e0be754a03 100644 --- a/v1.84/modules/background_update_controller_callbacks.html +++ b/v1.84/modules/background_update_controller_callbacks.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -232,5 +245,7 @@ ensure that progress is always made.

    + + - \ No newline at end of file + diff --git a/v1.84/modules/index.html b/v1.84/modules/index.html index b6c3f98dc5..974a455a88 100644 --- a/v1.84/modules/index.html +++ b/v1.84/modules/index.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -227,5 +240,7 @@ another part of Synapse's configuration file.

    + + - \ No newline at end of file + diff --git a/v1.84/modules/password_auth_provider_callbacks.html b/v1.84/modules/password_auth_provider_callbacks.html index cd68b32bf9..5e31141408 100644 --- a/v1.84/modules/password_auth_provider_callbacks.html +++ b/v1.84/modules/password_auth_provider_callbacks.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -422,5 +435,7 @@ class MyAuthProvider: + + - \ No newline at end of file + diff --git a/v1.84/modules/porting_legacy_module.html b/v1.84/modules/porting_legacy_module.html index 85f3c55082..c675925235 100644 --- a/v1.84/modules/porting_legacy_module.html +++ b/v1.84/modules/porting_legacy_module.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -202,5 +215,7 @@ for more info).

    + + - \ No newline at end of file + diff --git a/v1.84/modules/presence_router_callbacks.html b/v1.84/modules/presence_router_callbacks.html index 2747fbebe3..ce941ac162 100644 --- a/v1.84/modules/presence_router_callbacks.html +++ b/v1.84/modules/presence_router_callbacks.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -267,5 +280,7 @@ class CustomPresenceRouter: + + - \ No newline at end of file + diff --git a/v1.84/modules/spam_checker_callbacks.html b/v1.84/modules/spam_checker_callbacks.html index 7f816cf92c..bd491201fc 100644 --- a/v1.84/modules/spam_checker_callbacks.html +++ b/v1.84/modules/spam_checker_callbacks.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -537,5 +550,7 @@ class ListSpamChecker: + + - \ No newline at end of file + diff --git a/v1.84/modules/third_party_rules_callbacks.html b/v1.84/modules/third_party_rules_callbacks.html index 495af9c1b7..55e92a9b96 100644 --- a/v1.84/modules/third_party_rules_callbacks.html +++ b/v1.84/modules/third_party_rules_callbacks.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -433,5 +446,7 @@ class EventCensorer: + + - \ No newline at end of file + diff --git a/v1.84/modules/writing_a_module.html b/v1.84/modules/writing_a_module.html index e731074390..9dd327fc29 100644 --- a/v1.84/modules/writing_a_module.html +++ b/v1.84/modules/writing_a_module.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -294,5 +307,7 @@ class MyModule: + + - \ No newline at end of file + diff --git a/v1.84/openid.html b/v1.84/openid.html index 23e95a8eb0..abc6cbf867 100644 --- a/v1.84/openid.html +++ b/v1.84/openid.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -815,5 +828,7 @@ are randomly generated data.
  • + + - \ No newline at end of file + diff --git a/v1.84/opentracing.html b/v1.84/opentracing.html index b1184ef398..576528614c 100644 --- a/v1.84/opentracing.html +++ b/v1.84/opentracing.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -259,5 +272,7 @@ logged to OpenTracing's logs. + + - \ No newline at end of file + diff --git a/v1.84/other/running_synapse_on_single_board_computers.html b/v1.84/other/running_synapse_on_single_board_computers.html index 809ebb811f..e4daf61ec2 100644 --- a/v1.84/other/running_synapse_on_single_board_computers.html +++ b/v1.84/other/running_synapse_on_single_board_computers.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -235,5 +248,7 @@ admin@homeserver:~$ sudo --user postgres psql matrix-synapse --command 'select c + + - \ No newline at end of file + diff --git a/v1.84/password_auth_providers.html b/v1.84/password_auth_providers.html index 4c8014a4b3..83efa937ce 100644 --- a/v1.84/password_auth_providers.html +++ b/v1.84/password_auth_providers.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -299,5 +312,7 @@ wait for the Awaitable to complete, but the result is ignored.

    + + - \ No newline at end of file + diff --git a/v1.84/postgres.html b/v1.84/postgres.html index 8066c1cb14..211307ed10 100644 --- a/v1.84/postgres.html +++ b/v1.84/postgres.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -394,5 +407,7 @@ successfully.

    + + - \ No newline at end of file + diff --git a/v1.84/print.html b/v1.84/print.html index 2aea4e7d19..80400a4c71 100644 --- a/v1.84/print.html +++ b/v1.84/print.html @@ -29,6 +29,7 @@ + @@ -104,6 +105,18 @@ +
    + +

    Synapse

    @@ -18774,10 +18787,12 @@ admin@homeserver:~$ sudo --user postgres psql matrix-synapse --command 'select c + + - \ No newline at end of file + diff --git a/v1.84/replication.html b/v1.84/replication.html index 626f39bf24..5a0f22d7b3 100644 --- a/v1.84/replication.html +++ b/v1.84/replication.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -217,5 +230,7 @@ the classes interact, can be found in + + - \ No newline at end of file + diff --git a/v1.84/reverse_proxy.html b/v1.84/reverse_proxy.html index a0d2063c77..2fb89526b2 100644 --- a/v1.84/reverse_proxy.html +++ b/v1.84/reverse_proxy.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -407,5 +420,7 @@ we do not recommend exposing them to the public internet without good reason.

    + + - \ No newline at end of file + diff --git a/v1.84/room_and_user_statistics.html b/v1.84/room_and_user_statistics.html index 0c67a360cd..de34278222 100644 --- a/v1.84/room_and_user_statistics.html +++ b/v1.84/room_and_user_statistics.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -200,5 +213,7 @@ statistics for a room. Each subject can only have one entry.

    + + - \ No newline at end of file + diff --git a/v1.84/server_notices.html b/v1.84/server_notices.html index 24f2e177d1..8d5fadeaa6 100644 --- a/v1.84/server_notices.html +++ b/v1.84/server_notices.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -229,5 +242,7 @@ displayname and avatar of the Server Notices user.

    + + - \ No newline at end of file + diff --git a/v1.84/setup/forward_proxy.html b/v1.84/setup/forward_proxy.html index 6877b2f85d..d5ddce9694 100644 --- a/v1.84/setup/forward_proxy.html +++ b/v1.84/setup/forward_proxy.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -260,5 +273,7 @@ your homserver.ya + + - \ No newline at end of file + diff --git a/v1.84/setup/installation.html b/v1.84/setup/installation.html index 077c2f2cbd..8c53066c83 100644 --- a/v1.84/setup/installation.html +++ b/v1.84/setup/installation.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -610,5 +623,7 @@ failing, e.g.:

    + + - \ No newline at end of file + diff --git a/v1.84/setup/turn/coturn.html b/v1.84/setup/turn/coturn.html index 2872be318d..107690e553 100644 --- a/v1.84/setup/turn/coturn.html +++ b/v1.84/setup/turn/coturn.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -347,5 +360,7 @@ IPv6 address that is mapped by NAT to the external IPv6 address.

    + + - \ No newline at end of file + diff --git a/v1.84/setup/turn/eturnal.html b/v1.84/setup/turn/eturnal.html index 49d883d172..fd1b69cf92 100644 --- a/v1.84/setup/turn/eturnal.html +++ b/v1.84/setup/turn/eturnal.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -320,5 +333,7 @@ to query how many active sessions exist, to change logging behaviour and so on.< + + - \ No newline at end of file + diff --git a/v1.84/sso_mapping_providers.html b/v1.84/sso_mapping_providers.html index 1a6eb0a0fe..0e44f39cd1 100644 --- a/v1.84/sso_mapping_providers.html +++ b/v1.84/sso_mapping_providers.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -442,5 +455,7 @@ specified in the config. It is located at + + - \ No newline at end of file + diff --git a/v1.84/structured_logging.html b/v1.84/structured_logging.html index f1722b0dde..ee9e066ede 100644 --- a/v1.84/structured_logging.html +++ b/v1.84/structured_logging.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -254,5 +267,7 @@ remote endpoint at 10.1.2.3:9999.

    + + - \ No newline at end of file + diff --git a/v1.84/synctl_workers.html b/v1.84/synctl_workers.html index 01b916e690..9ac8957626 100644 --- a/v1.84/synctl_workers.html +++ b/v1.84/synctl_workers.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -208,5 +221,7 @@ notifications.

    + + - \ No newline at end of file + diff --git a/v1.84/systemd-with-workers/index.html b/v1.84/systemd-with-workers/index.html index fafc25f77b..8c52a0f2a7 100644 --- a/v1.84/systemd-with-workers/index.html +++ b/v1.84/systemd-with-workers/index.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -275,5 +288,7 @@ the changes being applied at a glance.

    + + - \ No newline at end of file + diff --git a/v1.84/tcp_replication.html b/v1.84/tcp_replication.html index b91ebb7d58..d7ece32ab1 100644 --- a/v1.84/tcp_replication.html +++ b/v1.84/tcp_replication.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -381,5 +394,7 @@ state + + - \ No newline at end of file + diff --git a/v1.84/templates.html b/v1.84/templates.html index c292b6cd5f..24bb210597 100644 --- a/v1.84/templates.html +++ b/v1.84/templates.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -467,5 +480,7 @@ When rendering, this template is given two variables: + + - \ No newline at end of file + diff --git a/v1.84/turn-howto.html b/v1.84/turn-howto.html index 8d04df1769..6840499e28 100644 --- a/v1.84/turn-howto.html +++ b/v1.84/turn-howto.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -342,5 +355,7 @@ entry in the results.

    + + - \ No newline at end of file + diff --git a/v1.84/upgrade.html b/v1.84/upgrade.html index d91683855a..6717787c74 100644 --- a/v1.84/upgrade.html +++ b/v1.84/upgrade.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -2071,5 +2084,7 @@ in the local HS will automatically rejoin the room.

    + + - \ No newline at end of file + diff --git a/v1.84/usage/administration/admin_api/background_updates.html b/v1.84/usage/administration/admin_api/background_updates.html index 7bc4efe403..250e6d72f4 100644 --- a/v1.84/usage/administration/admin_api/background_updates.html +++ b/v1.84/usage/administration/admin_api/background_updates.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -255,5 +268,7 @@ background updates which won't be cancelled once started.

    + + - \ No newline at end of file + diff --git a/v1.84/usage/administration/admin_api/federation.html b/v1.84/usage/administration/admin_api/federation.html index 1902d4a142..34531a3e7d 100644 --- a/v1.84/usage/administration/admin_api/federation.html +++ b/v1.84/usage/administration/admin_api/federation.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -357,5 +370,7 @@ even if the API already returns the http status 200.

    + + - \ No newline at end of file + diff --git a/v1.84/usage/administration/admin_api/index.html b/v1.84/usage/administration/admin_api/index.html index 0ac2e7fcd8..b5204cefa6 100644 --- a/v1.84/usage/administration/admin_api/index.html +++ b/v1.84/usage/administration/admin_api/index.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -217,5 +230,7 @@ information from the Admin API.

    + + - \ No newline at end of file + diff --git a/v1.84/usage/administration/admin_api/registration_tokens.html b/v1.84/usage/administration/admin_api/registration_tokens.html index 84fb365570..022a6ff7db 100644 --- a/v1.84/usage/administration/admin_api/registration_tokens.html +++ b/v1.84/usage/administration/admin_api/registration_tokens.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -423,5 +436,7 @@ the
    Ma + + - \ No newline at end of file + diff --git a/v1.84/usage/administration/admin_faq.html b/v1.84/usage/administration/admin_faq.html index 11fa941258..0240386f78 100644 --- a/v1.84/usage/administration/admin_faq.html +++ b/v1.84/usage/administration/admin_faq.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -395,5 +408,7 @@ you see this failure mode so we can help debug it, however.

    + + - \ No newline at end of file + diff --git a/v1.84/usage/administration/database_maintenance_tools.html b/v1.84/usage/administration/database_maintenance_tools.html index f949c57ecc..a6e5e9119b 100644 --- a/v1.84/usage/administration/database_maintenance_tools.html +++ b/v1.84/usage/administration/database_maintenance_tools.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -197,5 +210,7 @@ + + - \ No newline at end of file + diff --git a/v1.84/usage/administration/index.html b/v1.84/usage/administration/index.html index c99082bfdc..13d9ca465a 100644 --- a/v1.84/usage/administration/index.html +++ b/v1.84/usage/administration/index.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -192,5 +205,7 @@ + + - \ No newline at end of file + diff --git a/v1.84/usage/administration/monitoring/reporting_homeserver_usage_statistics.html b/v1.84/usage/administration/monitoring/reporting_homeserver_usage_statistics.html index a0930c7037..676a37d9f7 100644 --- a/v1.84/usage/administration/monitoring/reporting_homeserver_usage_statistics.html +++ b/v1.84/usage/administration/monitoring/reporting_homeserver_usage_statistics.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -259,5 +272,7 @@ consider using one of the following known implementations:

    + + - \ No newline at end of file + diff --git a/v1.84/usage/administration/monthly_active_users.html b/v1.84/usage/administration/monthly_active_users.html index d189460792..980406e2e1 100644 --- a/v1.84/usage/administration/monthly_active_users.html +++ b/v1.84/usage/administration/monthly_active_users.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -249,5 +262,7 @@ registered accounts on the homeserver.

    + + - \ No newline at end of file + diff --git a/v1.84/usage/administration/request_log.html b/v1.84/usage/administration/request_log.html index d122fc900b..315c3e32d2 100644 --- a/v1.84/usage/administration/request_log.html +++ b/v1.84/usage/administration/request_log.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -220,5 +233,7 @@ small processing times.

    + + - \ No newline at end of file + diff --git a/v1.84/usage/administration/state_groups.html b/v1.84/usage/administration/state_groups.html index ee51fd673f..80dae596f4 100644 --- a/v1.84/usage/administration/state_groups.html +++ b/v1.84/usage/administration/state_groups.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -198,5 +211,7 @@ + + - \ No newline at end of file + diff --git a/v1.84/usage/administration/understanding_synapse_through_grafana_graphs.html b/v1.84/usage/administration/understanding_synapse_through_grafana_graphs.html index 76f188a7b4..7eeae8a305 100644 --- a/v1.84/usage/administration/understanding_synapse_through_grafana_graphs.html +++ b/v1.84/usage/administration/understanding_synapse_through_grafana_graphs.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -235,5 +248,7 @@ to make use of multiple CPU cores / multiple machines for your homeserver.

    + + - \ No newline at end of file + diff --git a/v1.84/usage/administration/useful_sql_for_admins.html b/v1.84/usage/administration/useful_sql_for_admins.html index 69434ed404..5fdc141655 100644 --- a/v1.84/usage/administration/useful_sql_for_admins.html +++ b/v1.84/usage/administration/useful_sql_for_admins.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -355,5 +368,7 @@ WHERE room_stats_state.room_id = event_json.room_id" | psql -d synapse -h l + + - \ No newline at end of file + diff --git a/v1.84/usage/configuration/config_documentation.html b/v1.84/usage/configuration/config_documentation.html index 250c4fec81..67ab4d0a73 100644 --- a/v1.84/usage/configuration/config_documentation.html +++ b/v1.84/usage/configuration/config_documentation.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -3768,5 +3781,7 @@ Set a size to change the default. + + - \ No newline at end of file + diff --git a/v1.84/usage/configuration/homeserver_sample_config.html b/v1.84/usage/configuration/homeserver_sample_config.html index 9be5f0db82..6c599346f3 100644 --- a/v1.84/usage/configuration/homeserver_sample_config.html +++ b/v1.84/usage/configuration/homeserver_sample_config.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -239,5 +252,7 @@ trusted_key_servers: + + - \ No newline at end of file + diff --git a/v1.84/usage/configuration/index.html b/v1.84/usage/configuration/index.html index 6351be665f..b115402429 100644 --- a/v1.84/usage/configuration/index.html +++ b/v1.84/usage/configuration/index.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -188,5 +201,7 @@ file should have been generated when you
    + + - \ No newline at end of file + diff --git a/v1.84/usage/configuration/logging_sample_config.html b/v1.84/usage/configuration/logging_sample_config.html index 34c640f73d..659c2c7a12 100644 --- a/v1.84/usage/configuration/logging_sample_config.html +++ b/v1.84/usage/configuration/logging_sample_config.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -272,5 +285,7 @@ disable_existing_loggers: false + + - \ No newline at end of file + diff --git a/v1.84/usage/configuration/user_authentication/index.html b/v1.84/usage/configuration/user_authentication/index.html index 5d89b355da..1f96c4ba01 100644 --- a/v1.84/usage/configuration/user_authentication/index.html +++ b/v1.84/usage/configuration/user_authentication/index.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -198,5 +211,7 @@ modules.

    + + - \ No newline at end of file + diff --git a/v1.84/usage/configuration/user_authentication/refresh_tokens.html b/v1.84/usage/configuration/user_authentication/refresh_tokens.html index 444dd21da2..fbc30335e4 100644 --- a/v1.84/usage/configuration/user_authentication/refresh_tokens.html +++ b/v1.84/usage/configuration/user_authentication/refresh_tokens.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -307,5 +320,7 @@ above requirements will still hold.

    + + - \ No newline at end of file + diff --git a/v1.84/usage/configuration/user_authentication/single_sign_on/cas.html b/v1.84/usage/configuration/user_authentication/single_sign_on/cas.html index 67e0e49515..12e5bcca4c 100644 --- a/v1.84/usage/configuration/user_authentication/single_sign_on/cas.html +++ b/v1.84/usage/configuration/user_authentication/single_sign_on/cas.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -191,5 +204,7 @@ sections of the configuration manual for more details.

    + + - \ No newline at end of file + diff --git a/v1.84/usage/configuration/user_authentication/single_sign_on/index.html b/v1.84/usage/configuration/user_authentication/single_sign_on/index.html index 70eaf6baae..6865216d39 100644 --- a/v1.84/usage/configuration/user_authentication/single_sign_on/index.html +++ b/v1.84/usage/configuration/user_authentication/single_sign_on/index.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -189,5 +202,7 @@ auth provider modules.

    + + - \ No newline at end of file + diff --git a/v1.84/usage/configuration/user_authentication/single_sign_on/saml.html b/v1.84/usage/configuration/user_authentication/single_sign_on/saml.html index 929d42eaa4..7dedd426b3 100644 --- a/v1.84/usage/configuration/user_authentication/single_sign_on/saml.html +++ b/v1.84/usage/configuration/user_authentication/single_sign_on/saml.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -191,5 +204,7 @@ file
    for more details.

    + + - \ No newline at end of file + diff --git a/v1.84/user_directory.html b/v1.84/user_directory.html index 279ac4c6e2..33c832a274 100644 --- a/v1.84/user_directory.html +++ b/v1.84/user_directory.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -240,5 +253,7 @@ different, but this isn't enforced by a constraint.

    + + - \ No newline at end of file + diff --git a/v1.84/website_files/theme/index.hbs b/v1.84/website_files/theme/index.hbs index 3b7a5b6163..b169323a43 100644 --- a/v1.84/website_files/theme/index.hbs +++ b/v1.84/website_files/theme/index.hbs @@ -131,6 +131,18 @@ {{/if}} +
    + +

    {{ book_title }}

    @@ -309,4 +321,4 @@ {{/if}} - \ No newline at end of file + diff --git a/v1.84/website_files/version-picker.css b/v1.84/website_files/version-picker.css new file mode 100644 index 0000000000..28e5d5219a --- /dev/null +++ b/v1.84/website_files/version-picker.css @@ -0,0 +1,78 @@ +.version-picker { + display: flex; + align-items: center; +} + +.version-picker .dropdown { + width: 130px; + max-height: 29px; + margin-left: 10px; + display: inline-block; + border-radius: 4px; + border: 1px solid var(--theme-popup-border); + position: relative; + font-size: 13px; + color: var(--fg); + height: 100%; + text-align: left; +} +.version-picker .dropdown .select { + cursor: pointer; + display: block; + padding: 5px 2px 5px 15px; +} +.version-picker .dropdown .select > i { + font-size: 10px; + color: var(--fg); + cursor: pointer; + float: right; + line-height: 20px !important; +} +.version-picker .dropdown:hover { + border: 1px solid var(--theme-popup-border); +} +.version-picker .dropdown:active { + background-color: var(--theme-popup-bg); +} +.version-picker .dropdown.active:hover, +.version-picker .dropdown.active { + border: 1px solid var(--theme-popup-border); + border-radius: 2px 2px 0 0; + background-color: var(--theme-popup-bg); +} +.version-picker .dropdown.active .select > i { + transform: rotate(-180deg); +} +.version-picker .dropdown .dropdown-menu { + position: absolute; + background-color: var(--theme-popup-bg); + width: 100%; + left: -1px; + right: 1px; + margin-top: 1px; + border: 1px solid var(--theme-popup-border); + border-radius: 0 0 4px 4px; + overflow: hidden; + display: none; + max-height: 300px; + overflow-y: auto; + z-index: 9; +} +.version-picker .dropdown .dropdown-menu li { + font-size: 12px; + padding: 6px 20px; + cursor: pointer; +} +.version-picker .dropdown .dropdown-menu { + padding: 0; + list-style: none; +} +.version-picker .dropdown .dropdown-menu li:hover { + background-color: var(--theme-hover); +} +.version-picker .dropdown .dropdown-menu li.active::before { + display: inline-block; + content: "✓"; + margin-inline-start: -14px; + width: 14px; +} \ No newline at end of file diff --git a/v1.84/website_files/version-picker.js b/v1.84/website_files/version-picker.js new file mode 100644 index 0000000000..bb35a7d896 --- /dev/null +++ b/v1.84/website_files/version-picker.js @@ -0,0 +1,127 @@ + +const dropdown = document.querySelector('.version-picker .dropdown'); +const dropdownMenu = dropdown.querySelector('.dropdown-menu'); + +fetchVersions(dropdown, dropdownMenu).then(() => { + initializeVersionDropdown(dropdown, dropdownMenu); +}); + +/** + * Initialize the dropdown functionality for version selection. + * + * @param {Element} dropdown - The dropdown element. + * @param {Element} dropdownMenu - The dropdown menu element. + */ +function initializeVersionDropdown(dropdown, dropdownMenu) { + // Toggle the dropdown menu on click + dropdown.addEventListener('click', function () { + this.setAttribute('tabindex', 1); + this.classList.toggle('active'); + dropdownMenu.style.display = (dropdownMenu.style.display === 'block') ? 'none' : 'block'; + }); + + // Remove the 'active' class and hide the dropdown menu on focusout + dropdown.addEventListener('focusout', function () { + this.classList.remove('active'); + dropdownMenu.style.display = 'none'; + }); + + // Handle item selection within the dropdown menu + const dropdownMenuItems = dropdownMenu.querySelectorAll('li'); + dropdownMenuItems.forEach(function (item) { + item.addEventListener('click', function () { + dropdownMenuItems.forEach(function (item) { + item.classList.remove('active'); + }); + this.classList.add('active'); + dropdown.querySelector('span').textContent = this.textContent; + dropdown.querySelector('input').value = this.getAttribute('id'); + + window.location.href = changeVersion(window.location.href, this.textContent); + }); + }); +}; + +/** + * This function fetches the available versions from a GitHub repository + * and inserts them into the version picker. + * + * @param {Element} dropdown - The dropdown element. + * @param {Element} dropdownMenu - The dropdown menu element. + * @returns {Promise>} A promise that resolves with an array of available versions. + */ +function fetchVersions(dropdown, dropdownMenu) { + return new Promise((resolve, reject) => { + window.addEventListener("load", () => { + + fetch("https://api.github.com/repos/matrix-org/synapse/git/trees/gh-pages", { + cache: "force-cache", + }).then(res => + res.json() + ).then(resObject => { + const excluded = ['dev-docs', 'v1.91.0', 'v1.80.0', 'v1.69.0']; + const tree = resObject.tree.filter(item => item.type === "tree" && !excluded.includes(item.path)); + const versions = tree.map(item => item.path).sort(sortVersions); + + // Create a list of
  • items for versions + versions.forEach((version) => { + const li = document.createElement("li"); + li.textContent = version; + li.id = version; + + if (window.SYNAPSE_VERSION === version) { + li.classList.add('active'); + dropdown.querySelector('span').textContent = version; + dropdown.querySelector('input').value = version; + } + + dropdownMenu.appendChild(li); + }); + + resolve(versions); + + }).catch(ex => { + console.error("Failed to fetch version data", ex); + reject(ex); + }) + }); + }); +} + +/** + * Custom sorting function to sort an array of version strings. + * + * @param {string} a - The first version string to compare. + * @param {string} b - The second version string to compare. + * @returns {number} - A negative number if a should come before b, a positive number if b should come before a, or 0 if they are equal. + */ +function sortVersions(a, b) { + // Put 'develop' and 'latest' at the top + if (a === 'develop' || a === 'latest') return -1; + if (b === 'develop' || b === 'latest') return 1; + + const versionA = (a.match(/v\d+(\.\d+)+/) || [])[0]; + const versionB = (b.match(/v\d+(\.\d+)+/) || [])[0]; + + return versionB.localeCompare(versionA); +} + +/** + * Change the version in a URL path. + * + * @param {string} url - The original URL to be modified. + * @param {string} newVersion - The new version to replace the existing version in the URL. + * @returns {string} The updated URL with the new version. + */ +function changeVersion(url, newVersion) { + const parsedURL = new URL(url); + const pathSegments = parsedURL.pathname.split('/'); + + // Modify the version + pathSegments[2] = newVersion; + + // Reconstruct the URL + parsedURL.pathname = pathSegments.join('/'); + + return parsedURL.href; +} \ No newline at end of file diff --git a/v1.84/website_files/version.js b/v1.84/website_files/version.js new file mode 100644 index 0000000000..cd39e869c8 --- /dev/null +++ b/v1.84/website_files/version.js @@ -0,0 +1 @@ +window.SYNAPSE_VERSION = 'v1.84'; diff --git a/v1.84/welcome_and_overview.html b/v1.84/welcome_and_overview.html index a52dd12d95..76f290c703 100644 --- a/v1.84/welcome_and_overview.html +++ b/v1.84/welcome_and_overview.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -264,5 +277,7 @@ Policy. Thank you!

    + + - \ No newline at end of file + diff --git a/v1.84/workers.html b/v1.84/workers.html index 58eedb750d..097d4d9f07 100644 --- a/v1.84/workers.html +++ b/v1.84/workers.html @@ -28,6 +28,7 @@ + @@ -103,6 +104,18 @@ +
    + +

    Synapse

    @@ -912,5 +925,7 @@ in systemd service files, but not required for synctl).

    + + - \ No newline at end of file +