mirror of
https://github.com/kevinveenbirkenbach/computer-playbook.git
synced 2025-01-22 07:03:21 +01:00
Implemented ldap draft
This commit is contained in:
parent
e8bf6b18c7
commit
3f0f666d25
@ -1,16 +1,16 @@
|
|||||||
# 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
|
||||||
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
|
## Domain
|
||||||
primary_domain_tld: "localhost" # Top Level Domain of the server
|
primary_domain_tld: "localhost" # Top Level Domain of the server
|
||||||
primary_domain_sld: "cymais" # Second 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
|
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}}@{{primary_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
|
#user_administrator_initial_password: EXAMPLE_PASSWORD_123456 # Example initialisation password needs to be set in inventory file
|
||||||
|
|
||||||
# Email Configuration
|
# Email Configuration
|
||||||
@ -157,6 +157,7 @@ domain_gitea: "git.{{primary_domain}}"
|
|||||||
domain_gitlab: "gitlab.{{primary_domain}}"
|
domain_gitlab: "gitlab.{{primary_domain}}"
|
||||||
domain_portfolio: "{{primary_domain}}"
|
domain_portfolio: "{{primary_domain}}"
|
||||||
domain_keycloak: "auth.{{primary_domain}}"
|
domain_keycloak: "auth.{{primary_domain}}"
|
||||||
|
domain_ldap: "ldap.{{primary_domain}}"
|
||||||
domain_listmonk: "newsletter.{{primary_domain}}"
|
domain_listmonk: "newsletter.{{primary_domain}}"
|
||||||
domain_mailu: "{{system_email_host}}"
|
domain_mailu: "{{system_email_host}}"
|
||||||
domain_mastodon: "microblog.{{primary_domain}}"
|
domain_mastodon: "microblog.{{primary_domain}}"
|
||||||
@ -245,9 +246,9 @@ keycloak_administrator_username: "{{administrator_username}}"
|
|||||||
|
|
||||||
#### LDAP
|
#### LDAP
|
||||||
ldap_version: "latest"
|
ldap_version: "latest"
|
||||||
|
ldap_admin_version: "latest"
|
||||||
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
|
||||||
# ldap_database_password: # Needs to be defined in inventory
|
|
||||||
|
|
||||||
#### Listmonk
|
#### Listmonk
|
||||||
listmonk_admin_username: "{{administrator_username}}"
|
listmonk_admin_username: "{{administrator_username}}"
|
||||||
|
@ -306,6 +306,15 @@
|
|||||||
domain: "{{domain_keycloak}}"
|
domain: "{{domain_keycloak}}"
|
||||||
http_port: 8032
|
http_port: 8032
|
||||||
|
|
||||||
|
- name: setup ldap
|
||||||
|
hosts: ldap
|
||||||
|
become: true
|
||||||
|
roles:
|
||||||
|
- role: docker-ldap
|
||||||
|
vars:
|
||||||
|
domain: "{{domain_ldap}}"
|
||||||
|
http_port: 8033
|
||||||
|
|
||||||
# Native Webserver Roles
|
# Native Webserver Roles
|
||||||
- name: setup nginx-static-repositorys
|
- name: setup nginx-static-repositorys
|
||||||
hosts: nginx-static-repositorys
|
hosts: nginx-static-repositorys
|
||||||
|
@ -4,4 +4,7 @@ Draft role for an LDAP implementation with sso.
|
|||||||
- [ChatGPT Conversation](https://chat.openai.com/share/77919994-5d44-4a64-877d-b572d67483d4)
|
- [ChatGPT Conversation](https://chat.openai.com/share/77919994-5d44-4a64-877d-b572d67483d4)
|
||||||
- [Discouse Documentation](https://forum.veen.world/t/cymais-ldap-implementierung-documentation/49)
|
- [Discouse Documentation](https://forum.veen.world/t/cymais-ldap-implementierung-documentation/49)
|
||||||
- [Setup Guide](https://goneuland.de/ldap-nextcloud-und-mailserver-in-docker/)
|
- [Setup Guide](https://goneuland.de/ldap-nextcloud-und-mailserver-in-docker/)
|
||||||
- https://hub.docker.com/r/bitnami/openldap
|
- https://hub.docker.com/r/bitnami/openldap
|
||||||
|
- https://github.com/LDAPAccountManager/docker
|
||||||
|
- https://github.com/LDAPAccountManager/lam/blob/develop/lam-packaging/docker/.env
|
||||||
|
- https://github.com/leenooks/phpLDAPadmin/wiki/Docker-Container
|
23
roles/docker-ldap/tasks/main.yml
Normal file
23
roles/docker-ldap/tasks/main.yml
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
---
|
||||||
|
- name: "include docker/compose/common.yml"
|
||||||
|
include_tasks: docker/compose/common.yml
|
||||||
|
|
||||||
|
# optimize
|
||||||
|
- name: "include tasks nginx-docker-proxy-domain.yml"
|
||||||
|
include_tasks: nginx-docker-proxy-domain.yml
|
||||||
|
|
||||||
|
- name: "create {{docker_compose_instance_directory}}"
|
||||||
|
file:
|
||||||
|
path: "{{docker_compose_instance_directory}}"
|
||||||
|
state: directory
|
||||||
|
mode: 0755
|
||||||
|
|
||||||
|
- name: "include the nginx-docker-cert-deploy role"
|
||||||
|
include_role:
|
||||||
|
name: nginx-docker-cert-deploy
|
||||||
|
|
||||||
|
- name: add docker-compose.yml
|
||||||
|
template:
|
||||||
|
src: "docker-compose.yml.j2"
|
||||||
|
dest: "{{docker_compose_instance_directory}}docker-compose.yml"
|
||||||
|
notify: docker compose project setup
|
@ -1,6 +1,15 @@
|
|||||||
services:
|
services:
|
||||||
{% include 'templates/docker/services/' + database_type + '.yml.j2' %}
|
phpldapadmin:
|
||||||
|
image: leenooks/phpldapadmin:{{ldap_admin_version}}
|
||||||
|
logging:
|
||||||
|
driver: journald
|
||||||
|
restart: {{docker_restart_policy}}
|
||||||
|
ports:
|
||||||
|
- 127.0.0.1:{{http_port}}:8080
|
||||||
|
environment:
|
||||||
|
# @See https://github.com/leenooks/phpLDAPadmin/wiki/Docker-Container
|
||||||
|
APP_URL: https://{{domain}}
|
||||||
|
LDAP_HOST: {{domain}}
|
||||||
openldap:
|
openldap:
|
||||||
image: bitnami/openldap:{{ldap_version}}
|
image: bitnami/openldap:{{ldap_version}}
|
||||||
logging:
|
logging:
|
||||||
@ -10,6 +19,8 @@ services:
|
|||||||
- '127.0.0.1:389:1389' # Expose just on local host for security reasons
|
- '127.0.0.1:389:1389' # Expose just on local host for security reasons
|
||||||
- '636:636' # Expose to internet
|
- '636:636' # Expose to internet
|
||||||
environment:
|
environment:
|
||||||
|
# @See https://hub.docker.com/r/bitnami/openldap
|
||||||
|
|
||||||
# GENERAL
|
# GENERAL
|
||||||
LDAP_ADMIN_USERNAME: {{ldap_administrator_username}} # LDAP database admin user.
|
LDAP_ADMIN_USERNAME: {{ldap_administrator_username}} # LDAP database admin user.
|
||||||
LDAP_ADMIN_PASSWORD: {{ldap_administrator_password}} # LDAP database admin password.
|
LDAP_ADMIN_PASSWORD: {{ldap_administrator_password}} # LDAP database admin password.
|
||||||
@ -19,22 +30,16 @@ services:
|
|||||||
LDAP_ADMIN_DN: {{ldap_admin_dn}}
|
LDAP_ADMIN_DN: {{ldap_admin_dn}}
|
||||||
|
|
||||||
# TLS
|
# TLS
|
||||||
LDAP_ENABLE_TLS: yes # Whether to enable TLS for traffic or not. Defaults to no
|
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_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_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_CERT_FILE: /certs/cert.pem # 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_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: # 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.
|
||||||
|
|
||||||
# Database Configuration
|
|
||||||
MARIADB_ROOT_PASSWORD=root-password
|
|
||||||
MARIADB_USER=customuser
|
|
||||||
MARIADB_DATABASE=customdatabase
|
|
||||||
MARIADB_ENABLE_LDAP=yes
|
|
||||||
volumes:
|
volumes:
|
||||||
|
- {{cert_mount_directory}}:/certs
|
||||||
- 'data:/bitnami/openldap'
|
- 'data:/bitnami/openldap'
|
||||||
{% include 'templates/docker/container/depends-on-just-database.yml.j2' %}
|
|
||||||
{% 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' %}
|
||||||
data:
|
data:
|
||||||
|
@ -1,5 +1,3 @@
|
|||||||
docker_compose_project_name: "ldap"
|
docker_compose_project_name: "ldap"
|
||||||
database_type: "postgres"
|
|
||||||
database_password: "{{ldap_database_password}}"
|
|
||||||
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_dm: "cn={{ldap_administrator_username}},{{ldap_root}}"
|
Loading…
x
Reference in New Issue
Block a user