Compare commits

..

5 commits

Author SHA1 Message Date
max
ec8d79e596 remove apache role 2022-01-06 11:33:48 +00:00
Maximilian Deubel
5dda159d2d use docker_setup role 2022-01-06 11:04:35 +01:00
Max
419b89af37 role to playbook 2022-01-06 11:35:43 +01:00
Max
532c189ce7 change path 2022-01-06 11:29:32 +01:00
Maximilian Deubel
911fe28e06 add unifi controller role and playbook 2022-01-05 21:19:49 +01:00
6 changed files with 141 additions and 202 deletions

View file

@ -1,13 +0,0 @@
# EditorConfig is awesome: https://EditorConfig.org
# top-most EditorConfig file
root = true
# Unix-style newlines with a newline ending every file
[*]
end_of_line = lf
insert_final_newline = true
[*.yml]
indent_style = space
indent_size = 2

View file

@ -3,7 +3,6 @@
Currently including the following hosts: Currently including the following hosts:
* tau.netz39.de * tau.netz39.de
* pottwal.n39.eu * pottwal.n39.eu
* unicorn.n39.eu
## Setup ## Setup
```bash ```bash

View file

@ -76,5 +76,4 @@ all:
31356239323439666632333033616366663762646366343839663463633665333863343437343334 31356239323439666632333033616366663762646366343839663463633665333863343437343334
3665386538393066380a383366346235343531306561643534663035646537666534383536333230 3665386538393066380a383366346235343531306561643534663035646537666534383536333230
34613761363237633865306332653631323366343232353666343165666664343838 34613761363237633865306332653631323366343232353666343165666664343838
unicorn.n39.eu:
server_admin: "admin+unicorn@netz39.de"

View file

@ -40,5 +40,5 @@
- name: Pottwal specific setup - name: Pottwal specific setup
import_playbook: pottwal.yml import_playbook: pottwal.yml
- name: Specific setup for host unicorn - name: Unifi specific setup
import_playbook: unicorn.yml import_playbook: unifi.yml

View file

@ -14,7 +14,6 @@
openhab_configuration_source: https://github.com/netz39/n39-openhab.git openhab_configuration_source: https://github.com/netz39/n39-openhab.git
openhab_configuration_version: master openhab_configuration_version: master
gitea_host_port: 9091
uritools_host_port: 8080 uritools_host_port: 8080
entities_validation_svc_host_port: 8082 entities_validation_svc_host_port: 8082
shlink_host_port: 8083 shlink_host_port: 8083
@ -27,200 +26,155 @@
- role: apache - role: apache
tasks: tasks:
- name: Ensure apt-cacher container is running
docker_container:
name: apt_cacher_ng
image: "mrtux/apt-cacher-ng"
pull: true
state: started
restart_policy: unless-stopped
detach: yes
ports:
- 3142:3142
- name: Check if gitea data dir exists - name: Ensure the mosquitto directories exist
ansible.builtin.stat: file:
path: "/srv/data/gitea" path: "{{ item }}"
register: gitea_dir state: directory
- name: Fail if gitea data dir does not exist with_items:
ansible.builtin.fail: - "{{ mosquitto_data }}/config"
msg: "Gitea data dir is missing, please restore from the backup!" - "{{ mosquitto_data }}/data"
when: not gitea_dir.stat.exists - "{{ mosquitto_data }}/log"
# If port 2222 is changed here, it must also be adapted - name: Make sure mosquitto config is there
# in the gitea config file (see application volume)!! template:
- name: Setup the docker container for gitea src: "templates/mosquitto.conf.j2"
docker_container: dest: "{{ mosquitto_data }}/config/mosquitto.conf"
name: gitea notify: restart_mosquitto
image: "gitea/gitea:1.15.10"
pull: true
state: started
restart_policy: unless-stopped
detach: yes
ports:
# - 127.0.0.1:{{ gitea_host_port }}:3000
- "{{ gitea_host_port }}:3000"
- 2222:2222
env:
APP_NAME="Netz39 Gitea"
RUN_MODE="prod"
SSH_DOMAIN="gitea.n39.eu"
SSH_PORT="2222"
SSH_START_SERVER="false"
ROOT_URL="https://gitea.n39.eu"
DISABLE_REGISTRATION="true"
USER_UID=1000
USER_GID=1000
volumes:
- "/srv/data/gitea:/data:rw"
- name: Setup proxy site gitea.n39.eu - name: Ensure mosquitto is running
include_role: docker_container:
name: setup-http-site-proxy name: mosquitto
vars: image: "{{ mosquitto_image }}"
site_name: "gitea.n39.eu" pull: true
proxy_port: "{{ gitea_host_port }}" state: started
ports:
- 1883:1883
- 9001:9001
volumes:
- "{{ mosquitto_data }}/config:/mosquitto/config"
- "{{ mosquitto_data }}/data:/mosquitto/data"
- "{{ mosquitto_data }}/log:/mosquitto/log"
detach: yes
keep_volumes: yes
restart_policy: unless-stopped
- name: Ensure apt-cacher container is running - name: Ensure the openhab directories exist
docker_container: file:
name: apt_cacher_ng path: "{{ item }}"
image: "mrtux/apt-cacher-ng" state: directory
pull: true with_items:
state: started - "{{ openhab_data }}/addons"
restart_policy: unless-stopped - "{{ openhab_data }}/conf"
detach: yes - "{{ openhab_data }}/userdata"
ports:
- 3142:3142
- name: Clone or update configuration
git:
repo: "{{ openhab_configuration_source }}"
version: "{{ openhab_configuration_version }}"
dest: "{{ openhab_data }}/conf"
clone: yes
update: yes
- name: Ensure the mosquitto directories exist - name: ensure openhab is up and running
file: docker_container:
path: "{{ item }}" name: openhab
state: directory image: "{{ openhab_image }}"
with_items: pull: true
- "{{ mosquitto_data }}/config" state: started
- "{{ mosquitto_data }}/data" detach: yes
- "{{ mosquitto_data }}/log" interactive: yes
tty: yes
ports:
- "{{ openhab_host_port }}:8080"
volumes:
- /etc/localtime:/etc/localtime:ro
- /etc/timezone:/etc/timezone:ro
- "{{ openhab_data }}/addons:/openhab/addons:rw"
- "{{ openhab_data }}/conf:/openhab/conf:rw"
- "{{ openhab_data }}/userdata:/openhab/userdata:rw"
keep_volumes: yes
restart_policy: unless-stopped
env: EXTRA_JAVA_OPTS="-Duser.timezone=Europe/Berlin"
- name: Make sure mosquitto config is there - name: Setup proxy site openhab.n39.eu
template: include_role:
src: "templates/mosquitto.conf.j2" name: setup-http-site-proxy
dest: "{{ mosquitto_data }}/config/mosquitto.conf" vars:
notify: restart_mosquitto site_name: openhab.n39.eu
proxy_port: "{{ openhab_host_port }}"
- name: Ensure mosquitto is running - name: Ensure container for URI tools is running
docker_container: docker_container:
name: mosquitto name: uritools
image: "{{ mosquitto_image }}" image: mrtux/clean_uri
pull: true pull: true
state: started state: started
ports: detach: yes
- 1883:1883 ports:
- 9001:9001 - "{{ uritools_host_port }}:8080"
volumes: restart_policy: unless-stopped
- "{{ mosquitto_data }}/config:/mosquitto/config"
- "{{ mosquitto_data }}/data:/mosquitto/data"
- "{{ mosquitto_data }}/log:/mosquitto/log"
detach: yes
keep_volumes: yes
restart_policy: unless-stopped
- name: Ensure the openhab directories exist - name: Setup proxy site uritools.n39.eu
file: include_role:
path: "{{ item }}" name: setup-http-site-proxy
state: directory vars:
with_items: site_name: uritools.n39.eu
- "{{ openhab_data }}/addons" proxy_port: "{{ uritools_host_port }}"
- "{{ openhab_data }}/conf"
- "{{ openhab_data }}/userdata"
- name: Clone or update configuration - name: Ensure container for entities validation service is running
git: docker_container:
repo: "{{ openhab_configuration_source }}" name: entities_validation_svc
version: "{{ openhab_configuration_version }}" image: netz39/entities_validation_svc:v1.0.0
dest: "{{ openhab_data }}/conf" pull: true
clone: yes state: started
update: yes detach: yes
ports:
- "{{ entities_validation_svc_host_port }}:8080"
restart_policy: unless-stopped
- name: ensure openhab is up and running - name: Setup proxy site entities-validation.svc.n39.eu
docker_container: include_role:
name: openhab name: setup-http-site-proxy
image: "{{ openhab_image }}" vars:
pull: true site_name: entities-validation.svc.n39.eu
state: started proxy_port: "{{ entities_validation_svc_host_port }}"
detach: yes
interactive: yes
tty: yes
ports:
- "{{ openhab_host_port }}:8080"
volumes:
- /etc/localtime:/etc/localtime:ro
- /etc/timezone:/etc/timezone:ro
- "{{ openhab_data }}/addons:/openhab/addons:rw"
- "{{ openhab_data }}/conf:/openhab/conf:rw"
- "{{ openhab_data }}/userdata:/openhab/userdata:rw"
keep_volumes: yes
restart_policy: unless-stopped
env: EXTRA_JAVA_OPTS="-Duser.timezone=Europe/Berlin"
- name: Setup proxy site openhab.n39.eu - name: Ensure container for shlink is running
include_role: docker_container:
name: setup-http-site-proxy name: shlink
vars: image: shlinkio/shlink:2.6.2
site_name: openhab.n39.eu pull: true
proxy_port: "{{ openhab_host_port }}" state: started
detach: yes
ports:
- "{{ shlink_host_port }}:8080"
restart_policy: unless-stopped
env:
SHORT_DOMAIN_HOST: "{{ shlink_domain_name }}"
SHORT_DOMAIN_SCHEMA: https
GEOLITE_LICENSE_KEY: "{{ shlink_geolite_license_key }}"
- name: Ensure container for URI tools is running - name: Setup proxy site {{ shlink_domain_name }}
docker_container: include_role:
name: uritools name: setup-http-site-proxy
image: mrtux/clean_uri vars:
pull: true site_name: "{{ shlink_domain_name }}"
state: started proxy_port: "{{ shlink_host_port }}"
detach: yes
ports:
- "{{ uritools_host_port }}:8080"
restart_policy: unless-stopped
- name: Setup proxy site uritools.n39.eu
include_role:
name: setup-http-site-proxy
vars:
site_name: uritools.n39.eu
proxy_port: "{{ uritools_host_port }}"
- name: Ensure container for entities validation service is running
docker_container:
name: entities_validation_svc
image: netz39/entities_validation_svc:v1.0.0
pull: true
state: started
detach: yes
ports:
- "{{ entities_validation_svc_host_port }}:8080"
restart_policy: unless-stopped
- name: Setup proxy site entities-validation.svc.n39.eu
include_role:
name: setup-http-site-proxy
vars:
site_name: entities-validation.svc.n39.eu
proxy_port: "{{ entities_validation_svc_host_port }}"
- name: Ensure container for shlink is running
docker_container:
name: shlink
image: shlinkio/shlink:2.6.2
pull: true
state: started
detach: yes
ports:
- "{{ shlink_host_port }}:8080"
restart_policy: unless-stopped
env:
SHORT_DOMAIN_HOST: "{{ shlink_domain_name }}"
SHORT_DOMAIN_SCHEMA: https
GEOLITE_LICENSE_KEY: "{{ shlink_geolite_license_key }}"
- name: Setup proxy site {{ shlink_domain_name }}
include_role:
name: setup-http-site-proxy
vars:
site_name: "{{ shlink_domain_name }}"
proxy_port: "{{ shlink_host_port }}"
handlers: handlers:
- name: restart mosquitto - name: restart mosquitto
docker_container: docker_container:
name: mosquitto name: mosquitto
state: started state: started
restart: yes restart: yes

View file

@ -1,6 +1,6 @@
--- ---
# this is for a dedicated vm just hosting the unifi controller. # this is for a dedicated vm just hosting the unifi controller.
- hosts: unicorn.n39.eu - hosts: unifi.n39.eu
become: true become: true
vars: vars:
ansible_python_interpreter: /usr/bin/python3 ansible_python_interpreter: /usr/bin/python3