Go to file
ZerataX 83ae568f7c
pip include pngs and icos
2019-04-17 22:41:40 +02:00
.github/ISSUE_TEMPLATE Delete feature_request.md 2019-04-15 23:44:40 +02:00
matrix_registration pip include pngs and icos 2019-04-17 22:41:40 +02:00
resources update styling 2019-04-16 04:55:17 +02:00
tests remove unnecessary print statements 2018-10-09 19:29:03 +02: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 2019-04-15 23:30:51 +02:00
CONTRIBUTING.md update readme 2019-04-16 01:07:41 +02:00
LICENSE Create LICENSE 2018-05-14 02:13:11 +02:00
README.md success error modal 2019-04-17 22:34:50 +02:00
config.sample.yaml success error modal 2019-04-17 22:34:50 +02:00
requirements.txt update requirements 2019-04-15 21:00:56 +02:00
setup.py pip include pngs and icos 2019-04-17 22:41:40 +02:00

README.md

Build Status Coverage Status PyPI - Python Version PyPI Matrix Chat

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

Then download the config.sample.yaml and save a modified version to config.yaml in the folder that you want to execute matrix-registration.

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

$ python -m matrix_registration -h
usage: python -m matrix_registration [-h] {api,gen,status} ...

a token based matrix registration app

positional arguments:
  {api,gen,status}  sub-commands. for ex. 'gen -h' for additional help
    api             start as api
    gen             generate new token. -o onetime, -e expire date
    status          view status or disable token. -s status, -d disable, -l
                    list

optional arguments:
  -h, --help

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 a simple html form, see the sample 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

For more info check the wiki