X-Git-Url: https://git.openstreetmap.org./chef.git/blobdiff_plain/4f6e8225fdfcd054fdb09f61b8be1e3e2684197c..9eb8943ae3e825d148f52860473a892f8ea7366d:/cookbooks/nominatim/templates/default/apache.erb?ds=sidebyside diff --git a/cookbooks/nominatim/templates/default/apache.erb b/cookbooks/nominatim/templates/default/apache.erb index 8e12362d1..5cda3e467 100644 --- a/cookbooks/nominatim/templates/default/apache.erb +++ b/cookbooks/nominatim/templates/default/apache.erb @@ -1,62 +1,50 @@ # DO NOT EDIT - This file is being maintained by Chef -<% [80, 443].each do |port| -%> -> - ServerName nominatim.openstreetmap.org - ServerAdmin webmaster@openstreetmap.org - ServerAlias nominatim.osm.org + + ServerName <%= node[:fqdn] %> ServerAlias nominatim.openstreetmap.org + ServerAlias nominatim.osm.org + ServerAlias nominatim.openstreetmap.com ServerAlias nominatim.openstreetmap.net ServerAlias nominatim.openstreetmaps.org ServerAlias nominatim.openmaps.org + ServerAdmin webmaster@openstreetmap.org -<% if port == 443 -%> - # # Enable SSL - # SSLEngine on -<% end -%> + SSLProxyEngine on + SSLCertificateFile /etc/ssl/certs/nominatim.openstreetmap.org.pem + SSLCertificateKeyFile /etc/ssl/private/nominatim.openstreetmap.org.key + + # Remove Proxy request header to mitigate https://httpoxy.org/ + RequestHeader unset Proxy early - CustomLog /var/log/apache2/nominatim.openstreetmap.org-access.log combined + RequestReadTimeout header=15-30,MinRate=500 body=15-30,MinRate=500 + + CustomLog <%= node[:nominatim][:logdir] %>/nominatim.openstreetmap.org-access.log combined ErrorLog /var/log/apache2/nominatim.openstreetmap.org-error.log DocumentRoot <%= @directory %>/website /website/"> DirectoryIndex search.php - Options MultiViews FollowSymLinks - AddType text/html .php - AddType application/xml .phpx - AddType application/json .phpj -<% if node[:lsb][:release].to_f >= 14.04 -%> - ProxyPassMatch ^/(.*\.php(/.*)?)$ unix:/var/run/php5-fpm-www.sock|fcgi://localhost<%= @directory %>/website/ - ProxyPassMatch ^/(.*\.phpx(/.*)?)$ unix:/var/run/php5-fpm-www.sock|fcgi://localhost<%= @directory %>/website/ - ProxyPassMatch ^/(.*\.phpj(/.*)?)$ unix:/var/run/php5-fpm-www.sock|fcgi://localhost<%= @directory %>/website/ -<% else -%> - AddHandler fcgi:/var/run/php5-fpm-www.sock .php - AddHandler fcgi:/var/run/php5-fpm-www.sock .phpx - AddHandler fcgi:/var/run/php5-fpm-www.sock .phpj -<% end -%> + Options FollowSymLinks + Require all granted + ProxyPassMatch ^/([^/]*\.php(/.*)?)$ fcgi://127.0.0.1:<%= @pools[:www][:port ]%><%= @directory %>/website/$1 + <% @pools.each do |name,details| -%> Alias /pool-<%= name %>/ "<%= @directory %>/website/" - > -<% if node[:lsb][:release].to_f >= 14.04 -%> - ProxyPassMatch ^/(.*\.php(/.*)?)$ unix:/var/run/php5-fpm-<%= name %>.sock|fcgi://localhost<%= @directory %>/website/ - ProxyPassMatch ^/(.*\.phpx(/.*)?)$ unix:/var/run/php5-fpm-<%= name %>.sock|fcgi://localhost<%= @directory %>/website/ - ProxyPassMatch ^/(.*\.phpj(/.*)?)$ unix:/var/run/php5-fpm-<%= name %>.sock|fcgi://localhost<%= @directory %>/website/ -<% else -%> - AddHandler fcgi:/var/run/php5-fpm-<%= name %>.sock .php - AddHandler fcgi:/var/run/php5-fpm-<%= name %>.sock .phpx - AddHandler fcgi:/var/run/php5-fpm-<%= name %>.sock .phpj -<% end -%> - + <% node[:nominatim][:redirects].each do |url,host| -%> + ProxyPassMatch ^/pool-<%= name %>/(<%= url %>\.php(/.*)?) http<% if port == 443 -%>s<% end -%>://<%= host %>/pool-<%= name %>/$1 + <% end -%> + ProxyPassMatch ^/pool-<%= name %>/(.*\.php(/.*)?) fcgi://127.0.0.1:<%= details[:port ]%><%= @directory %>/website/$1 <% end -%> - Redirect 420 /pool-block/ - ErrorDocument 420 /509.html + Redirect 429 /pool-block/ + ErrorDocument 429 /509.html - ErrorDocument 420 /509.html + ErrorDocument 429 /509.html Redirect 403 /pool-ban/ @@ -71,8 +59,23 @@ # regular requests and autoblocks RewriteMap bulklist txt:<%= @directory %>/settings/ip_blocks.map - RewriteRule ^/([sdr].*) /pool-${bulklist:%{REMOTE_ADDR}|www}/$1 [PT] - + RewriteRule ^/(search|reverse|lookup)(\.php)?(/.*)? /pool-${bulklist:%{REMOTE_ADDR}|www}/$1.php$3 [PT] + RewriteRule ^/details(\.php)?(/.*)? /pool-${bulklist:%{REMOTE_ADDR}|details}/details.php$2 [PT] -<% end -%> + + ServerName <%= node[:fqdn] %> + ServerAlias nominatim.openstreetmap.org + ServerAlias nominatim.osm.org + ServerAlias nominatim.openstreetmap.com + ServerAlias nominatim.openstreetmap.net + ServerAlias nominatim.openstreetmaps.org + ServerAlias nominatim.openmaps.org + ServerAdmin webmaster@openstreetmap.org + + CustomLog <%= node[:nominatim][:logdir] %>/nominatim.openstreetmap.org-access.log combined + ErrorLog /var/log/apache2/nominatim.openstreetmap.org-error.log + + RedirectPermanent /.well-known/acme-challenge/ http://acme.openstreetmap.org/.well-known/acme-challenge/ + RedirectPermanent / https://nominatim.openstreetmap.org/ +