A Synapse plugin module which allows users to choose their username when they first log in.
This plugin can be installed via PyPi:
pip install matrix-synapse-saml-mozilla
Add the following in your Synapse config:
saml2_config:
user_mapping_provider:
module: "matrix_synapse_saml_mozilla.SamlMappingProvider"Also, under the HTTP client listener, configure an additional_resource as per
the below:
listeners:
- port: <port>
type: http
resources:
- names: [client]
additional_resources:
"/_matrix/saml2/pick_username":
module: "matrix_synapse_saml_mozilla.pick_username_resource"Synapse allows SAML mapping providers to specify custom configuration through the
saml2_config.user_mapping_provider.config option.
Currently the following options are supported:
-
use_name_id_for_remote_uid: if set toFalse, we will use the SAML attribute mapped touidto identify the remote user instead of theNameIDfrom the assertion.Trueby default. -
bad_domain_file: should point a file containing a list of domains (one per line); users who have an email address on any of these domains will be blocked from registration. -
bad_domain_list: an alternative tobad_domain_fileallowing the list of bad domains to be specified inline in the config.If both
bad_domain_fileandbad_domain_listare specified, the two lists are merged.
The login flow looks something like this:
This repository uses tox to run linting and tests.
Code is linted with the flake8 tool. Run tox -e lint to check for linting
errors in the codebase.
This repository uses unittest to run the tests located in the tests
directory. They can be ran with tox -e tests.
git tag vX.Y
python3 setup.py sdist
twine upload dist/matrix-synapse-saml-mozilla-X.Y.tar.gz
git push origin vX.Y