matrix-org / matrix-synapse-ldap3

An LDAP3 auth provider for Synapse
Apache License 2.0
125 stars 47 forks source link

Synapse LDAP Auth Provider

Allows synapse to use LDAP as a password provider.

This allows users to log in to synapse with their username and password from an LDAP server. There is also ma1sd <https://github.com/ma1uta/ma1sd>_ (3rd party) that offers more fully-featured integration.

Installation

Usage

Example Synapse configuration:

.. code:: yaml

modules:

If you would like to specify more than one LDAP server for HA, you can provide uri parameter with a list. Default HA strategy of ldap3.ServerPool is employed, so first available server is used.

.. code:: yaml

modules:

If you would like to enable login/registration via email, or givenName/email binding upon registration, you need to enable search mode. An example config in search mode is provided below:

.. code:: yaml

modules:

Alternatively you can also put the bind_password of your service user into its own file to not leak secrets into your configuration:

.. code:: yaml

modules:

Please note that every trailing \n in the password file will be stripped automatically.

Active Directory forest support

If the active_directory flag is set to true, an Active Directory forest will be searched for the login details. In this mode, the user enters their login details in one of the forms:

In either case, this will be mapped to the Matrix UID <login>/<domain> (The normal AD domain separators, @ and \, cannot be used in Matrix User Identifiers, so / is used instead.)

Let's say you have several domains in the example.com forest:

.. code:: yaml

modules:

With this configuration the user can log in with either main\someuser, main.example.com\someuser, someuser/main.example.com or someuser.

Users of other domains in the example.com forest can log in with domain\login or login/domain.

Please note that userPrincipalName or a similar-looking LDAP attribute in the format login@domain must be used when the active_directory option is enabled.

Troubleshooting and Debugging

matrix-synapse-ldap3 logging is included in the Synapse homeserver log (typically homeserver.log). The LDAP plugin log level can be increased to DEBUG for troubleshooting and debugging by making the following modifications to your Synapse server's logging configuration file:

.. code:: yaml

handlers: file:

[...]

   level: DEBUG

.. code:: yaml

loggers:

[...]

  ldap3:
    level: DEBUG
  ldap_auth_provider:
    level: DEBUG

Finally, restart your Synapse server for the changes to take effect:

.. code:: sh

synctl restart