Replace easy_install_package with python_package
[chef.git] / cookbooks / tile / recipes / default.rb
1 #
2 # Cookbook Name:: tile
3 # Recipe:: default
4 #
5 # Copyright 2013, 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 #     http://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 "apache"
21 include_recipe "git"
22 include_recipe "nodejs"
23 include_recipe "postgresql"
24 include_recipe "python"
25 include_recipe "tools"
26
27 blocks = data_bag_item("tile", "blocks")
28 web_passwords = data_bag_item("web", "passwords")
29
30 apache_module "alias"
31 apache_module "cgi"
32 apache_module "expires"
33 apache_module "headers"
34 apache_module "remoteip"
35 apache_module "rewrite"
36
37 apache_module "tile" do
38   conf "tile.conf.erb"
39 end
40
41 tilecaches = search(:node, "roles:tilecache").sort_by { |n| n[:hostname] }
42
43 apache_site "default" do
44   action [:disable]
45 end
46
47 apache_site "tile.openstreetmap.org" do
48   template "apache.erb"
49   variables :caches => tilecaches
50 end
51
52 template "/etc/logrotate.d/apache2" do
53   source "logrotate.apache.erb"
54   owner "root"
55   group "root"
56   mode 0o644
57 end
58
59 directory "/srv/tile.openstreetmap.org" do
60   owner "tile"
61   group "tile"
62   mode 0o755
63 end
64
65 package "renderd"
66
67 systemd_service "renderd" do
68   description "Mapnik rendering daemon"
69   after "postgresql.service"
70   wants "postgresql.service"
71   user "www-data"
72   exec_start "/usr/bin/renderd -f"
73   runtime_directory "renderd"
74   standard_error "null"
75   private_tmp true
76   private_devices true
77   private_network true
78   protect_system "full"
79   protect_home true
80   no_new_privileges true
81   restart "on-failure"
82 end
83
84 service "renderd" do
85   action [:enable, :start]
86   subscribes :restart, "systemd_service[renderd]"
87 end
88
89 directory "/srv/tile.openstreetmap.org/tiles" do
90   owner "tile"
91   group "tile"
92   mode 0o755
93 end
94
95 template "/etc/renderd.conf" do
96   source "renderd.conf.erb"
97   owner "root"
98   group "root"
99   mode 0o644
100   notifies :reload, "service[apache2]"
101   notifies :restart, "service[renderd]"
102 end
103
104 remote_directory "/srv/tile.openstreetmap.org/html" do
105   source "html"
106   owner "tile"
107   group "tile"
108   mode 0o755
109   files_owner "tile"
110   files_group "tile"
111   files_mode 0o644
112 end
113
114 template "/srv/tile.openstreetmap.org/html/index.html" do
115   source "index.html.erb"
116   owner "tile"
117   group "tile"
118   mode 0o644
119 end
120
121 package "python-cairo"
122 package "python-mapnik"
123 package "python-setuptools"
124
125 python_package "pyotp"
126
127 package "fonts-noto-cjk"
128 package "fonts-noto-hinted"
129 package "fonts-noto-unhinted"
130 package "ttf-unifont"
131
132 directory "/srv/tile.openstreetmap.org/cgi-bin" do
133   owner "tile"
134   group "tile"
135   mode 0o755
136 end
137
138 template "/srv/tile.openstreetmap.org/cgi-bin/export" do
139   source "export.erb"
140   owner "tile"
141   group "tile"
142   mode 0o755
143   variables :blocks => blocks, :totp_key => web_passwords["totp_key"]
144 end
145
146 template "/srv/tile.openstreetmap.org/cgi-bin/debug" do
147   source "debug.erb"
148   owner "tile"
149   group "tile"
150   mode 0o755
151 end
152
153 template "/etc/cron.hourly/export" do
154   source "export.cron.erb"
155   owner "root"
156   group "root"
157   mode 0o755
158 end
159
160 directory "/srv/tile.openstreetmap.org/data" do
161   owner "tile"
162   group "tile"
163   mode 0o755
164 end
165
166 package "mapnik-utils"
167
168 node[:tile][:data].each_value do |data|
169   url = data[:url]
170   file = "/srv/tile.openstreetmap.org/data/#{File.basename(url)}"
171
172   if data[:directory]
173     directory = "/srv/tile.openstreetmap.org/data/#{data[:directory]}"
174
175     directory directory do
176       owner "tile"
177       group "tile"
178       mode 0o755
179     end
180   else
181     directory = "/srv/tile.openstreetmap.org/data"
182   end
183
184   if file =~ /\.tgz$/
185     package "tar"
186
187     execute file do
188       action :nothing
189       command "tar -zxf #{file} -C #{directory}"
190       user "tile"
191       group "tile"
192     end
193   elsif file =~ /\.tar\.bz2$/
194     package "tar"
195
196     execute file do
197       action :nothing
198       command "tar -jxf #{file} -C #{directory}"
199       user "tile"
200       group "tile"
201     end
202   elsif file =~ /\.zip$/
203     package "unzip"
204
205     execute file do
206       action :nothing
207       command "unzip -qq -o #{file} -d #{directory}"
208       user "tile"
209       group "tile"
210     end
211   end
212
213   execute "#{file}_shapeindex" do
214     action :nothing
215     command "find #{directory} -type f -iname '*.shp' -print0 | xargs -0 --no-run-if-empty shapeindex --shape_files"
216     user "tile"
217     group "tile"
218     subscribes :run, "execute[#{file}]", :immediately
219   end
220
221   remote_file file do
222     if data[:refresh]
223       action :create
224       use_conditional_get true
225       ignore_failure true
226     else
227       action :create_if_missing
228     end
229
230     source url
231     owner "tile"
232     group "tile"
233     mode 0o644
234     backup false
235     notifies :run, "execute[#{file}]", :immediately
236     notifies :restart, "service[renderd]"
237   end
238 end
239
240 nodejs_package "carto"
241 nodejs_package "millstone"
242
243 systemd_service "update-lowzoom@" do
244   description "Low zoom tile update service for %i layer"
245   user "tile"
246   exec_start "/usr/local/bin/update-lowzoom-%i"
247   private_tmp true
248   private_devices true
249   private_network true
250   protect_system "full"
251   protect_home true
252   no_new_privileges true
253   restart "on-failure"
254 end
255
256 directory "/srv/tile.openstreetmap.org/styles" do
257   owner "tile"
258   group "tile"
259   mode 0o755
260 end
261
262 node[:tile][:styles].each do |name, details|
263   style_directory = "/srv/tile.openstreetmap.org/styles/#{name}"
264   tile_directory = "/srv/tile.openstreetmap.org/tiles/#{name}"
265
266   template "/usr/local/bin/update-lowzoom-#{name}" do
267     source "update-lowzoom.erb"
268     owner "root"
269     group "root"
270     mode 0o755
271     variables :style => name
272   end
273
274   service "update-lowzoom@#{name}" do
275     action :disable
276     supports :restart => true
277   end
278
279   directory tile_directory do
280     owner "tile"
281     group "tile"
282     mode 0o755
283   end
284
285   details[:tile_directories].each do |directory|
286     directory directory[:name] do
287       owner "www-data"
288       group "www-data"
289       mode 0o755
290     end
291
292     directory[:min_zoom].upto(directory[:max_zoom]) do |zoom|
293       directory "#{directory[:name]}/#{zoom}" do
294         owner "www-data"
295         group "www-data"
296         mode 0o755
297       end
298
299       link "#{tile_directory}/#{zoom}" do
300         to "#{directory[:name]}/#{zoom}"
301         owner "tile"
302         group "tile"
303       end
304     end
305   end
306
307   file "#{tile_directory}/planet-import-complete" do
308     action :create_if_missing
309     owner "tile"
310     group "tile"
311     mode 0o444
312   end
313
314   git style_directory do
315     action :sync
316     repository details[:repository]
317     revision details[:revision]
318     user "tile"
319     group "tile"
320   end
321
322   link "#{style_directory}/data" do
323     to "/srv/tile.openstreetmap.org/data"
324     owner "tile"
325     group "tile"
326   end
327
328   execute "#{style_directory}/project.mml" do
329     action :nothing
330     command "carto -a 3.0.0 project.mml > project.xml"
331     cwd style_directory
332     user "tile"
333     group "tile"
334     subscribes :run, "git[#{style_directory}]"
335     notifies :restart, "service[renderd]", :immediately
336     notifies :restart, "service[update-lowzoom@#{name}]"
337   end
338 end
339
340 postgresql_version = node[:tile][:database][:cluster].split("/").first
341
342 package "postgis"
343 package "postgresql-#{postgresql_version}-postgis-2.3"
344
345 postgresql_user "jburgess" do
346   cluster node[:tile][:database][:cluster]
347   superuser true
348 end
349
350 postgresql_user "tomh" do
351   cluster node[:tile][:database][:cluster]
352   superuser true
353 end
354
355 postgresql_user "tile" do
356   cluster node[:tile][:database][:cluster]
357 end
358
359 postgresql_user "www-data" do
360   cluster node[:tile][:database][:cluster]
361 end
362
363 postgresql_database "gis" do
364   cluster node[:tile][:database][:cluster]
365   owner "tile"
366 end
367
368 postgresql_extension "postgis" do
369   cluster node[:tile][:database][:cluster]
370   database "gis"
371 end
372
373 %w(geography_columns planet_osm_nodes planet_osm_rels planet_osm_ways raster_columns raster_overviews spatial_ref_sys).each do |table|
374   postgresql_table table do
375     cluster node[:tile][:database][:cluster]
376     database "gis"
377     owner "tile"
378     permissions "tile" => :all
379   end
380 end
381
382 %w(geometry_columns planet_osm_line planet_osm_point planet_osm_polygon planet_osm_roads).each do |table|
383   postgresql_table table do
384     cluster node[:tile][:database][:cluster]
385     database "gis"
386     owner "tile"
387     permissions "tile" => :all, "www-data" => :select
388   end
389 end
390
391 postgresql_munin "gis" do
392   cluster node[:tile][:database][:cluster]
393   database "gis"
394 end
395
396 file node[:tile][:node_file] do
397   owner "tile"
398   group "www-data"
399   mode 0o640
400 end
401
402 directory "/var/log/tile" do
403   owner "tile"
404   group "tile"
405   mode 0o755
406 end
407
408 package "osm2pgsql"
409 package "osmosis"
410
411 package "ruby"
412 package "ruby-dev"
413
414 package "libproj-dev"
415 package "libxml2-dev"
416
417 gem_package "proj4rb"
418 gem_package "libxml-ruby"
419
420 remote_directory "/usr/local/lib/site_ruby" do
421   source "ruby"
422   owner "root"
423   group "root"
424   mode 0o755
425   files_owner "root"
426   files_group "root"
427   files_mode 0o644
428 end
429
430 template "/usr/local/bin/expire-tiles" do
431   source "expire-tiles.erb"
432   owner "root"
433   group "root"
434   mode 0o755
435 end
436
437 directory "/var/lib/replicate" do
438   owner "tile"
439   group "tile"
440   mode 0o755
441 end
442
443 directory "/var/lib/replicate/expire-queue" do
444   owner "tile"
445   group "www-data"
446   mode 0o775
447 end
448
449 template "/var/lib/replicate/configuration.txt" do
450   source "replicate.configuration.erb"
451   owner "tile"
452   group "tile"
453   mode 0o644
454 end
455
456 template "/usr/local/bin/replicate" do
457   source "replicate.erb"
458   owner "root"
459   group "root"
460   mode 0o755
461 end
462
463 systemd_service "expire-tiles" do
464   description "Tile dirtying service"
465   type "simple"
466   user "www-data"
467   exec_start "/usr/local/bin/expire-tiles"
468   standard_output "null"
469   private_tmp true
470   private_devices true
471   protect_system "full"
472   protect_home true
473   no_new_privileges true
474 end
475
476 systemd_path "expire-tiles" do
477   description "Tile dirtying trigger"
478   directory_not_empty "/var/lib/replicate/expire-queue"
479 end
480
481 service "expire-tiles.path" do
482   action [:enable, :start]
483   subscribes :restart, "systemd_path[expire-tiles]"
484 end
485
486 systemd_service "replicate" do
487   description "Rendering database replication service"
488   after "postgresql.service"
489   wants "postgresql.service"
490   user "tile"
491   exec_start "/usr/local/bin/replicate"
492   private_tmp true
493   private_devices true
494   protect_system "full"
495   protect_home true
496   no_new_privileges true
497   restart "on-failure"
498 end
499
500 service "replicate" do
501   action [:enable, :start]
502   subscribes :restart, "template[/usr/local/bin/replicate]"
503   subscribes :restart, "systemd_service[replicate]"
504 end
505
506 template "/etc/logrotate.d/replicate" do
507   source "replicate.logrotate.erb"
508   owner "root"
509   group "root"
510   mode 0o644
511 end
512
513 template "/usr/local/bin/render-lowzoom" do
514   source "render-lowzoom.erb"
515   owner "root"
516   group "root"
517   mode 0o755
518 end
519
520 template "/etc/cron.d/render-lowzoom" do
521   source "render-lowzoom.cron.erb"
522   owner "root"
523   group "root"
524   mode 0o644
525 end
526
527 package "liblockfile-simple-perl"
528 package "libfilesys-df-perl"
529
530 template "/usr/local/bin/cleanup-tiles" do
531   source "cleanup-tiles.erb"
532   owner "root"
533   group "root"
534   mode 0o755
535 end
536
537 tile_directories = node[:tile][:styles].collect do |_, style|
538   style[:tile_directories].collect { |directory| directory[:name] }
539 end.flatten.sort.uniq
540
541 template "/etc/cron.d/cleanup-tiles" do
542   source "cleanup-tiles.cron.erb"
543   owner "root"
544   group "root"
545   mode 0o644
546   variables :directories => tile_directories
547 end
548
549 munin_plugin "mod_tile_fresh"
550 munin_plugin "mod_tile_latency"
551 munin_plugin "mod_tile_response"
552 munin_plugin "mod_tile_zoom"
553
554 munin_plugin "renderd_processed"
555 munin_plugin "renderd_queue"
556 munin_plugin "renderd_queue_time"
557 munin_plugin "renderd_zoom"
558 munin_plugin "renderd_zoom_time"
559
560 munin_plugin "replication_delay" do
561   conf "munin.erb"
562 end