]> git.openstreetmap.org Git - chef.git/blob - cookbooks/mediawiki/templates/default/apache.erb
fd23a53418ef1aa5395e262cd5a5c19308d70a5b
[chef.git] / cookbooks / mediawiki / templates / default / apache.erb
1 # DO NOT EDIT - This file is being maintained by Chef
2
3 <VirtualHost *:80>
4   ServerName <%= @name %>
5 <% @aliases.each do |alias_name| -%>
6   ServerAlias <%= alias_name %>
7 <% end -%>
8
9   ServerAdmin webmaster@openstreetmap.org
10
11   CustomLog /var/log/apache2/<%= @name %>-access.log combined
12   ErrorLog /var/log/apache2/<%= @name %>-error.log
13
14   RedirectPermanent /.well-known/acme-challenge/ http://acme.openstreetmap.org/.well-known/acme-challenge/
15   RedirectPermanent / https://<%= @name %>/
16 </VirtualHost>
17
18 <VirtualHost *:443>
19   ServerName <%= @name %>
20 <% @aliases.each do |alias_name| -%>
21   ServerAlias <%= alias_name %>
22 <% end -%>
23
24   ServerAdmin webmaster@openstreetmap.org
25
26   SSLEngine on
27   SSLCertificateFile /etc/ssl/certs/<%= @name %>.pem
28   SSLCertificateKeyFile /etc/ssl/private/<%= @name %>.key
29
30   CustomLog /var/log/apache2/<%= @name %>-secure-access.log combined
31   ErrorLog /var/log/apache2/<%= @name %>-secure-error.log
32
33   DocumentRoot <%= @directory %>
34
35   AllowEncodedSlashes NoDecode
36
37   ProxyTimeout 300
38
39   RewriteCond %{SERVER_NAME} !=<%= @name %>
40   RewriteRule ^/(.*)$ https://<%= @name %>/$1 [R=permanent]
41
42   RedirectMatch 301 ^/$                           /wiki/Main_Page
43
44   #Historical Compatibility Links
45   RedirectMatch 301 ^/index\.php$                 /w/index.php
46   RedirectMatch 301 ^/index\.php/(.*)$            /wiki/$1
47   RedirectMatch 301 ^/skins/(.*)$                 /w/skins/$1
48   RedirectMatch 301 ^/images/(.*)$                /w/images/$1
49   RedirectMatch 301 ^/api\.php$                   /w/api.php
50   RedirectMatch 301 ^/opensearch_desc\.php$       /w/opensearch_desc.php
51
52   #Support Wikidata redirects based on Wikimedia's redirects:
53   # https://github.com/wikimedia/puppet/blob/production/modules/mediawiki/files/apache/sites/wikidata-uris.incl
54   RedirectMatch 301 ^/entity/statement/([QqPp]\d+).*$        /wiki/Special:EntityData/$1
55   RedirectMatch 301 ^/value/(.*)$                            /wiki/Special:ListDatatypes
56   RedirectMatch 301 ^/reference/(.*)$                        https://wikidata.org/wiki/Help:Sources
57   RedirectMatch 301 ^/prop/direct/(.*)$                      /wiki/Property:$1
58   RedirectMatch 301 ^/prop/direct-normalized/(.*)$           /wiki/Property:$1
59   RedirectMatch 301 ^/prop/novalue/(.*)$                     /wiki/Property:$1
60   RedirectMatch 301 ^/prop/statement/value/(.*)$             /wiki/Property:$1
61   RedirectMatch 301 ^/prop/statement/value-normalized/(.*)$  /wiki/Property:$1
62   RedirectMatch 301 ^/prop/qualifier/value/(.*)$             /wiki/Property:$1
63   RedirectMatch 301 ^/prop/qualifier/value-normalized/(.*)$  /wiki/Property:$1
64   RedirectMatch 301 ^/prop/reference/value/(.*)$             /wiki/Property:$1
65   RedirectMatch 301 ^/prop/reference/value-normalized/(.*)$  /wiki/Property:$1
66   RedirectMatch 301 ^/prop/statement/(.*)$                   /wiki/Property:$1
67   RedirectMatch 301 ^/prop/qualifier/(.*)$                   /wiki/Property:$1
68   RedirectMatch 301 ^/prop/reference/(.*)$                   /wiki/Property:$1
69   RedirectMatch 301 ^/prop/(.*)$                             /wiki/Property:$1
70   RedirectMatch 301 ^/entity/(.*)$                           /wiki/Special:EntityData/$1
71
72   Alias /wiki <%= @directory %>/w/index.php
73
74   #Support /pagename -> /wiki/pagename
75   RewriteEngine on
76   RewriteCond %{REQUEST_URI} !^/w/
77   RewriteCond %{REQUEST_URI} !^/wiki/
78   RewriteCond %{REQUEST_URI} !^/index\.php
79   RewriteCond %{REQUEST_URI} !^/skins/
80   RewriteCond %{REQUEST_URI} !^/images/
81   RewriteCond %{REQUEST_URI} !^/api\.php$
82   RewriteCond %{REQUEST_URI} !^/opensearch_desc\.php$
83   RewriteCond %{REQUEST_URI} !^/entity/
84   RewriteCond %{REQUEST_URI} !^/value/
85   RewriteCond %{REQUEST_URI} !^/reference/
86   RewriteCond %{REQUEST_URI} !^/prop/  
87   RewriteCond %{REQUEST_URI} !^/dump/  
88   RewriteCond %{REQUEST_URI} !^/server-status
89   RewriteCond %{REQUEST_URI} !^/.well-known/
90   RewriteCond %{LA-U:REQUEST_FILENAME} !-f
91   RewriteCond %{LA-U:REQUEST_FILENAME} !-d
92   RewriteRule ^/(.*) /wiki/$1 [R,L]
93
94   <Directory <%= @directory %>>
95     Options -Indexes
96     Require all granted
97
98     <FilesMatch ".+\.ph(ar|p|tml)$">
99       SetHandler "proxy:unix:/run/php/php-<%= @name %>-fpm.sock|fcgi://127.0.0.1"
100     </FilesMatch>
101   </Directory>
102
103   <Directory <%= @directory %>/w/images/>
104     Options -ExecCGI -Includes -Indexes
105     AllowOverride None
106     AddType text/plain .html .htm .shtml
107 <% if @private_site -%>
108     Require all denied
109 <% end -%>
110     <FilesMatch ".+\.ph(ar|p|tml)$">
111       SetHandler None
112     </FilesMatch>
113   </Directory>
114
115   <Directory <%= @directory %>/w/images/thumb/>
116     RewriteEngine on
117
118     RewriteCond %{REQUEST_FILENAME} !-f
119     RewriteCond %{REQUEST_FILENAME} !-d
120     RewriteRule ^[0-9a-f]/[0-9a-f][0-9a-f]/([^/]+)/page([0-9]+)-([0-9]+)px-.*$ /w/thumb.php?f=$1&page=$2&width=$3 [L,QSA,B]
121
122     RewriteCond %{REQUEST_FILENAME} !-f
123     RewriteCond %{REQUEST_FILENAME} !-d
124     RewriteRule ^archive/[0-9a-f]/[0-9a-f][0-9a-f]/([^/]+)/page([0-9]+)-([0-9]+)px-.*$ /w/thumb.php?f=$1&page=$2&width=$3&archived=1 [L,QSA,B]
125
126     RewriteCond %{REQUEST_FILENAME} !-f
127     RewriteCond %{REQUEST_FILENAME} !-d
128     RewriteRule ^[0-9a-f]/[0-9a-f][0-9a-f]/([^/]+)/([0-9]+)px-.*$ /w/thumb.php?f=$1&width=$2 [L,QSA,B]
129
130     RewriteCond %{REQUEST_FILENAME} !-f
131     RewriteCond %{REQUEST_FILENAME} !-d
132     RewriteRule ^archive/[0-9a-f]/[0-9a-f][0-9a-f]/([^/]+)/([0-9]+)px-.*$ /w/thumb.php?f=$1&width=$2&archived=1 [L,QSA,B]
133   </Directory>
134
135   <Directory <%= @directory %>/w/maintenance/>
136     Require all denied
137   </Directory>
138
139   <Files <%= @directory %>/w/LocalSettings.php>
140     Require all denied
141   </Files>
142
143   <Directory <%= @directory %>/w/cache/>
144     Options -ExecCGI -Includes -Indexes
145     AllowOverride None
146     AddType text/plain .html .htm .shtml
147     <FilesMatch ".+\.ph(ar|p|tml)$">
148       SetHandler None
149     </FilesMatch>
150   </Directory>
151
152   <Directory <%= @directory %>/dump/>
153     Options Indexes FollowSymLinks MultiViews
154     AllowOverride All
155     IndexIgnore .ht* . robots.txt HEADER.html HEADER.cgi logo.png style.css
156     IndexOptions FancyIndexing FoldersFirst NameWidth=* TrackModified
157     IndexOrderDefault Descending Date
158   </Directory>
159
160   <Directory ~ "\.svn">
161     Require all denied
162   </Directory>
163
164   <Directory ~ "\.git">
165     Require all denied
166   </Directory>
167
168   <Files ~ "~$">
169     Require all denied
170   </Files>
171 </VirtualHost>