X-Git-Url: https://git.openstreetmap.org/rails.git/blobdiff_plain/10079fbba9eb376a1f0aeaf24ff4484bde0a726d..1f399ffd8591835c0315bae25c5f48f6060e12c7:/config/nginx.conf diff --git a/config/nginx.conf b/config/nginx.conf index a78e1dc70..1da97a6d5 100644 --- a/config/nginx.conf +++ b/config/nginx.conf @@ -136,8 +136,19 @@ http { } # Placeholder for blocking abuse + include /etc/nginx/blocked_hosts; allow all; - + + # Block some bulk download agents + if ($http_user_agent ~* LWP::Simple|downloadosm|BBBike) { + return 403; + } + + # Block some robots + if ($http_user_agent ~* msnbot|twiceler) { + return 403; + } + # Map api.openstreetmap/0.n/... to api.openstreetmap/api/0.n/... if ($host ~* ^api\.) { rewrite ^/(0\.[0-9]+)/(.*)$ /api/$1/$2; @@ -147,6 +158,16 @@ http { # Strip asset tags location ~ ^/(images|javascripts|openlayers|stylesheets|user/image)/ { rewrite ^/(.*)/[0-9]+$ /$1; + expires max; + + # Handle Special Case Expiry + if ($uri ~ ^/openlayers/) { + expires 7d; + } + } + # Handle Special Case Expiry + location ~ ^/export/embed.html$ { + expires 7d; } # Include fastcgi configuration @@ -194,17 +215,6 @@ http { return 404; } - # Handle Special Case Expiry - location ~ ^/openlayers/ { - expires 7d; - } - location ~ ^/export/embed.html$ { - expires 7d; - } - location ~ ^/(images|javascripts|stylesheets)/ { - expires max; - } - # Send everything else to the web backend unless it exists # in the rails public tree location / { @@ -228,5 +238,13 @@ http { text/x-cross-domain-policy xml; } } + + # Give munin access to some statistics + location /server-status { + stub_status on; + access_log off; + allow 127.0.0.1; + deny all; + } } }