Skip to content

A Matrix bot to invite users of the VOW platform to specific rooms and spaces.

License

Notifications You must be signed in to change notification settings

Shorty1o1/vow-matrix-invite-bot

 
 

Repository files navigation

vow-matrix-invite-bot

This is an invite Bot for Matrix. Depending on the Keycloak groups of a given user, it will create and/or invite users to specific Matrix rooms and/or spaces.

It uses three APIs for this purpose (the Matrix Client-Server API, the Synapse Admin API and the Keycloak Admin API).

This bot consists of two separate and independent parts:

1. Sending a DM when a valid user enters a specific room

Sequence diagram of the DM logic:

flowchart TD
    A[User joins monitored room] -->B[User known to Keycloak?]
    B -->|Yes| C[Check Groups]
    B -->|No| D[Do nothing]
    C -->|Crew| E[Space exists?]
    C -->|Owner| F[Space exists?]
    E -->|Yes| G[Send 'Exists DM' & Invite]
    E -->|No| H[Do nothing]
    F -->|Yes| G
    F -->|No| J[Send 'Create DM']
Loading

2. Creating/inviting a user, when he sends a creation command

Local development setup

To test/develop this project locally, you need to have Node.js installed (for correct version, see .nvmrc). Just clone the repo, switch to the new folder and run npm install. Now add/adjust your .env file and then run npm run dev.

Production setup (via Docker)

  • Clone the project
  • Either create a .env file or set the environment variables inside of docker-compose.yml
  • Run docker-compose up

Problems/Todos

  • Somehow the Keycloak API always fails on first start. Restarting the bot fixes it, but it's annoying and should be fixed.
  • Currently, message encryption is not supported, b/c there seems to be no way to extract a proper token from Synapse when using SSO login. The token that can be extracted from Element is device-specific does not work with encryption enabled.

About

A Matrix bot to invite users of the VOW platform to specific rooms and spaces.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 99.3%
  • Dockerfile 0.7%