0
Fork 0
mirror of https://github.com/dani-garcia/vaultwarden.git synced 2025-04-01 02:42:49 -05:00

add nginx ansible role

This commit is contained in:
Sudoix 2025-01-08 10:18:03 +01:00
parent bff88aa1ac
commit c6db070479
3 changed files with 151 additions and 0 deletions

View file

@ -0,0 +1,96 @@
---
# tasks file for nginx
- name: Install certbot
apt:
name:
- certbot
update_cache: true
state: present
- name: Create nginx docker directory if it doesn't exist
file:
path: "{{ nginx_dir }}"
state: directory
- name: Create nginx data docker directory if it doesn't exist
file:
path: "{{ nginx_data_dir }}"
state: directory
- name: Delete nginx certs directory if it exists
file:
path: "{{ nginx_certs_dir }}"
state: absent
- name: Create nginx certs directory
file:
path: "{{ nginx_certs_dir }}"
state: directory
- name: copy nginx config file to data directory
template:
src: loadbalancer.conf.j2
dest: "{{ nginx_data_dir }}/loadbalancer.conf"
- name: Copy nginx docker compose file
template:
src: nginx-docker-compose.yaml.j2
dest: "{{ nginx_dir }}/docker-compose.yaml"
- name: Check if {{ nginx_container_name }} exists
community.docker.docker_container_info:
name: "{{ nginx_container_name }}"
register: nginx_running
- name: Ask for confirmation to remove {{ nginx_container_name }}
pause:
prompt: "We found a running {{ nginx_container_name }} container. Would you like to remove it? (y/n)"
echo: yes
register: confirmation
when: nginx_running.exists
delegate_to: localhost
run_once: true
- block:
- name: Stop and remove {{ nginx_container_name }} if confirmed
community.docker.docker_container:
name: "{{ nginx_container_name }}"
state: absent
when: nginx_running.exists and confirmation.user_input | lower in ['y', 'yes']
- name: Prune docker containers
shell: sudo docker container prune -f
when: nginx_running.exists and confirmation.user_input | lower in ['y', 'yes']
- name: Remove {{ nginx_container_name }} if it exists
community.docker.docker_container:
name: "{{ nginx_container_name }}"
state: absent
when: nginx_running.exists and confirmation.user_input | lower in ['y', 'yes']
- name: Obtain SSL certificates using Certbot
shell: yes | certbot -d {{ vaultwarden_domain }} --config-dir {{ nginx_certs_dir }} certonly --standalone -m {{ nginx_certs_email }} --agree-tos
when: ansible_hostname == 'nginx-srv-1'
- name: Synchronization of SSL cert files and directory from server to local
ansible.posix.synchronize:
mode: pull
src: "{{ nginx_certs_dir }}"
dest: /tmp
- name: Synchronization of src on the control machine to {{ nginx_certs_dir }} on the remote hosts
ansible.posix.synchronize:
src: /tmp/certs
dest: "{{ nginx_dir }}"
- name: Delete SSL cert files on the local machine
file:
path: /tmp/certs
state: absent
delegate_to: localhost
- name: Start {{ nginx_container_name }} with docker compose
community.docker.docker_compose:
project_src: "{{ nginx_dir }}"
files:
- docker-compose.yaml

View file

@ -0,0 +1,40 @@
upstream backend {
ip_hash; # DONT CHANGE IT
{% for host in groups['vaultwarden'] %}
server {{ hostvars[host]['private_ip'] }}:{{ vaultwarden_port }} weight=5;
{% endfor %}
keepalive 64;
}
server {
listen 80;
server_name {{ vaultwarden_domain }};
location / {
return 301 https://$host$request_uri;
}
location /.well-known/acme-challenge/ {
root /var/www/certbot;
}
}
server {
listen 443 ssl;
listen [::]:443 ssl;
http2 on;
server_name {{ vaultwarden_domain }};
ssl_certificate /etc/letsencrypt/live/{{ vaultwarden_domain }}/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/{{ vaultwarden_domain }}/privkey.pem;
location / {
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_pass http://backend;
}
}

View file

@ -0,0 +1,15 @@
version: '{{ compose_version }}'
services:
nginx:
container_name: {{ nginx_container_name }}
restart: unless-stopped
hostname: {{ nginx_container_name }}
image: {{ nginx_docker_image }}
ports:
- {{ nginx_http_port }}:80
- {{ nginx_https_port }}:443
volumes:
- {{ nginx_data_dir }}:/etc/nginx/conf.d
- {{ nginx_certs_dir }}/live/{{ vaultwarden_domain }}:/etc/letsencrypt/live/{{ vaultwarden_domain }}
- {{ nginx_certs_dir }}/archive/{{ vaultwarden_domain }}:/etc/letsencrypt/archive/{{ vaultwarden_domain }}