#!/bin/sh # Check if the necessary parameters are provided if [ "$#" -ne 2 ]; then echo "Usage: $0 " exit 1 fi # Assign parameters domain="$1" docker_compose_instance_directory="$2" # Copy certificates cp -RvL "/etc/letsencrypt/live/$domain/"* "$docker_compose_instance_directory/certs" || exit 1 # This code is optimized for mailu cp -v "/etc/letsencrypt/live/$domain/privkey.pem" "$docker_compose_instance_directory/certs/key.pem" || exit 1 cp -v "/etc/letsencrypt/live/$domain/fullchain.pem" "$docker_compose_instance_directory/certs/cert.pem" || exit 1 # Set correct reading rights chmod a+r -v "$docker_compose_instance_directory/certs/"* # Flag to track if any Nginx reload was successful nginx_reload_successful=false # Reload Nginx in all containers within the Docker Compose setup cd "$docker_compose_instance_directory" || exit 1 # Iterate over all services for service in $(docker compose ps --services); do echo "Checking service: $service" # Check if Nginx exists in the container if docker compose exec -T "$service" which nginx > /dev/null 2>&1; then echo "Reloading Nginx for service: $service" if docker compose exec -T "$service" nginx -s reload; then nginx_reload_successful=true echo "Successfully reloaded Nginx for service: $service" else echo "Failed to reload Nginx for service: $service" >&2 fi else echo "Nginx not found in service: $service, skipping." fi done # Restart all containers if no Nginx reload was successful if [ "$nginx_reload_successful" = false ]; then echo "No Nginx reload was successful. Restarting all Docker containers." docker compose restart || exit 1 else echo "At least one Nginx reload was successful. No restart needed." fi