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:
parent
bff88aa1ac
commit
c6db070479
3 changed files with 151 additions and 0 deletions
96
deployment/roles/nginx/tasks/main.yml
Normal file
96
deployment/roles/nginx/tasks/main.yml
Normal 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
|
40
deployment/roles/nginx/templates/loadbalancer.conf.j2
Normal file
40
deployment/roles/nginx/templates/loadbalancer.conf.j2
Normal 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;
|
||||
}
|
||||
}
|
|
@ -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 }}
|
Loading…
Add table
Reference in a new issue