nginx + certbot yo

This commit is contained in:
les 2020-11-21 23:42:08 +01:00
parent 6b3c732ec2
commit af0dda2f9d
14 changed files with 170 additions and 69 deletions

View file

@ -1,15 +1,14 @@
# silicone ## Silicone
Un angolo ragionato per facilitare la messa in opera di servizi autogestiti di prossimità Un angolo ragionato per facilitare la messa in opera di servizi autogestiti di prossimità
## Come si usa #### Come si usa
Si imposta il proprio inventory (inventory.yml) e il proprio playbook Si imposta il proprio inventory (inventory.yml) e il proprio playbook (infra.yml)
(infra.yml)
## Password #### Password
Per le password si usa pass, il path usato e' specificato nell'inventory Per le password si usa pass, il path usato e' specificato nell'inventory
## Creare nuovi ruoli: #### Creare nuovi ruoli:
Ci sono varie possibilità, si può usare docker o vagrant, sono dentro Ci sono varie possibilità, si può usare docker o vagrant, sono dentro
`dev/`, per docker c'e' un README.md `dev/`, per docker c'e' un README.md

View file

@ -1,31 +1,36 @@
--- ---
## FRONTEND
- name: Frontend
hosts: frontend
roles: ['stable/common', 'stable/nginx']
vars_files: vars/frontend.yml
tags: frontend
## ETHERPAD # ETHERPAD
- name: Etherpad - name: Etherpad
hosts: paddone hosts: paddone
roles: tags: etherpad
- role: stable/common roles: ['stable/common', 'stable/etherpad']
- role: stable/etherpad vars_files: vars/etherpad.yml
vars_files:
- vars/etherpad.yml
## CICLES # CICLES
- name: Cicles - name: Cicles
hosts: cicles hosts: cicles
roles: tags: cicles
- role: stable/common roles: ['stable/common', 'stable/goploader']
- role: stable/goploader
## GANCIO # GANCIO
- name: Gancio - name: Gancio
hosts: gancio hosts: gancio
roles: tags: gancio
- role: stable/common roles: ['stable/common', 'stable/gancio']
- role: stable/gancio vars_files: vars/gancio.yml
vars_files:
- vars/gancio.yml
# TEST
## MASTODON - name: Test
hosts: test
roles: ['stable/common', 'stable/nginx']
tags: test
vars_files: vars/frontend.yml

View file

@ -7,6 +7,14 @@ cicles:
gancio: gancio:
hosts: 192.168.199.106 hosts: 192.168.199.106
frontend:
hosts: 172.172.0.3
test:
hosts: jolly.roger
vars:
ansible_user: debian
all: all:
vars: vars:
passwordstore_path: cisti.org/ansible passwordstore_path: cisti.org/ansible

View file

@ -1,32 +0,0 @@
---
- name: Install NGINX
become: yes
apt:
name: nginx
- name: Disable NGINX Default Virtual Host
become: yes
file:
src: /etc/nginx/sites-enabled/default
state: unlink
- name: Configure Reverse Proxies
become: yes
template:
src: reverse_proxy.conf
dest: /etc/nginx/sites-available/reverse_proxy_{{item.key}}.conf
with_dict: "{{ proxies }}"
- name: Link NGINX Reverse Proxies
file:
src: "/etc/nginx/sites-available/reverse_proxy_{{item.key}}.conf"
dest: "/etc/nginx/sites-enabled/reverse_proxy_{{item.key}}.conf"
state: link
with_dict: "{{ proxies }}"
- name: Make sure NGINX Service is running
become: yes
service:
name: nginx
state: restarted
enabled: yes

View file

@ -2,10 +2,11 @@
- name: Update apt cache if needed - name: Update apt cache if needed
become: yes become: yes
apt: apt:
update_cache=yes update_cache: yes
cache_valid_time=3600 cache_valid_time: 3600
- name: Install generic deps - name: Install generic deps
become: yes
apt: apt:
pkg: pkg:
- git - git
@ -13,17 +14,20 @@
- acl - acl
- name: Add Backports Repository - name: Add Backports Repository
become: yes
apt_repository: apt_repository:
repo: deb http://deb.debian.org/debian buster-backports main contrib non-free repo: deb http://deb.debian.org/debian buster-backports main contrib non-free
state: present state: present
update_cache: yes update_cache: yes
- name: Install Unattended Upgrades - name: Install Unattended Upgrades
become: yes
apt: apt:
pkg: pkg:
- unattended-upgrades - unattended-upgrades
- name: Activate Unattented Upgrades - name: Activate Unattented Upgrades
become: yes
copy: copy:
src: 20auto-upgrades src: 20auto-upgrades
dest: /etc/apt/apt.conf.d/20auto-upgrades dest: /etc/apt/apt.conf.d/20auto-upgrades

View file

@ -12,11 +12,9 @@ dependencies:
password: "{{ database_password }}" password: "{{ database_password }}"
database: etherpad database: etherpad
# install caddy and configure it as reverse proxy # install certbot nginx and configure it as reverse proxy
# - role: caddy # - role: stable/nginx
# when: with_nginx | bool # when: with_nginx | bool
# vars: # vars:
# caddy_config: | # with_certbot: true
# {{hostname}} # proxy_pass: http://
# encode gzip
# reverse_proxy localhost:31337

View file

@ -1,7 +1,7 @@
--- ---
- name: Install postgresql - name: Install postgresql
apt: apt:
pkg: pkg:
- postgresql - postgresql
- python3-psycopg2 - python3-psycopg2

View file

@ -2,11 +2,11 @@
dependencies: dependencies:
# install nodejs # install nodejs
- role: nodejs - role: stable/nodejs
# install postgres # install postgres
# and create an gancio user and db # and create an gancio user and db
- role: postgresql - role: stable/postgresql
vars: vars:
username: gancio username: gancio
password: "{{ database_password }}" password: "{{ database_password }}"

View file

@ -21,7 +21,7 @@
global: yes global: yes
production: yes production: yes
state: present state: present
- name: Copy settings - name: Copy settings
template: template:
src: config.json.j2 src: config.json.j2
@ -36,4 +36,4 @@
shell: pm2 start gancio -- start --config config.json shell: pm2 start gancio -- start --config config.json
args: args:
chdir: /srv/gancio chdir: /srv/gancio
ignore_errors: yes ignore_errors: yes

View file

@ -0,0 +1,22 @@
---
- name: Install snapd
become: yes
apt:
pkg: ['snapd']
- name: Install snap core
become: yes
snap:
name: core
- name: Install cerbot via snap
become: yes
snap:
name: certbot
classic: yes
- name: Generate certificate if needed
become: yes
command: certbot-auto --nginx --non-interactive --agree-tos
--domains {{ servers | items2dict(key_name='server_name', value_name='server_name') | join(',') }}
--email {{certbot_email}}

View file

@ -0,0 +1,31 @@
---
- name: Install NGINX
become: yes
apt:
name: nginx
- name: Configure Reverse Proxies
become: yes
template:
src: reverse_proxy.conf.j2
dest: /etc/nginx/sites-available/{{item.server_name}}.conf
loop: "{{ servers }}"
- name: Link NGINX Reverse Proxies
become: yes
file:
src: "/etc/nginx/sites-available/{{item.server_name}}.conf"
dest: "/etc/nginx/sites-enabled/{{item.server_name}}.conf"
state: link
loop: "{{ servers }}"
- name: Make sure NGINX Service is running
become: yes
service:
name: nginx
state: restarted
enabled: yes
- name: Run Certbot if needed
include: certbot.yml
when: with_certbot | bool

View file

@ -0,0 +1,19 @@
# cache
# proxy_cache_path /tmp levels=1:2 keys_zone=STATIC:10m inactive=24h max_size=1g;
keepalive 30;
# redirect all http traffic to https
server {
listen 80 default_server;
listen [::]:80 default_server;
server_name _;
return 301 https://$host$request_uri;
}
# enable proxy websocket
map $http_upgrade $connection_upgrade {
default upgrade;
'' close;
}

View file

@ -0,0 +1,33 @@
# nginx ssl file
server {
listen 80;
listen [::]:80;
server_name {{item.server_name}};
keepalive_timeout 200;
{{item.custom_config | default('') | indent(2)}}
location / {
proxy_pass {{item.proxy_pass}};
proxy_http_version 1.1;
# hide client ip to backend
proxy_set_header X-Real-IP 42.42.42.42;
# set host
proxy_set_header Host $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header X-Forwarded-Host $host;
proxy_set_header X-Forwarded-Port $server_port;
# upgrade websocket
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
# cache
# proxy_cache {{item.server_name}}
}
}

14
vars/frontend.yml Normal file
View file

@ -0,0 +1,14 @@
---
with_certbot: true
certbot_email: info@cisti.org
servers:
- cicles:
server_name: antani.cisti.org
proxy_pass: http://192.168.199.105:8080
custom_config: |
sendfile on;
client_max_body_size 80m;
- gancio:
server_name: sblinda.cisti.org
proxy_pass: http://192.168.199.104:8000