summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRomain Porte <microjoe@microjoe.org>2019-10-17 15:50:49 +0200
committerRomain Porte <microjoe@microjoe.org>2019-10-17 15:50:49 +0200
commitf39d017039d8ce74eee0191b6bf6f84b96f5f57b (patch)
treeded85468bf8eb0497573534bb3b0bd6bf1717e29
parentd74f937216c9eb97711f8aa5b12f9d1c460a84b4 (diff)
downloadMicroJoe.nginx-f39d017039d8ce74eee0191b6bf6f84b96f5f57b.tar.gz
MicroJoe.nginx-f39d017039d8ce74eee0191b6bf6f84b96f5f57b.zip
add default server with https
-rw-r--r--files/default.j2113
-rw-r--r--tasks/main.yml6
2 files changed, 119 insertions, 0 deletions
diff --git a/files/default.j2 b/files/default.j2
new file mode 100644
index 0000000..1f7b6ec
--- /dev/null
+++ b/files/default.j2
@@ -0,0 +1,113 @@
+##
+# You should look at the following URL's in order to grasp a solid understanding
+# of Nginx configuration files in order to fully unleash the power of Nginx.
+# https://www.nginx.com/resources/wiki/start/
+# https://www.nginx.com/resources/wiki/start/topics/tutorials/config_pitfalls/
+# https://wiki.debian.org/Nginx/DirectoryStructure
+#
+# In most cases, administrators will remove this file from sites-enabled/ and
+# leave it as reference inside of sites-available where it will continue to be
+# updated by the nginx packaging team.
+#
+# This file will automatically load configuration files provided by other
+# applications, such as Drupal or Wordpress. These applications will be made
+# available underneath a path with that package name, such as /drupal8.
+#
+# Please see /usr/share/doc/nginx-doc/examples/ for more detailed examples.
+##
+
+# Default server configuration
+#
+server {
+ listen 80 default_server;
+ listen [::]:80 default_server;
+
+ # SSL configuration
+ #
+ #listen 443 ssl default_server;
+ #listen [::]:443 ssl default_server;
+ #
+ # Note: You should disable gzip for SSL traffic.
+ # See: https://bugs.debian.org/773332
+ #
+ # Read up on ssl_ciphers to ensure a secure configuration.
+ # See: https://bugs.debian.org/765782
+ #
+ # Self signed certs generated by the ssl-cert package
+ # Don't use them in a production server!
+ #
+ # include snippets/snakeoil.conf;
+ include snippets/ssl.conf;
+
+ root /var/www/html;
+
+ # Add index.php to the list if you are using PHP
+ index index.html index.htm index.nginx-debian.html;
+
+ server_name _;
+
+ location / {
+ # First attempt to serve request as file, then
+ # as directory, then fall back to displaying a 404.
+ try_files $uri $uri/ =404;
+ }
+
+ # pass PHP scripts to FastCGI server
+ #
+ #location ~ \.php$ {
+ # include snippets/fastcgi-php.conf;
+ #
+ # # With php-fpm (or other unix sockets):
+ # fastcgi_pass unix:/var/run/php/php7.0-fpm.sock;
+ # # With php-cgi (or other tcp sockets):
+ # fastcgi_pass 127.0.0.1:9000;
+ #}
+
+ # deny access to .htaccess files, if Apache's document root
+ # concurs with nginx's one
+ #
+ #location ~ /\.ht {
+ # deny all;
+ #}
+}
+
+
+# Virtual Host configuration for example.com
+#
+# You can move that to a different file under sites-available/ and symlink that
+# to sites-enabled/ to enable it.
+#
+#server {
+# listen 80;
+# listen [::]:80;
+#
+# server_name example.com;
+#
+# root /var/www/example.com;
+# index index.html;
+#
+# location / {
+# try_files $uri $uri/ =404;
+# }
+#}
+server {
+ listen 443 ssl default_server;
+ listen [::]:443 ssl default_server;
+
+ ssl on;
+ ssl_certificate /etc/letsencrypt/live/{{ letsencrypt_default_domain }}/fullchain.pem;
+ ssl_certificate_key /etc/letsencrypt/live/{{ letsencrypt_default_domain }}/privkey.pem;
+
+ include /etc/nginx/snippets/ssl.conf;
+
+ root /var/www/html;
+ index index.html index.htm index.nginx-debian.html;
+
+ server_name _;
+
+ location / {
+ # First attempt to serve request as file, then
+ # as directory, then fall back to displaying a 404.
+ try_files $uri $uri/ =404;
+ }
+}
diff --git a/tasks/main.yml b/tasks/main.yml
index e876fcb..5e906a4 100644
--- a/tasks/main.yml
+++ b/tasks/main.yml
@@ -13,6 +13,12 @@
chdir: /etc/nginx/
creates: dhparam4096.pem
+- name: Install nginx default server
+ template:
+ src: files/default.j2
+ dest: /etc/nginx/sites-available/default
+ notify: restart nginx
+
- name: Install nginx snippets
copy:
src: files/ssl.conf