aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorjaseg <code@jaseg.net>2019-03-28 01:50:07 +0900
committerjaseg <git@jaseg.net>2019-03-28 01:50:07 +0900
commit30da6478a624bfdeb835eb106ef34860cd7e7c60 (patch)
treecd801cb3b95def896b6549819fd97437c537c143
parent295302ba9420e7b83e5053ea45d14601c1312e3f (diff)
downloadinfra-30da6478a624bfdeb835eb106ef34860cd7e7c60.tar.gz
infra-30da6478a624bfdeb835eb106ef34860cd7e7c60.tar.bz2
infra-30da6478a624bfdeb835eb106ef34860cd7e7c60.zip
gerboweb: Add HTTPS via letsencrypt
-rw-r--r--nginx.conf50
-rw-r--r--playbook.yml17
2 files changed, 36 insertions, 31 deletions
diff --git a/nginx.conf b/nginx.conf
index 22b3be2..c76a3db 100644
--- a/nginx.conf
+++ b/nginx.conf
@@ -39,8 +39,28 @@ http {
listen 80 default_server;
listen [::]:80 default_server;
server_name gerbolyze.jaseg.net;
+ return 301 https://$host$request_uri;
+ }
+
+ server {
+ listen 443 ssl http2 default_server;
+ listen [::]:443 ssl http2 default_server;
+ server_name gerbolyze.jaseg.net;
root /usr/share/nginx/html;
+ ssl_certificate "/etc/letsencrypt/live/gerbolyze.jaseg.net/fullchain.pem";
+ ssl_certificate_key "/etc/letsencrypt/live/gerbolyze.jaseg.net/privkey.pem";
+ ssl_dhparam "/etc/letsencrypt/ssl-dhparams.pem";
+ include /etc/letsencrypt/options-ssl-nginx.conf;
+
+ ssl_stapling on;
+ ssl_stapling_verify on;
+
+ resolver 67.207.67.2 67.207.67.3 valid=300s;
+ resolver_timeout 10s;
+
+ add_header Strict-Transport-Security "max-age=86400";
+
# Load configuration files for the default server block.
include /etc/nginx/default.d/*.conf;
@@ -64,35 +84,5 @@ http {
}
}
-# Settings for a TLS enabled server.
-#
-# server {
-# listen 443 ssl http2 default_server;
-# listen [::]:443 ssl http2 default_server;
-# server_name _;
-# root /usr/share/nginx/html;
-#
-# ssl_certificate "/etc/pki/nginx/server.crt";
-# ssl_certificate_key "/etc/pki/nginx/private/server.key";
-# ssl_session_cache shared:SSL:1m;
-# ssl_session_timeout 10m;
-# ssl_ciphers PROFILE=SYSTEM;
-# ssl_prefer_server_ciphers on;
-#
-# # Load configuration files for the default server block.
-# include /etc/nginx/default.d/*.conf;
-#
-# location / {
-# }
-#
-# error_page 404 /404.html;
-# location = /40x.html {
-# }
-#
-# error_page 500 502 503 504 /50x.html;
-# location = /50x.html {
-# }
-# }
-
}
diff --git a/playbook.yml b/playbook.yml
index eb4f367..3789c21 100644
--- a/playbook.yml
+++ b/playbook.yml
@@ -16,7 +16,7 @@
- name: Install host requisites
dnf:
- name: btrfs-progs,arch-install-scripts,nginx,uwsgi,python3-flask,python3-flask-wtf,systemd-container,uwsgi-plugin-python3
+ name: btrfs-progs,arch-install-scripts,nginx,uwsgi,python3-flask,python3-flask-wtf,systemd-container,uwsgi-plugin-python3,certbot,python3-certbot-nginx
state: latest
- name: Create container image filesystem
@@ -131,6 +131,21 @@
src: gerboweb-job-processor.service
dest: /etc/systemd/system/
+ - name: Set SELinux to permissive mode # FIXME
+ selinux:
+ state: permissive
+ policy: targeted
+
+ - name: Create letsencrypt certificate
+ command: certbot --nginx certonly -d gerbolyze.jaseg.net -n --agree-tos --email gerboweb@jaseg.net
+ args:
+ creates: /etc/letsencrypt/live/gerbolyze.jaseg.net/fullchain.pem
+
+ - name: Enable certbot renewal timer
+ systemd:
+ name: certbot-renew.timer
+ enabled: yes
+
- name: Enable uwsgi systemd socket
systemd:
daemon-reload: yes