Go to file
ZerataX 7e71f4c319
add TODO comments
2018-09-09 20:01:55 +02:00
matrix_registration add TODO comments 2018-09-09 20:01:55 +02:00
resources add logo 2018-06-15 18:32:23 +02:00
tests add TODO comments 2018-09-09 20:01:55 +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
LICENSE Create LICENSE 2018-05-14 02:13:11 +02:00
README.md add logo 2018-06-15 18:32:23 +02:00
config.sample.yaml allow cors 2018-06-17 23:41:28 +02:00
requirements.txt allow cors 2018-06-17 23:41: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

git clone https://github.com/ZerataX/matrix-registration.git
cd matrix-registration

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

cp config.sample.yaml config.yaml

and edit config.yaml

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;

    if ($request_method = POST ) {
        proxy_pass http://localhost:5000;
    }
}

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.: https://homeserver.tld/register.html?token=DoubleWizardSki

For more info check the wiki