summary refs log tree commit diff
diff options
context:
space:
mode:
authorAndrew Morgan <andrew@amorgan.xyz>2020-02-14 10:56:35 +0000
committerAndrew Morgan <andrew@amorgan.xyz>2020-02-14 10:56:35 +0000
commit673d3f88fa9bb5e1ed02398af0bf5119cc8bd4be (patch)
tree57d08a87712d0a7e30f60cb3f62f98d1be801ac8
parentInclude systemd-python in Debian package to allow logging to journal (#5261) (diff)
parentAdded possibilty to disable local password authentication (#5092) (diff)
downloadsynapse-673d3f88fa9bb5e1ed02398af0bf5119cc8bd4be.tar.xz
Added possibilty to disable local password authentication (#5092)
-rw-r--r--changelog.d/5092.feature1
-rw-r--r--docs/sample_config.yaml6
-rw-r--r--synapse/config/password.py7
-rw-r--r--synapse/handlers/auth.py2
-rw-r--r--synapse/handlers/set_password.py3
5 files changed, 18 insertions, 1 deletions
diff --git a/changelog.d/5092.feature b/changelog.d/5092.feature
new file mode 100644
index 0000000000..c22f586d08
--- /dev/null
+++ b/changelog.d/5092.feature
@@ -0,0 +1 @@
+Added possibilty to disable local password authentication. Contributed by Daniel Hoffend.
diff --git a/docs/sample_config.yaml b/docs/sample_config.yaml
index 6baca7066e..c0e9ce3640 100644
--- a/docs/sample_config.yaml
+++ b/docs/sample_config.yaml
@@ -1213,6 +1213,12 @@ password_config:
    #
    #enabled: false
 
+   # Uncomment to disable authentication against the local password
+   # database. This is ignored if `enabled` is false, and is only useful
+   # if you have other password_providers.
+   #
+   #localdb_enabled: false
+
    # Uncomment and change to a secret random string for extra security.
    # DO NOT CHANGE THIS AFTER INITIAL SETUP!
    #
diff --git a/synapse/config/password.py b/synapse/config/password.py
index 091062b587..47df98f41a 100644
--- a/synapse/config/password.py
+++ b/synapse/config/password.py
@@ -28,6 +28,7 @@ class PasswordConfig(Config):
             password_config = {}
 
         self.password_enabled = password_config.get("enabled", True)
+        self.password_localdb_enabled = password_config.get("localdb_enabled", True)
         self.password_pepper = password_config.get("pepper", "")
 
         # Password policy
@@ -41,6 +42,12 @@ class PasswordConfig(Config):
            #
            #enabled: false
 
+           # Uncomment to disable authentication against the local password
+           # database. This is ignored if `enabled` is false, and is only useful
+           # if you have other password_providers.
+           #
+           #localdb_enabled: false
+
            # Uncomment and change to a secret random string for extra security.
            # DO NOT CHANGE THIS AFTER INITIAL SETUP!
            #
diff --git a/synapse/handlers/auth.py b/synapse/handlers/auth.py
index 94b3879c61..57e5283bd8 100644
--- a/synapse/handlers/auth.py
+++ b/synapse/handlers/auth.py
@@ -743,7 +743,7 @@ class AuthHandler(BaseHandler):
                     result = (result, None)
                 defer.returnValue(result)
 
-        if login_type == LoginType.PASSWORD:
+        if login_type == LoginType.PASSWORD and self.hs.config.password_localdb_enabled:
             known_login_type = True
 
             canonical_user_id = yield self._check_local_password(
diff --git a/synapse/handlers/set_password.py b/synapse/handlers/set_password.py
index dea9a3bc77..3f50d6de47 100644
--- a/synapse/handlers/set_password.py
+++ b/synapse/handlers/set_password.py
@@ -35,6 +35,9 @@ class SetPasswordHandler(BaseHandler):
 
     @defer.inlineCallbacks
     def set_password(self, user_id, newpassword, requester=None):
+        if not self.hs.config.password_localdb_enabled:
+            raise SynapseError(403, "Password change disabled", errcode=Codes.FORBIDDEN)
+
         self._password_policy_handler.validate_password(newpassword)
 
         password_hash = yield self._auth_handler.hash(newpassword)