Last active
October 20, 2017 10:22
-
-
Save surdaft/b98109adf31cd64491548dc6d6fb894b to your computer and use it in GitHub Desktop.
Nginx configurations for Homestead
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#!/usr/bin/env bash | |
declare -A params=$6 # Create an associative array | |
paramsTXT="" | |
if [ -n "$6" ]; then | |
for element in "${!params[@]}" | |
do | |
paramsTXT="${paramsTXT} | |
fastcgi_param ${element} ${params[$element]};" | |
done | |
fi | |
block=" | |
map \$uri \$blogname{ | |
~^(?P<blogpath>/[^/]+/)files/(.*) \$blogpath ; | |
} | |
map \$blogname \$blogid{ | |
default -999; | |
#Ref: http://wordpress.org/extend/plugins/nginx-helper/ | |
#include /var/www/wordpress/wp-content/plugins/nginx-helper/map.conf ; | |
} | |
server { | |
listen ${3:-80}; | |
listen ${4:-443} ssl http2; | |
server_name $1; | |
root \"$2\"; | |
index index.html index.htm index.php; | |
charset utf-8; | |
location / { | |
try_files \$uri \$uri/ /index.php?\$query_string; | |
} | |
location ~* /wp-(content|admin|includes).*(js|css|png|jpg|jpeg|gif|ico) { | |
rewrite ^/([_0-9a-zA-Z-]+/)?(wp-(content|admin|includes).*) /\$2 break; | |
expires 24h; | |
log_not_found off; | |
try_files $uri $uri/ =404; | |
} | |
location = /favicon.ico { access_log off; log_not_found off; } | |
location = /robots.txt { access_log off; log_not_found off; } | |
access_log off; | |
error_log /var/log/nginx/$1-error.log error; | |
sendfile off; | |
client_max_body_size 100m; | |
if (!-e \$request_filename) { | |
rewrite /wp-admin$ \$scheme://\$host\$uri/ permanent; | |
# rewrite ^(/[^/]+)?(/wp-.*) \$2 last; - This line rewrote wp-content which fucked everything up. :( | |
rewrite ^(/[^/]+)?(/.*\.php) \$2 last; | |
} | |
location ~ \.php { | |
fastcgi_split_path_info ^(.+\.php)(/.+)$; | |
fastcgi_pass unix:/var/run/php/php$5-fpm.sock; | |
fastcgi_index index.php; | |
include fastcgi_params; | |
fastcgi_param SCRIPT_FILENAME \$document_root\$fastcgi_script_name; | |
$paramsTXT | |
fastcgi_intercept_errors off; | |
fastcgi_buffer_size 16k; | |
fastcgi_buffers 4 16k; | |
fastcgi_connect_timeout 300; | |
fastcgi_send_timeout 300; | |
fastcgi_read_timeout 300; | |
} | |
location ~ /\.ht { | |
deny all; | |
} | |
ssl_certificate /etc/nginx/ssl/$1.crt; | |
ssl_certificate_key /etc/nginx/ssl/$1.key; | |
} | |
" | |
echo "$block" > "/etc/nginx/sites-available/$1" | |
ln -fs "/etc/nginx/sites-available/$1" "/etc/nginx/sites-enabled/$1" |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#!/usr/bin/env bash | |
declare -A params=$6 # Create an associative array | |
paramsTXT="" | |
if [ -n "$6" ]; then | |
for element in "${!params[@]}" | |
do | |
paramsTXT="${paramsTXT} | |
fastcgi_param ${element} ${params[$element]};" | |
done | |
fi | |
block="server { | |
listen ${3:-80}; | |
listen ${4:-443} ssl http2; | |
server_name $1; | |
root \"$2\"; | |
index index.html index.htm index.php; | |
charset utf-8; | |
location / { | |
try_files \$uri \$uri/ /index.php?\$query_string; | |
} | |
location = /favicon.ico { access_log off; log_not_found off; } | |
location = /robots.txt { access_log off; log_not_found off; } | |
access_log off; | |
error_log /var/log/nginx/$1-error.log error; | |
sendfile off; | |
client_max_body_size 100m; | |
location ~ \.php$ { | |
fastcgi_split_path_info ^(.+\.php)(/.+)$; | |
fastcgi_pass unix:/var/run/php/php$5-fpm.sock; | |
fastcgi_index index.php; | |
include fastcgi_params; | |
fastcgi_param SCRIPT_FILENAME \$document_root\$fastcgi_script_name; | |
$paramsTXT | |
fastcgi_intercept_errors off; | |
fastcgi_buffer_size 16k; | |
fastcgi_buffers 4 16k; | |
fastcgi_connect_timeout 300; | |
fastcgi_send_timeout 300; | |
fastcgi_read_timeout 300; | |
} | |
location ~ /\.ht { | |
deny all; | |
} | |
ssl_certificate /etc/nginx/ssl/$1.crt; | |
ssl_certificate_key /etc/nginx/ssl/$1.key; | |
} | |
" | |
echo "$block" > "/etc/nginx/sites-available/$1" | |
ln -fs "/etc/nginx/sites-available/$1" "/etc/nginx/sites-enabled/$1" |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment