#!/bin/bash # This script expects a mapping of services and ports in the SERVICES env var, # with one line per service containing "NAME PORT". # Other vars: # THRIMBLETRIMMER: Set non-empty to also serve thrimbletrimmer on /thrimbletrimmer # BUSCRIBE: Set non-empty to also serve buscribe on /buscribe # SEGMENTS: Set to path to segments dir to also serve segments dir on /segments # SSL: Set to path to file containing SSL cert and key, if any. generate_location() { # generate_location PATH URL # We indirect via a variable to prevent nginx from caching dns forever echo -e "\t\tlocation $1 { set \$name \"$2\"; proxy_pass \$name; }" } LOCATIONS=$( [ -n "$SERVICES" ] && echo "$SERVICES" | while read name port; do # restreamer is the catch-all [ "$name" == "restreamer" ] && generate_location / "http://restreamer:$port" # thrimshim and buscribe-api take any calls to SERVICE/ if [ "$name" == "thrimshim" ] || [ "$name" == "buscribe_api" ]; then generate_location "/$name" "http://$name:$port" fi # all services have metrics under /metrics/SERVICE, except for thrimebletrimmer generate_location "/metrics/$name" "http://$name:$port/metrics" done [ -n "$THRIMBLETRIMMER" ] && echo -e "\t\tlocation = / { return 301 /thrimbletrimmer/; }" && echo -e "\t\tlocation /thrimbletrimmer { }" [ -n "$BUSCRIBE" ] && echo -e "\t\tlocation /buscribe { }" [ -n "$SEGMENTS" ] && echo -e "\t\tlocation /segments/ { alias $SEGMENTS/; }" ) [ -n "$SSL" ] && SSL_CONF=$(cat < /etc/nginx/nginx.conf <