2 # Load the modules that we need
 
  17 # Basic server configuration
 
  19 server.username = "www-data"
 
  20 server.groupname = "www-data"
 
  21 server.pid-file = "/var/run/lighttpd.pid"
 
  23 server.reject-expect-100-with-417 = "disable"
 
  28 accesslog.filename = "/var/log/lighttpd/access.log"
 
  29 accesslog.format = "%h %V %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\" \"%{Accept-Language}i\""
 
  30 server.errorlog = "/var/log/lighttpd/error.log"
 
  33 # Allow munin to monitor the server's status
 
  35 $HTTP["remoteip"] == "128.40.168.98" {
 
  36   status.config-url = "/server-config"
 
  37   status.status-url = "/server-status"
 
  38   status.statistics-url = "/server-statistics"
 
  44 include_shell "lighttpd-host-blocks.sh"
 
  47 # Block some troublesome robots
 
  49 #$HTTP["useragent"] =~ "msnbot" { url.access-deny = ("") }
 
  50 $HTTP["useragent"] =~ "Twiceler" { url.access-deny = ("") }
 
  51 $HTTP["useragent"] =~ "Baiduspider" { url.access-deny = ("") }
 
  52 $HTTP["useragent"] =~ "Sosospider+" { url.access-deny = ("") }
 
  53 #$HTTP["useragent"] =~ "Yahoo! Slurp" { url.access-deny = ("") }
 
  54 $HTTP["useragent"] =~ "Yeti" { url.access-deny = ("") }
 
  55 #$HTTP["useragent"] =~ "Googlebot" { url.access-deny = ("") }
 
  56 $HTTP["useragent"] =~ "The Hare and the Hedgeho" { url.access-deny = ("") }
 
  61 $HTTP["useragent"] =~ "tilesAtHome" { url.access-deny = ("") }
 
  64 # Block JOSM revisions  1722-1727 as they have a serious bug that causes
 
  65 # lat/lon to be swapped (http://josm.openstreetmap.de/ticket/2804)
 
  67 $HTTP["useragent"] =~ "^JOSM/[0-9]+\.[0-9]+ \(172[234567] " {
 
  68   url.access-deny = ("")
 
  72 # Setup MIME type mapping
 
  76   ".gif" => "image/gif",
 
  77   ".html" => "text/html; charset=utf-8",
 
  78   ".jpg" => "image/jpeg",
 
  79   ".js" => "application/x-javascript",
 
  80   ".png" => "image/png",
 
  81   ".swf" => "application/x-shockwave-flash",
 
  82   ".txt" => "text/plain",
 
  87 # Force special MIME type for crossdomain.xml files
 
  89 $HTTP["url"] =~ "/crossdomain\.xml$" {
 
  90   mimetype.assign = ( ".xml" => "text/x-cross-domain-policy" )
 
  94 # Enable compression of appropriate static content
 
  97   "application/x-javascript",
 
  98   "application/x-shockwave-flash",
 
 105 # Set expiry for static content
 
 108   "/export/embed.html" => "access 7 days",
 
 109   "/images/" => "access 10 years",
 
 110   "/javascripts/" => "access 10 years",
 
 111   "/openlayers/" => "access 7 days",
 
 112   "/stylesheets/" => "access 10 years"
 
 116 # Cache compressed content
 
 118 compress.cache-dir = "/var/cache/lighttpd"
 
 121 # Redirect trac and wiki requests to the right places
 
 124   "^/trac/(.*)$" => "http://trac.openstreetmap.org/$1",
 
 125   "^/wiki/(.*)$" => "http://wiki.openstreetmap.org/$1"
 
 129 # Redirect everything except www.openstreetmap.org and
 
 130 # api.openstreetmap.org to www.openstreetmap.org
 
 132 $HTTP["host"] =~ "^api\." {
 
 133   $HTTP["host"] != "api.openstreetmap.org" {
 
 134     url.redirect = ( "^(.*)$" => "http://api.openstreetmap.org$1" )
 
 137 else $HTTP["host"] != "www.openstreetmap.org" {
 
 138   url.redirect = ( "^(.*)$" => "http://www.openstreetmap.org$1" )
 
 142 # Run anything with a .pl iextension as a CGI script
 
 144 cgi.assign = ( ".pl" => "/usr/bin/perl" )
 
 147 # Serve static content from the rails public area ourselves
 
 149 server.document-root = "/home/rails/public"
 
 152 # Send everything else to the appropriate FastCGI server
 
 154 $HTTP["url"] =~ "^/trace/[0-9]+/data$" {
 
 155   server.error-handler-404 = "/dispatch.bulkapi"
 
 157 else $HTTP["url"] =~ "^/api/0\.6/map$" {
 
 158   server.error-handler-404 = "/dispatch.map"
 
 160 else $HTTP["url"] =~ "^/api/0\.6/(trackpoints|amf|amf/read|swf/trackpoints|changeset/[0-9]+/(upload|download))$" {
 
 161   server.error-handler-404 = "/dispatch.bulkapi"
 
 163 else $HTTP["url"] =~ "^/api/0\.6/.*/(full|history|search|ways)$" {
 
 164   server.error-handler-404 = "/dispatch.bulkapi"
 
 166 else $HTTP["url"] =~ "^/api/0\.6/" {
 
 167   server.error-handler-404 = "/dispatch.api"
 
 169 else $HTTP["url"] =~ "^/api/0\.[0-9]+/" {
 
 170   url.access-deny = ("")
 
 172 else $HTTP["url"] =~ "^/geocoder/(search|description)_geonames$" {
 
 173   server.error-handler-404 = "/dispatch.geonames"
 
 175 else $HTTP["url"] =~ "^/" {
 
 176   server.error-handler-404 = "/dispatch.web"
 
 180 # Configure the FastCGI servers
 
 184     ( "host" => "127.0.0.1", "port" => 8000, "check-local" => "disable" ),
 
 185     ( "host" => "127.0.0.1", "port" => 8001, "check-local" => "disable" ),
 
 186     ( "host" => "127.0.0.1", "port" => 8002, "check-local" => "disable" ),
 
 187     ( "host" => "127.0.0.1", "port" => 8003, "check-local" => "disable" ),
 
 188     ( "host" => "127.0.0.1", "port" => 8004, "check-local" => "disable" ),
 
 189     ( "host" => "127.0.0.1", "port" => 8005, "check-local" => "disable" ),
 
 190     ( "host" => "127.0.0.1", "port" => 8006, "check-local" => "disable" ),
 
 191     ( "host" => "127.0.0.1", "port" => 8007, "check-local" => "disable" ),
 
 192     ( "host" => "127.0.0.1", "port" => 8008, "check-local" => "disable" ),
 
 193     ( "host" => "127.0.0.1", "port" => 8009, "check-local" => "disable" ),
 
 194     ( "host" => "127.0.0.1", "port" => 8010, "check-local" => "disable" ),
 
 195     ( "host" => "127.0.0.1", "port" => 8011, "check-local" => "disable" ),
 
 196     ( "host" => "127.0.0.1", "port" => 8012, "check-local" => "disable" ),
 
 197     ( "host" => "127.0.0.1", "port" => 8013, "check-local" => "disable" ),
 
 198     ( "host" => "127.0.0.1", "port" => 8014, "check-local" => "disable" ),
 
 199     ( "host" => "127.0.0.1", "port" => 8015, "check-local" => "disable" ),
 
 200     ( "host" => "127.0.0.1", "port" => 8016, "check-local" => "disable" ),
 
 201     ( "host" => "127.0.0.1", "port" => 8017, "check-local" => "disable" ),
 
 202     ( "host" => "127.0.0.1", "port" => 8018, "check-local" => "disable" ),
 
 203     ( "host" => "127.0.0.1", "port" => 8019, "check-local" => "disable" ),
 
 204     ( "host" => "127.0.0.1", "port" => 8020, "check-local" => "disable" ),
 
 205     ( "host" => "127.0.0.1", "port" => 8021, "check-local" => "disable" ),
 
 206     ( "host" => "127.0.0.1", "port" => 8022, "check-local" => "disable" ),
 
 207     ( "host" => "127.0.0.1", "port" => 8023, "check-local" => "disable" ),
 
 208     ( "host" => "127.0.0.1", "port" => 8024, "check-local" => "disable" ),
 
 209     ( "host" => "127.0.0.1", "port" => 8025, "check-local" => "disable" ),
 
 210     ( "host" => "127.0.0.1", "port" => 8026, "check-local" => "disable" ),
 
 211     ( "host" => "127.0.0.1", "port" => 8027, "check-local" => "disable" ),
 
 212     ( "host" => "127.0.0.1", "port" => 8028, "check-local" => "disable" ),
 
 213     ( "host" => "127.0.0.1", "port" => 8029, "check-local" => "disable" )
 
 216     ( "host" => "127.0.0.1", "port" => 8030, "check-local" => "disable" ),
 
 217     ( "host" => "127.0.0.1", "port" => 8031, "check-local" => "disable" ),
 
 218     ( "host" => "127.0.0.1", "port" => 8032, "check-local" => "disable" ),
 
 219     ( "host" => "127.0.0.1", "port" => 8033, "check-local" => "disable" )
 
 222     ( "host" => "127.0.0.1", "port" => 8034, "check-local" => "disable" ),
 
 223     ( "host" => "127.0.0.1", "port" => 8035, "check-local" => "disable" ),
 
 224     ( "host" => "127.0.0.1", "port" => 8036, "check-local" => "disable" ),
 
 225     ( "host" => "127.0.0.1", "port" => 8037, "check-local" => "disable" ),
 
 226     ( "host" => "127.0.0.1", "port" => 8038, "check-local" => "disable" ),
 
 227     ( "host" => "127.0.0.1", "port" => 8039, "check-local" => "disable" ),
 
 228     ( "host" => "127.0.0.1", "port" => 8040, "check-local" => "disable" ),
 
 229     ( "host" => "127.0.0.1", "port" => 8041, "check-local" => "disable" ),
 
 230     ( "host" => "127.0.0.1", "port" => 8042, "check-local" => "disable" ),
 
 231     ( "host" => "127.0.0.1", "port" => 8043, "check-local" => "disable" ),
 
 232     ( "host" => "127.0.0.1", "port" => 8044, "check-local" => "disable" ),
 
 233     ( "host" => "127.0.0.1", "port" => 8045, "check-local" => "disable" ),
 
 234     ( "host" => "127.0.0.1", "port" => 8046, "check-local" => "disable" ),
 
 235     ( "host" => "127.0.0.1", "port" => 8047, "check-local" => "disable" ),
 
 236     ( "host" => "127.0.0.1", "port" => 8048, "check-local" => "disable" )
 
 239     ( "host" => "10.0.0.10", "port" => 8000, "check-local" => "disable" ),
 
 240     ( "host" => "10.0.0.11", "port" => 8000, "check-local" => "disable" ),
 
 241     ( "host" => "10.0.0.12", "port" => 8000, "check-local" => "disable" ),
 
 242     ( "host" => "10.0.0.10", "port" => 8001, "check-local" => "disable" ),
 
 243     ( "host" => "10.0.0.11", "port" => 8001, "check-local" => "disable" ),
 
 244     ( "host" => "10.0.0.12", "port" => 8001, "check-local" => "disable" ),
 
 245     ( "host" => "10.0.0.10", "port" => 8002, "check-local" => "disable" ),
 
 246     ( "host" => "10.0.0.11", "port" => 8002, "check-local" => "disable" ),
 
 247     ( "host" => "10.0.0.12", "port" => 8002, "check-local" => "disable" ),
 
 248     ( "host" => "10.0.0.10", "port" => 8003, "check-local" => "disable" ),
 
 249     ( "host" => "10.0.0.11", "port" => 8003, "check-local" => "disable" ),
 
 250     ( "host" => "10.0.0.12", "port" => 8003, "check-local" => "disable" ),
 
 251     ( "host" => "10.0.0.10", "port" => 8004, "check-local" => "disable" ),
 
 252     ( "host" => "10.0.0.11", "port" => 8004, "check-local" => "disable" ),
 
 253     ( "host" => "10.0.0.12", "port" => 8004, "check-local" => "disable" ),
 
 254     ( "host" => "10.0.0.10", "port" => 8005, "check-local" => "disable" ),
 
 255     ( "host" => "10.0.0.11", "port" => 8005, "check-local" => "disable" ),
 
 256     ( "host" => "10.0.0.12", "port" => 8005, "check-local" => "disable" ),
 
 257     ( "host" => "10.0.0.10", "port" => 8006, "check-local" => "disable" ),
 
 258     ( "host" => "10.0.0.11", "port" => 8006, "check-local" => "disable" ),
 
 259     ( "host" => "10.0.0.12", "port" => 8006, "check-local" => "disable" ),
 
 260     ( "host" => "10.0.0.10", "port" => 8007, "check-local" => "disable" ),
 
 261     ( "host" => "10.0.0.11", "port" => 8007, "check-local" => "disable" ),
 
 262     ( "host" => "10.0.0.12", "port" => 8007, "check-local" => "disable" ),
 
 263     ( "host" => "10.0.0.10", "port" => 8008, "check-local" => "disable" ),
 
 264     ( "host" => "10.0.0.11", "port" => 8008, "check-local" => "disable" ),
 
 265     ( "host" => "10.0.0.12", "port" => 8008, "check-local" => "disable" ),
 
 266     ( "host" => "10.0.0.10", "port" => 8009, "check-local" => "disable" ),
 
 267     ( "host" => "10.0.0.11", "port" => 8009, "check-local" => "disable" ),
 
 268     ( "host" => "10.0.0.12", "port" => 8009, "check-local" => "disable" ),
 
 269     ( "host" => "10.0.0.10", "port" => 8010, "check-local" => "disable" ),
 
 270     ( "host" => "10.0.0.11", "port" => 8010, "check-local" => "disable" ),
 
 271     ( "host" => "10.0.0.12", "port" => 8010, "check-local" => "disable" ),
 
 272     ( "host" => "10.0.0.10", "port" => 8011, "check-local" => "disable" ),
 
 273     ( "host" => "10.0.0.11", "port" => 8011, "check-local" => "disable" ),
 
 274     ( "host" => "10.0.0.12", "port" => 8011, "check-local" => "disable" )
 
 277     ( "host" => "10.0.0.10", "port" => 9000, "check-local" => "disable" ),
 
 278     ( "host" => "10.0.0.11", "port" => 9000, "check-local" => "disable" ),
 
 279     ( "host" => "10.0.0.12", "port" => 9000, "check-local" => "disable" )