From 90bcfaa2aa39b6e32ac8044f888d8a7de1f36c67 Mon Sep 17 00:00:00 2001 From: Azrenbeth Date: Mon, 6 Sep 2021 15:08:24 +0000 Subject: deploy: 6e895366ea7f194cd48fae08a9909ee01a9fadae --- develop/print.html | 42 ++++++++++++++++++++++++++++++++++++++---- 1 file changed, 38 insertions(+), 4 deletions(-) (limited to 'develop/print.html') diff --git a/develop/print.html b/develop/print.html index ee674b8156..cb23b1ae2e 100644 --- a/develop/print.html +++ b/develop/print.html @@ -3274,6 +3274,24 @@ listeners: # bind_addresses: ['::1', '127.0.0.1'] # type: manhole +# Connection settings for the manhole +# +manhole_settings: + # The username for the manhole. This defaults to 'matrix'. + # + #username: manhole + + # The password for the manhole. This defaults to 'rabbithole'. + # + #password: mypassword + + # The private and public SSH key pair used to encrypt the manhole traffic. + # If these are left unset, then hardcoded and non-secret keys are used, + # which could allow traffic to be intercepted if sent over a public network. + # + #ssh_priv_key_path: CONFDIR/id_rsa + #ssh_pub_key_path: CONFDIR/id_rsa.pub + # Forward extremities can build up in a room due to networking delays between # homeservers. Once this happens in a large room, calculation of the state of # that room can become quite expensive. To mitigate this, once the number of @@ -11180,7 +11198,7 @@ debugging.

Note that this will give administrative access to synapse to all users with shell access to the server. It should therefore not be enabled in environments where untrusted users have shell access.

-
+

Configuring the manhole

To enable it, first uncomment the manhole listener configuration in homeserver.yaml. The configuration is slightly different if you're using docker.

Docker config

@@ -11208,12 +11226,28 @@ The bind_addresses in the example below is important: it ensures th bind_addresses: ['::1', '127.0.0.1'] type: manhole -

Accessing synapse manhole

+

Security settings

+

The following config options are available:

+ +

For example:

+
manhole_settings:
+  username: manhole
+  password: mypassword
+  ssh_priv_key: "/home/synapse/manhole_keys/id_rsa"
+  ssh_pub_key: "/home/synapse/manhole_keys/id_rsa.pub"
+
+

Accessing synapse manhole

Then restart synapse, and point an ssh client at port 9000 on localhost, using -the username matrix:

+the username and password configured in homeserver.yaml - with the default +configuration, this would be:

ssh -p9000 matrix@localhost
 
-

The password is rabbithole.

+

Then enter the password when prompted (the default is rabbithole).

This gives a Python REPL in which hs gives access to the synapse.server.HomeServer object - which in turn gives access to many other parts of the process.

-- cgit 1.5.1