#!/bin/bash # # Proxy Service PATH=$HOME/.docker/cli-plugins:/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin config_proxy() { echo -ne "\n* Configuring /federated/apps/proxy container.." spin & SPINPID=$! DOMAIN_ARRAY=(${DOMAIN//./ }) DOMAIN_FIRST=${DOMAIN_ARRAY[0]} DOMAIN_MIDDLE=${DOMAIN_ARRAY[1]} DOMAIN_LAST=${DOMAIN_ARRAY[2]} if [ ! -d "/federated/apps/proxy" ]; then mkdir -p /federated/apps/proxy/data/root/certs &> /dev/null cp /federated/apps/dns/data/etc/letsencrypt/archive/$DOMAIN_MIDDLE.$DOMAIN_LAST/fullchain1.pem /federated/apps/proxy/data/root/certs/$DOMAIN_MIDDLE.$DOMAIN_LAST.crt cp /federated/apps/dns/data/etc/letsencrypt/archive/$DOMAIN_MIDDLE.$DOMAIN_LAST/privkey1.pem /federated/apps/proxy/data/root/certs/$DOMAIN_MIDDLE.$DOMAIN_LAST.key fi # DOMAIN_ARRAY=(${DOMAIN//./ }) # DOMAIN_FIRST=${DOMAIN_ARRAY[0]} # DOMAIN_LAST=${DOMAIN_ARRAY[1]} cat > /federated/apps/proxy/docker-compose.yml <<EOF services: proxy: image: jwilder/nginx-proxy:\${IMAGE_VERSION} container_name: proxy hostname: proxy.$DOMAIN restart: always networks: core: ipv4_address: 192.168.0.15 ports: - "80:80" - "443:443" volumes: - /var/run/docker.sock:/tmp/docker.sock:ro - ./data/root/certs:/etc/nginx/certs - ./data/custom.conf:/etc/nginx/conf.d/custom.conf:ro env_file: - ./.env networks: core: external: true EOF cat > /federated/apps/proxy/.env <<EOF IMAGE_VERSION="1.1" DEFAULT_HOST=www.$DOMAIN EOF chmod 600 /federated/apps/proxy/.env cat > /federated/apps/proxy/data/custom.conf <<EOF client_max_body_size 64000M; EOF kill -9 $SPINPID &> /dev/null echo -ne "done." } start_proxy() { # Start service with command to make sure it's up before proceeding start_service "proxy" "nc -z 192.168.0.15 443 &> /dev/null" kill -9 $SPINPID &> /dev/null echo -ne "done." }