#
-# Cookbook Name:: tile
+# Cookbook:: tile
# Recipe:: default
#
-# Copyright 2013, OpenStreetMap Foundation
+# Copyright:: 2013, OpenStreetMap Foundation
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
-# http://www.apache.org/licenses/LICENSE-2.0
+# https://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# limitations under the License.
#
+include_recipe "accounts"
include_recipe "apache"
include_recipe "git"
+include_recipe "munin"
include_recipe "nodejs"
include_recipe "postgresql"
include_recipe "python"
conf "tile.conf.erb"
end
+ssl_certificate node[:fqdn] do
+ domains [node[:fqdn], "tile.openstreetmap.org", "render.openstreetmap.org"]
+ notifies :reload, "service[apache2]"
+end
+
tilecaches = search(:node, "roles:tilecache").sort_by { |n| n[:hostname] }
apache_site "default" do
mode 0o644
end
-package "python-cairo"
-package "python-mapnik"
-package "python-setuptools"
+package %w[
+ python-cairo
+ python-mapnik
+ python-setuptools
+]
python_package "pyotp"
-package "fonts-noto-cjk"
-package "fonts-noto-hinted"
-package "fonts-noto-unhinted"
-package "fonts-hanazono"
-package "ttf-unifont"
+package %w[
+ fonts-noto-cjk
+ fonts-noto-hinted
+ fonts-noto-unhinted
+ fonts-hanazono
+ ttf-unifont
+]
+
+["NotoSansArabicUI-Regular.ttf", "NotoSansArabicUI-Bold.ttf"].each do |font|
+ remote_file "/usr/share/fonts/truetype/noto/#{font}" do
+ action :create_if_missing
+ source "https://github.com/googlei18n/noto-fonts/raw/master/hinted/#{font}"
+ owner "root"
+ group "root"
+ mode 0o644
+ end
+end
directory "/srv/tile.openstreetmap.org/cgi-bin" do
owner "tile"
end
postgresql_version = node[:tile][:database][:cluster].split("/").first
+postgis_version = node[:tile][:database][:postgis]
-package "postgis"
-package "postgresql-#{postgresql_version}-postgis-2.3"
+package "postgresql-#{postgresql_version}-postgis-#{postgis_version}"
postgresql_user "jburgess" do
cluster node[:tile][:database][:cluster]
database "gis"
end
-%w(geography_columns planet_osm_nodes planet_osm_rels planet_osm_ways raster_columns raster_overviews spatial_ref_sys).each do |table|
+postgresql_extension "hstore" do
+ cluster node[:tile][:database][:cluster]
+ database "gis"
+ only_if { node[:tile][:database][:hstore] }
+end
+
+%w[geography_columns planet_osm_nodes planet_osm_rels planet_osm_ways raster_columns raster_overviews spatial_ref_sys].each do |table|
postgresql_table table do
cluster node[:tile][:database][:cluster]
database "gis"
end
end
-%w(geometry_columns planet_osm_line planet_osm_point planet_osm_polygon planet_osm_roads).each do |table|
+%w[geometry_columns planet_osm_line planet_osm_point planet_osm_polygon planet_osm_roads].each do |table|
postgresql_table table do
cluster node[:tile][:database][:cluster]
database "gis"
database "gis"
end
-file node[:tile][:node_file] do
+directory File.dirname(node[:tile][:database][:node_file]) do
+ owner "root"
+ group "root"
+ mode 0o755
+ recursive true
+end
+
+file node[:tile][:database][:node_file] do
owner "tile"
group "www-data"
- mode 0o640
+ mode 0o660
end
directory "/var/log/tile" do
mode 0o755
end
-package "osm2pgsql"
-package "osmosis"
-
-package "ruby"
-package "ruby-dev"
-
-package "libproj-dev"
-package "libxml2-dev"
+package %w[
+ osm2pgsql
+ ruby
+ osmium-tool
+ pyosmium
+ python-pyproj
+]
-gem_package "proj4rb"
-gem_package "libxml-ruby"
-
-remote_directory "/usr/local/lib/site_ruby" do
- source "ruby"
+remote_directory "/usr/local/bin" do
+ source "bin"
owner "root"
group "root"
mode 0o755
files_owner "root"
files_group "root"
- files_mode 0o644
+ files_mode 0o755
end
template "/usr/local/bin/expire-tiles" do
mode 0o775
end
-template "/var/lib/replicate/configuration.txt" do
- source "replicate.configuration.erb"
- owner "tile"
- group "tile"
- mode 0o644
-end
-
template "/usr/local/bin/replicate" do
source "replicate.erb"
owner "root"
group "root"
mode 0o755
+ variables :postgresql_version => postgresql_version.to_f
end
systemd_service "expire-tiles" do
mode 0o755
end
-template "/etc/cron.d/render-lowzoom" do
- source "render-lowzoom.cron.erb"
- owner "root"
- group "root"
- mode 0o644
+systemd_service "render-lowzoom" do
+ description "Render low zoom tiles"
+ user "tile"
+ exec_start "/usr/local/bin/render-lowzoom"
+ private_tmp true
+ private_devices true
+ private_network true
+ protect_system "full"
+ protect_home true
+ no_new_privileges true
+end
+
+systemd_timer "render-lowzoom" do
+ description "Render low zoom tiles"
+ on_calendar "Sun *-*~07/1 01:00:00"
+end
+
+service "render-lowzoom.timer" do
+ action [:enable, :start]
+end
+
+file "/etc/cron.d/render-lowzoom" do
+ action :delete
end
package "liblockfile-simple-perl"
munin_plugin "renderd_zoom"
munin_plugin "renderd_zoom_time"
-munin_plugin "replication_delay" do
- conf "munin.erb"
-end
+munin_plugin "replication_delay"