WIP: Linting #128
|
@ -1,14 +1,15 @@
|
|||
---
|
||||
repos:
|
||||
|
||||
#- repo: https://github.com/semaphor-dk/dansabel
|
||||
# rev: b72c70351d1a9e32a75db505fcb3aa414f3282f8
|
||||
# hooks:
|
||||
# - id: dansabel
|
||||
- repo: https://github.com/lyz-code/yamlfix/
|
||||
rev: master
|
||||
hooks:
|
||||
- id: yamlfix
|
||||
|
||||
- repo: https://github.com/ansible/ansible-lint
|
||||
rev: v6.9.0
|
||||
hooks:
|
||||
- id: ansible-lint
|
||||
files: \.(yaml|yml)$
|
||||
additional_dependencies:
|
||||
- ansible
|
||||
- repo: https://github.com/ansible/ansible-lint
|
||||
rev: v6.9.0
|
||||
hooks:
|
||||
- id: ansible-lint
|
||||
files: \.(yaml|yml)$
|
||||
additional_dependencies:
|
||||
- ansible
|
||||
|
|
|
@ -12,7 +12,8 @@ users:
|
|||
groups:
|
||||
- sudo
|
||||
ssh_keys:
|
||||
- ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDUmGeHc6QXDcJHkmVxbTUv04Q3vs20avquoGr6eOkkvYbcgjuFnBOOtvs2Nul1odcvvnHa1nN7DfL8XJamiwsB1B/xe2seaNS1axgwk9XowlVN9pgga8gsC+4gZWBtSObG2GR8n4NtPENzPmW5deNn8dRpTvULPMxZ0VRE9yNQOx8v8w85yYh+vxbbkWGVDYJU23yuJI50U9y6bXxNHinsACDFBeR/giXDlw29TaOaSxz0R6zrRPBoX+V68RyWwBL+KWQKtX2ULtJI40S98Ohd6p41bIxYHCBS/zroqNne8PjYOLcHHsjHUGfTvhcS5a3zdz/iHsvsaOOjFjsydAXH valberg
|
||||
- ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDUmGeHc6QXDcJHkmVxbTUv04Q3vs20avquoGr6eOkkvYbcgjuFnBOOtvs2Nul1odcvvnHa1nN7DfL8XJamiwsB1B/xe2seaNS1axgwk9XowlVN9pgga8gsC+4gZWBtSObG2GR8n4NtPENzPmW5deNn8dRpTvULPMxZ0VRE9yNQOx8v8w85yYh+vxbbkWGVDYJU23yuJI50U9y6bXxNHinsACDFBeR/giXDlw29TaOaSxz0R6zrRPBoX+V68RyWwBL+KWQKtX2ULtJI40S98Ohd6p41bIxYHCBS/zroqNne8PjYOLcHHsjHUGfTvhcS5a3zdz/iHsvsaOOjFjsydAXH
|
||||
valberg
|
||||
|
||||
- name: reynir
|
||||
comment: Reynir Björnsson
|
||||
|
@ -20,8 +21,10 @@ users:
|
|||
groups:
|
||||
- sudo
|
||||
ssh_keys:
|
||||
- ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAACAQDJl8/rikIUnqr9fPF3rE0rjWHCNzte10LvkjGmpdO9ka/NubQ7O25fp08rC+n0d1pUooYwHBAgiv9Hsql6HF9QfNKNUp7IKp7CXWcjb4ga02kuzWGSXjm40Vf0jSadIrJ33M4SeJHTByDGoeYPQBQ7n+qHdwcqJADBQygBuc5sRzxm8i0sbmzF3DJDDVeTJjEY5pfR4vnJlpmU8SC2d1ZkhCjmKCsL0PShntTIt1ztCt0yO71KoHKaNPu1jutGxcU9u7J1pEqcPT6EzU/cQJ4DMVzrGp26nIV0msRl3NeGNjukwXOzAh6KmsmXG7yWFyQmLRqgc/bjUeyhuWJ10vwUbaYVeIef7YrgEOgnkYLIFeWRMhdnwtL/W8g1D66SFx7+iYJj180eTi8Lc8rZm2NaiGynvWlFcJ4PGdTYZsWcFzQ+SaDziNMw1H3IixxdlD8Shw9mxpijJ+A4dH2kkUXyGVsc13zRIU7hq9ax8nrw6HVLGFLn09rEPig+SkyWrqRpRGMBWyqTRJywIV6jk0ll+i8rJZA2McY0rABbACrzXT5VBj5dLKnnRITLDicAYgt7YuEiQ0ffErQrPXXHUVeI0QKnJgplSHxH5QsX9a1Y+NoaoditdMT2bjvEqROi+/JYRycLR/BQV/d2nFPhqwq1x1AFvL4f8UvVH/hxp3PXWw== reynir yubikey
|
||||
- ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIPR8t/wNRp7Dt3wr9uZKVTofTDVYrcoQNru5ETxL+37t reynir@spurv
|
||||
- ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAACAQDJl8/rikIUnqr9fPF3rE0rjWHCNzte10LvkjGmpdO9ka/NubQ7O25fp08rC+n0d1pUooYwHBAgiv9Hsql6HF9QfNKNUp7IKp7CXWcjb4ga02kuzWGSXjm40Vf0jSadIrJ33M4SeJHTByDGoeYPQBQ7n+qHdwcqJADBQygBuc5sRzxm8i0sbmzF3DJDDVeTJjEY5pfR4vnJlpmU8SC2d1ZkhCjmKCsL0PShntTIt1ztCt0yO71KoHKaNPu1jutGxcU9u7J1pEqcPT6EzU/cQJ4DMVzrGp26nIV0msRl3NeGNjukwXOzAh6KmsmXG7yWFyQmLRqgc/bjUeyhuWJ10vwUbaYVeIef7YrgEOgnkYLIFeWRMhdnwtL/W8g1D66SFx7+iYJj180eTi8Lc8rZm2NaiGynvWlFcJ4PGdTYZsWcFzQ+SaDziNMw1H3IixxdlD8Shw9mxpijJ+A4dH2kkUXyGVsc13zRIU7hq9ax8nrw6HVLGFLn09rEPig+SkyWrqRpRGMBWyqTRJywIV6jk0ll+i8rJZA2McY0rABbACrzXT5VBj5dLKnnRITLDicAYgt7YuEiQ0ffErQrPXXHUVeI0QKnJgplSHxH5QsX9a1Y+NoaoditdMT2bjvEqROi+/JYRycLR/BQV/d2nFPhqwq1x1AFvL4f8UvVH/hxp3PXWw==
|
||||
reynir yubikey
|
||||
- ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIPR8t/wNRp7Dt3wr9uZKVTofTDVYrcoQNru5ETxL+37t
|
||||
reynir@spurv
|
||||
|
||||
- name: samsapti
|
||||
comment: Sam Al-Sapti
|
||||
|
@ -29,4 +32,5 @@ users:
|
|||
groups:
|
||||
- sudo
|
||||
ssh_keys:
|
||||
- ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIPd/4fQV7CL8/KVwbo/phiV5UdXFBIDlkZ+ps8C7FeRf samsapti
|
||||
- ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIPd/4fQV7CL8/KVwbo/phiV5UdXFBIDlkZ+ps8C7FeRf
|
||||
samsapti
|
||||
|
|
|
@ -5,13 +5,13 @@
|
|||
vars:
|
||||
base_domain: data.coop
|
||||
letsencrypt_email: admin@data.coop
|
||||
ldap_dn: "dc=data,dc=coop"
|
||||
ldap_dn: dc=data,dc=coop
|
||||
|
||||
vagrant: "{{ ansible_virtualization_role == 'guest' }}"
|
||||
letsencrypt_enabled: "{{ not vagrant }}"
|
||||
letsencrypt_enabled: '{{ not vagrant }}'
|
||||
|
||||
smtp_host: "postfix"
|
||||
smtp_port: "587"
|
||||
smtp_host: postfix
|
||||
smtp_port: '587'
|
||||
|
||||
tasks:
|
||||
- import_role:
|
||||
|
|
|
@ -1,169 +1,169 @@
|
|||
---
|
||||
volume_root_folder: "/docker-volumes"
|
||||
volume_root_folder: /docker-volumes
|
||||
|
||||
services:
|
||||
|
||||
### Internal services ###
|
||||
### Internal services ###
|
||||
postfix:
|
||||
file: postfix.yml
|
||||
version: "v3.5.0"
|
||||
version: v3.5.0
|
||||
|
||||
nginx_proxy:
|
||||
file: nginx_proxy.yml
|
||||
version: "1.0-alpine"
|
||||
volume_folder: "{{ volume_root_folder }}/nginx"
|
||||
version: 1.0-alpine
|
||||
volume_folder: '{{ volume_root_folder }}/nginx'
|
||||
|
||||
nginx_acme_companion:
|
||||
version: "2.2"
|
||||
version: '2.2'
|
||||
|
||||
openldap:
|
||||
file: openldap.yml
|
||||
domain: "ldap.{{ base_domain }}"
|
||||
volume_folder: "{{ volume_root_folder }}/openldap"
|
||||
version: "1.5.0"
|
||||
domain: ldap.{{ base_domain }}
|
||||
volume_folder: '{{ volume_root_folder }}/openldap'
|
||||
version: 1.5.0
|
||||
|
||||
phpldapadmin:
|
||||
version: "0.9.0"
|
||||
version: 0.9.0
|
||||
|
||||
netdata:
|
||||
file: netdata.yml
|
||||
domain: "netdata.{{ base_domain }}"
|
||||
version: "v1"
|
||||
domain: netdata.{{ base_domain }}
|
||||
version: v1
|
||||
|
||||
portainer:
|
||||
file: portainer.yml
|
||||
domain: "portainer.{{ base_domain }}"
|
||||
volume_folder: "{{ volume_root_folder }}/portainer"
|
||||
version: "2.16.2"
|
||||
domain: portainer.{{ base_domain }}
|
||||
volume_folder: '{{ volume_root_folder }}/portainer'
|
||||
version: 2.16.2
|
||||
|
||||
keycloak:
|
||||
file: keycloak.yml
|
||||
domain: sso.{{ base_domain }}
|
||||
volume_folder: "{{ volume_root_folder }}/keycloak"
|
||||
version: "20.0"
|
||||
volume_folder: '{{ volume_root_folder }}/keycloak'
|
||||
version: '20.0'
|
||||
|
||||
restic:
|
||||
file: restic_backup.yml
|
||||
user: "datacoop"
|
||||
domain: "restic.cannedtuna.org"
|
||||
repository: "datacoop-hevonen"
|
||||
version: "1.6.0"
|
||||
user: datacoop
|
||||
domain: restic.cannedtuna.org
|
||||
repository: datacoop-hevonen
|
||||
version: 1.6.0
|
||||
disabled_in_vagrant: true
|
||||
|
||||
docker_registry:
|
||||
file: docker_registry.yml
|
||||
domain: "docker.{{ base_domain }}"
|
||||
volume_folder: "{{ volume_root_folder }}/docker-registry"
|
||||
username: "docker"
|
||||
password: "{{ docker_password }}"
|
||||
version: "2"
|
||||
domain: docker.{{ base_domain }}
|
||||
volume_folder: '{{ volume_root_folder }}/docker-registry'
|
||||
username: docker
|
||||
password: '{{ docker_password }}'
|
||||
version: '2'
|
||||
|
||||
### External services ###
|
||||
### External services ###
|
||||
|
||||
nextcloud:
|
||||
file: nextcloud.yml
|
||||
domain: "cloud.{{ base_domain }}"
|
||||
volume_folder: "{{ volume_root_folder }}/nextcloud"
|
||||
domain: cloud.{{ base_domain }}
|
||||
volume_folder: '{{ volume_root_folder }}/nextcloud'
|
||||
version: 25-apache
|
||||
|
||||
gitea:
|
||||
file: gitea.yml
|
||||
domain: "git.{{ base_domain }}"
|
||||
volume_folder: "{{ volume_root_folder }}/gitea"
|
||||
domain: git.{{ base_domain }}
|
||||
volume_folder: '{{ volume_root_folder }}/gitea'
|
||||
version: 1.17.3
|
||||
allowed_sender_domain: true
|
||||
|
||||
passit:
|
||||
file: passit.yml
|
||||
domain: "passit.{{ base_domain }}"
|
||||
volume_folder: "{{ volume_root_folder }}/passit"
|
||||
domain: passit.{{ base_domain }}
|
||||
volume_folder: '{{ volume_root_folder }}/passit'
|
||||
version: stable
|
||||
allowed_sender_domain: true
|
||||
|
||||
matrix:
|
||||
file: matrix_riot.yml
|
||||
domain: "matrix.{{ base_domain }}"
|
||||
volume_folder: "{{ volume_root_folder }}/matrix"
|
||||
domain: matrix.{{ base_domain }}
|
||||
volume_folder: '{{ volume_root_folder }}/matrix'
|
||||
version: v1.63.1
|
||||
|
||||
riot:
|
||||
domains:
|
||||
- "riot.{{ base_domain }}"
|
||||
- "element.{{ base_domain }}"
|
||||
volume_folder: "{{ volume_root_folder }}/riot"
|
||||
- riot.{{ base_domain }}
|
||||
- element.{{ base_domain }}
|
||||
volume_folder: '{{ volume_root_folder }}/riot'
|
||||
version: v1.11.8
|
||||
|
||||
privatebin:
|
||||
file: privatebin.yml
|
||||
domain: "paste.{{ base_domain }}"
|
||||
volume_folder: "{{ volume_root_folder }}/privatebin"
|
||||
domain: paste.{{ base_domain }}
|
||||
volume_folder: '{{ volume_root_folder }}/privatebin'
|
||||
version: 20221009
|
||||
|
||||
codimd:
|
||||
domain: "oldpad.{{ base_domain }}"
|
||||
volume_folder: "{{ volume_root_folder }}/codimd"
|
||||
domain: oldpad.{{ base_domain }}
|
||||
volume_folder: '{{ volume_root_folder }}/codimd'
|
||||
|
||||
hedgedoc:
|
||||
file: hedgedoc.yml
|
||||
domain: "pad.{{ base_domain }}"
|
||||
volume_folder: "{{ volume_root_folder }}/hedgedoc"
|
||||
domain: pad.{{ base_domain }}
|
||||
volume_folder: '{{ volume_root_folder }}/hedgedoc'
|
||||
version: 1.9.6
|
||||
|
||||
data_coop_website:
|
||||
file: websites/data.coop.yml
|
||||
domains:
|
||||
- "{{ base_domain }}"
|
||||
- "www.{{ base_domain }}"
|
||||
- '{{ base_domain }}'
|
||||
- www.{{ base_domain }}
|
||||
|
||||
cryptohagen_website:
|
||||
file: websites/cryptohagen.dk.yml
|
||||
domains:
|
||||
- "cryptohagen.dk"
|
||||
- "www.cryptohagen.dk"
|
||||
- cryptohagen.dk
|
||||
- www.cryptohagen.dk
|
||||
|
||||
ulovliglogning_website:
|
||||
file: websites/ulovliglogning.dk.yml
|
||||
domains:
|
||||
- "ulovliglogning.dk"
|
||||
- "www.ulovliglogning.dk"
|
||||
- "ulovlig-logning.dk"
|
||||
- ulovliglogning.dk
|
||||
- www.ulovliglogning.dk
|
||||
- ulovlig-logning.dk
|
||||
|
||||
cryptoaarhus_website:
|
||||
file: websites/cryptoaarhus.dk.yml
|
||||
domains:
|
||||
- "cryptoaarhus.dk"
|
||||
- "www.cryptoaarhus.dk"
|
||||
- cryptoaarhus.dk
|
||||
- www.cryptoaarhus.dk
|
||||
|
||||
drone:
|
||||
file: drone.yml
|
||||
domain: "drone.{{ base_domain }}"
|
||||
volume_folder: "{{ volume_root_folder }}/drone"
|
||||
domain: drone.{{ base_domain }}
|
||||
volume_folder: '{{ volume_root_folder }}/drone'
|
||||
version: 1
|
||||
|
||||
mailu:
|
||||
file: mailu.yml
|
||||
version: 1.6
|
||||
domain: "mail.{{ base_domain }}"
|
||||
domain: mail.{{ base_domain }}
|
||||
dns: 192.168.203.254
|
||||
subnet: 192.168.203.0/24
|
||||
volume_folder: "{{ volume_root_folder }}/mailu"
|
||||
volume_folder: '{{ volume_root_folder }}/mailu'
|
||||
|
||||
mastodon:
|
||||
file: mastodon.yml
|
||||
domain: "social.{{ base_domain }}"
|
||||
volume_folder: "{{ volume_root_folder }}/mastodon"
|
||||
domain: social.{{ base_domain }}
|
||||
volume_folder: '{{ volume_root_folder }}/mastodon'
|
||||
version: v4.0.2
|
||||
allowed_sender_domain: true
|
||||
|
||||
rallly:
|
||||
file: rallly.yml
|
||||
domain: "when.{{ base_domain }}"
|
||||
volume_folder: "{{ volume_root_folder }}/rallly"
|
||||
domain: when.{{ base_domain }}
|
||||
volume_folder: '{{ volume_root_folder }}/rallly'
|
||||
version: a21f92bf74308d66cfcd545d49b81eba0211a222
|
||||
allowed_sender_domain: true
|
||||
|
||||
membersystem:
|
||||
file: membersystem.yml
|
||||
domain: "member.{{ base_domain }}"
|
||||
django_admins: "Vidir:valberg@orn.li"
|
||||
domain: member.{{ base_domain }}
|
||||
django_admins: Vidir:valberg@orn.li
|
||||
allowed_sender_domain: true
|
||||
|
|
|
@ -1,7 +1,6 @@
|
|||
---
|
||||
- name: "restart nginx"
|
||||
- name: restart nginx
|
||||
community.docker.docker_container:
|
||||
name: "nginx-proxy"
|
||||
restart: "yes"
|
||||
state: "started"
|
||||
|
||||
name: nginx-proxy
|
||||
restart: 'yes'
|
||||
state: started
|
||||
|
|
|
@ -6,25 +6,25 @@
|
|||
state: present
|
||||
|
||||
- name: add docker apt repository
|
||||
apt_repository:
|
||||
ansible.builtin.apt_repository:
|
||||
repo: deb https://download.docker.com/linux/ubuntu bionic stable
|
||||
state: present
|
||||
update_cache: yes
|
||||
update_cache: true
|
||||
|
||||
- name: install docker-ce
|
||||
apt:
|
||||
ansible.builtin.apt:
|
||||
name: docker-ce
|
||||
state: present
|
||||
|
||||
- name: install docker python bindings
|
||||
pip:
|
||||
executable: "pip3"
|
||||
name: "docker-compose"
|
||||
executable: pip3
|
||||
name: docker-compose
|
||||
state: present
|
||||
|
||||
- name: create folder structure for bind mounts
|
||||
file:
|
||||
name: "{{ volume_root_folder }}"
|
||||
ansible.builtin.file:
|
||||
name: '{{ volume_root_folder }}'
|
||||
state: directory
|
||||
|
||||
- name: setup services
|
||||
|
|
|
@ -1,18 +1,15 @@
|
|||
---
|
||||
- name: setup external services network
|
||||
docker_network:
|
||||
community.docker.docker_network:
|
||||
name: external_services
|
||||
|
||||
- name: setup services
|
||||
include_tasks: "services/{{ item.value.file }}"
|
||||
loop: "{{ services | dict2items }}"
|
||||
when: single_service is not defined and
|
||||
item.value.file is defined and
|
||||
item.value.disabled_in_vagrant is not defined
|
||||
include_tasks: services/{{ item.value.file }}
|
||||
loop: '{{ services | dict2items }}'
|
||||
when: single_service is not defined and item.value.file is defined and item.value.disabled_in_vagrant
|
||||
is not defined
|
||||
|
||||
- name: setup single service
|
||||
include_tasks: "services/{{ services[single_service].file }}"
|
||||
when: single_service is defined and
|
||||
single_service in services and
|
||||
services[single_service].file is defined and
|
||||
services[single_service].disabled_in_vagrant is not defined
|
||||
include_tasks: services/{{ services[single_service].file }}
|
||||
when: single_service is defined and single_service in services and services[single_service].file
|
||||
is defined and services[single_service].disabled_in_vagrant is not defined
|
||||
|
|
|
@ -1,22 +1,22 @@
|
|||
---
|
||||
|
||||
- name: codimd network
|
||||
docker_network:
|
||||
community.docker.docker_network:
|
||||
name: codimd
|
||||
|
||||
- name: create codimd volume folders
|
||||
file:
|
||||
name: "{{ codimd.volume_folder }}/{{ volume }}"
|
||||
ansible.builtin.file:
|
||||
name: '{{ codimd.volume_folder }}/{{ volume }}'
|
||||
state: directory
|
||||
loop:
|
||||
- "db"
|
||||
- "codimd/uploads"
|
||||
- db
|
||||
- codimd/uploads
|
||||
|
||||
loop_control:
|
||||
loop_var: volume
|
||||
|
||||
- name: codimd database container
|
||||
docker_container:
|
||||
community.docker.docker_container:
|
||||
name: codimd_db
|
||||
image: postgres:10
|
||||
state: started
|
||||
|
@ -24,13 +24,13 @@
|
|||
networks:
|
||||
- name: codimd
|
||||
volumes:
|
||||
- "{{ codimd.volume_folder }}/db:/var/lib/postgresql/data"
|
||||
- '{{ codimd.volume_folder }}/db:/var/lib/postgresql/data'
|
||||
env:
|
||||
POSTGRES_USER: "codimd"
|
||||
POSTGRES_PASSWORD: "{{ postgres_passwords.codimd }}"
|
||||
POSTGRES_USER: codimd
|
||||
POSTGRES_PASSWORD: '{{ postgres_passwords.codimd }}'
|
||||
|
||||
- name: codimd app container
|
||||
docker_container:
|
||||
community.docker.docker_container:
|
||||
name: codimd_app
|
||||
image: hackmdio/hackmd:1.3.0
|
||||
restart_policy: unless-stopped
|
||||
|
@ -39,19 +39,19 @@
|
|||
- name: ldap
|
||||
- name: external_services
|
||||
volumes:
|
||||
- "{{ codimd.volume_folder }}/codimd/uploads:/codimd/public/uploads"
|
||||
- '{{ codimd.volume_folder }}/codimd/uploads:/codimd/public/uploads'
|
||||
|
||||
env:
|
||||
CMD_DB_URL: "postgres://codimd:{{ postgres_passwords.codimd }}@codimd_db:5432/codimd"
|
||||
CMD_ALLOW_EMAIL_REGISTER: "False"
|
||||
CMD_IMAGE_UPLOAD_TYPE: "filesystem"
|
||||
CMD_EMAIL: "False"
|
||||
CMD_LDAP_URL: "ldap://openldap"
|
||||
CMD_LDAP_BINDDN: "cn=admin,dc=data,dc=coop"
|
||||
CMD_LDAP_BINDCREDENTIALS: "{{ ldap_admin_password }}"
|
||||
CMD_LDAP_SEARCHBASE: "dc=data,dc=coop"
|
||||
CMD_LDAP_SEARCHFILTER: "(&(uid={{ '{{username}}' }})(objectClass=inetOrgPerson))"
|
||||
CMD_USECDN: "false"
|
||||
VIRTUAL_HOST: "{{ codimd.domain }}"
|
||||
LETSENCRYPT_HOST: "{{ codimd.domain }}"
|
||||
LETSENCRYPT_EMAIL: "{{ letsencrypt_email }}"
|
||||
CMD_DB_URL: postgres://codimd:{{ postgres_passwords.codimd }}@codimd_db:5432/codimd
|
||||
CMD_ALLOW_EMAIL_REGISTER: 'False'
|
||||
CMD_IMAGE_UPLOAD_TYPE: filesystem
|
||||
CMD_EMAIL: 'False'
|
||||
CMD_LDAP_URL: ldap://openldap
|
||||
CMD_LDAP_BINDDN: cn=admin,dc=data,dc=coop
|
||||
CMD_LDAP_BINDCREDENTIALS: '{{ ldap_admin_password }}'
|
||||
CMD_LDAP_SEARCHBASE: dc=data,dc=coop
|
||||
CMD_LDAP_SEARCHFILTER: (&(uid={{ '{{username}}' }})(objectClass=inetOrgPerson))
|
||||
CMD_USECDN: 'false'
|
||||
VIRTUAL_HOST: '{{ codimd.domain }}'
|
||||
LETSENCRYPT_HOST: '{{ codimd.domain }}'
|
||||
LETSENCRYPT_EMAIL: '{{ letsencrypt_email }}'
|
||||
|
|
|
@ -1,35 +1,37 @@
|
|||
---
|
||||
- name: copy docker registry nginx configuration
|
||||
copy:
|
||||
src: "files/configs/docker_registry/nginx.conf"
|
||||
dest: "/docker-volumes/nginx/vhost/{{ services.docker_registry.domain }}"
|
||||
mode: "0644"
|
||||
ansible.builtin.copy:
|
||||
src: files/configs/docker_registry/nginx.conf
|
||||
dest: /docker-volumes/nginx/vhost/{{ services.docker_registry.domain }}
|
||||
mode: '0644'
|
||||
|
||||
- name: docker registry container
|
||||
docker_container:
|
||||
community.docker.docker_container:
|
||||
name: registry
|
||||
image: registry:{{ services.docker_registry.version }}
|
||||
restart_policy: always
|
||||
volumes:
|
||||
- "{{ services.docker_registry.volume_folder }}/registry:/var/lib/registry"
|
||||
- "{{ services.docker_registry.volume_folder }}/auth:/auth"
|
||||
- '{{ services.docker_registry.volume_folder }}/registry:/var/lib/registry'
|
||||
- '{{ services.docker_registry.volume_folder }}/auth:/auth'
|
||||
networks:
|
||||
- name: external_services
|
||||
env:
|
||||
VIRTUAL_HOST: "{{ services.docker_registry.domain }}"
|
||||
LETSENCRYPT_HOST: "{{ services.docker_registry.domain }}"
|
||||
LETSENCRYPT_EMAIL: "{{ letsencrypt_email }}"
|
||||
REGISTRY_AUTH: "htpasswd"
|
||||
REGISTRY_AUTH_HTPASSWD_PATH: "/auth/htpasswd"
|
||||
REGISTRY_AUTH_HTPASSWD_REALM: "data.coop docker registry"
|
||||
VIRTUAL_HOST: '{{ services.docker_registry.domain }}'
|
||||
LETSENCRYPT_HOST: '{{ services.docker_registry.domain }}'
|
||||
LETSENCRYPT_EMAIL: '{{ letsencrypt_email }}'
|
||||
REGISTRY_AUTH: htpasswd
|
||||
REGISTRY_AUTH_HTPASSWD_PATH: /auth/htpasswd
|
||||
REGISTRY_AUTH_HTPASSWD_REALM: data.coop docker registry
|
||||
|
||||
- name: generate htpasswd file
|
||||
shell: "docker exec -it registry htpasswd -Bbn docker {{ docker_password }} > {{ services.docker_registry.volume_folder }}/auth/htpasswd"
|
||||
shell: docker exec -it registry htpasswd -Bbn docker {{ docker_password }} > {{
|
||||
services.docker_registry.volume_folder }}/auth/htpasswd
|
||||
args:
|
||||
creates: "{{ services.docker_registry.volume_folder }}/auth/htpasswd"
|
||||
creates: '{{ services.docker_registry.volume_folder }}/auth/htpasswd'
|
||||
|
||||
- name: log in to registry
|
||||
docker_login:
|
||||
registry: "{{ 'docker.data.coop' if vagrant else services.docker_registry.domain }}"
|
||||
username: "docker"
|
||||
password: "{{ docker_password }}"
|
||||
registry: "{{ 'docker.data.coop' if vagrant else services.docker_registry.domain\
|
||||
\ }}"
|
||||
username: docker
|
||||
password: '{{ docker_password }}'
|
||||
|
|
|
@ -1,51 +1,51 @@
|
|||
---
|
||||
- name: set up drone with docker runner
|
||||
docker_compose:
|
||||
community.docker.docker_compose:
|
||||
project_name: drone
|
||||
pull: yes
|
||||
pull: true
|
||||
definition:
|
||||
version: "3.6"
|
||||
version: '3.6'
|
||||
services:
|
||||
drone:
|
||||
container_name: "drone"
|
||||
container_name: drone
|
||||
image: drone/drone:1
|
||||
restart: unless-stopped
|
||||
networks:
|
||||
- external_services
|
||||
- drone
|
||||
volumes:
|
||||
- "{{ services.drone.volume_folder }}:/data"
|
||||
- "/var/run/docker.sock:/var/run/docker.sock"
|
||||
- '{{ services.drone.volume_folder }}:/data'
|
||||
- /var/run/docker.sock:/var/run/docker.sock
|
||||
environment:
|
||||
DRONE_GITEA_SERVER: "https://{{ services.gitea.domain }}"
|
||||
DRONE_GITEA_CLIENT_ID: "{{ drone_secrets.oauth_client_id }}"
|
||||
DRONE_GITEA_CLIENT_SECRET: "{{ drone_secrets.oauth_client_secret }}"
|
||||
DRONE_GIT_ALWAYS_AUTH: "true"
|
||||
DRONE_SERVER_HOST: "{{ services.drone.domain }}"
|
||||
DRONE_SERVER_PROTO: "https"
|
||||
DRONE_RPC_SECRET: "{{ drone_secrets.rpc_shared_secret }}"
|
||||
PLUGIN_CUSTOM_DNS: "91.239.100.100"
|
||||
VIRTUAL_HOST: "{{ services.drone.domain }}"
|
||||
LETSENCRYPT_HOST: "{{ services.drone.domain }}"
|
||||
LETSENCRYPT_EMAIL: "{{ letsencrypt_email }}"
|
||||
DRONE_GITEA_SERVER: https://{{ services.gitea.domain }}
|
||||
DRONE_GITEA_CLIENT_ID: '{{ drone_secrets.oauth_client_id }}'
|
||||
DRONE_GITEA_CLIENT_SECRET: '{{ drone_secrets.oauth_client_secret }}'
|
||||
DRONE_GIT_ALWAYS_AUTH: 'true'
|
||||
DRONE_SERVER_HOST: '{{ services.drone.domain }}'
|
||||
DRONE_SERVER_PROTO: https
|
||||
DRONE_RPC_SECRET: '{{ drone_secrets.rpc_shared_secret }}'
|
||||
PLUGIN_CUSTOM_DNS: 91.239.100.100
|
||||
VIRTUAL_HOST: '{{ services.drone.domain }}'
|
||||
LETSENCRYPT_HOST: '{{ services.drone.domain }}'
|
||||
LETSENCRYPT_EMAIL: '{{ letsencrypt_email }}'
|
||||
|
||||
drone-runner-docker:
|
||||
container_name: "drone-runner-docker"
|
||||
image: "drone/drone-runner-docker:{{ services.drone.version }}"
|
||||
container_name: drone-runner-docker
|
||||
image: drone/drone-runner-docker:{{ services.drone.version }}
|
||||
restart: unless-stopped
|
||||
networks:
|
||||
- drone
|
||||
volumes:
|
||||
- "/var/run/docker.sock:/var/run/docker.sock"
|
||||
- /var/run/docker.sock:/var/run/docker.sock
|
||||
environment:
|
||||
DRONE_RPC_HOST: "{{ services.drone.domain }}"
|
||||
DRONE_RPC_PROTO: "https"
|
||||
DRONE_RPC_SECRET: "{{ drone_secrets.rpc_shared_secret }}"
|
||||
DRONE_RPC_HOST: '{{ services.drone.domain }}'
|
||||
DRONE_RPC_PROTO: https
|
||||
DRONE_RPC_SECRET: '{{ drone_secrets.rpc_shared_secret }}'
|
||||
DRONE_RUNNER_CAPACITY: 2
|
||||
DRONE_RUNNER_NAME: "data.coop_drone_runner"
|
||||
DRONE_RUNNER_NAME: data.coop_drone_runner
|
||||
|
||||
networks:
|
||||
drone:
|
||||
external_services:
|
||||
external:
|
||||
name: external_services
|
||||
name: external_services
|
||||
|
|
|
@ -1,11 +1,11 @@
|
|||
---
|
||||
- name: gitea network
|
||||
docker_network:
|
||||
community.docker.docker_network:
|
||||
name: gitea
|
||||
|
||||
# old DNS: 138.68.71.153
|
||||
- name: gitea container
|
||||
docker_container:
|
||||
community.docker.docker_container:
|
||||
name: gitea
|
||||
image: gitea/gitea:{{ services.gitea.version }}
|
||||
restart_policy: unless-stopped
|
||||
|
@ -14,25 +14,25 @@
|
|||
- name: postfix
|
||||
- name: external_services
|
||||
volumes:
|
||||
- "{{ services.gitea.volume_folder }}:/data"
|
||||
- '{{ services.gitea.volume_folder }}:/data'
|
||||
published_ports:
|
||||
- "22:22"
|
||||
- 22:22
|
||||
env:
|
||||
VIRTUAL_HOST: "{{ services.gitea.domain }}"
|
||||
VIRTUAL_PORT: "3000"
|
||||
LETSENCRYPT_HOST: "{{ services.gitea.domain }}"
|
||||
LETSENCRYPT_EMAIL: "{{ letsencrypt_email }}"
|
||||
# Gitea customization, see: https://docs.gitea.io/en-us/install-with-docker/#customization
|
||||
# https://docs.gitea.io/en-us/config-cheat-sheet/#security-security
|
||||
GITEA__mailer__ENABLED: "true"
|
||||
GITEA__mailer__FROM: "noreply@{{ services.gitea.domain }}"
|
||||
GITEA__mailer__MAILER_TYPE: "smtp"
|
||||
GITEA__mailer__HOST: "{{ smtp_host }}:{{ smtp_port }}"
|
||||
GITEA__mailer__USER: "noop"
|
||||
GITEA__mailer__PASSWD: "noop"
|
||||
GITEA__security__LOGIN_REMEMBER_DAYS: "60"
|
||||
GITEA__security__PASSWORD_COMPLEXITY: "off"
|
||||
GITEA__security__MIN_PASSWORD_LENGTH: "8"
|
||||
GITEA__security__PASSWORD_CHECK_PWN: "true"
|
||||
GITEA__service__ENABLE_NOTIFY_MAIL: "true"
|
||||
GITEA__service__REGISTER_EMAIL_CONFIRM: "true"
|
||||
VIRTUAL_HOST: '{{ services.gitea.domain }}'
|
||||
VIRTUAL_PORT: '3000'
|
||||
LETSENCRYPT_HOST: '{{ services.gitea.domain }}'
|
||||
LETSENCRYPT_EMAIL: '{{ letsencrypt_email }}'
|
||||
# Gitea customization, see: https://docs.gitea.io/en-us/install-with-docker/#customization
|
||||
# https://docs.gitea.io/en-us/config-cheat-sheet/#security-security
|
||||
GITEA__mailer__ENABLED: 'true'
|
||||
GITEA__mailer__FROM: noreply@{{ services.gitea.domain }}
|
||||
GITEA__mailer__MAILER_TYPE: smtp
|
||||
GITEA__mailer__HOST: '{{ smtp_host }}:{{ smtp_port }}'
|
||||
GITEA__mailer__USER: noop
|
||||
GITEA__mailer__PASSWD: noop
|
||||
GITEA__security__LOGIN_REMEMBER_DAYS: '60'
|
||||
GITEA__security__PASSWORD_COMPLEXITY: 'off'
|
||||
GITEA__security__MIN_PASSWORD_LENGTH: '8'
|
||||
GITEA__security__PASSWORD_CHECK_PWN: 'true'
|
||||
GITEA__service__ENABLE_NOTIFY_MAIL: 'true'
|
||||
GITEA__service__REGISTER_EMAIL_CONFIRM: 'true'
|
||||
|
|
|
@ -1,66 +1,65 @@
|
|||
---
|
||||
- name: create hedgedoc volume folders
|
||||
file:
|
||||
name: "{{ services.hedgedoc.volume_folder }}/{{ volume }}"
|
||||
ansible.builtin.file:
|
||||
name: '{{ services.hedgedoc.volume_folder }}/{{ volume }}'
|
||||
state: directory
|
||||
loop:
|
||||
- "db"
|
||||
- "hedgedoc/uploads"
|
||||
- db
|
||||
- hedgedoc/uploads
|
||||
loop_control:
|
||||
loop_var: volume
|
||||
|
||||
- name: copy sso public certificate
|
||||
copy:
|
||||
src: "files/sso/sso.data.coop.pem"
|
||||
dest: "{{ services.hedgedoc.volume_folder }}/sso.data.coop.pem"
|
||||
mode: "0644"
|
||||
ansible.builtin.copy:
|
||||
src: files/sso/sso.data.coop.pem
|
||||
dest: '{{ services.hedgedoc.volume_folder }}/sso.data.coop.pem'
|
||||
mode: '0644'
|
||||
|
||||
- name: setup hedgedoc
|
||||
docker_compose:
|
||||
project_name: "hedgedoc"
|
||||
pull: "yes"
|
||||
community.docker.docker_compose:
|
||||
project_name: hedgedoc
|
||||
pull: true
|
||||
definition:
|
||||
services:
|
||||
database:
|
||||
image: "postgres:10-alpine"
|
||||
image: postgres:10-alpine
|
||||
environment:
|
||||
POSTGRES_USER: "codimd"
|
||||
POSTGRES_PASSWORD: "{{ postgres_passwords.hedgedoc }}"
|
||||
POSTGRES_DB: "codimd"
|
||||
restart: "unless-stopped"
|
||||
POSTGRES_USER: codimd
|
||||
POSTGRES_PASSWORD: '{{ postgres_passwords.hedgedoc }}'
|
||||
POSTGRES_DB: codimd
|
||||
restart: unless-stopped
|
||||
networks:
|
||||
- "hedgedoc"
|
||||
- hedgedoc
|
||||
volumes:
|
||||
- "{{ services.hedgedoc.volume_folder }}/db:/var/lib/postgresql/data"
|
||||
|
||||
- '{{ services.hedgedoc.volume_folder }}/db:/var/lib/postgresql/data'
|
||||
app:
|
||||
image: quay.io/hedgedoc/hedgedoc:{{ services.hedgedoc.version }}
|
||||
environment:
|
||||
CMD_DB_URL: "postgres://codimd:{{ postgres_passwords.hedgedoc }}@hedgedoc_database_1:5432/codimd"
|
||||
CMD_DOMAIN: "{{ services.hedgedoc.domain }}"
|
||||
CMD_ALLOW_EMAIL_REGISTER: "False"
|
||||
CMD_IMAGE_UPLOAD_TYPE: "filesystem"
|
||||
CMD_EMAIL: "False"
|
||||
CMD_SAML_IDPCERT: "/sso.data.coop.pem"
|
||||
CMD_SAML_IDPSSOURL: "https://sso.data.coop/auth/realms/datacoop/protocol/saml"
|
||||
CMD_SAML_ISSUER: "hedgedoc"
|
||||
CMD_SAML_IDENTIFIERFORMAT: "urn:oasis:names:tc:SAML:1.1:nameid-format:unspecified"
|
||||
CMD_USECDN: "false"
|
||||
CMD_PROTOCOL_USESSL: "true"
|
||||
VIRTUAL_HOST: "{{ services.hedgedoc.domain }}"
|
||||
LETSENCRYPT_HOST: "{{ services.hedgedoc.domain }}"
|
||||
LETSENCRYPT_EMAIL: "{{ letsencrypt_email }}"
|
||||
CMD_DB_URL: postgres://codimd:{{ postgres_passwords.hedgedoc }}@hedgedoc_database_1:5432/codimd
|
||||
CMD_DOMAIN: '{{ services.hedgedoc.domain }}'
|
||||
CMD_ALLOW_EMAIL_REGISTER: 'False'
|
||||
CMD_IMAGE_UPLOAD_TYPE: filesystem
|
||||
CMD_EMAIL: 'False'
|
||||
CMD_SAML_IDPCERT: /sso.data.coop.pem
|
||||
CMD_SAML_IDPSSOURL: https://sso.data.coop/auth/realms/datacoop/protocol/saml
|
||||
CMD_SAML_ISSUER: hedgedoc
|
||||
CMD_SAML_IDENTIFIERFORMAT: urn:oasis:names:tc:SAML:1.1:nameid-format:unspecified
|
||||
CMD_USECDN: 'false'
|
||||
CMD_PROTOCOL_USESSL: 'true'
|
||||
VIRTUAL_HOST: '{{ services.hedgedoc.domain }}'
|
||||
LETSENCRYPT_HOST: '{{ services.hedgedoc.domain }}'
|
||||
LETSENCRYPT_EMAIL: '{{ letsencrypt_email }}'
|
||||
volumes:
|
||||
- "{{ services.hedgedoc.volume_folder }}/hedgedoc/uploads:/hedgedoc/public/uploads"
|
||||
- "{{ services.hedgedoc.volume_folder }}/sso.data.coop.pem:/sso.data.coop.pem"
|
||||
restart: "unless-stopped"
|
||||
networks:
|
||||
- "hedgedoc"
|
||||
- "external_services"
|
||||
- '{{ services.hedgedoc.volume_folder }}/hedgedoc/uploads:/hedgedoc/public/uploads'
|
||||
- '{{ services.hedgedoc.volume_folder }}/sso.data.coop.pem:/sso.data.coop.pem'
|
||||
restart: unless-stopped
|
||||
networks:
|
||||
- hedgedoc
|
||||
- external_services
|
||||
depends_on:
|
||||
- database
|
||||
|
||||
networks:
|
||||
networks:
|
||||
hedgedoc:
|
||||
external_services:
|
||||
external: true
|
||||
|
|
|
@ -1,36 +1,40 @@
|
|||
---
|
||||
- name: setup keycloak containers for sso.data.coop
|
||||
docker_compose:
|
||||
project_name: "keycloak"
|
||||
pull: "yes"
|
||||
community.docker.docker_compose:
|
||||
project_name: keycloak
|
||||
pull: true
|
||||
definition:
|
||||
version: "3.6"
|
||||
version: '3.6'
|
||||
services:
|
||||
|
||||
postgres:
|
||||
image: "postgres:10"
|
||||
restart: "unless-stopped"
|
||||
image: postgres:10
|
||||
restart: unless-stopped
|
||||
networks:
|
||||
- "keycloak"
|
||||
- keycloak
|
||||
volumes:
|
||||
- "{{ services.keycloak.volume_folder }}/data:/var/lib/postgresql/data"
|
||||
- '{{ services.keycloak.volume_folder }}/data:/var/lib/postgresql/data'
|
||||
environment:
|
||||
POSTGRES_USER: "keycloak"
|
||||
POSTGRES_PASSWORD: "{{ postgres_passwords.keycloak }}"
|
||||
POSTGRES_DB: "keycloak"
|
||||
POSTGRES_USER: keycloak
|
||||
POSTGRES_PASSWORD: '{{ postgres_passwords.keycloak }}'
|
||||
POSTGRES_DB: keycloak
|
||||
|
||||
app:
|
||||
image: "quay.io/keycloak/keycloak:{{ services.keycloak.version }}"
|
||||
restart: "unless-stopped"
|
||||
image: quay.io/keycloak/keycloak:{{ services.keycloak.version }}
|
||||
restart: unless-stopped
|
||||
networks:
|
||||
- "keycloak"
|
||||
- "postfix"
|
||||
- "external_services"
|
||||
command: "start --db=postgres --db-url=jdbc:postgresql://postgres:5432/keycloak --db-username=keycloak --db-password={{ postgres_passwords.keycloak }} --hostname={{ services.keycloak.domain }} --proxy=edge --https-port=8080 --http-relative-path=/auth"
|
||||
- keycloak
|
||||
- postfix
|
||||
- external_services
|
||||
command: start --db=postgres --db-url=jdbc:postgresql://postgres:5432/keycloak
|
||||
--db-username=keycloak --db-password={{ postgres_passwords.keycloak
|
||||
}} --hostname={{ services.keycloak.domain }} --proxy=edge --https-port=8080
|
||||
--http-relative-path=/auth
|
||||
environment:
|
||||
VIRTUAL_HOST: "{{ services.keycloak.domain }}"
|
||||
VIRTUAL_PORT: "8080"
|
||||
LETSENCRYPT_HOST: "{{ services.keycloak.domain }}"
|
||||
LETSENCRYPT_EMAIL: "{{ letsencrypt_email }}"
|
||||
VIRTUAL_HOST: '{{ services.keycloak.domain }}'
|
||||
VIRTUAL_PORT: '8080'
|
||||
LETSENCRYPT_HOST: '{{ services.keycloak.domain }}'
|
||||
LETSENCRYPT_EMAIL: '{{ letsencrypt_email }}'
|
||||
|
||||
networks:
|
||||
keycloak:
|
||||
|
|
|
@ -1,8 +1,8 @@
|
|||
---
|
||||
|
||||
- name: create mailu volume folders
|
||||
file:
|
||||
name: "{{ services.mailu.volume_folder }}/{{ volume }}"
|
||||
ansible.builtin.file:
|
||||
name: '{{ services.mailu.volume_folder }}/{{ volume }}'
|
||||
state: directory
|
||||
loop:
|
||||
- redis
|
||||
|
@ -18,30 +18,32 @@
|
|||
loop_var: volume
|
||||
|
||||
- name: upload mailu.env file
|
||||
template:
|
||||
ansible.builtin.template:
|
||||
src: mailu.env.j2
|
||||
dest: "{{ services.mailu.volume_folder}}/mailu.env"
|
||||
dest: '{{ services.mailu.volume_folder}}/mailu.env'
|
||||
|
||||
- name: hard link to Let's Encrypt TLS certificate
|
||||
file:
|
||||
src: "{{ services.nginx_proxy.volume_folder }}/certs/{{ services.mailu.domain }}/fullchain.pem"
|
||||
dest: "{{ services.mailu.volume_folder }}/certs/cert.pem"
|
||||
ansible.builtin.file:
|
||||
src: '{{ services.nginx_proxy.volume_folder }}/certs/{{ services.mailu.domain
|
||||
}}/fullchain.pem'
|
||||
dest: '{{ services.mailu.volume_folder }}/certs/cert.pem'
|
||||
state: hard
|
||||
force: yes
|
||||
force: true
|
||||
when: letsencrypt_enabled
|
||||
|
||||
- name: hard link to Let's Encrypt TLS key
|
||||
file:
|
||||
src: "{{ services.nginx_proxy.volume_folder }}/certs/{{ services.mailu.domain }}/key.pem"
|
||||
dest: "{{ services.mailu.volume_folder }}/certs/key.pem"
|
||||
ansible.builtin.file:
|
||||
src: '{{ services.nginx_proxy.volume_folder }}/certs/{{ services.mailu.domain
|
||||
}}/key.pem'
|
||||
dest: '{{ services.mailu.volume_folder }}/certs/key.pem'
|
||||
state: hard
|
||||
force: yes
|
||||
force: true
|
||||
when: letsencrypt_enabled
|
||||
|
||||
- name: run mail server containers
|
||||
docker_compose:
|
||||
community.docker.docker_compose:
|
||||
project_name: mail_server
|
||||
pull: yes
|
||||
pull: true
|
||||
definition:
|
||||
version: '3.6'
|
||||
services:
|
||||
|
@ -49,15 +51,15 @@
|
|||
image: redis:alpine
|
||||
restart: always
|
||||
volumes:
|
||||
- "{{ services.mailu.volume_folder }}/redis:/data"
|
||||
- '{{ services.mailu.volume_folder }}/redis:/data'
|
||||
|
||||
database:
|
||||
image: mailu/postgresql:{{ services.mailu.version }}
|
||||
restart: always
|
||||
env_file: "{{ services.mailu.volume_folder}}/mailu.env"
|
||||
env_file: '{{ services.mailu.volume_folder}}/mailu.env'
|
||||
volumes:
|
||||
- "{{ services.mailu.volume_folder }}/data/psql_db:/data"
|
||||
- "{{ services.mailu.volume_folder }}/data/psql_backup:/backup"
|
||||
- '{{ services.mailu.volume_folder }}/data/psql_db:/data'
|
||||
- '{{ services.mailu.volume_folder }}/data/psql_backup:/backup'
|
||||
networks:
|
||||
- default
|
||||
- external_services
|
||||
|
@ -65,21 +67,21 @@
|
|||
front:
|
||||
image: mailu/nginx:{{ services.mailu.version }}
|
||||
restart: always
|
||||
env_file: "{{ services.mailu.volume_folder}}/mailu.env"
|
||||
env_file: '{{ services.mailu.volume_folder}}/mailu.env'
|
||||
environment:
|
||||
VIRTUAL_HOST: "{{ services.mailu.domain }}"
|
||||
LETSENCRYPT_HOST: "{{ services.mailu.domain }}"
|
||||
LETSENCRYPT_EMAIL: "{{ letsencrypt_email }}"
|
||||
VIRTUAL_HOST: '{{ services.mailu.domain }}'
|
||||
LETSENCRYPT_HOST: '{{ services.mailu.domain }}'
|
||||
LETSENCRYPT_EMAIL: '{{ letsencrypt_email }}'
|
||||
volumes:
|
||||
- "{{ services.mailu.volume_folder }}/certs:/certs"
|
||||
- "{{ services.mailu.volume_folder }}/overrides/nginx:/overrides"
|
||||
- '{{ services.mailu.volume_folder }}/certs:/certs'
|
||||
- '{{ services.mailu.volume_folder }}/overrides/nginx:/overrides'
|
||||
expose:
|
||||
- "80"
|
||||
- '80'
|
||||
ports:
|
||||
- "993:993"
|
||||
- "25:25"
|
||||
- "587:587"
|
||||
- "465:465"
|
||||
- 993:993
|
||||
- 25:25
|
||||
- 587:587
|
||||
- 465:465
|
||||
networks:
|
||||
- default
|
||||
- external_services
|
||||
|
@ -87,68 +89,68 @@
|
|||
resolver:
|
||||
image: mailu/unbound:{{ services.mailu.version }}
|
||||
restart: always
|
||||
env_file: "{{ services.mailu.volume_folder}}/mailu.env"
|
||||
env_file: '{{ services.mailu.volume_folder}}/mailu.env'
|
||||
networks:
|
||||
default:
|
||||
ipv4_address: "{{ services.mailu.dns }}"
|
||||
ipv4_address: '{{ services.mailu.dns }}'
|
||||
|
||||
admin:
|
||||
image: mailu/admin:{{ services.mailu.version }}
|
||||
restart: always
|
||||
env_file: "{{ services.mailu.volume_folder}}/mailu.env"
|
||||
env_file: '{{ services.mailu.volume_folder}}/mailu.env'
|
||||
volumes:
|
||||
- "{{ services.mailu.volume_folder }}/data:/data"
|
||||
- "{{ services.mailu.volume_folder }}/dkim:/dkim"
|
||||
- '{{ services.mailu.volume_folder }}/data:/data'
|
||||
- '{{ services.mailu.volume_folder }}/dkim:/dkim'
|
||||
depends_on:
|
||||
- redis
|
||||
|
||||
imap:
|
||||
image: mailu/dovecot:{{ services.mailu.version }}
|
||||
restart: always
|
||||
env_file: "{{ services.mailu.volume_folder}}/mailu.env"
|
||||
env_file: '{{ services.mailu.volume_folder}}/mailu.env'
|
||||
volumes:
|
||||
- "{{ services.mailu.volume_folder }}/mail:/mail"
|
||||
- "{{ services.mailu.volume_folder }}/overrides:/overrides"
|
||||
- '{{ services.mailu.volume_folder }}/mail:/mail'
|
||||
- '{{ services.mailu.volume_folder }}/overrides:/overrides'
|
||||
depends_on:
|
||||
- front
|
||||
|
||||
smtp:
|
||||
image: mailu/postfix:{{ services.mailu.version }}
|
||||
restart: always
|
||||
env_file: "{{ services.mailu.volume_folder}}/mailu.env"
|
||||
env_file: '{{ services.mailu.volume_folder}}/mailu.env'
|
||||
volumes:
|
||||
- "{{ services.mailu.volume_folder }}/overrides:/overrides"
|
||||
- '{{ services.mailu.volume_folder }}/overrides:/overrides'
|
||||
depends_on:
|
||||
- front
|
||||
- resolver
|
||||
dns:
|
||||
- "{{ services.mailu.dns }}"
|
||||
- '{{ services.mailu.dns }}'
|
||||
|
||||
antispam:
|
||||
image: mailu/rspamd:{{ services.mailu.version }}
|
||||
restart: always
|
||||
env_file: "{{ services.mailu.volume_folder}}/mailu.env"
|
||||
env_file: '{{ services.mailu.volume_folder}}/mailu.env'
|
||||
volumes:
|
||||
- "{{ services.mailu.volume_folder }}/filter:/var/lib/rspamd"
|
||||
- "{{ services.mailu.volume_folder }}/dkim:/dkim"
|
||||
- "{{ services.mailu.volume_folder }}/overrides/rspamd:/etc/rspamd/override.d"
|
||||
- '{{ services.mailu.volume_folder }}/filter:/var/lib/rspamd'
|
||||
- '{{ services.mailu.volume_folder }}/dkim:/dkim'
|
||||
- '{{ services.mailu.volume_folder }}/overrides/rspamd:/etc/rspamd/override.d'
|
||||
depends_on:
|
||||
- front
|
||||
- resolver
|
||||
dns:
|
||||
- "{{ services.mailu.dns }}"
|
||||
- '{{ services.mailu.dns }}'
|
||||
|
||||
webmail:
|
||||
image: mailu/rainloop:1.6
|
||||
restart: always
|
||||
env_file: "{{ services.mailu.volume_folder}}/mailu.env"
|
||||
env_file: '{{ services.mailu.volume_folder}}/mailu.env'
|
||||
volumes:
|
||||
- "{{ services.mailu.volume_folder }}/webmail:/data"
|
||||
- '{{ services.mailu.volume_folder }}/webmail:/data'
|
||||
depends_on:
|
||||
- front
|
||||
- resolver
|
||||
dns:
|
||||
- "{{ services.mailu.dns }}"
|
||||
- '{{ services.mailu.dns }}'
|
||||
|
||||
networks:
|
||||
default:
|
||||
|
@ -156,7 +158,7 @@
|
|||
ipam:
|
||||
driver: default
|
||||
config:
|
||||
- subnet: "{{ services.mailu.subnet }}"
|
||||
- subnet: '{{ services.mailu.subnet }}'
|
||||
external_services:
|
||||
external:
|
||||
name: external_services
|
||||
|
|
|
@ -1,30 +1,32 @@
|
|||
---
|
||||
- name: create mastodon volume folders
|
||||
file:
|
||||
name: "{{ services.mastodon.volume_folder }}/{{ volume }}"
|
||||
ansible.builtin.file:
|
||||
name: '{{ services.mastodon.volume_folder }}/{{ volume }}'
|
||||
state: directory
|
||||
owner: "991"
|
||||
group: "991"
|
||||
owner: '991'
|
||||
group: '991'
|
||||
loop:
|
||||
- "postgres_data"
|
||||
- "redis_data"
|
||||
- "mastodon_data"
|
||||
- postgres_data
|
||||
- redis_data
|
||||
- mastodon_data
|
||||
loop_control:
|
||||
loop_var: volume
|
||||
|
||||
- name: Copy mastodon environment file
|
||||
template:
|
||||
ansible.builtin.template:
|
||||
src: files/configs/mastodon/env_file.j2
|
||||
dest: "{{ services.mastodon.volume_folder }}/env_file"
|
||||
dest: '{{ services.mastodon.volume_folder }}/env_file'
|
||||
|
||||
- name: upload vhost config for root domain
|
||||
template:
|
||||
ansible.builtin.template:
|
||||
src: files/configs/mastodon/vhost-mastodon
|
||||
dest: "{{ services.nginx_proxy.volume_folder }}/vhost/{{ services.mastodon.domain }}"
|
||||
dest: '{{ services.nginx_proxy.volume_folder }}/vhost/{{ services.mastodon.domain
|
||||
}}'
|
||||
|
||||
- name: set up mastodon
|
||||
docker_compose:
|
||||
community.docker.docker_compose:
|
||||
project_name: mastodon
|
||||
pull: yes
|
||||
pull: true
|
||||
definition:
|
||||
version: '3'
|
||||
services:
|
||||
|
@ -35,11 +37,11 @@
|
|||
networks:
|
||||
- internal_network
|
||||
healthcheck:
|
||||
test: ['CMD', 'pg_isready', '-U', 'postgres']
|
||||
test: [CMD, pg_isready, -U, postgres]
|
||||
volumes:
|
||||
- "{{ services.mastodon.volume_folder }}/postgres_data:/var/lib/postgresql/data"
|
||||
- '{{ services.mastodon.volume_folder }}/postgres_data:/var/lib/postgresql/data'
|
||||
environment:
|
||||
- 'POSTGRES_HOST_AUTH_METHOD=trust'
|
||||
- POSTGRES_HOST_AUTH_METHOD=trust
|
||||
|
||||
redis:
|
||||
restart: always
|
||||
|
@ -47,58 +49,59 @@
|
|||
networks:
|
||||
- internal_network
|
||||
healthcheck:
|
||||
test: ['CMD', 'redis-cli', 'ping']
|
||||
test: [CMD, redis-cli, ping]
|
||||
volumes:
|
||||
- "{{ services.mastodon.volume_folder }}/redis_data:/data"
|
||||
- '{{ services.mastodon.volume_folder }}/redis_data:/data'
|
||||
|
||||
web:
|
||||
image: "tootsuite/mastodon:{{ services.mastodon.version }}"
|
||||
image: tootsuite/mastodon:{{ services.mastodon.version }}
|
||||
restart: always
|
||||
env_file: "{{ services.mastodon.volume_folder }}/env_file"
|
||||
command: bash -c "rm -f /mastodon/tmp/pids/server.pid; bundle exec rails s -p 3000"
|
||||
env_file: '{{ services.mastodon.volume_folder }}/env_file'
|
||||
command: bash -c "rm -f /mastodon/tmp/pids/server.pid; bundle exec rails
|
||||
s -p 3000"
|
||||
networks:
|
||||
- external_services
|
||||
- internal_network
|
||||
healthcheck:
|
||||
# prettier-ignore
|
||||
test: ['CMD-SHELL', 'wget -q --spider --proxy=off localhost:3000/health || exit 1']
|
||||
test: |
|
||||
[CMD-SHELL, wget -q --spider --proxy=off localhost:3000/health || exit 1]
|
||||
depends_on:
|
||||
- db
|
||||
- redis
|
||||
volumes:
|
||||
- "{{ services.mastodon.volume_folder }}/mastodon_data:/mastodon/public/system"
|
||||
- '{{ services.mastodon.volume_folder }}/mastodon_data:/mastodon/public/system'
|
||||
environment:
|
||||
VIRTUAL_HOST: "{{ services.mastodon.domain }}"
|
||||
VIRTUAL_PORT: "3000"
|
||||
VIRTUAL_PATH: "/"
|
||||
LETSENCRYPT_HOST: "{{ services.mastodon.domain }}"
|
||||
LETSENCRYPT_EMAIL: "{{ letsencrypt_email }}"
|
||||
VIRTUAL_HOST: '{{ services.mastodon.domain }}'
|
||||
VIRTUAL_PORT: '3000'
|
||||
VIRTUAL_PATH: /
|
||||
LETSENCRYPT_HOST: '{{ services.mastodon.domain }}'
|
||||
LETSENCRYPT_EMAIL: '{{ letsencrypt_email }}'
|
||||
|
||||
streaming:
|
||||
image: "tootsuite/mastodon:{{ services.mastodon.version }}"
|
||||
image: tootsuite/mastodon:{{ services.mastodon.version }}
|
||||
restart: always
|
||||
env_file: "{{ services.mastodon.volume_folder }}/env_file"
|
||||
env_file: '{{ services.mastodon.volume_folder }}/env_file'
|
||||
command: node ./streaming
|
||||
networks:
|
||||
- external_services
|
||||
- internal_network
|
||||
healthcheck:
|
||||
# prettier-ignore
|
||||
test: ['CMD-SHELL', 'wget -q --spider --proxy=off localhost:4000/api/v1/streaming/health || exit 1']
|
||||
test: |
|
||||
[CMD-SHELL, wget -q --spider --proxy=off localhost:4000/api/v1/streaming/health || exit 1]
|
||||
ports:
|
||||
- '127.0.0.1:4000:4000'
|
||||
- 127.0.0.1:4000:4000
|
||||
depends_on:
|
||||
- db
|
||||
- redis
|
||||
environment:
|
||||
VIRTUAL_HOST: "{{ services.mastodon.domain }}"
|
||||
VIRTUAL_PORT: "4000"
|
||||
VIRTUAL_PATH: "/api/v1/streaming"
|
||||
VIRTUAL_HOST: '{{ services.mastodon.domain }}'
|
||||
VIRTUAL_PORT: '4000'
|
||||
VIRTUAL_PATH: /api/v1/streaming
|
||||
|
||||
sidekiq:
|
||||
image: "tootsuite/mastodon:{{ services.mastodon.version }}"
|
||||
image: tootsuite/mastodon:{{ services.mastodon.version }}
|
||||
restart: always
|
||||
env_file: "{{ services.mastodon.volume_folder }}/env_file"
|
||||
env_file: '{{ services.mastodon.volume_folder }}/env_file'
|
||||
command: bundle exec sidekiq -c 32
|
||||
environment:
|
||||
DB_POOL: 32
|
||||
|
@ -110,9 +113,9 @@
|
|||
- external_services
|
||||
- internal_network
|
||||
volumes:
|
||||
- "{{ services.mastodon.volume_folder }}/mastodon_data:/mastodon/public/system"
|
||||
- '{{ services.mastodon.volume_folder }}/mastodon_data:/mastodon/public/system'
|
||||
healthcheck:
|
||||
test: ['CMD-SHELL', "ps aux | grep '[s]idekiq\ 6' || false"]
|
||||
test: [CMD-SHELL, "ps aux | grep '[s]idekiq 6' || false"]
|
||||
|
||||
networks:
|
||||
external_services:
|
||||
|
@ -120,4 +123,4 @@
|
|||
postfix:
|
||||
external: true
|
||||
internal_network:
|
||||
internal: true
|
||||
internal: true
|
||||
|
|
|
@ -1,73 +1,74 @@
|
|||
---
|
||||
- name: create matrix volume folders
|
||||
file:
|
||||
name: "{{ services.matrix.volume_folder }}/{{ volume }}"
|
||||
ansible.builtin.file:
|
||||
name: '{{ services.matrix.volume_folder }}/{{ volume }}'
|
||||
state: directory
|
||||
owner: "991"
|
||||
group: "991"
|
||||
owner: '991'
|
||||
group: '991'
|
||||
loop:
|
||||
- "data"
|
||||
- "data/uploads"
|
||||
- "data/media"
|
||||
- data
|
||||
- data/uploads
|
||||
- data/media
|
||||
loop_control:
|
||||
loop_var: volume
|
||||
|
||||
- name: create matrix DB folder
|
||||
file:
|
||||
name: "{{ services.matrix.volume_folder }}/db"
|
||||
state: "directory"
|
||||
ansible.builtin.file:
|
||||
name: '{{ services.matrix.volume_folder }}/db'
|
||||
state: directory
|
||||
|
||||
- name: create riot volume folders
|
||||
file:
|
||||
name: "{{ services.riot.volume_folder }}/{{ volume }}"
|
||||
ansible.builtin.file:
|
||||
name: '{{ services.riot.volume_folder }}/{{ volume }}'
|
||||
state: directory
|
||||
loop:
|
||||
- "data"
|
||||
- data
|
||||
loop_control:
|
||||
loop_var: volume
|
||||
|
||||
- name: upload riot config.json
|
||||
template:
|
||||
ansible.builtin.template:
|
||||
src: files/configs/riot/config.json
|
||||
dest: "{{ services.riot.volume_folder }}/data/config.json"
|
||||
dest: '{{ services.riot.volume_folder }}/data/config.json'
|
||||
|
||||
- name: upload riot.im.conf
|
||||
template:
|
||||
ansible.builtin.template:
|
||||
src: files/configs/riot/riot.im.conf
|
||||
dest: "{{ services.riot.volume_folder }}/data/riot.im.conf"
|
||||
dest: '{{ services.riot.volume_folder }}/data/riot.im.conf'
|
||||
|
||||
- name: upload vhost config for root domain
|
||||
template:
|
||||
ansible.builtin.template:
|
||||
src: files/configs/matrix/vhost-root
|
||||
dest: "{{ services.nginx_proxy.volume_folder }}/vhost/{{ base_domain }}"
|
||||
dest: '{{ services.nginx_proxy.volume_folder }}/vhost/{{ base_domain }}'
|
||||
|
||||
- name: upload vhost config for matrix domain
|
||||
template:
|
||||
ansible.builtin.template:
|
||||
src: files/configs/matrix/vhost-matrix
|
||||
dest: "{{ services.nginx_proxy.volume_folder }}/vhost/{{ services.matrix.domain }}"
|
||||
dest: '{{ services.nginx_proxy.volume_folder }}/vhost/{{ services.matrix.domain
|
||||
}}'
|
||||
|
||||
- name: upload vhost config for riot domain
|
||||
template:
|
||||
ansible.builtin.template:
|
||||
src: files/configs/matrix/vhost-riot
|
||||
dest: "{{ services.nginx_proxy.volume_folder }}/vhost/{{ item }}"
|
||||
loop: "{{ services.riot.domains }}"
|
||||
dest: '{{ services.nginx_proxy.volume_folder }}/vhost/{{ item }}'
|
||||
loop: '{{ services.riot.domains }}'
|
||||
|
||||
- name: upload homeserver.yaml
|
||||
template:
|
||||
src: "files/configs/matrix/homeserver.yaml.j2"
|
||||
dest: "{{ services.matrix.volume_folder }}/data/homeserver.yaml"
|
||||
ansible.builtin.template:
|
||||
src: files/configs/matrix/homeserver.yaml.j2
|
||||
dest: '{{ services.matrix.volume_folder }}/data/homeserver.yaml'
|
||||
|
||||
- name: upload matrix logging config
|
||||
template:
|
||||
src: "files/configs/matrix/matrix.data.coop.log.config"
|
||||
dest: "{{ services.matrix.volume_folder }}/data/matrix.data.coop.log.config"
|
||||
ansible.builtin.template:
|
||||
src: files/configs/matrix/matrix.data.coop.log.config
|
||||
dest: '{{ services.matrix.volume_folder }}/data/matrix.data.coop.log.config'
|
||||
|
||||
- name: set up matrix and riot
|
||||
docker_compose:
|
||||
community.docker.docker_compose:
|
||||
project_name: matrix
|
||||
pull: yes
|
||||
pull: true
|
||||
definition:
|
||||
version: "3.6"
|
||||
version: '3.6'
|
||||
services:
|
||||
matrix_db:
|
||||
container_name: matrix_db
|
||||
|
@ -76,10 +77,10 @@
|
|||
networks:
|
||||
- matrix
|
||||
volumes:
|
||||
- "{{ services.matrix.volume_folder }}/db:/var/lib/postgresql/data"
|
||||
- '{{ services.matrix.volume_folder }}/db:/var/lib/postgresql/data'
|
||||
environment:
|
||||
POSTGRES_USER: "synapse"
|
||||
POSTGRES_PASSWORD: "{{ postgres_passwords.matrix }}"
|
||||
POSTGRES_USER: synapse
|
||||
POSTGRES_PASSWORD: '{{ postgres_passwords.matrix }}'
|
||||
|
||||
matrix_app:
|
||||
container_name: matrix
|
||||
|
@ -89,15 +90,15 @@
|
|||
- matrix
|
||||
- external_services
|
||||
volumes:
|
||||
- "{{ services.matrix.volume_folder }}/data:/data"
|
||||
- '{{ services.matrix.volume_folder }}/data:/data'
|
||||
environment:
|
||||
SYNAPSE_CONFIG_PATH: "/data/homeserver.yaml"
|
||||
SYNAPSE_CACHE_FACTOR: "2"
|
||||
SYNAPSE_LOG_LEVEL: "INFO"
|
||||
VIRTUAL_HOST: "{{ services.matrix.domain }}"
|
||||
VIRTUAL_PORT: "8008"
|
||||
LETSENCRYPT_HOST: "{{ services.matrix.domain }}"
|
||||
LETSENCRYPT_EMAIL: "{{ letsencrypt_email }}"
|
||||
SYNAPSE_CONFIG_PATH: /data/homeserver.yaml
|
||||
SYNAPSE_CACHE_FACTOR: '2'
|
||||
SYNAPSE_LOG_LEVEL: INFO
|
||||
VIRTUAL_HOST: '{{ services.matrix.domain }}'
|
||||
VIRTUAL_PORT: '8008'
|
||||
LETSENCRYPT_HOST: '{{ services.matrix.domain }}'
|
||||
LETSENCRYPT_EMAIL: '{{ letsencrypt_email }}'
|
||||
|
||||
riot:
|
||||
container_name: riot_app
|
||||
|
@ -109,16 +110,16 @@
|
|||
expose:
|
||||
- 8080
|
||||
volumes:
|
||||
- "{{ services.riot.volume_folder }}/data:/data"
|
||||
- '{{ services.riot.volume_folder }}/data:/data'
|
||||
environment:
|
||||
VIRTUAL_HOST: "{{ services.riot.domains|join(',') }}"
|
||||
VIRTUAL_PORT: "8080"
|
||||
VIRTUAL_PORT: '8080'
|
||||
LETSENCRYPT_HOST: "{{ services.riot.domains|join(',') }}"
|
||||
LETSENCRYPT_EMAIL: "{{ letsencrypt_email }}"
|
||||
LETSENCRYPT_EMAIL: '{{ letsencrypt_email }}'
|
||||
|
||||
networks:
|
||||
external_services:
|
||||
external:
|
||||
name: external_services
|
||||
matrix:
|
||||
name: "matrix"
|
||||
name: matrix
|
||||
|
|
|
@ -1,11 +1,11 @@
|
|||
---
|
||||
|
||||
- name: run membersystem containers
|
||||
docker_compose:
|
||||
project_name: "member.data.coop"
|
||||
pull: yes
|
||||
community.docker.docker_compose:
|
||||
project_name: member.data.coop
|
||||
pull: true
|
||||
definition:
|
||||
version: "3"
|
||||
version: '3'
|
||||
services:
|
||||
backend:
|
||||
image: docker.data.coop/membersystem:latest
|
||||
|
@ -19,32 +19,33 @@
|
|||
- external_services
|
||||
- postfix
|
||||
environment:
|
||||
SECRET_KEY: "{{ membersystem_secrets.secret_key }}"
|
||||
DATABASE_URL: postgres://postgres:{{ postgres_passwords.membersystem }}@postgres:5432/postgres
|
||||
SECRET_KEY: '{{ membersystem_secrets.secret_key }}'
|
||||
DATABASE_URL: postgres://postgres:{{ postgres_passwords.membersystem
|
||||
}}@postgres:5432/postgres
|
||||
POSTGRES_HOST: postgres
|
||||
POSTGRES_PORT: 5432
|
||||
EMAIL_BACKEND: "django.core.mail.backends.smtp.EmailBackend"
|
||||
EMAIL_URL: "smtp://noop@{{ smtp_host }}:{{ smtp_port }}"
|
||||
VIRTUAL_HOST: "{{ services.membersystem.domain }}"
|
||||
VIRTUAL_PORT: "8000"
|
||||
LETSENCRYPT_HOST: "{{ services.membersystem.domain }}"
|
||||
LETSENCRYPT_EMAIL: "{{ letsencrypt_email }}"
|
||||
ALLOWED_HOSTS: "{{ services.membersystem.domain }}"
|
||||
CSRF_TRUSTED_ORIGINS: "https://{{ services.membersystem.domain }}"
|
||||
DJANGO_ADMINS: "{{ services.membersystem.django_admins }}"
|
||||
DEFAULT_FROM_EMAIL: "noreply@{{ services.membersystem.domain }}"
|
||||
EMAIL_BACKEND: django.core.mail.backends.smtp.EmailBackend
|
||||
EMAIL_URL: smtp://noop@{{ smtp_host }}:{{ smtp_port }}
|
||||
VIRTUAL_HOST: '{{ services.membersystem.domain }}'
|
||||
VIRTUAL_PORT: '8000'
|
||||
LETSENCRYPT_HOST: '{{ services.membersystem.domain }}'
|
||||
LETSENCRYPT_EMAIL: '{{ letsencrypt_email }}'
|
||||
ALLOWED_HOSTS: '{{ services.membersystem.domain }}'
|
||||
CSRF_TRUSTED_ORIGINS: https://{{ services.membersystem.domain }}
|
||||
DJANGO_ADMINS: '{{ services.membersystem.django_admins }}'
|
||||
DEFAULT_FROM_EMAIL: noreply@{{ services.membersystem.domain }}
|
||||
labels:
|
||||
com.centurylinklabs.watchtower.enable: "true"
|
||||
com.centurylinklabs.watchtower.enable: 'true'
|
||||
|
||||
postgres:
|
||||
image: postgres:13-alpine
|
||||
restart: always
|
||||
volumes:
|
||||
- "{{ volume_root_folder }}/membersystem/postgres/data:/var/lib/postgresql/data"
|
||||
- '{{ volume_root_folder }}/membersystem/postgres/data:/var/lib/postgresql/data'
|
||||
networks:
|
||||
- membersystem
|
||||
environment:
|
||||
POSTGRES_PASSWORD: "{{ postgres_passwords.membersystem }}"
|
||||
POSTGRES_PASSWORD: '{{ postgres_passwords.membersystem }}'
|
||||
|
||||
networks:
|
||||
membersystem:
|
||||
|
|
|
@ -1,11 +1,11 @@
|
|||
---
|
||||
|
||||
- name: setup netdata docker container for system monitoring
|
||||
docker_container:
|
||||
community.docker.docker_container:
|
||||
name: netdata
|
||||
image: netdata/netdata:{{ services.netdata.version }}
|
||||
restart_policy: unless-stopped
|
||||
hostname: "hevonen.servers.{{ base_domain }}"
|
||||
hostname: hevonen.servers.{{ base_domain }}
|
||||
capabilities:
|
||||
- SYS_PTRACE
|
||||
security_opts:
|
||||
|
@ -17,11 +17,9 @@
|
|||
networks:
|
||||
- name: external_services
|
||||
env:
|
||||
VIRTUAL_HOST : "{{ services.netdata.domain }}"
|
||||
LETSENCRYPT_HOST: "{{ services.netdata.domain }}"
|
||||
LETSENCRYPT_EMAIL: "{{ letsencrypt_email }}"
|
||||
PGID: "999"
|
||||
VIRTUAL_HOST: '{{ services.netdata.domain }}'
|
||||
LETSENCRYPT_HOST: '{{ services.netdata.domain }}'
|
||||
LETSENCRYPT_EMAIL: '{{ letsencrypt_email }}'
|
||||
PGID: '999'
|
||||
labels:
|
||||
com.centurylinklabs.watchtower.enable: "true"
|
||||
|
||||
|
||||
com.centurylinklabs.watchtower.enable: 'true'
|
||||
|
|
|
@ -1,75 +1,76 @@
|
|||
---
|
||||
- name: upload vhost config for cloud.data.coop
|
||||
template:
|
||||
ansible.builtin.template:
|
||||
src: files/configs/nextcloud/vhost
|
||||
dest: "{{ services.nginx_proxy.volume_folder }}/vhost/{{ services.nextcloud.domain }}"
|
||||
notify: "restart nginx"
|
||||
dest: '{{ services.nginx_proxy.volume_folder }}/vhost/{{ services.nextcloud.domain
|
||||
}}'
|
||||
notify: restart nginx
|
||||
|
||||
- name: setup nextcloud containers
|
||||
docker_compose:
|
||||
project_name: "nextcloud"
|
||||
pull: "yes"
|
||||
community.docker.docker_compose:
|
||||
project_name: nextcloud
|
||||
pull: true
|
||||
definition:
|
||||
services:
|
||||
postgres:
|
||||
image: "postgres:10"
|
||||
restart: "unless-stopped"
|
||||
image: postgres:10
|
||||
restart: unless-stopped
|
||||
networks:
|
||||
- "nextcloud"
|
||||
- nextcloud
|
||||
volumes:
|
||||
- "{{ services.nextcloud.volume_folder }}/postgres:/var/lib/postgresql/data"
|
||||
environment:
|
||||
POSTGRES_DB: "nextcloud"
|
||||
POSTGRES_PASSWORD: "{{ postgres_passwords.nextcloud }}"
|
||||
POSTGRES_USER: "nextcloud"
|
||||
- '{{ services.nextcloud.volume_folder }}/postgres:/var/lib/postgresql/data'
|
||||
environment:
|
||||
POSTGRES_DB: nextcloud
|
||||
POSTGRES_PASSWORD: '{{ postgres_passwords.nextcloud }}'
|
||||
POSTGRES_USER: nextcloud
|
||||
|
||||
redis:
|
||||
image: "redis:7-alpine"
|
||||
restart: "unless-stopped"
|
||||
command: "redis-server --requirepass {{ nextcloud_secrets.redis_password }}"
|
||||
image: redis:7-alpine
|
||||
restart: unless-stopped
|
||||
command: redis-server --requirepass {{ nextcloud_secrets.redis_password
|
||||
}}
|
||||
tmpfs:
|
||||
- /var/lib/redis
|
||||
networks:
|
||||
- "nextcloud"
|
||||
- nextcloud
|
||||
|
||||
cron:
|
||||
image: "nextcloud:{{ services.nextcloud.version }}"
|
||||
restart: "unless-stopped"
|
||||
entrypoint: "/cron.sh"
|
||||
image: nextcloud:{{ services.nextcloud.version }}
|
||||
restart: unless-stopped
|
||||
entrypoint: /cron.sh
|
||||
networks:
|
||||
- "nextcloud"
|
||||
- nextcloud
|
||||
volumes:
|
||||
- "{{ services.nextcloud.volume_folder }}/app:/var/www/html"
|
||||
- '{{ services.nextcloud.volume_folder }}/app:/var/www/html'
|
||||
depends_on:
|
||||
- "postgres"
|
||||
- "redis"
|
||||
|
||||
- postgres
|
||||
- redis
|
||||
app:
|
||||
image: "nextcloud:{{ services.nextcloud.version }}"
|
||||
restart: "unless-stopped"
|
||||
image: nextcloud:{{ services.nextcloud.version }}
|
||||
restart: unless-stopped
|
||||
networks:
|
||||
- "nextcloud"
|
||||
- "postfix"
|
||||
- "external_services"
|
||||
- nextcloud
|
||||
- postfix
|
||||
- external_services
|
||||
volumes:
|
||||
- "{{ services.nextcloud.volume_folder }}/app:/var/www/html"
|
||||
- '{{ services.nextcloud.volume_folder }}/app:/var/www/html'
|
||||
environment:
|
||||
VIRTUAL_HOST: "{{ services.nextcloud.domain }}"
|
||||
LETSENCRYPT_HOST: "{{ services.nextcloud.domain }}"
|
||||
LETSENCRYPT_EMAIL: "{{ letsencrypt_email }}"
|
||||
POSTGRES_HOST: "postgres"
|
||||
POSTGRES_DB: "nextcloud"
|
||||
POSTGRES_USER: "nextcloud"
|
||||
POSTGRES_PASSWORD: "{{ postgres_passwords.nextcloud }}"
|
||||
REDIS_HOST: "redis"
|
||||
REDIS_HOST_PASSWORD: "{{ nextcloud_secrets.redis_password }}"
|
||||
VIRTUAL_HOST: '{{ services.nextcloud.domain }}'
|
||||
LETSENCRYPT_HOST: '{{ services.nextcloud.domain }}'
|
||||
LETSENCRYPT_EMAIL: '{{ letsencrypt_email }}'
|
||||
POSTGRES_HOST: postgres
|
||||
POSTGRES_DB: nextcloud
|
||||
POSTGRES_USER: nextcloud
|
||||
POSTGRES_PASSWORD: '{{ postgres_passwords.nextcloud }}'
|
||||
REDIS_HOST: redis
|
||||
REDIS_HOST_PASSWORD: '{{ nextcloud_secrets.redis_password }}'
|
||||
depends_on:
|
||||
- "postgres"
|
||||
- "redis"
|
||||
- postgres
|
||||
- redis
|
||||
|
||||
networks:
|
||||
nextcloud:
|
||||
postfix:
|
||||
external: true
|
||||
external_services:
|
||||
external: true
|
||||
nextcloud:
|
||||
postfix:
|
||||
external: true
|
||||
external_services:
|
||||
external: true
|
||||
|
|
|
@ -1,8 +1,8 @@
|
|||
---
|
||||
|
||||
- name: create nginx-proxy volume folders
|
||||
file:
|
||||
name: "{{ services.nginx_proxy.volume_folder }}/{{ volume }}"
|
||||
ansible.builtin.file:
|
||||
name: '{{ services.nginx_proxy.volume_folder }}/{{ volume }}'
|
||||
state: directory
|
||||
loop:
|
||||
- conf
|
||||
|
@ -14,35 +14,34 @@
|
|||
loop_var: volume
|
||||
|
||||
- name: nginx proxy container
|
||||
docker_container:
|
||||
community.docker.docker_container:
|
||||
name: nginx-proxy
|
||||
image: nginxproxy/nginx-proxy:{{ services.nginx_proxy.version }}
|
||||
restart_policy: always
|
||||
networks:
|
||||
- name: external_services
|
||||
published_ports:
|
||||
- "80:80"
|
||||
- "443:443"
|
||||
- 80:80
|
||||
- 443:443
|
||||
volumes:
|
||||
- "{{ services.nginx_proxy.volume_folder }}/conf:/etc/nginx/conf.d"
|
||||
- "{{ services.nginx_proxy.volume_folder }}/vhost:/etc/nginx/vhost.d"
|
||||
- "{{ services.nginx_proxy.volume_folder }}/html:/usr/share/nginx/html"
|
||||
- "{{ services.nginx_proxy.volume_folder }}/dhparam:/etc/nginx/dhparam"
|
||||
- "{{ services.nginx_proxy.volume_folder }}/certs:/etc/nginx/certs:ro"
|
||||
- '{{ services.nginx_proxy.volume_folder }}/conf:/etc/nginx/conf.d'
|
||||
- '{{ services.nginx_proxy.volume_folder }}/vhost:/etc/nginx/vhost.d'
|
||||
- '{{ services.nginx_proxy.volume_folder }}/html:/usr/share/nginx/html'
|
||||
- '{{ services.nginx_proxy.volume_folder }}/dhparam:/etc/nginx/dhparam'
|
||||
- '{{ services.nginx_proxy.volume_folder }}/certs:/etc/nginx/certs:ro'
|
||||
- /var/run/docker.sock:/tmp/docker.sock:ro
|
||||
|
||||
- name: nginx letsencrypt container
|
||||
docker_container:
|
||||
community.docker.docker_container:
|
||||
name: nginx-proxy-le
|
||||
image: nginxproxy/acme-companion:{{ services.nginx_acme_companion.version }}
|
||||
restart_policy: always
|
||||
volumes:
|
||||
- "{{ services.nginx_proxy.volume_folder }}/vhost:/etc/nginx/vhost.d"
|
||||
- "{{ services.nginx_proxy.volume_folder }}/html:/usr/share/nginx/html"
|
||||
- "{{ services.nginx_proxy.volume_folder }}/dhparam:/etc/nginx/dhparam:ro"
|
||||
- "{{ services.nginx_proxy.volume_folder }}/certs:/etc/nginx/certs"
|
||||
- '{{ services.nginx_proxy.volume_folder }}/vhost:/etc/nginx/vhost.d'
|
||||
- '{{ services.nginx_proxy.volume_folder }}/html:/usr/share/nginx/html'
|
||||
- '{{ services.nginx_proxy.volume_folder }}/dhparam:/etc/nginx/dhparam:ro'
|
||||
- '{{ services.nginx_proxy.volume_folder }}/certs:/etc/nginx/certs'
|
||||
- /var/run/docker.sock:/var/run/docker.sock:ro
|
||||
env:
|
||||
NGINX_PROXY_CONTAINER: nginx-proxy
|
||||
when: letsencrypt_enabled
|
||||
|
||||
|
|
|
@ -1,62 +1,62 @@
|
|||
---
|
||||
- name: create ldap volume folders
|
||||
file:
|
||||
name: "{{ services.openldap.volume_folder }}/{{ volume }}"
|
||||
ansible.builtin.file:
|
||||
name: '{{ services.openldap.volume_folder }}/{{ volume }}'
|
||||
state: directory
|
||||
loop:
|
||||
- "var/lib/ldap"
|
||||
- "etc/slapd"
|
||||
- "certs"
|
||||
- var/lib/ldap
|
||||
- etc/slapd
|
||||
- certs
|
||||
loop_control:
|
||||
loop_var: volume
|
||||
|
||||
- name: Create a network for ldap
|
||||
docker_network:
|
||||
community.docker.docker_network:
|
||||
name: ldap
|
||||
|
||||
- name: openLDAP container
|
||||
docker_container:
|
||||
community.docker.docker_container:
|
||||
name: openldap
|
||||
image: osixia/openldap:{{ services.openldap.version }}
|
||||
tty: true
|
||||
interactive: true
|
||||
restart_policy: unless-stopped
|
||||
volumes:
|
||||
- "{{ services.openldap.volume_folder }}/var/lib/ldap:/var/lib/ldap"
|
||||
- "{{ services.openldap.volume_folder }}/etc/slapd.d:/etc/ldap/slapd.d"
|
||||
- "{{ services.openldap.volume_folder }}/certs:/container/service/slapd/assets/certs/"
|
||||
- '{{ services.openldap.volume_folder }}/var/lib/ldap:/var/lib/ldap'
|
||||
- '{{ services.openldap.volume_folder }}/etc/slapd.d:/etc/ldap/slapd.d'
|
||||
- '{{ services.openldap.volume_folder }}/certs:/container/service/slapd/assets/certs/'
|
||||
published_ports:
|
||||
- "389:389"
|
||||
- "636:636"
|
||||
hostname: "{{ services.openldap.domain }}"
|
||||
domainname: "{{ services.openldap.domain }}" # important: same as hostname
|
||||
- 389:389
|
||||
- 636:636
|
||||
hostname: '{{ services.openldap.domain }}'
|
||||
domainname: '{{ services.openldap.domain }}' # important: same as hostname
|
||||
networks:
|
||||
- name: ldap
|
||||
env:
|
||||
LDAP_LOG_LEVEL: "256"
|
||||
LDAP_ORGANISATION: "{{ base_domain }}"
|
||||
LDAP_DOMAIN: "{{ base_domain }}"
|
||||
LDAP_BASE_DN: ""
|
||||
LDAP_ADMIN_PASSWORD: "{{ ldap_admin_password }}"
|
||||
LDAP_CONFIG_PASSWORD: "{{ ldap_config_password }}"
|
||||
LDAP_READONLY_USER: "false"
|
||||
LDAP_RFC2307BIS_SCHEMA: "false"
|
||||
LDAP_BACKEND: "mdb"
|
||||
LDAP_TLS: "true"
|
||||
LDAP_TLS_CRT_FILENAME: "ldap.crt"
|
||||
LDAP_TLS_KEY_FILENAME: "ldap.key"
|
||||
LDAP_TLS_CA_CRT_FILENAME: "ca.crt"
|
||||
LDAP_TLS_ENFORCE: "false"
|
||||
LDAP_TLS_CIPHER_SUITE: "SECURE256:-VERS-SSL3.0"
|
||||
LDAP_TLS_PROTOCOL_MIN: "3.1"
|
||||
LDAP_TLS_VERIFY_CLIENT: "demand"
|
||||
LDAP_REPLICATION: "false"
|
||||
KEEP_EXISTING_CONFIG: "false"
|
||||
LDAP_REMOVE_CONFIG_AFTER_SETUP: "true"
|
||||
LDAP_SSL_HELPER_PREFIX: "ldap"
|
||||
LDAP_LOG_LEVEL: '256'
|
||||
LDAP_ORGANISATION: '{{ base_domain }}'
|
||||
LDAP_DOMAIN: '{{ base_domain }}'
|
||||
LDAP_BASE_DN: ''
|
||||
LDAP_ADMIN_PASSWORD: '{{ ldap_admin_password }}'
|
||||
LDAP_CONFIG_PASSWORD: '{{ ldap_config_password }}'
|
||||
LDAP_READONLY_USER: 'false'
|
||||
LDAP_RFC2307BIS_SCHEMA: 'false'
|
||||
LDAP_BACKEND: mdb
|
||||
LDAP_TLS: 'true'
|
||||
LDAP_TLS_CRT_FILENAME: ldap.crt
|
||||
LDAP_TLS_KEY_FILENAME: ldap.key
|
||||
LDAP_TLS_CA_CRT_FILENAME: ca.crt
|
||||
LDAP_TLS_ENFORCE: 'false'
|
||||
LDAP_TLS_CIPHER_SUITE: SECURE256:-VERS-SSL3.0
|
||||
LDAP_TLS_PROTOCOL_MIN: '3.1'
|
||||
LDAP_TLS_VERIFY_CLIENT: demand
|
||||
LDAP_REPLICATION: 'false'
|
||||
KEEP_EXISTING_CONFIG: 'false'
|
||||
LDAP_REMOVE_CONFIG_AFTER_SETUP: 'true'
|
||||
LDAP_SSL_HELPER_PREFIX: ldap
|
||||
|
||||
- name: phpLDAPadmin container
|
||||
docker_container:
|
||||
community.docker.docker_container:
|
||||
name: phpldapadmin
|
||||
image: osixia/phpldapadmin:{{ services.phpldapadmin.version }}
|
||||
restart_policy: unless-stopped
|
||||
|
@ -64,10 +64,10 @@
|
|||
- name: external_services
|
||||
- name: ldap
|
||||
env:
|
||||
PHPLDAPADMIN_LDAP_HOSTS: "openldap"
|
||||
PHPLDAPADMIN_HTTPS: "false"
|
||||
PHPLDAPADMIN_TRUST_PROXY_SSL: "true"
|
||||
PHPLDAPADMIN_LDAP_HOSTS: openldap
|
||||
PHPLDAPADMIN_HTTPS: 'false'
|
||||
PHPLDAPADMIN_TRUST_PROXY_SSL: 'true'
|
||||
|
||||
VIRTUAL_HOST: "{{ services.openldap.domain }}"
|
||||
LETSENCRYPT_HOST: "{{ services.openldap.domain }}"
|
||||
LETSENCRYPT_EMAIL: "{{ letsencrypt_email }}"
|
||||
VIRTUAL_HOST: '{{ services.openldap.domain }}'
|
||||
LETSENCRYPT_HOST: '{{ services.openldap.domain }}'
|
||||
LETSENCRYPT_EMAIL: '{{ letsencrypt_email }}'
|
||||
|
|
|
@ -1,42 +1,42 @@
|
|||
---
|
||||
|
||||
- name: setup passit containers
|
||||
docker_compose:
|
||||
project_name: "passit"
|
||||
pull: "yes"
|
||||
community.docker.docker_compose:
|
||||
project_name: passit
|
||||
pull: true
|
||||
definition:
|
||||
version: "3.6"
|
||||
version: '3.6'
|
||||
services:
|
||||
passit_db:
|
||||
image: "postgres:10"
|
||||
restart: "always"
|
||||
image: postgres:10
|
||||
restart: always
|
||||
networks:
|
||||
- "passit"
|
||||
- passit
|
||||
volumes:
|
||||
- "{{ services.passit.volume_folder }}/data:/var/lib/postgresql/data"
|
||||
- '{{ services.passit.volume_folder }}/data:/var/lib/postgresql/data'
|
||||
environment:
|
||||
POSTGRES_USER: "passit"
|
||||
POSTGRES_PASSWORD: "{{ postgres_passwords.passit }}"
|
||||
POSTGRES_USER: passit
|
||||
POSTGRES_PASSWORD: '{{ postgres_passwords.passit }}'
|
||||
|
||||
passit_app:
|
||||
image: "passit/passit:{{ services.passit.version }}"
|
||||
command: "bin/start.sh"
|
||||
restart: "always"
|
||||
image: passit/passit:{{ services.passit.version }}
|
||||
command: bin/start.sh
|
||||
restart: always
|
||||
networks:
|
||||
- "passit"
|
||||
- "postfix"
|
||||
- "external_services"
|
||||
- passit
|
||||
- postfix
|
||||
- external_services
|
||||
environment:
|
||||
DATABASE_URL: "postgres://passit:{{ postgres_passwords.passit }}@passit_db:5432/passit"
|
||||
SECRET_KEY: "{{ passit_secret_key }}"
|
||||
DATABASE_URL: postgres://passit:{{ postgres_passwords.passit }}@passit_db:5432/passit
|
||||
SECRET_KEY: '{{ passit_secret_key }}'
|
||||
IS_DEBUG: 'False'
|
||||
EMAIL_URL: "smtp://noop@{{ smtp_host }}:{{ smtp_port }}"
|
||||
DEFAULT_FROM_EMAIL: "noreply@{{ services.passit.domain }}"
|
||||
EMAIL_CONFIRMATION_HOST: "https://{{ services.passit.domain }}"
|
||||
FIDO_SERVER_ID: "{{ services.passit.domain }}"
|
||||
VIRTUAL_HOST: "{{ services.passit.domain }}"
|
||||
LETSENCRYPT_HOST: "{{ services.passit.domain }}"
|
||||
LETSENCRYPT_EMAIL: "{{ letsencrypt_email }}"
|
||||
EMAIL_URL: smtp://noop@{{ smtp_host }}:{{ smtp_port }}
|
||||
DEFAULT_FROM_EMAIL: noreply@{{ services.passit.domain }}
|
||||
EMAIL_CONFIRMATION_HOST: https://{{ services.passit.domain }}
|
||||
FIDO_SERVER_ID: '{{ services.passit.domain }}'
|
||||
VIRTUAL_HOST: '{{ services.passit.domain }}'
|
||||
LETSENCRYPT_HOST: '{{ services.passit.domain }}'
|
||||
LETSENCRYPT_EMAIL: '{{ letsencrypt_email }}'
|
||||
|
||||
networks:
|
||||
passit:
|
||||
|
|
|
@ -1,12 +1,12 @@
|
|||
---
|
||||
|
||||
- name: create portainer volume folder
|
||||
file:
|
||||
name: "{{ services.portainer.volume_folder }}"
|
||||
ansible.builtin.file:
|
||||
name: '{{ services.portainer.volume_folder }}'
|
||||
state: directory
|
||||
|
||||
- name: run portainer
|
||||
docker_container:
|
||||
community.docker.docker_container:
|
||||
name: portainer
|
||||
image: portainer/portainer-ee:{{ services.portainer.version }}
|
||||
restart_policy: always
|
||||
|
@ -14,9 +14,9 @@
|
|||
- name: external_services
|
||||
volumes:
|
||||
- /var/run/docker.sock:/var/run/docker.sock
|
||||
- "{{ services.portainer.volume_folder }}:/data"
|
||||
- '{{ services.portainer.volume_folder }}:/data'
|
||||
env:
|
||||
VIRTUAL_HOST: "{{ services.portainer.domain }}"
|
||||
VIRTUAL_PORT: "9000"
|
||||
LETSENCRYPT_HOST: "{{ services.portainer.domain }}"
|
||||
LETSENCRYPT_EMAIL: "{{ letsencrypt_email }}"
|
||||
VIRTUAL_HOST: '{{ services.portainer.domain }}'
|
||||
VIRTUAL_PORT: '9000'
|
||||
LETSENCRYPT_HOST: '{{ services.portainer.domain }}'
|
||||
LETSENCRYPT_EMAIL: '{{ letsencrypt_email }}'
|
||||
|
|
|
@ -1,20 +1,21 @@
|
|||
---
|
||||
|
||||
- name: setup network for postfix
|
||||
docker_network:
|
||||
community.docker.docker_network:
|
||||
name: postfix
|
||||
ipam_config:
|
||||
- subnet: '172.16.0.0/16'
|
||||
- subnet: 172.16.0.0/16
|
||||
gateway: 172.16.0.1
|
||||
|
||||
- name: setup postfix docker container for outgoing mail
|
||||
docker_container:
|
||||
community.docker.docker_container:
|
||||
name: postfix
|
||||
image: boky/postfix:{{ services.postfix.version }}
|
||||
restart_policy: always
|
||||
networks:
|
||||
- name: postfix
|
||||
env:
|
||||
# Get all services which have allowed_sender_domain defined
|
||||
ALLOWED_SENDER_DOMAINS: "{{ services | dict2items | selectattr('value.allowed_sender_domain', 'defined') | map(attribute='value.domain') | list | join(' ') }}"
|
||||
HOSTNAME: "smtp.data.coop" # the name the smtp server will identify itself as
|
||||
# Get all services which have allowed_sender_domain defined
|
||||
ALLOWED_SENDER_DOMAINS: "{{ services | dict2items | selectattr('value.allowed_sender_domain',\
|
||||
\ 'defined') | map(attribute='value.domain') | list | join(' ') }}"
|
||||
HOSTNAME: smtp.data.coop # the name the smtp server will identify itself as
|
||||
|
|
|
@ -1,8 +1,8 @@
|
|||
---
|
||||
|
||||
- name: create privatebin volume folders
|
||||
file:
|
||||
name: "{{ services.privatebin.volume_folder }}/{{ volume }}"
|
||||
ansible.builtin.file:
|
||||
name: '{{ services.privatebin.volume_folder }}/{{ volume }}'
|
||||
state: directory
|
||||
loop:
|
||||
- cfg
|
||||
|
@ -11,21 +11,21 @@
|
|||
loop_var: volume
|
||||
|
||||
- name: upload privatebin config
|
||||
template:
|
||||
ansible.builtin.template:
|
||||
src: files/configs/privatebin-conf.php
|
||||
dest: "{{ services.privatebin.volume_folder }}/cfg/conf.php"
|
||||
dest: '{{ services.privatebin.volume_folder }}/cfg/conf.php'
|
||||
|
||||
- name: privatebin app container
|
||||
docker_container:
|
||||
community.docker.docker_container:
|
||||
name: privatebin
|
||||
image: jgeusebroek/privatebin:{{ services.privatebin.version }}
|
||||
restart_policy: unless-stopped
|
||||
volumes:
|
||||
- "{{ services.privatebin.volume_folder }}/cfg:/privatebin/cfg"
|
||||
- "{{ services.privatebin.volume_folder }}/data:/privatebin/data"
|
||||
- '{{ services.privatebin.volume_folder }}/cfg:/privatebin/cfg'
|
||||
- '{{ services.privatebin.volume_folder }}/data:/privatebin/data'
|
||||
networks:
|
||||
- name: external_services
|
||||
env:
|
||||
VIRTUAL_HOST: "{{ services.privatebin.domain }}"
|
||||
LETSENCRYPT_HOST: "{{ services.privatebin.domain }}"
|
||||
LETSENCRYPT_EMAIL: "{{ letsencrypt_email }}"
|
||||
VIRTUAL_HOST: '{{ services.privatebin.domain }}'
|
||||
LETSENCRYPT_HOST: '{{ services.privatebin.domain }}'
|
||||
LETSENCRYPT_EMAIL: '{{ letsencrypt_email }}'
|
||||
|
|
|
@ -1,58 +1,59 @@
|
|||
---
|
||||
- name: Create rallly volume folders
|
||||
file:
|
||||
name: "{{ services.rallly.volume_folder }}/postgres"
|
||||
ansible.builtin.file:
|
||||
name: '{{ services.rallly.volume_folder }}/postgres'
|
||||
state: directory
|
||||
|
||||
- name: Copy Rallly environment file
|
||||
template:
|
||||
ansible.builtin.template:
|
||||
src: files/configs/rallly/env_file.j2
|
||||
dest: "{{ services.rallly.volume_folder }}/env_file"
|
||||
dest: '{{ services.rallly.volume_folder }}/env_file'
|
||||
|
||||
- name: Set up Rallly
|
||||
docker_compose:
|
||||
project_name: "rallly"
|
||||
pull: "yes"
|
||||
community.docker.docker_compose:
|
||||
project_name: rallly
|
||||
pull: true
|
||||
definition:
|
||||
version: "3.8"
|
||||
version: '3.8'
|
||||
services:
|
||||
rallly_db:
|
||||
image: "postgres:14-alpine"
|
||||
restart: "always"
|
||||
shm_size: "256mb"
|
||||
image: postgres:14-alpine
|
||||
restart: always
|
||||
shm_size: 256mb
|
||||
networks:
|
||||
rallly_internal:
|
||||
volumes:
|
||||
- "{{ services.rallly.volume_folder }}/postgres:/var/lib/postgresql/data"
|
||||
- '{{ services.rallly.volume_folder }}/postgres:/var/lib/postgresql/data'
|
||||
environment:
|
||||
POSTGRES_PASSWORD: "{{ postgres_passwords.rallly }}"
|
||||
POSTGRES_DB: "rallly_db"
|
||||
POSTGRES_PASSWORD: '{{ postgres_passwords.rallly }}'
|
||||
POSTGRES_DB: rallly_db
|
||||
healthcheck:
|
||||
test: ["CMD-SHELL", "pg_isready -U postgres"]
|
||||
test: [CMD-SHELL, pg_isready -U postgres]
|
||||
interval: 5s
|
||||
timeout: 5s
|
||||
retries: 5
|
||||
labels:
|
||||
com.centurylinklabs.watchtower.enable: "true"
|
||||
com.centurylinklabs.watchtower.enable: 'true'
|
||||
|
||||
rallly:
|
||||
image: "lukevella/rallly:{{ services.rallly.version }}"
|
||||
restart: "always"
|
||||
image: lukevella/rallly:{{ services.rallly.version }}
|
||||
restart: always
|
||||
networks:
|
||||
rallly_internal:
|
||||
external_services:
|
||||
postfix:
|
||||
depends_on:
|
||||
rallly_db:
|
||||
condition: "service_healthy"
|
||||
condition: service_healthy
|
||||
env_file:
|
||||
- "{{ services.rallly.volume_folder }}/env_file"
|
||||
- '{{ services.rallly.volume_folder }}/env_file'
|
||||
environment:
|
||||
VIRTUAL_HOST: "{{ services.rallly.domain }}"
|
||||
VIRTUAL_PORT: "3000"
|
||||
LETSENCRYPT_HOST: "{{ services.rallly.domain }}"
|
||||
LETSENCRYPT_EMAIL: "{{ letsencrypt_email }}"
|
||||
VIRTUAL_HOST: '{{ services.rallly.domain }}'
|
||||
VIRTUAL_PORT: '3000'
|
||||
LETSENCRYPT_HOST: '{{ services.rallly.domain }}'
|
||||
LETSENCRYPT_EMAIL: '{{ letsencrypt_email }}'
|
||||
labels:
|
||||
com.centurylinklabs.watchtower.enable: "true"
|
||||
com.centurylinklabs.watchtower.enable: 'true'
|
||||
|
||||
networks:
|
||||
rallly_internal:
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
---
|
||||
- name: Setup restic backup
|
||||
docker_compose:
|
||||
community.docker.docker_compose:
|
||||
project_name: restic_backup
|
||||
pull: true
|
||||
definition:
|
||||
|
@ -10,11 +10,12 @@
|
|||
image: mazzolino/restic:{{ services.restic.version }}
|
||||
restart: always
|
||||
environment:
|
||||
RUN_ON_STARTUP: "true"
|
||||
BACKUP_CRON: "0 30 3 * * *"
|
||||
RESTIC_REPOSITORY: "rest:https://{{ services.restic.user }}:{{ restic_secrets.user_password }}@{{ services.restic.domain }}/{{ services.restic.repository }}"
|
||||
RESTIC_PASSWORD: "{{ restic_secrets.repository_password }}"
|
||||
RESTIC_BACKUP_SOURCES: "/mnt/volumes"
|
||||
RUN_ON_STARTUP: 'true'
|
||||
BACKUP_CRON: 0 30 3 * * *
|
||||
RESTIC_REPOSITORY: rest:https://{{ services.restic.user }}:{{ restic_secrets.user_password
|
||||
}}@{{ services.restic.domain }}/{{ services.restic.repository }}
|
||||
RESTIC_PASSWORD: '{{ restic_secrets.repository_password }}'
|
||||
RESTIC_BACKUP_SOURCES: /mnt/volumes
|
||||
RESTIC_BACKUP_ARGS: >-
|
||||
--tag datacoop-volumes
|
||||
--exclude='*.tmp'
|
||||
|
@ -29,10 +30,11 @@
|
|||
- /docker-volumes:/mnt/volumes:ro
|
||||
|
||||
restic-prune:
|
||||
image: "mazzolino/restic:{{ services.restic.version }}"
|
||||
image: mazzolino/restic:{{ services.restic.version }}
|
||||
environment:
|
||||
RUN_ON_STARTUP: "true"
|
||||
PRUNE_CRON: "0 0 4 * * *"
|
||||
RESTIC_REPOSITORY: "rest:https://{{ services.restic.user }}:{{ restic_secrets.user_password }}@{{ services.restic.domain }}/{{ services.restic.repository }}"
|
||||
RESTIC_PASSWORD: "{{ restic_secrets.repository_password }}"
|
||||
RUN_ON_STARTUP: 'true'
|
||||
PRUNE_CRON: 0 0 4 * * *
|
||||
RESTIC_REPOSITORY: rest:https://{{ services.restic.user }}:{{ restic_secrets.user_password
|
||||
}}@{{ services.restic.domain }}/{{ services.restic.repository }}
|
||||
RESTIC_PASSWORD: '{{ restic_secrets.repository_password }}'
|
||||
TZ: Europe/copenhagen
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
---
|
||||
- name: watchtower container
|
||||
docker_container:
|
||||
community.docker.docker_container:
|
||||
name: watchtower
|
||||
image: containrrr/watchtower:1.4.0
|
||||
restart_policy: unless-stopped
|
||||
|
@ -8,7 +8,7 @@
|
|||
- name: external_services
|
||||
volumes:
|
||||
- /var/run/docker.sock:/var/run/docker.sock
|
||||
- "{{ services.docker_registry.volume_folder }}/auth/config.json:/config.json"
|
||||
- '{{ services.docker_registry.volume_folder }}/auth/config.json:/config.json'
|
||||
env:
|
||||
WATCHTOWER_LABEL_ENABLE: "true"
|
||||
WATCHTOWER_POLL_INTERVAL: "60"
|
||||
WATCHTOWER_LABEL_ENABLE: 'true'
|
||||
WATCHTOWER_POLL_INTERVAL: '60'
|
||||
|
|
|
@ -1,23 +1,24 @@
|
|||
---
|
||||
|
||||
- name: setup 2022.slides.data.coop website using unipi
|
||||
docker_container:
|
||||
community.docker.docker_container:
|
||||
name: 2022.slides.data.coop_website
|
||||
image: docker.data.coop/unipi:latest
|
||||
restart_policy: unless-stopped
|
||||
purge_networks: yes
|
||||
purge_networks: true
|
||||
networks:
|
||||
- name: external_services
|
||||
env:
|
||||
VIRTUAL_HOST: "2022.slides.{{ services.data_coop_website.domains|join(',') }}"
|
||||
LETSENCRYPT_HOST: "2022.slides.{{ services.data_coop_website.domains|join(',') }}"
|
||||
LETSENCRYPT_EMAIL: "{{ letsencrypt_email }}"
|
||||
# Temporarily hosting on github
|
||||
command: "--remote=https://github.com/sorbusursina/datacoop-slides.git#slides2022"
|
||||
VIRTUAL_HOST: 2022.slides.{{ services.data_coop_website.domains|join(',')
|
||||
}}
|
||||
LETSENCRYPT_HOST: 2022.slides.{{ services.data_coop_website.domains|join(',')
|
||||
}}
|
||||
LETSENCRYPT_EMAIL: '{{ letsencrypt_email }}'
|
||||
# Temporarily hosting on github
|
||||
command: --remote=https://github.com/sorbusursina/datacoop-slides.git#slides2022
|
||||
capabilities:
|
||||
- NET_ADMIN
|
||||
devices:
|
||||
- "/dev/net/tun"
|
||||
- /dev/net/tun
|
||||
labels:
|
||||
com.centurylinklabs.watchtower.enable: "true"
|
||||
|
||||
com.centurylinklabs.watchtower.enable: 'true'
|
||||
|
|
|
@ -1,15 +1,15 @@
|
|||
---
|
||||
|
||||
- name: setup cryptoaarhus.dk website docker container
|
||||
docker_container:
|
||||
community.docker.docker_container:
|
||||
name: cryptoaarhus_website
|
||||
restart_policy: unless-stopped
|
||||
image: docker.data.coop/cryptoaarhus-website
|
||||
networks:
|
||||
- name: external_services
|
||||
env:
|
||||
VIRTUAL_HOST : "{{ services.cryptoaarhus_website.domains|join(',') }}"
|
||||
VIRTUAL_HOST: "{{ services.cryptoaarhus_website.domains|join(',') }}"
|
||||
LETSENCRYPT_HOST: "{{ services.cryptoaarhus_website.domains|join(',') }}"
|
||||
LETSENCRYPT_EMAIL: "{{ letsencrypt_email }}"
|
||||
LETSENCRYPT_EMAIL: '{{ letsencrypt_email }}'
|
||||
labels:
|
||||
com.centurylinklabs.watchtower.enable: "true"
|
||||
com.centurylinklabs.watchtower.enable: 'true'
|
||||
|
|
|
@ -1,15 +1,15 @@
|
|||
---
|
||||
|
||||
- name: setup cryptohagen.dk website docker container
|
||||
docker_container:
|
||||
community.docker.docker_container:
|
||||
name: cryptohagen_website
|
||||
restart_policy: unless-stopped
|
||||
image: docker.data.coop/cryptohagen-website
|
||||
networks:
|
||||
- name: external_services
|
||||
env:
|
||||
VIRTUAL_HOST : "{{ services.cryptohagen_website.domains|join(',') }}"
|
||||
VIRTUAL_HOST: "{{ services.cryptohagen_website.domains|join(',') }}"
|
||||
LETSENCRYPT_HOST: "{{ services.cryptohagen_website.domains|join(',') }}"
|
||||
LETSENCRYPT_EMAIL: "{{ letsencrypt_email }}"
|
||||
LETSENCRYPT_EMAIL: '{{ letsencrypt_email }}'
|
||||
labels:
|
||||
com.centurylinklabs.watchtower.enable: "true"
|
||||
com.centurylinklabs.watchtower.enable: 'true'
|
||||
|
|
|
@ -1,15 +1,15 @@
|
|||
---
|
||||
|
||||
- name: setup data.coop website docker container
|
||||
docker_container:
|
||||
community.docker.docker_container:
|
||||
name: data.coop_website
|
||||
image: docker.data.coop/data-coop-website
|
||||
restart_policy: unless-stopped
|
||||
networks:
|
||||
- name: external_services
|
||||
env:
|
||||
VIRTUAL_HOST : "{{ services.data_coop_website.domains|join(',') }}"
|
||||
VIRTUAL_HOST: "{{ services.data_coop_website.domains|join(',') }}"
|
||||
LETSENCRYPT_HOST: "{{ services.data_coop_website.domains|join(',') }}"
|
||||
LETSENCRYPT_EMAIL: "{{ letsencrypt_email }}"
|
||||
LETSENCRYPT_EMAIL: '{{ letsencrypt_email }}'
|
||||
labels:
|
||||
com.centurylinklabs.watchtower.enable: "true"
|
||||
com.centurylinklabs.watchtower.enable: 'true'
|
||||
|
|
|
@ -1,21 +1,23 @@
|
|||
---
|
||||
- name: setup new-new data.coop website using unipi
|
||||
docker_container:
|
||||
community.docker.docker_container:
|
||||
name: new-new.data.coop_website
|
||||
image: docker.data.coop/unipi:latest
|
||||
restart_policy: unless-stopped
|
||||
purge_networks: yes
|
||||
purge_networks: true
|
||||
networks:
|
||||
- name: external_services
|
||||
env:
|
||||
VIRTUAL_HOST: "new-new.{{ services.data_coop_website.domains|join(',') }}"
|
||||
LETSENCRYPT_HOST: "new-new.{{ services.data_coop_website.domains|join(',') }}"
|
||||
LETSENCRYPT_EMAIL: "{{ letsencrypt_email }}"
|
||||
# The ssh-key is for read-only only
|
||||
command: "--remote=git@git.data.coop:halfd/new-website.git#main --ssh-key ed25519:Ag9RekCyC2eow4P/e5crVvSTQ7dTK46WkG0wqEPVJbU= --ssh-authenticator SHA256:l9kdLkb0kJm46pOJ4tCHCtFUaqV1ImbZWMA5oje10fI"
|
||||
VIRTUAL_HOST: new-new.{{ services.data_coop_website.domains|join(',') }}
|
||||
LETSENCRYPT_HOST: new-new.{{ services.data_coop_website.domains|join(',')
|
||||
}}
|
||||
LETSENCRYPT_EMAIL: '{{ letsencrypt_email }}'
|
||||
# The ssh-key is for read-only only
|
||||
command: --remote=git@git.data.coop:halfd/new-website.git#main --ssh-key ed25519:Ag9RekCyC2eow4P/e5crVvSTQ7dTK46WkG0wqEPVJbU=
|
||||
--ssh-authenticator SHA256:l9kdLkb0kJm46pOJ4tCHCtFUaqV1ImbZWMA5oje10fI
|
||||
capabilities:
|
||||
- NET_ADMIN
|
||||
devices:
|
||||
- "/dev/net/tun"
|
||||
- /dev/net/tun
|
||||
labels:
|
||||
com.centurylinklabs.watchtower.enable: "true"
|
||||
|
||||
com.centurylinklabs.watchtower.enable: 'true'
|
||||
|
|
|
@ -1,15 +1,15 @@
|
|||
---
|
||||
|
||||
- name: setup new data.coop website using hugo
|
||||
docker_container:
|
||||
community.docker.docker_container:
|
||||
name: new.data.coop_website
|
||||
image: docker.data.coop/data-coop-website:hugo
|
||||
restart_policy: unless-stopped
|
||||
networks:
|
||||
- name: external_services
|
||||
env:
|
||||
VIRTUAL_HOST : "new.{{ services.data_coop_website.domains|join(',') }}"
|
||||
LETSENCRYPT_HOST: "new.{{ services.data_coop_website.domains|join(',') }}"
|
||||
LETSENCRYPT_EMAIL: "{{ letsencrypt_email }}"
|
||||
VIRTUAL_HOST: new.{{ services.data_coop_website.domains|join(',') }}
|
||||
LETSENCRYPT_HOST: new.{{ services.data_coop_website.domains|join(',') }}
|
||||
LETSENCRYPT_EMAIL: '{{ letsencrypt_email }}'
|
||||
labels:
|
||||
com.centurylinklabs.watchtower.enable: "true"
|
||||
com.centurylinklabs.watchtower.enable: 'true'
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
---
|
||||
- name: setup ulovliglogning.dk website docker container
|
||||
docker_container:
|
||||
community.docker.docker_container:
|
||||
name: ulovliglogning_website
|
||||
restart_policy: unless-stopped
|
||||
image: ulovliglogning/ulovliglogning.dk:latest
|
||||
|
@ -8,6 +9,6 @@
|
|||
env:
|
||||
VIRTUAL_HOST: "{{ services.ulovliglogning_website.domains|join(',') }}"
|
||||
LETSENCRYPT_HOST: "{{ services.ulovliglogning_website.domains|join(',') }}"
|
||||
LETSENCRYPT_EMAIL: "{{ letsencrypt_email }}"
|
||||
LETSENCRYPT_EMAIL: '{{ letsencrypt_email }}'
|
||||
labels:
|
||||
com.centurylinklabs.watchtower.enable: "true"
|
||||
com.centurylinklabs.watchtower.enable: 'true'
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
---
|
||||
- name: Install necessary packages via apt
|
||||
apt:
|
||||
name: "{{ packages }}"
|
||||
ansible.builtin.apt:
|
||||
name: '{{ packages }}'
|
||||
vars:
|
||||
packages:
|
||||
- aptitude
|
||||
|
@ -11,13 +11,13 @@
|
|||
- mosh
|
||||
|
||||
- name: Install Dell OpenManage
|
||||
apt:
|
||||
ansible.builtin.apt:
|
||||
name: srvadmin-all
|
||||
when: not vagrant
|
||||
|
||||
- name: Install necessary packages via pip
|
||||
pip:
|
||||
name: "{{ packages }}"
|
||||
name: '{{ packages }}'
|
||||
vars:
|
||||
packages:
|
||||
- docker
|
||||
|
|
|
@ -1,18 +1,19 @@
|
|||
---
|
||||
- name: Import dell apt signing key
|
||||
apt_key:
|
||||
id: "1285491434D8786F"
|
||||
keyserver: "keyserver.ubuntu.com"
|
||||
id: 1285491434D8786F
|
||||
keyserver: keyserver.ubuntu.com
|
||||
|
||||
- name: Configure dell apt repo
|
||||
apt_repository:
|
||||
repo: "deb https://linux.dell.com/repo/community/openmanage/10101/focal focal main"
|
||||
ansible.builtin.apt_repository:
|
||||
repo: deb https://linux.dell.com/repo/community/openmanage/10101/focal focal
|
||||
main
|
||||
state: present
|
||||
|
||||
- name: Restrict dell apt repo"
|
||||
copy:
|
||||
dest: "/etc/apt/preferences.d/dell"
|
||||
content: |
|
||||
ansible.builtin.copy:
|
||||
dest: /etc/apt/preferences.d/dell
|
||||
content: |-
|
||||
Explanation: Deny all packages from this repo that exist elsewhere
|
||||
Package: *
|
||||
Pin: origin "linux.dell.com"
|
||||
|
|
|
@ -1,22 +1,22 @@
|
|||
---
|
||||
- name: Setup firewall with UFW
|
||||
community.general.ufw:
|
||||
community.general.ufw:
|
||||
state: enabled
|
||||
policy: deny
|
||||
|
||||
- name: Allow necessary ports
|
||||
community.general.ufw:
|
||||
rule: allow
|
||||
port: "{{ item.port }}"
|
||||
port: '{{ item.port }}'
|
||||
proto: "{{ item.proto | default('tcp') }}"
|
||||
loop:
|
||||
- port: 22 # Gitea SSH
|
||||
- port: 80 # HTTP
|
||||
- port: 443 # HTTPS
|
||||
- port: 389 # OpenLDAP
|
||||
- port: 636 # OpenLDAP
|
||||
- port: 25 # Email
|
||||
- port: 465 # Email
|
||||
- port: 587 # Email
|
||||
- port: 993 # Email
|
||||
- port: 19022 # SSH
|
||||
- port: 22 # Gitea SSH
|
||||
- port: 80 # HTTP
|
||||
- port: 443 # HTTPS
|
||||
- port: 389 # OpenLDAP
|
||||
- port: 636 # OpenLDAP
|
||||
- port: 25 # Email
|
||||
- port: 465 # Email
|
||||
- port: 587 # Email
|
||||
- port: 993 # Email
|
||||
- port: 19022 # SSH
|
||||
|
|
|
@ -1,19 +1,25 @@
|
|||
---
|
||||
- import_tasks: ssh-port.yml
|
||||
- name: Set SSH port
|
||||
ansible.builtin.import_tasks: ssh-port.yml
|
||||
tags: [change-ssh-port]
|
||||
|
||||
- import_tasks: dell-apt-repo.yml
|
||||
- name: Set up Dell apt repo
|
||||
ansible.builtin.import_tasks: dell-apt-repo.yml
|
||||
tags: [setup-dell-apt-repo]
|
||||
when: not vagrant
|
||||
|
||||
- import_tasks: upgrade.yml
|
||||
- name: Make sure system is up to date
|
||||
ansible.builtin.import_tasks: upgrade.yml
|
||||
tags: [do-full-system-upgrade]
|
||||
|
||||
- import_tasks: base.yml
|
||||
- name: Install base packages
|
||||
ansible.builtin.import_tasks: base.yml
|
||||
tags: [install-base-packages]
|
||||
|
||||
- import_tasks: users.yml
|
||||
- name: Setup users
|
||||
ansible.builtin.import_tasks: users.yml
|
||||
tags: [setup-users]
|
||||
|
||||
- import_tasks: firewall.yml
|
||||
- name: Setup firewall
|
||||
ansible.builtin.import_tasks: firewall.yml
|
||||
tags: [setup-firewall]
|
||||
|
|
|
@ -1,20 +1,18 @@
|
|||
---
|
||||
- name: Change SSH port on host
|
||||
lineinfile:
|
||||
dest: "/etc/ssh/sshd_config"
|
||||
regexp: "^#?Port "
|
||||
line: "Port 19022"
|
||||
ansible.builtin.lineinfile:
|
||||
dest: /etc/ssh/sshd_config
|
||||
regexp: '^#?Port '
|
||||
line: Port 19022
|
||||
register: ssh_changed
|
||||
|
||||
- name: Restart sshd
|
||||
service:
|
||||
ansible.builtin.service:
|
||||
name: sshd
|
||||
state: restarted
|
||||
when: ssh_changed is defined and
|
||||
ssh_changed.changed
|
||||
when: ssh_changed is defined and ssh_changed.changed
|
||||
|
||||
- name: Change Ansible port to 19022
|
||||
set_fact:
|
||||
ansible.builtin.set_fact:
|
||||
ansible_port: 19022
|
||||
when: ssh_changed is defined and
|
||||
ssh_changed.changed
|
||||
when: ssh_changed is defined and ssh_changed.changed
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
---
|
||||
- name: update and upgrade system via apt
|
||||
apt:
|
||||
update_cache: yes
|
||||
- name: Update and upgrade system via apt
|
||||
ansible.builtin.apt:
|
||||
update_cache: true
|
||||
upgrade: full
|
||||
|
|
|
@ -1,22 +1,23 @@
|
|||
---
|
||||
- name: "Add users"
|
||||
- name: Add users
|
||||
user:
|
||||
name: "{{ item.name }}"
|
||||
comment: "{{ item.comment }}"
|
||||
password: "{{ item.password }}"
|
||||
groups: "{{ item.groups }}"
|
||||
update_password: "always"
|
||||
loop: "{{ users | default([]) }}"
|
||||
name: '{{ item.name }}'
|
||||
comment: '{{ item.comment }}'
|
||||
password: '{{ item.password }}'
|
||||
groups: '{{ item.groups }}'
|
||||
update_password: always
|
||||
loop: '{{ users | default([]) }}'
|
||||
|
||||
- name: "Add ssh authorized_keys"
|
||||
- name: Add ssh authorized_keys
|
||||
ansible.posix.authorized_key:
|
||||
user: "{{ item.name }}"
|
||||
user: '{{ item.name }}'
|
||||
key: "{{ item.ssh_keys | join('\n') }}"
|
||||
exclusive: true
|
||||
loop: "{{ users | default([]) }}"
|
||||
loop: '{{ users | default([]) }}'
|
||||
|
||||
- name: "Add ssh authorized_keys to root user"
|
||||
- name: Add ssh authorized_keys to root user
|
||||
ansible.posix.authorized_key:
|
||||
user: "root"
|
||||
key: "{{ users | default([]) | map(attribute='ssh_keys') | flatten | join('\n') }}"
|
||||
user: root
|
||||
key: "{{ users | default([]) | map(attribute='ssh_keys') | flatten | join('\n\
|
||||
') }}"
|
||||
exclusive: true
|
||||
|
|
Loading…
Reference in a new issue