Go to file
ZerataX c59d04e6a7
init db with alembic as well
2020-12-12 04:34:56 +01:00
.github deprecate python 3.6 support 2020-12-12 04:01:34 +01:00
alembic init db with alembic as well 2020-12-12 04:34:56 +01:00
matrix_registration init db with alembic as well 2020-12-12 04:34:56 +01:00
resources update styling 2019-04-16 04:55:17 +02:00
tests adjust tests for new api naming scheme 2020-12-12 03:59:55 +01:00
.coveragerc coverage omit __main__ 2018-05-14 01:56:25 +02:00
.gitignore pep8 code 2019-04-17 11:41:23 +02:00
.travis.yml Update .travis.yml 2020-06-14 01:20:53 +02:00
CODE_OF_CONDUCT.md Update CODE_OF_CONDUCT.md 2019-04-16 02:28:46 +02:00
CONTRIBUTING.md Update CONTRIBUTING.md 2019-04-16 18:24:40 +02:00
Dockerfile Improve the dockerfile 2020-06-21 21:40:19 +02:00
LICENSE Create LICENSE 2018-05-14 02:13:11 +02:00
README.md Update README.md 2020-07-21 21:10:04 +02:00
alembic.ini add logging and database upgrading with alembic 2020-12-12 03:08:27 +01:00
config.sample.yaml add logging and database upgrading with alembic 2020-12-12 03:08:27 +01:00
setup.py init db with alembic as well 2020-12-12 04:34:56 +01:00
shell.nix add base_url option 2020-12-11 23:11:06 +01:00
tox.ini python 3.8 2019-04-16 17:20:53 +02:00

README.md

Build Status Coverage Status PyPI - Python Version PyPI Matrix

matrix-registration

a simple python application to have a token based matrix registration

if you like me encountered the situation where you want to invite your friends to your homeserver, but neither wanted to open up public registration nor create accounts for every individual user yourself, this project should be the solution.

with this project you can just quickly generate tokens on the fly and share them with your friends to allow them to register to your homeserver.

setup

pip3 install matrix-registration
matrix-registration

INFO:

  • This only asks you for the most important options. You should definitely take a look at the actual configuration file.
  • The shared_secret has to be the same as registration_shared_secret in your homeserver.yaml

nginx reverse-proxy

an example nginx setup:

location  ~ ^/(static|register) {
        proxy_pass http://localhost:5000;
}

If you already have a website and want to use your own register page, the wiki describes a more advanced nginx setup.

usage

$ matrix-registration -h
Usage: matrix-registration [OPTIONS] COMMAND [ARGS]...

  a token based matrix registration app

Options:
  --config-path TEXT  specifies the config file to be used
  --version           Show the flask version
  -h, --help          Show this message and exit.

Commands:
  generate  generate new token
  serve     start api server
  status    view status or disable

after you've started the api server and generated a token you can register an account with a simple post request, e.g.:

curl -X POST \
     -F 'username=test' \
     -F 'password=verysecure' \
     -F 'confirm=verysecure' \
     -F 'token=DoubleWizardSki' \
     http://localhost:5000/register

or by visiting http://localhost:5000/register?token=DoubleWizardSki

resources

if you want to write your own registration page, you can take a look at the sample in resources/example.html

the html page looks for the query paramater token and sets the token input field to it's value. this would allow you to directly share links with the token included, e.g.: https://homeserver.tld/register.html?token=DoubleWizardSki

troubleshooting

SQLAlchemy complains that a value isn't in a DateTime value

Before #17 introduced SQLAlchemy support the sqlite database incorrectly stored the expire dates, to fix this you have to manually run:

update tokens set ex_date=null where ex_date='None';

on your database once, or just delete your current database.

similar projects

For more info check the wiki