In between commit LDAP integration

This commit is contained in:
Kevin Veen-Birkenbach 2025-01-21 14:09:06 +01:00
parent 02ae02634b
commit 936fdbad66
14 changed files with 144 additions and 119 deletions

View File

@ -1,18 +1,23 @@
# General # General
pause_duration: "120" # Database delay to wait for the central database before continue tasks pause_duration: "120" # Database delay to wait for the central database before continue tasks
top_domain: "localhost" # Change this in inventory to your domain
ip4_address: "127.0.0.1" # Change thie in inventory to the ip address of your server ip4_address: "127.0.0.1" # Change thie in inventory to the ip address of your server
backups_folder_path: "/Backups/" # Path to the backups folder backups_folder_path: "/Backups/" # Path to the backups folder
## Domain
primary_domain_tld: "localhost" # Top Level Domain of the server
primary_domain_sld: "cymais" # Second Level Domain of the server
primary_domain: "{{primary_domain_sld}}.{{primary_domain_tld}}" # Primary Domain of the server
# Administrator # Administrator
administrator_username: "administrator" # Username of the administrator administrator_username: "administrator" # Username of the administrator
administrator_email: "{{administrator_username}}@{{top_domain}}" # Email of the administrator administrator_email: "{{administrator_username}}@{{primary_domain}}" # Email of the administrator
#user_administrator_initial_password: EXAMPLE_PASSWORD_123456 # Example initialisation password needs to be set in inventory file
# Email Configuration # Email Configuration
system_email_local: no-reply system_email_local: no-reply
system_email_domain: "{{top_domain}}" system_email_domain: "{{primary_domain}}"
system_email_username: "{{system_email_local}}@{{system_email_domain}}" system_email_username: "{{system_email_local}}@{{system_email_domain}}"
system_email_host: "mail.{{top_domain}}" system_email_host: "mail.{{primary_domain}}"
system_email_smtp_port: 465 system_email_smtp_port: 465
system_email_tls: true system_email_tls: true
system_email_start_tls: false system_email_start_tls: false
@ -20,7 +25,7 @@ system_email_from: "{{system_email_username}}"
system_email_smtp: true system_email_smtp: true
# Test Email # Test Email
test_email: "test@{{top_domain}}" test_email: "test@{{primary_domain}}"
# Mode # Mode
@ -36,7 +41,7 @@ mode_setup: false # Execute the setup and initializing procedures
# Server Tact Variables # Server Tact Variables
## Ours in which the server is "awake" (100% working). Rest of the time is reserved for maintanance ## Ours in which the server is "awake" (100% working). Rest of the time is reserved for maintanance
hours_server_awake: "0..23" hours_server_awake: "0..23"
## Random delay for systemd timers to avoid peak loads. ## Random delay for systemd timers to avoid peak loads.
randomized_delay_sec: "5min" randomized_delay_sec: "5min"
@ -73,16 +78,16 @@ size_percent_disc_space_warning: 90 # Warning threshold in percent
# Path Variables for Key Directories and Scripts # Path Variables for Key Directories and Scripts
path_administrator_home: "/home/administrator/" path_administrator_home: "/home/administrator/"
path_administrator_scripts: "{{path_administrator_home}}scripts/" path_administrator_scripts: "{{path_administrator_home}}scripts/"
path_docker_volumes: "{{path_administrator_home}}volumes/docker/" path_docker_volumes: "{{path_administrator_home}}volumes/docker/"
path_docker_compose_instances: "{{path_administrator_home}}docker-compose/" path_docker_compose_instances: "{{path_administrator_home}}docker-compose/"
path_system_lock_script: "{{path_administrator_scripts}}system-maintenance-lock.py" path_system_lock_script: "{{path_administrator_scripts}}system-maintenance-lock.py"
# Runtime Variables for Process Control # Runtime Variables for Process Control
activate_all_timers: false # Activates all timers, independend if the handlers had been triggered activate_all_timers: false # Activates all timers, independend if the handlers had been triggered
nginx_matomo_tracking: false # Activates matomo tracking on all html pages nginx_matomo_tracking: false # Activates matomo tracking on all html pages
# System maintenance Services # System maintenance Services
@ -132,60 +137,63 @@ nginx_upstreams_directory: "{{nginx_configuration_directory}}upstreams/"
nginx_well_known_root: "/usr/share/nginx/well-known/" # Path where well-known files are stored nginx_well_known_root: "/usr/share/nginx/well-known/" # Path where well-known files are stored
nginx_homepage_root: "/usr/share/nginx/homepage/" # Path where the static homepage files are stored nginx_homepage_root: "/usr/share/nginx/homepage/" # Path where the static homepage files are stored
## Nginx static repository
nginx_static_repository_address: NULL #This should contain the url to an git repository which has a static homepage included and an index.html file
## Domains ## Domains
### Service Domains ### Service Domains
domain_akaunting: "accounting.{{top_domain}}" domain_akaunting: "accounting.{{primary_domain}}"
domain_attendize: "tickets.{{top_domain}}" domain_attendize: "tickets.{{primary_domain}}"
domain_baserow: "baserow.{{top_domain}}" domain_baserow: "baserow.{{primary_domain}}"
domain_bigbluebutton: "meet.{{top_domain}}" domain_bigbluebutton: "meet.{{primary_domain}}"
domain_bluesky_api: "bluesky.{{top_domain}}" domain_bluesky_api: "bluesky.{{primary_domain}}"
domain_bluesky_web: "bskyweb.{{top_domain}}" domain_bluesky_web: "bskyweb.{{primary_domain}}"
domain_discourse: "forum.{{top_domain}}" domain_discourse: "forum.{{primary_domain}}"
domain_elk: "elk.{{top_domain}}" domain_elk: "elk.{{primary_domain}}"
domain_friendica: "friendica.{{top_domain}}" domain_friendica: "friendica.{{primary_domain}}"
domain_funkwhale: "music.{{top_domain}}" domain_funkwhale: "music.{{primary_domain}}"
domain_gitea: "git.{{top_domain}}" domain_gitea: "git.{{primary_domain}}"
domain_gitlab: "gitlab.{{top_domain}}" domain_gitlab: "gitlab.{{primary_domain}}"
domain_portfolio: "{{top_domain}}" domain_portfolio: "{{primary_domain}}"
domain_keycloak: "auth.{{top_domain}}" domain_keycloak: "auth.{{primary_domain}}"
domain_listmonk: "newsletter.{{top_domain}}" domain_listmonk: "newsletter.{{primary_domain}}"
domain_mailu: "{{system_email_host}}" domain_mailu: "{{system_email_host}}"
domain_mastodon: "microblog.{{top_domain}}" domain_mastodon: "microblog.{{primary_domain}}"
domains_mastodon_alternates: ["mastodon.{{top_domain}}"] domains_mastodon_alternates: ["mastodon.{{primary_domain}}"]
domain_matomo: "matomo.{{top_domain}}" domain_matomo: "matomo.{{primary_domain}}"
domain_matrix_synapse: "matrix.{{top_domain}}" domain_matrix_synapse: "matrix.{{primary_domain}}"
domain_matrix_element: "element.{{top_domain}}" domain_matrix_element: "element.{{primary_domain}}"
domain_moodle: "academy.{{top_domain}}" domain_moodle: "academy.{{primary_domain}}"
domain_mediawiki: "wiki.{{top_domain}}" domain_mediawiki: "wiki.{{primary_domain}}"
domain_nextcloud: "cloud.{{top_domain}}" domain_nextcloud: "cloud.{{primary_domain}}"
domain_openproject: "project.{{top_domain}}" domain_openproject: "project.{{primary_domain}}"
domain_pixelfed: "picture.{{top_domain}}" domain_pixelfed: "picture.{{primary_domain}}"
domain_peertube: "video.{{top_domain}}" domain_peertube: "video.{{primary_domain}}"
domains_peertube: [] domains_peertube: []
domain_roulette: "roulette.{{top_domain}}" domain_roulette: "roulette.{{primary_domain}}"
domain_taiga: "kanban.{{top_domain}}" domain_taiga: "kanban.{{primary_domain}}"
domain_yourls: "s.{{top_domain}}" domain_yourls: "s.{{primary_domain}}"
domains_wordpress: ["wordpress.{{top_domain}}","blog.{{top_domain}}"] domains_wordpress: ["wordpress.{{primary_domain}}","blog.{{primary_domain}}"]
### Domain Redirects ### Domain Redirects
redirect_domain_mappings: redirect_domain_mappings:
- { source: "akaunting.{{top_domain}}", target: "{{domain_akaunting}}" } - { source: "akaunting.{{primary_domain}}", target: "{{domain_akaunting}}" }
- { source: "bbb.{{top_domain}}", target: "{{domain_bigbluebutton}}" } - { source: "bbb.{{primary_domain}}", target: "{{domain_bigbluebutton}}" }
- { source: "discourse.{{top_domain}}", target: "{{domain_discourse}}" } - { source: "discourse.{{primary_domain}}", target: "{{domain_discourse}}" }
- { source: "funkwhale.{{top_domain}}", target: "{{domain_funkwhale}}" } - { source: "funkwhale.{{primary_domain}}", target: "{{domain_funkwhale}}" }
- { source: "gitea.{{top_domain}}", target: "{{domain_gitea}}" } - { source: "gitea.{{primary_domain}}", target: "{{domain_gitea}}" }
- { source: "keycloak.{{top_domain}}", target: "{{domain_keycloak}}" } - { source: "keycloak.{{primary_domain}}", target: "{{domain_keycloak}}" }
- { source: "listmonk.{{top_domain}}", target: "{{domain_listmonk}}" } - { source: "listmonk.{{primary_domain}}", target: "{{domain_listmonk}}" }
- { source: "moodle.{{top_domain}}", target: "{{domain_moodle}}" } - { source: "moodle.{{primary_domain}}", target: "{{domain_moodle}}" }
- { source: "nextcloud.{{top_domain}}", target: "{{domain_nextcloud}}" } - { source: "nextcloud.{{primary_domain}}", target: "{{domain_nextcloud}}" }
- { source: "openproject.{{top_domain}}", target: "{{domain_openproject}}" } - { source: "openproject.{{primary_domain}}", target: "{{domain_openproject}}" }
- { source: "peertube.{{top_domain}}", target: "{{domain_peertube}}" } - { source: "peertube.{{primary_domain}}", target: "{{domain_peertube}}" }
- { source: "pictures.{{top_domain}}", target: "{{domain_pixelfed}}" } - { source: "pictures.{{primary_domain}}", target: "{{domain_pixelfed}}" }
- { source: "pixelfed.{{top_domain}}", target: "{{domain_pixelfed}}" } - { source: "pixelfed.{{primary_domain}}", target: "{{domain_pixelfed}}" }
- { source: "short.{{top_domain}}", target: "{{domain_yourls}}" } - { source: "short.{{primary_domain}}", target: "{{domain_yourls}}" }
- { source: "taiga.{{top_domain}}", target: "{{domain_taiga}}" } - { source: "taiga.{{primary_domain}}", target: "{{domain_taiga}}" }
- { source: "videos.{{top_domain}}", target: "{{domain_peertube}}" } - { source: "videos.{{primary_domain}}", target: "{{domain_peertube}}" }
## Docker Applications ## Docker Applications
@ -202,7 +210,7 @@ docker_restart_policy: "unless-stopped"
#### Akaunting #### Akaunting
akaunting_version: "latest" akaunting_version: "latest"
akaunting_company_name: "{{top_domain}}" akaunting_company_name: "{{primary_domain}}"
akaunting_company_email: "{{administrator_email}}" akaunting_company_email: "{{administrator_email}}"
akaunting_setup_admin_email: "{{administrator_email}}" akaunting_setup_admin_email: "{{administrator_email}}"
@ -232,13 +240,19 @@ gitlab_version: "latest"
joomla_version: "latest" joomla_version: "latest"
#### Keycloak #### Keycloak
keycloak_version: "latest" keycloak_version: "latest"
keycloak_administrator_username: "{{administrator_username}}" keycloak_administrator_username: "{{administrator_username}}"
#### LDAP
ldap_version: "latest"
ldap_administrator_username: "{{administrator_username}}"
ldap_administrator_password: "{{user_administrator_initial_password}}" #CHANGE for security reasons
# ldap_database_password: # Needs to be defined in inventory
#### Listmonk #### Listmonk
listmonk_admin_username: "admin" listmonk_admin_username: "{{administrator_username}}"
listmonk_public_api_activated: False # Security hole. Can be used for spaming listmonk_public_api_activated: False # Security hole. Can be used for spaming
listmonk_version: "latest" listmonk_version: "latest"
#### MariaDB #### MariaDB
mariadb_version: "latest" mariadb_version: "latest"
@ -254,17 +268,17 @@ mastodon_single_user_mode: false
matrix_administrator_username: "{{administrator_username}}" # Accountname of the matrix admin matrix_administrator_username: "{{administrator_username}}" # Accountname of the matrix admin
matrix_playbook_tags: "setup-all,start" # For the initial update use: install-all,ensure-matrix-users-created,start matrix_playbook_tags: "setup-all,start" # For the initial update use: install-all,ensure-matrix-users-created,start
matrix_role: "compose" # Role to setup Matrix. Valid values: ansible, compose matrix_role: "compose" # Role to setup Matrix. Valid values: ansible, compose
matrix_server_name: "{{top_domain}}" # Adress for the account names etc. matrix_server_name: "{{primary_domain}}" # Adress for the account names etc.
matrix_synapse_version: "latest" matrix_synapse_version: "latest"
matrix_element_version: "latest" matrix_element_version: "latest"
#### Mailu #### Mailu
mailu_version: "2024.06" mailu_version: "2024.06"
mailu_domain: "{{top_domain}}" mailu_domain: "{{primary_domain}}"
mailu_subnet: "192.168.203.0/24" mailu_subnet: "192.168.203.0/24"
#### Moodle #### Moodle
moodle_site_name: "Global Learning Academy on {{top_domain}}" moodle_site_name: "Global Learning Academy on {{primary_domain}}"
moodle_administrator_name: "{{administrator_username}}" moodle_administrator_name: "{{administrator_username}}"
moodle_administrator_email: "{{administrator_email}}" moodle_administrator_email: "{{administrator_email}}"
moodle_version: "latest" moodle_version: "latest"
@ -279,7 +293,7 @@ nextcloud_version: "production" # @see https://nextcloud.com/blog/nextclou
peertube_version: "bookworm" peertube_version: "bookworm"
#### Pixelfed #### Pixelfed
pixelfed_app_name: "Pictures on {{top_domain}}" pixelfed_app_name: "Pictures on {{primary_domain}}"
pixelfed_version: "latest" pixelfed_version: "latest"
#### Postgres #### Postgres

View File

@ -313,7 +313,7 @@
roles: roles:
- role: nginx-static-repository - role: nginx-static-repository
vars: vars:
domain: "{{top_domain}}" domain: "{{primary_domain}}"
- name: setup redirect hosts - name: setup redirect hosts
hosts: redirect hosts: redirect

View File

@ -11,7 +11,7 @@ services:
PDS_ADMIN_EMAIL: "{{bluesky_administrator_email}}" PDS_ADMIN_EMAIL: "{{bluesky_administrator_email}}"
PDS_SERVICE_DID: "did:web:{{domain_api}}" PDS_SERVICE_DID: "did:web:{{domain_api}}"
# See https://mattdyson.org/blog/2024/11/self-hosting-bluesky-pds/ # See https://mattdyson.org/blog/2024/11/self-hosting-bluesky-pds/
PDS_SERVICE_HANDLE_DOMAINS: ".{{top_domain}}" PDS_SERVICE_HANDLE_DOMAINS: ".{{primary_domain}}"
PDS_JWT_SECRET: "{{bluesky_pds_jwt_secret}}" PDS_JWT_SECRET: "{{bluesky_pds_jwt_secret}}"
PDS_ADMIN_PASSWORD: "{{bluesky_pds_admin_password}}" PDS_ADMIN_PASSWORD: "{{bluesky_pds_admin_password}}"
PDS_PLC_ROTATION_KEY_K256_PRIVATE_KEY_HEX: "{{bluesky_pds_plc_rotation_key_k256_private_key_hex}}" PDS_PLC_ROTATION_KEY_K256_PRIVATE_KEY_HEX: "{{bluesky_pds_plc_rotation_key_k256_private_key_hex}}"
@ -47,7 +47,7 @@ services:
args: args:
REACT_APP_PDS_URL: "http://{{domain_api}}" # URL des PDS REACT_APP_PDS_URL: "http://{{domain_api}}" # URL des PDS
REACT_APP_API_URL: "http://{{domain_api}}" # API-URL des PDS REACT_APP_API_URL: "http://{{domain_api}}" # API-URL des PDS
REACT_APP_SITE_NAME: "{{top_domain | upper}} - Bluesky" REACT_APP_SITE_NAME: "{{primary_domain | upper}} - Bluesky"
REACT_APP_SITE_DESCRIPTION: "Decentral Social " REACT_APP_SITE_DESCRIPTION: "Decentral Social "
restart: {{docker_restart_policy}} restart: {{docker_restart_policy}}
ports: ports:

View File

@ -1,36 +1,42 @@
version: '2'
networks:
my-network:
driver: bridge
services: services:
openldap: {% include 'templates/docker/services/' + database_type + '.yml.j2' %}
image: bitnami/openldap:2
ports:
- '389:1389'
- '636:1636'
environment:
- LDAP_ADMIN_USERNAME=admin
- LDAP_ADMIN_PASSWORD=adminpassword
- LDAP_USERS=user01,user02 # Comma separated list of LDAP users to create in the default LDAP tree. Default: user01,user02
- LDAP_PASSWORDS=password1,password2 #Comma separated list of passwords to use for LDAP users. Default: bitnami1,bitnami2
- LDAP_ROOT=dc=example,dc=org
- LDAP_ADMIN_DN=cn=admin,dc=example,dc=org
- MARIADB_ROOT_PASSWORD=root-password openldap:
- MARIADB_GALERA_MARIABACKUP_PASSWORD=backup-password image: bitnami/openldap:{{ldap_version}}
- MARIADB_USER=customuser logging:
- MARIADB_DATABASE=customdatabase driver: journald
- MARIADB_ENABLE_LDAP=yes restart: {{docker_restart_policy}}
networks: ports:
- my-network - '127.0.0.1:389:1389' # Expose just on local host for security reasons
- '636:636' # Expose to internet
environment:
# GENERAL
LDAP_ADMIN_USERNAME: {{ldap_administrator_username}} # LDAP database admin user.
LDAP_ADMIN_PASSWORD: {{ldap_administrator_password}} # LDAP database admin password.
#LDAP_USERS: user01,user02 # Comma separated list of LDAP users to create in the default LDAP tree. Default: user01,user02
#LDAP_PASSWORDS: password1,password2 # Comma separated list of passwords to use for LDAP users. Default: bitnami1,bitnami
LDAP_ROOT: {{ldap_root}} # LDAP baseDN (or suffix) of the LDAP tree. Default: dc=example,dc=org
LDAP_ADMIN_DN: {{ldap_admin_dn}}
# TLS
LDAP_ENABLE_TLS: yes # Whether to enable TLS for traffic or not. Defaults to no
LDAP_REQUIRE_TLS: yes # Whether connections must use TLS. Will only be applied with LDAP_ENABLE_TLS active. Defaults to no
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: File containing the certificate file for the TLS traffic. No defaults.
LDAP_TLS_KEY_FILE: File containing the key for certificate. No defaults.
LDAP_TLS_CA_FILE: File containing the CA of the certificate. No defaults.
LDAP_TLS_DH_PARAMS_FILE: File containing the DH parameters. No defaults.
# Database Configuration
MARIADB_ROOT_PASSWORD=root-password
MARIADB_USER=customuser
MARIADB_DATABASE=customdatabase
MARIADB_ENABLE_LDAP=yes
volumes: volumes:
- 'openldap_data:/bitnami/openldap' - 'data:/bitnami/openldap'
myapp: {% include 'templates/docker/container/depends-on-just-database.yml.j2' %}
image: 'YOUR_APPLICATION_IMAGE' {% include 'templates/docker/container/networks.yml.j2' %}
networks: {% include 'templates/docker/compose/volumes.yml.j2' %}
- my-network data:
volumes:
openldap_data: {% include 'templates/docker/compose/networks.yml.j2' %}
driver: local

View File

@ -0,0 +1,5 @@
docker_compose_project_name: "ldap"
database_type: "postgres"
database_password: "{{ldap_database_password}}"
ldap_root: "dc={{primary_domain_sld}},dc={{primary_domain_tld}}"
ldap_admin_dm: "cn={{ldap_administrator_username}},{{ldap_root}}"

View File

@ -68,7 +68,7 @@
- name: execute database migration - name: execute database migration
command: command:
cmd: "docker compose -p mailu exec admin flask mailu admin admin {{top_domain}} {{mailu_initial_root_password}}" cmd: "docker compose -p mailu exec admin flask mailu admin admin {{primary_domain}} {{mailu_initial_root_password}}"
chdir: "{{docker_compose_instance_directory}}" chdir: "{{docker_compose_instance_directory}}"
ignore_errors: true ignore_errors: true
when: mode_setup |bool when: mode_setup |bool

View File

@ -5,7 +5,7 @@
"server_name": "{{domain_matrix_synapse}}" "server_name": "{{domain_matrix_synapse}}"
}, },
"m.identity_server": { "m.identity_server": {
"base_url": "https://{{top_domain}}" "base_url": "https://{{primary_domain}}"
} }
}, },
"brand": "Element", "brand": "Element",

View File

@ -8,8 +8,8 @@
### Multi Domain Installation ### Multi Domain Installation
If you want to access your mybb over multiple domains, keep the following in mind: If you want to access your mybb over multiple domains, keep the following in mind:
- Set Cookie Domain to nothing - Set Cookie Domain to nothing
- Access mybb for installation via mybb.<top_domain> - Access mybb for installation via mybb.<primary_domain>
- Set the Board Url to mybb.<top_domain> - Set the Board Url to mybb.<primary_domain>
### Manual Installation of MyBB Plugins ### Manual Installation of MyBB Plugins

View File

@ -3,6 +3,6 @@ docker_compose_project_name: "mybb"
docker_compose_instance_confd_directory: "{{docker_compose_instance_directory}}conf.d/" docker_compose_instance_confd_directory: "{{docker_compose_instance_directory}}conf.d/"
docker_compose_instance_confd_defaultconf_file: "{{docker_compose_instance_confd_directory}}default.conf" docker_compose_instance_confd_defaultconf_file: "{{docker_compose_instance_confd_directory}}default.conf"
target_mount_conf_d_directory: "{{nginx_servers_directory}}" target_mount_conf_d_directory: "{{nginx_servers_directory}}"
source_domain: "mybb.{{top_domain}}" source_domain: "mybb.{{primary_domain}}"
database_password: "{{mybb_database_password}}" database_password: "{{mybb_database_password}}"
database_type: "mariadb" database_type: "mariadb"

View File

@ -3,5 +3,5 @@ more_set_headers "Content-Security-Policy: ";
# sub filters to integrate matomo tracking code in nginx websites # sub filters to integrate matomo tracking code in nginx websites
sub_filter '</head>' '<script>{{matomo_tracking_code_one_liner}}</script></head>'; sub_filter '</head>' '<script>{{matomo_tracking_code_one_liner}}</script></head>';
sub_filter '</body>' '<noscript><p><img src="//matomo.{{top_domain}}/matomo.php?idsite={{matomo_site_id}}&rec=1" style="border:0;" alt="" /></p></noscript></body>'; sub_filter '</body>' '<noscript><p><img src="//matomo.{{primary_domain}}/matomo.php?idsite={{matomo_site_id}}&rec=1" style="border:0;" alt="" /></p></noscript></body>';
sub_filter_once off; sub_filter_once off;

View File

@ -1,2 +1,2 @@
matomo_domain: "matomo.{{top_domain}}" matomo_domain: "matomo.{{primary_domain}}"
base_domain: "{{ domain | regex_replace('^(?:.*\\.)?(.+\\..+)$', '\\1') }}" base_domain: "{{ domain | regex_replace('^(?:.*\\.)?(.+\\..+)$', '\\1') }}"

View File

@ -14,7 +14,7 @@ This Ansible role configures an Nginx server to serve a static homepage. It hand
- `nginx_homepage_root`: The directory where the homepage content will be stored (default: `/usr/share/nginx/homepage`) - `nginx_homepage_root`: The directory where the homepage content will be stored (default: `/usr/share/nginx/homepage`)
- `domain`: The domain name for the Nginx server configuration - `domain`: The domain name for the Nginx server configuration
- `administrator_email`: The email used for SSL certificate registration with Let's Encrypt - `administrator_email`: The email used for SSL certificate registration with Let's Encrypt
- `nginx_homepage_repository_address`: The Git repository address containing the homepage content - `nginx_static_repository_address`: The Git repository address containing the homepage content
## Dependencies ## Dependencies

View File

@ -1,16 +1,16 @@
--- ---
- name: "pull homepage from {{nginx_homepage_repository_address}}" - name: "pull homepage from {{nginx_static_repository_address}}"
git: git:
repo: "{{nginx_homepage_repository_address}}" repo: "{{nginx_static_repository_address}}"
dest: "{{nginx_homepage_root}}" dest: "{{nginx_homepage_root}}"
update: yes update: yes
ignore_errors: true ignore_errors: true
- name: configure {{top_domain}}.conf - name: configure {{primary_domain}}.conf
template: template:
src: "static.nginx.conf.j2" src: "static.nginx.conf.j2"
dest: "{{nginx_servers_directory}}{{top_domain}}.conf" dest: "{{nginx_servers_directory}}{{primary_domain}}.conf"
vars: vars:
domain: "{{top_domain}}" domain: "{{primary_domain}}"
notify: restart nginx notify: restart nginx
when: run_once_nginx is not defined when: run_once_nginx is not defined

View File

@ -33,7 +33,7 @@
include_tasks: certbot-matomo.yml include_tasks: certbot-matomo.yml
when: run_once_nginx is not defined when: run_once_nginx is not defined
vars: vars:
domain: "{{top_domain}}" domain: "{{primary_domain}}"
when: run_once_nginx is not defined when: run_once_nginx is not defined
- name: flush nginx service - name: flush nginx service