|
|
@@ -0,0 +1,97 @@
|
|
|
+server {
|
|
|
+ listen %ip%:%web_ssl_port%;
|
|
|
+ server_name %domain_idn% %alias_idn%;
|
|
|
+ root %docroot%;
|
|
|
+ index index.php index.html index.htm;
|
|
|
+ access_log /var/log/nginx/domains/%domain%.log combined;
|
|
|
+ access_log /var/log/nginx/domains/%domain%.bytes bytes;
|
|
|
+ error_log /var/log/nginx/domains/%domain%.error.log error;
|
|
|
+
|
|
|
+ ssl on;
|
|
|
+ ssl_certificate %ssl_pem%;
|
|
|
+ ssl_certificate_key %ssl_key%;
|
|
|
+
|
|
|
+ location = /favicon.ico {
|
|
|
+ log_not_found off;
|
|
|
+ access_log off;
|
|
|
+ }
|
|
|
+
|
|
|
+ location = /robots.txt {
|
|
|
+ allow all;
|
|
|
+ log_not_found off;
|
|
|
+ access_log off;
|
|
|
+ }
|
|
|
+
|
|
|
+ location ~* \.(txt|log)$ {
|
|
|
+ allow 192.168.0.0/16;
|
|
|
+ deny all;
|
|
|
+ }
|
|
|
+
|
|
|
+ location ~ \..*/.*\.php$ {
|
|
|
+ return 403;
|
|
|
+ }
|
|
|
+
|
|
|
+ # No no for private
|
|
|
+ location ~ ^/sites/.*/private/ {
|
|
|
+ return 403;
|
|
|
+ }
|
|
|
+
|
|
|
+ # Block access to "hidden" files and directories whose names begin with a
|
|
|
+ # period. This includes directories used by version control systems such
|
|
|
+ # as Subversion or Git to store control files.
|
|
|
+ location ~ (^|/)\. {
|
|
|
+ return 403;
|
|
|
+ }
|
|
|
+
|
|
|
+ location / {
|
|
|
+ try_files $uri @rewrite;
|
|
|
+
|
|
|
+ location ~* ^.+\.(jpeg|jpg|png|gif|bmp|ico|svg|css|js)$ {
|
|
|
+ expires max;
|
|
|
+ }
|
|
|
+
|
|
|
+ location ~ [^/]\.php(/|$)|^/update.php {
|
|
|
+ fastcgi_split_path_info ^(.+?\.php)(|/.*)$;
|
|
|
+ fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
|
|
|
+ if (!-f $document_root$fastcgi_script_name) {
|
|
|
+ return 404;
|
|
|
+ }
|
|
|
+
|
|
|
+ fastcgi_pass %backend_lsnr%;
|
|
|
+ fastcgi_index index.php;
|
|
|
+ fastcgi_param SCRIPT_FILENAME $request_filename;
|
|
|
+ fastcgi_intercept_errors on;
|
|
|
+ include /etc/nginx/fastcgi_params;
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ location @rewrite {
|
|
|
+ # You have 2 options here
|
|
|
+ # For D7 and above:
|
|
|
+ # Clean URLs are handled in drupal_environment_initialize().
|
|
|
+ rewrite ^ /index.php;
|
|
|
+ }
|
|
|
+
|
|
|
+ location ~ ^/sites/.*/files/styles/ {
|
|
|
+ try_files $uri @rewrite;
|
|
|
+ }
|
|
|
+
|
|
|
+ error_page 403 /error/404.html;
|
|
|
+ error_page 404 /error/404.html;
|
|
|
+ error_page 500 502 503 504 /error/50x.html;
|
|
|
+
|
|
|
+ location /error/ {
|
|
|
+ alias %home%/%user%/web/%domain%/document_errors/;
|
|
|
+ }
|
|
|
+
|
|
|
+ location ~* "/\.(htaccess|htpasswd)$" {
|
|
|
+ deny all;
|
|
|
+ return 404;
|
|
|
+ }
|
|
|
+
|
|
|
+ include /etc/nginx/conf.d/phpmyadmin.inc*;
|
|
|
+ include /etc/nginx/conf.d/phppgadmin.inc*;
|
|
|
+ include /etc/nginx/conf.d/webmail.inc*;
|
|
|
+
|
|
|
+ include %home%/%user%/conf/web/nginx.%domain%.conf*;
|
|
|
+}
|