#!/bin/bash
#
# Matrix Signal Service

PATH=$HOME/.docker/cli-plugins:/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin

config_matrixsignal() {
  echo -ne "\n* Configuring /federated/apps/matrixsignal container.."

  if [ ! -d "/federated/apps/matrixsignal" ]; then
    mkdir -p /federated/apps/matrixsignal/data
  fi

cat > /federated/apps/matrixsignal/docker-compose.yml <<EOF
services:
  matrixsignal:
    image: dock.mau.dev/mautrix/signal:\${IMAGE_VERSION}
    container_name: matrixsignal
    hostname: matrixsignal.$DOMAIN
    restart: always
    networks:
      core:
        ipv4_address: 192.168.0.81
    env_file:
      - ./.env
    volumes:
      - ./data:/data
    labels:
      - "traefik.enable=true"
      - "traefik.http.routers.matrixsignal.rule=Host(\`matrixsignal.$DOMAIN\`)"
      - "traefik.http.routers.matrixsignal.entrypoints=websecure"
      - "traefik.http.routers.matrixsignal.tls.certresolver=letsencrypt"

networks:
  core:
    external: true
EOF

MATRIXSIGNAL_SECRET=$(create_password);

# Run to create the config file
docker run --rm -v /federated/apps/matrixsignal/data:/data:z dock.mau.dev/mautrix/signal:latest

cat > /federated/apps/matrixsignal/.env <<EOF
IMAGE_VERSION="latest"
EOF
chmod 600 /federated/apps/matrixsignal/.env

# Change config values in config.yaml
sed -i '0,/address:.*/s//address: http:\/\/192.168.0.19:8008/' /federated/apps/matrixsignal/data/config.yaml
sed -i "s/localhost/192.168.0.81/g" /federated/apps/matrixsignal/data/config.yaml
sed -i "s#domain:.*#domain: matrix.$DOMAIN#g" /federated/apps/matrixsignal/data/config.yaml
sed -i "s#uri:.*#uri: postgres://matrixsignal:$MATRIXSIGNAL_SECRET@postgresql.$DOMAIN/matrixsignal?sslmode=disable#g" /federated/apps/matrixsignal/data/config.yaml
sed -i "s/example.com/matrix.$DOMAIN/g" /federated/apps/matrixsignal/data/config.yaml

# Create database and user in postgresql
docker exec postgresql psql -U postgres -c "CREATE USER matrixsignal WITH PASSWORD '$MATRIXSIGNAL_SECRET'" &> /dev/null
docker exec postgresql psql -U postgres -c "CREATE DATABASE matrixsignal" &> /dev/null
docker exec postgresql psql -U postgres -c "GRANT ALL PRIVILEGES ON DATABASE matrixsignal TO matrixsignal" &> /dev/null

# Run again to create the registration file
docker run --rm -v /federated/apps/matrixsignal/data:/data:z dock.mau.dev/mautrix/signal:latest

# Insert our Matrix Slack config into Matrix homeserverl.yaml
cp /federated/apps/matrixsignal/data/registration.yaml /federated/apps/matrix/data/matrix/matrixsignal-registration.yaml
cat >> /federated/apps/matrix/data/matrix/homeserver.yaml <<EOF
app_service_config_files:
- /data/matrixsignal-registration.yaml
EOF

# Set permissions
chown -R 991:991 /federated/apps/matrix/data/matrix
 
echo -ne "done."
}
start_matrixsignal() {
  # Start service with command to make sure it's up before proceeding
  start_service "matrixsignal" "nc -z 192.168.0.81 29328 &> /dev/null" "7"

  echo -ne "done."
}
uninstall_matrixsignal() {
  echo -ne "* Uninstalling matrixsignal container.."
  spin &
  SPINPID=$!

  # First stop the service
  cd /federated/apps/matrixsignal && docker compose -f docker-compose.yml -p matrixsignal down &> /dev/null

  # Delete database and user in postgresql
  docker exec postgresql psql -U postgres -c "DROP DATABASE matrixsignal" &> /dev/null
  docker exec postgresql psql -U postgres -c "DROP USER matrixsignal" &> /dev/null

  # Delete the app directory
  rm -rf /federated/apps/matrixsignal

  kill -9 $SPINPID &> /dev/null
  echo -ne "done.\n"
}