]> git.openstreetmap.org Git - chef.git/blob - cookbooks/wordpress/templates/default/apache.erb
d78d0dfb53157e2100b58b3b56aa888d20322bf5
[chef.git] / cookbooks / wordpress / 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
23   ServerAdmin webmaster@openstreetmap.org
24
25   SSLEngine on
26   SSLCertificateFile /etc/ssl/certs/<%= @name %>.pem
27   SSLCertificateKeyFile /etc/ssl/private/<%= @name %>.key
28
29   CustomLog /var/log/apache2/<%= @name %>-access.log combined
30   ErrorLog /var/log/apache2/<%= @name %>-error.log
31 <% end -%>
32
33   DocumentRoot <%= @directory %>
34 <% @urls.each do |url,directory| -%>
35   Alias <%= url %> <%= directory %>
36   <Directory <%= directory %>>
37     AllowOverride None
38     Require all granted
39     <FilesMatch ".+\.ph(ar|p|tml)$">
40       SetHandler None
41     </FilesMatch>
42   </Directory>
43 <% end -%>
44
45   <Directory <%= @directory %>>
46     RewriteEngine on
47
48     RewriteRule ^wp-admin/includes/ - [F,L]
49     RewriteRule !^wp-includes/ - [S=3]
50     RewriteRule ^wp-includes/[^/]+\.php$ - [F,L]
51     RewriteRule ^wp-includes/js/tinymce/langs/.+\.php - [F,L]
52     RewriteRule ^wp-includes/theme-compat/ - [F,L]
53     RewriteRule ^readme\.html$ [F,L]
54     RewriteCond %{REQUEST_FILENAME} !-f
55     RewriteCond %{REQUEST_FILENAME} !-d
56     RewriteRule . /index.php [L]
57
58     Options -Indexes
59     AllowOverride AuthConfig
60
61     Require all granted
62
63     # https://www.wp-pay.org/http-authorization-header-missing/
64     CGIPassAuth on
65
66     <FilesMatch ".+\.ph(ar|p|tml)$">
67       SetHandler "proxy:unix:/run/php/php-<%= @name %>-fpm.sock|fcgi://127.0.0.1"
68     </FilesMatch>
69   </Directory>
70
71   <Files <%= @directory %>/wp-config.php>
72     Require all denied
73   </Files>
74
75   <Directory <%= @directory %>/uploads>
76     AllowOverride None
77     AddType text/plain .html .htm .shtml
78     <FilesMatch ".+\.ph(ar|p|tml)$">
79       SetHandler None
80     </FilesMatch>
81   </Directory>
82
83   <Directory ~ "\.svn">
84     Require all denied
85   </Directory>
86
87   <Directory ~ "\.git">
88     Require all denied
89   </Directory>
90
91   <Files ~ "\.(txt|md)$">
92     Require all denied
93   </Files>
94
95   <Files ~ "~$">
96     Require all denied
97   </Files>
98 </VirtualHost>