]> git.openstreetmap.org Git - chef.git/blob - cookbooks/planet/recipes/default.rb
dns: upgrade dnscontrol to 4.12.5
[chef.git] / cookbooks / planet / recipes / default.rb
1 #
2 # Cookbook:: planet
3 # Recipe:: default
4 #
5 # Copyright:: 2011, OpenStreetMap Foundation
6 #
7 # Licensed under the Apache License, Version 2.0 (the "License");
8 # you may not use this file except in compliance with the License.
9 # You may obtain a copy of the License at
10 #
11 #     https://www.apache.org/licenses/LICENSE-2.0
12 #
13 # Unless required by applicable law or agreed to in writing, software
14 # distributed under the License is distributed on an "AS IS" BASIS,
15 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 # See the License for the specific language governing permissions and
17 # limitations under the License.
18 #
19
20 include_recipe "accounts"
21 include_recipe "apache"
22 include_recipe "geoipupdate"
23 include_recipe "planet::aws"
24
25 package %w[
26   python3
27   python3-geoip2
28 ]
29
30 remote_directory "/store/planet#html" do
31   path "/store/planet"
32   source "html"
33   owner "root"
34   group "root"
35   mode "0755"
36   files_owner "root"
37   files_group "root"
38   files_mode "644"
39 end
40
41 remote_directory "/store/planet#cgi" do
42   path "/store/planet"
43   source "cgi"
44   owner "root"
45   group "root"
46   mode "755"
47   files_owner "root"
48   files_group "root"
49   files_mode "755"
50 end
51
52 remote_directory node[:planet][:dump][:xml_history_directory] do
53   source "history_cgi"
54   owner "planet"
55   group "planet"
56   mode "775"
57   files_owner "root"
58   files_group "root"
59   files_mode "755"
60 end
61
62 remote_directory "/store/planet/cc-by-sa" do
63   source "ccbysa_cgi"
64   owner "planet"
65   group "planet"
66   mode "775"
67   files_owner "root"
68   files_group "root"
69   files_mode "755"
70 end
71
72 remote_directory "/store/planet/cc-by-sa/full-experimental" do
73   source "ccbysa_history_cgi"
74   owner "planet"
75   group "planet"
76   mode "775"
77   files_owner "root"
78   files_group "root"
79   files_mode "755"
80 end
81
82 [:xml_directory, :xml_history_directory,
83  :pbf_directory, :pbf_history_directory].each do |dir|
84   directory node[:planet][:dump][dir] do
85     owner "planet"
86     group "planet"
87     mode "775"
88   end
89 end
90
91 directory "/store/planet/notes" do
92   owner "planet"
93   group "planet"
94   mode "775"
95 end
96
97 directory "/store/planet/statistics" do
98   owner "planet"
99   group "planet"
100   mode "775"
101 end
102
103 template "/usr/local/bin/apache-latest-planet-filename" do
104   source "apache-latest-planet-filename.erb"
105   owner "root"
106   group "root"
107   mode "755"
108   notifies :restart, "service[apache2]"
109 end
110
111 template "/usr/local/bin/apache-s3-ip2region" do
112   source "apache-s3-ip2region.erb"
113   owner "root"
114   group "root"
115   mode "755"
116   notifies :restart, "service[apache2]"
117 end
118
119 apache_module "cgid"
120 apache_module "rewrite"
121 apache_module "proxy_http"
122 apache_module "ratelimit"
123
124 ssl_certificate "planet.openstreetmap.org" do
125   domains ["planet.openstreetmap.org", "planet.osm.org"]
126   notifies :reload, "service[apache2]"
127 end
128
129 apache_site "planet.openstreetmap.org" do
130   template "apache.erb"
131 end
132
133 template "/etc/logrotate.d/apache2" do
134   source "logrotate.apache.erb"
135   owner "root"
136   group "root"
137   mode "644"
138 end
139
140 template "/usr/local/bin/planet-file-cleanup" do
141   source "planet-file-cleanup.erb"
142   owner "root"
143   group "root"
144   mode "755"
145 end
146
147 systemd_service "planet-file-cleanup" do
148   description "Cleanup old planet files"
149   exec_start "/usr/local/bin/planet-file-cleanup --debug"
150   user "planet"
151   sandbox true
152   read_write_paths [
153     node[:planet][:dump][:xml_directory],
154     node[:planet][:dump][:pbf_directory]
155   ]
156 end
157
158 systemd_timer "planet-file-cleanup" do
159   description "Cleanup old planet files"
160   on_calendar "Mon *-*-1..7 03:44"
161 end
162
163 service "planet-file-cleanup.timer" do
164   action [:enable, :start]
165 end