Go to file
ZerataX 688157b7bc
bump version
2018-06-01 04:58:10 +02:00
matrix_registration bump version 2018-06-01 04:58:10 +02:00
resources added comments to api.py 2018-05-30 20:38:40 +02:00
tests added comments to api.py 2018-05-30 20:38:40 +02:00
.coveragerc coverage omit __main__ 2018-05-14 01:56:25 +02:00
.gitignore update tests 2018-05-26 19:05:24 +02:00
.travis.yml update travis 2018-05-14 02:08:49 +02:00
README.md added comments to api.py 2018-05-30 20:38:40 +02:00
config.sample.yaml added comments to api.py 2018-05-30 20:38:40 +02:00
requirements.txt admin api 2018-06-01 04:57:28 +02:00
setup.py update readme 2018-05-14 04:51:00 +02:00

README.md

Build Status Coverage Status 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

  virtualenv -p /usr/bin/python3.6 .
  source ./bin/activate
  pip install -r requirements.txt

usage

python -m matrix_registration -h

if you've started the api server and generated a token you can register an account with curl, 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.: http://localhost:5000/register?token=DoubleWizardSki

easying the registration even further

For more info check the wiki

nginx reverse-proxy

an example nginx setup to expose the html form and the api endpoint on the same URL, based on whether a POST or GET request was made.

location /register {
    alias resources/example.html;

    limit_except POST {
        proxy_pass http://localhost:5000;
    }
}