mirror of
https://github.com/kevinveenbirkenbach/computer-playbook.git
synced 2025-01-22 07:03:21 +01:00
Solved cert bugs
This commit is contained in:
parent
3f0f666d25
commit
b9c51d29ae
@ -246,7 +246,7 @@ keycloak_administrator_username: "{{administrator_username}}"
|
|||||||
|
|
||||||
#### LDAP
|
#### LDAP
|
||||||
ldap_version: "latest"
|
ldap_version: "latest"
|
||||||
ldap_admin_version: "latest"
|
ldap_admin_version: "2.0.0-dev"
|
||||||
ldap_administrator_username: "{{administrator_username}}"
|
ldap_administrator_username: "{{administrator_username}}"
|
||||||
ldap_administrator_password: "{{user_administrator_initial_password}}" #CHANGE for security reasons
|
ldap_administrator_password: "{{user_administrator_initial_password}}" #CHANGE for security reasons
|
||||||
|
|
||||||
|
@ -2,7 +2,6 @@
|
|||||||
- name: "include docker/compose/common.yml"
|
- name: "include docker/compose/common.yml"
|
||||||
include_tasks: docker/compose/common.yml
|
include_tasks: docker/compose/common.yml
|
||||||
|
|
||||||
# optimize
|
|
||||||
- name: "include tasks nginx-docker-proxy-domain.yml"
|
- name: "include tasks nginx-docker-proxy-domain.yml"
|
||||||
include_tasks: nginx-docker-proxy-domain.yml
|
include_tasks: nginx-docker-proxy-domain.yml
|
||||||
|
|
||||||
|
@ -35,10 +35,10 @@ services:
|
|||||||
LDAP_LDAPS_PORT_NUMBER: 636 # Port used for TLS secure traffic. Priviledged port is supported (e.g. 636). Default: 1636 (non privileged port).
|
LDAP_LDAPS_PORT_NUMBER: 636 # Port used for TLS secure traffic. Priviledged port is supported (e.g. 636). Default: 1636 (non privileged port).
|
||||||
LDAP_TLS_CERT_FILE: /certs/cert.pem # File containing the certificate file for the TLS traffic. No defaults.
|
LDAP_TLS_CERT_FILE: /certs/cert.pem # File containing the certificate file for the TLS traffic. No defaults.
|
||||||
LDAP_TLS_KEY_FILE: /certs/key.pem # File containing the key for certificate. No defaults.
|
LDAP_TLS_KEY_FILE: /certs/key.pem # File containing the key for certificate. No defaults.
|
||||||
#LDAP_TLS_CA_FILE: # File containing the CA of the certificate. No defaults.
|
LDAP_TLS_CA_FILE: /certs/chain.pem # File containing the CA of the certificate. No defaults.
|
||||||
#LDAP_TLS_DH_PARAMS_FILE: # File containing the DH parameters. No defaults.
|
#LDAP_TLS_DH_PARAMS_FILE: # File containing the DH parameters. No defaults.
|
||||||
volumes:
|
volumes:
|
||||||
- {{cert_mount_directory}}:/certs
|
- {{cert_mount_directory}}:/certs:ro
|
||||||
- 'data:/bitnami/openldap'
|
- 'data:/bitnami/openldap'
|
||||||
{% include 'templates/docker/container/networks.yml.j2' %}
|
{% include 'templates/docker/container/networks.yml.j2' %}
|
||||||
{% include 'templates/docker/compose/volumes.yml.j2' %}
|
{% include 'templates/docker/compose/volumes.yml.j2' %}
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
docker_compose_project_name: "ldap"
|
docker_compose_project_name: "ldap"
|
||||||
ldap_root: "dc={{primary_domain_sld}},dc={{primary_domain_tld}}"
|
ldap_root: "dc={{primary_domain_sld}},dc={{primary_domain_tld}}"
|
||||||
ldap_admin_dm: "cn={{ldap_administrator_username}},{{ldap_root}}"
|
ldap_admin_dn: "cn={{ldap_administrator_username}},{{ldap_root}}"
|
||||||
|
cert_mount_directory: "{{docker_compose_instance_directory}}/certs/"
|
@ -32,7 +32,7 @@ services:
|
|||||||
- "{{ ip4_address }}:4190:4190"
|
- "{{ ip4_address }}:4190:4190"
|
||||||
volumes:
|
volumes:
|
||||||
- "/etc/mailu/overrides/nginx:/overrides:ro"
|
- "/etc/mailu/overrides/nginx:/overrides:ro"
|
||||||
- "{{docker_compose_instance_directory}}/certs/:/certs"
|
- "{{cert_mount_directory}}:/certs:ro"
|
||||||
{% include 'templates/docker/container/depends-on-also-database.yml.j2' %}
|
{% include 'templates/docker/container/depends-on-also-database.yml.j2' %}
|
||||||
resolver:
|
resolver:
|
||||||
condition: service_started
|
condition: service_started
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
docker_compose_project_name: "mailu"
|
docker_compose_project_name: "mailu"
|
||||||
database_password: "{{mailu_database_password}}"
|
database_password: "{{mailu_database_password}}"
|
||||||
database_type: "mariadb"
|
database_type: "mariadb"
|
||||||
|
cert_mount_directory: "{{docker_compose_instance_directory}}/certs/"
|
@ -11,14 +11,35 @@ domain="$1"
|
|||||||
docker_compose_instance_directory="$2"
|
docker_compose_instance_directory="$2"
|
||||||
|
|
||||||
# Copy certificates
|
# Copy certificates
|
||||||
cp "/etc/letsencrypt/live/$domain/privkey.pem" "$docker_compose_instance_directory/certs/key.pem" || exit 1
|
cp -Rv "/etc/letsencrypt/live/$domain/"* "$docker_compose_instance_directory/certs" || exit 1
|
||||||
cp "/etc/letsencrypt/live/$domain/fullchain.pem" $docker_compose_instance_directory/certs/cert.pem || exit 1
|
|
||||||
|
# Flag to track if any Nginx reload was successful
|
||||||
|
nginx_reload_successful=false
|
||||||
|
|
||||||
# Reload Nginx in all containers within the Docker Compose setup
|
# Reload Nginx in all containers within the Docker Compose setup
|
||||||
cd "$docker_compose_instance_directory" || exit 1
|
cd "$docker_compose_instance_directory" || exit 1
|
||||||
docker compose ps --services | while read -r service; do
|
|
||||||
docker compose exec "$service" nginx -s reload && exit 0
|
# 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
|
done
|
||||||
|
|
||||||
# Restart all docker containers if no nginx reload is possible
|
# Restart all containers if no Nginx reload was successful
|
||||||
docker compose restart || exit 1
|
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
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
---
|
---
|
||||||
- name: "restart nginx-docker-cert-deploy.cymais.service"
|
- name: "restart nginx-docker-cert-deploy.cymais.service"
|
||||||
systemd:
|
systemd:
|
||||||
name: nginx-docker-cert-deploy.{{domain}}.cymais.service
|
name: nginx-docker-cert-deploy.{{docker_compose_project_name}}.cymais.service
|
||||||
state: restarted
|
state: restarted
|
||||||
enabled: yes
|
enabled: yes
|
||||||
daemon_reload: yes
|
daemon_reload: yes
|
@ -1,2 +1 @@
|
|||||||
cert_mount_directory: "{{docker_compose_instance_directory}}/certs/"
|
|
||||||
nginx_docker_cert_deploy_script: "{{path_administrator_scripts}}nginx-docker-cert-deploy.sh"
|
nginx_docker_cert_deploy_script: "{{path_administrator_scripts}}nginx-docker-cert-deploy.sh"
|
Loading…
x
Reference in New Issue
Block a user