X-Git-Url: https://git.openstreetmap.org/chef.git/blobdiff_plain/5484f64dfab168ab94af4c077e9ce178b659f6a2..de935728632b0969362c56e9f66d13295bde91f8:/cookbooks/tile/recipes/default.rb diff --git a/cookbooks/tile/recipes/default.rb b/cookbooks/tile/recipes/default.rb index 0a703017c..62f9a8858 100644 --- a/cookbooks/tile/recipes/default.rb +++ b/cookbooks/tile/recipes/default.rb @@ -24,6 +24,7 @@ include_recipe "postgresql" include_recipe "tools" blocks = data_bag_item("tile", "blocks") +web_passwords = data_bag_item("web", "passwords") apache_module "alias" apache_module "cgi" @@ -62,9 +63,24 @@ end package "renderd" +systemd_service "renderd" do + description "Mapnik rendering daemon" + after "postgresql.service" + wants "postgresql.service" + user "www-data" + exec_start "/usr/bin/renderd -f" + runtime_directory "renderd" + standard_error "null" + private_tmp true + private_devices true + private_network true + protect_system "full" + protect_home true + restart "on-failure" +end + service "renderd" do action [:enable, :start] - supports :status => false, :restart => true, :reload => false end directory "/srv/tile.openstreetmap.org/tiles" do @@ -101,23 +117,14 @@ end package "python-cairo" package "python-mapnik" +package "python-setuptools" -package "ttf-dejavu" -package "ttf-unifont" - -if node[:lsb][:release].to_f >= 16.04 - package "fonts-droid-fallback" -else - package "fonts-droid" -end +easy_install_package "pyotp" -package "fonts-sipa-arundina" -package "fonts-sil-padauk" -package "fonts-khmeros" -package "fonts-beng-extra" -package "fonts-gargi" -package "fonts-taml-tscu" -package "fonts-tibetan-machine" +package "fonts-noto-cjk" +package "fonts-noto-hinted" +package "fonts-noto-unhinted" +package "ttf-unifont" directory "/srv/tile.openstreetmap.org/cgi-bin" do owner "tile" @@ -130,7 +137,7 @@ template "/srv/tile.openstreetmap.org/cgi-bin/export" do owner "tile" group "tile" mode 0o755 - variables :blocks => blocks + variables :blocks => blocks, :totp_key => web_passwords["totp_key"] end template "/srv/tile.openstreetmap.org/cgi-bin/debug" do @@ -312,7 +319,7 @@ node[:tile][:styles].each do |name, details| execute "#{style_directory}/project.mml" do action :nothing - command "carto project.mml > project.xml" + command "carto -a 3.0.0 project.mml > project.xml" cwd style_directory user "tile" group "tile" @@ -322,7 +329,10 @@ node[:tile][:styles].each do |name, details| end end +postgresql_version = node[:tile][:database][:cluster].split("/").first + package "postgis" +package "postgresql-#{postgresql_version}-postgis-2.3" postgresql_user "jburgess" do cluster node[:tile][:database][:cluster] @@ -443,18 +453,23 @@ template "/usr/local/bin/replicate" do mode 0o755 end -template "/etc/init.d/replicate" do - source "replicate.init.erb" - owner "root" - group "root" - mode 0o755 +systemd_service "replicate" do + description "Rendering database replication service" + after "postgresql.service" + wants "postgresql.service" + user "tile" + exec_start "/usr/local/bin/replicate" + private_tmp true + private_devices true + protect_system "full" + protect_home true + restart "on-failure" end service "replicate" do action [:enable, :start] - supports :restart => true subscribes :restart, "template[/usr/local/bin/replicate]" - subscribes :restart, "template[/etc/init.d/replicate]" + subscribes :restart, "systemd_service[replicate]" end template "/etc/logrotate.d/replicate" do @@ -478,32 +493,6 @@ template "/etc/cron.d/render-lowzoom" do mode 0o644 end -if node[:lsb][:release].to_f >= 16.04 - file "/etc/rsyslog.d/20-renderd.conf" do - action :delete - notifies :restart, "service[rsyslog]" - end - - file "/etc/logrotate.d/renderd" do - action :delete - end -else - template "/etc/rsyslog.d/20-renderd.conf" do - source "renderd.rsyslog.erb" - owner "root" - group "root" - mode 0o644 - notifies :restart, "service[rsyslog]" - end - - template "/etc/logrotate.d/renderd" do - source "renderd.logrotate.erb" - owner "root" - group "root" - mode 0o644 - end -end - package "liblockfile-simple-perl" package "libfilesys-df-perl"