Skip to content
This repository has been archived by the owner on Apr 26, 2024. It is now read-only.

Explicitly log when a homeserver does not have a trusted key server configured #6090

Merged
merged 10 commits into from
Sep 26, 2019
1 change: 1 addition & 0 deletions changelog.d/6090.doc
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Explicitly log when a homeserver does not have the 'trusted_key_servers' config field configured.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

not really a doc change imho. A feature, I guess.

11 changes: 7 additions & 4 deletions docs/sample_config.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -1061,6 +1061,10 @@ signing_key_path: "CONFDIR/SERVERNAME.signing.key"
# This setting supercedes an older setting named `perspectives`. The old format
# is still supported for backwards-compatibility, but it is deprecated.
#
# 'trusted_key_servers' defaults to matrix.org, but using it will generate a
# warning on start up to suppress this warning set 'suppress_key_server_warning'
# to true.
#
# Options for each entry in the list include:
#
# server_name: the name of the server. required.
Expand All @@ -1085,12 +1089,11 @@ signing_key_path: "CONFDIR/SERVERNAME.signing.key"
# "ed25519:auto": "abcdefghijklmnopqrstuvwxyzabcdefghijklmopqr"
# - server_name: "my_other_trusted_server.example.com"
#
# The default configuration is:
trusted_key_servers:
- server_name: "matrix.org"
#
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
#

#trusted_key_servers:
# - server_name: "matrix.org"
#suppress_key_server_warning: true
#
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
#


# The signing keys to use when acting as a trusted key server. If not specified
# defaults to the server signing key.
#
Expand Down
45 changes: 41 additions & 4 deletions synapse/config/key.py
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,31 @@
If you are *sure* you want to do this, set 'accept_keys_insecurely' on the
trusted_key_server configuration."""

TRUSTED_KEY_SERVER_NOT_CONFIGURED_WARN = """\
Synapse requires that a list of trusted key servers are specified in order to
provide signing keys for other servers in the federation.

This homeserver does not have a trusted key server configured in
homeserver.yaml and will fall back to the default of 'matrix.org'.

Trusted key servers should be long-lived and stable which makes matrix.org a
good choice for many admins, but some admins may wish to choose another. To
suppress this warning, the admin should set 'trusted_key_servers' in
homeserver.yaml to their desired key server and 'suppress_key_server_warning'
to 'true'.

In a future release the software-defined default will be removed entirely and
the trusted key server will be defined exclusively by the value of
'trusted_key_servers'."""

TRUSTED_KEY_SERVER_CONFIGURED_AS_M_ORG_WARN = """\
This server is configured to use 'matrix.org' as its trusted key server via the
'trusted_key_servers' config option. 'matrix.org' is a good choice for a key
server since it is long-lived, stable and trusted. However, some admins may
wish to use another server for this purpose.

To suppress this warning and continue using 'matrix.org', admins should set
'suppress_key_server_warning' to 'true' in homeserver.yaml."""

logger = logging.getLogger(__name__)

Expand Down Expand Up @@ -85,6 +110,7 @@ def read_config(self, config, config_dir_path, **kwargs):
config.get("key_refresh_interval", "1d")
)

richvdh marked this conversation as resolved.
Show resolved Hide resolved
suppress_key_server_warning = config.get("suppress_key_server_warning", False)
key_server_signing_keys_path = config.get("key_server_signing_keys_path")
if key_server_signing_keys_path:
self.key_server_signing_keys = self.read_signing_keys(
Expand All @@ -95,6 +121,7 @@ def read_config(self, config, config_dir_path, **kwargs):

# if neither trusted_key_servers nor perspectives are given, use the default.
if "perspectives" not in config and "trusted_key_servers" not in config:
logger.warn(TRUSTED_KEY_SERVER_NOT_CONFIGURED_WARN)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

just as a note for future reference: note that logger.warn is deprecated

key_servers = [{"server_name": "matrix.org"}]
else:
key_servers = config.get("trusted_key_servers", [])
Expand All @@ -105,6 +132,13 @@ def read_config(self, config, config_dir_path, **kwargs):
% (type(key_servers).__name__,)
)

for server in key_servers:
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

again: I think this could do with being after the _perspectives_to_key_servers logic so that perspectives are covered in the warning too.

if (
server["server_name"] == "matrix.org"
and not suppress_key_server_warning
):
logger.warn(TRUSTED_KEY_SERVER_CONFIGURED_AS_M_ORG_WARN)

# merge the 'perspectives' config into the 'trusted_key_servers' config.
key_servers.extend(_perspectives_to_key_servers(config))

Expand Down Expand Up @@ -190,6 +224,10 @@ def generate_config_section(
# This setting supercedes an older setting named `perspectives`. The old format
# is still supported for backwards-compatibility, but it is deprecated.
#
# 'trusted_key_servers' defaults to matrix.org, but using it will generate a
# warning on start up to suppress this warning set 'suppress_key_server_warning'
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
# warning on start up to suppress this warning set 'suppress_key_server_warning'
# warning on start up. To suppress this warning set 'suppress_key_server_warning'

# to true.
#
# Options for each entry in the list include:
#
# server_name: the name of the server. required.
Expand All @@ -214,12 +252,11 @@ def generate_config_section(
# "ed25519:auto": "abcdefghijklmnopqrstuvwxyzabcdefghijklmopqr"
# - server_name: "my_other_trusted_server.example.com"
#
# The default configuration is:
trusted_key_servers:
- server_name: "matrix.org"
#
#trusted_key_servers:
# - server_name: "matrix.org"
#suppress_key_server_warning: true
#

# The signing keys to use when acting as a trusted key server. If not specified
# defaults to the server signing key.
#
Expand Down