61 lines
1.6 KiB
YAML
Executable File
61 lines
1.6 KiB
YAML
Executable File
#################################################
|
|
# DO Community Playbooks: Docker
|
|
#################################################
|
|
---
|
|
- hosts: all
|
|
become: true
|
|
vars_files:
|
|
- vars/default.yml
|
|
|
|
tasks:
|
|
- name: Pull Bitwarden Vault Warden image
|
|
docker_image:
|
|
name: "{{ container_image }}"
|
|
source: pull
|
|
force_source: yes
|
|
|
|
- name: Create bitwarden container
|
|
docker_container:
|
|
name: "{{ container_name }}"
|
|
image: "{{ container_image }}"
|
|
state: started
|
|
restart_policy: "unless-stopped"
|
|
env:
|
|
DATABASE_URL: "{{ db_url }}"
|
|
DOMAIN: "https://{{ http_host }}"
|
|
links:
|
|
- "postgres:db"
|
|
published_ports:
|
|
- 127.0.0.1:8080:80
|
|
- 127.0.0.1:3012:3012
|
|
volumes:
|
|
- /var/lib/bitwarden/data:/data/
|
|
|
|
- name: Check if Nginx conf file exists
|
|
stat: path="/etc/nginx/sites-available/{{ http_conf }}"
|
|
register: status
|
|
|
|
- name: No need to reload Nginx
|
|
debug: msg= {{ "No need to reload Nginx as sites-available entries have already been created" }}
|
|
|
|
- name: Set Nginx conf file
|
|
when: status.stat.exists == false
|
|
template:
|
|
src: "files/nginx.conf.j2"
|
|
dest: "/etc/nginx/sites-available/{{ http_conf }}"
|
|
|
|
- name: Enable new site
|
|
when: status.stat.exists == false
|
|
file:
|
|
src: "/etc/nginx/sites-available/{{ http_conf }}"
|
|
dest: "/etc/nginx/sites-enabled/{{ http_conf }}"
|
|
state: link
|
|
notify: Reload Nginx
|
|
|
|
handlers:
|
|
- name: Reload Nginx
|
|
service:
|
|
name: nginx
|
|
state: reloaded
|
|
|