#!/bin/bash # # Matrix Service PATH=$HOME/.docker/cli-plugins:/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin config_matrix() { echo -ne "\n* Configuring /federated/apps/matrix container.." spin & SPINPID=$! if [ ! -d "/federated/apps/matrix" ]; then mkdir -p /federated/apps/matrix/data/matrix &> /dev/null cp /federated/certs/certs/$DOMAIN.crt /federated/certs/private/$DOMAIN.key /federated/apps/matrix/data/matrix/ chmod 644 /federated/apps/matrix/data/matrix/$DOMAIN.crt /federated/apps/matrix/data/matrix/$DOMAIN.key fi cat > /federated/apps/matrix/docker-compose.yml < /federated/apps/matrix/.env < /dev/null [ $? -ne 0 ] && fail "Couldn't run docker matrixdotorg/synapse:latest generate" # Take out default Sqlite database config sed -i 's!database: /data/homeserver.db!!g' /federated/apps/matrix/data/matrix/homeserver.yaml sed -i 's!database:!!g' /federated/apps/matrix/data/matrix/homeserver.yaml sed -i 's!name: sqlite3!!g' /federated/apps/matrix/data/matrix/homeserver.yaml sed -i 's!args:!!g' /federated/apps/matrix/data/matrix/homeserver.yaml # Insert our Postgres and LDAP config cat >> /federated/apps/matrix/data/matrix/homeserver.yaml <" app_name: $COMPANY Matrix Server modules: - module: "ldap_auth_provider.LdapAuthProviderModule" config: enabled: true uri: "ldaps://ldap.$DOMAIN:636" start_tls: true base: "dc=federatedcomputer,dc=cloud" attributes: mail: "mail" uid: "uid" name: "givenName" bind_dn: cn=admin,dc=federatedcomputer,dc=cloud bind_password: $LDAP_SECRET tls_options: validate: true local_certificate_file: /data/$DOMAIN.crt local_private_key_file: /data/$DOMAIN.key EOF kill -9 $SPINPID &> /dev/null echo -ne "done." } start_matrix() { # Start service with command to make sure it's up before proceeding start_service "matrix" "nc -z 172.99.0.19 8008 &> /dev/null" "8" kill -9 $SPINPID &> /dev/null echo -ne "done." }