#
-# Cookbook Name:: imagery
+# Cookbook:: imagery
# Resource:: imagery_layer
#
-# Copyright 2016, OpenStreetMap Foundation
+# Copyright:: 2016, 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,
property :layer, String, :name_property => true
property :site, String, :required => true
property :source, String, :required => true
-property :root_layer, [TrueClass, FalseClass], :default => false
-property :text, String
+property :root_layer, [true, false], :default => false
+property :title, String
property :copyright, String, :default => "Copyright"
property :projection, String, :default => "EPSG:3857"
property :palette, String
property :resample, String, :default => "average"
property :imagemode, String
property :extension, String, :default => "png"
-property :max_zoom, Fixnum, :default => 23
+property :max_zoom, Integer, :default => 18
property :url_aliases, [String, Array], :default => []
-property :revision, Fixnum, :default => 1
-property :overlay, [TrueClass, FalseClass], :default => false
+property :revision, Integer, :default => 0
+property :overlay, [true, false], :default => false
+property :default_layer, [true, false], :default => false
action :create do
- file "create layer yaml definition" do
+ file "/srv/imagery/layers/#{new_resource.site}/#{new_resource.layer}.yml" do
owner "root"
group "root"
- mode 0644
- if new_resource.overlay
- path "/srv/imagery/overlays/#{site}/#{layer}.yml"
- else
- path "/srv/imagery/layers/#{site}/#{layer}.yml"
- end
- content YAML.dump(:name => layer,
- :url => "http://#{site}/layer/#{layer}/{z}/{x}/{y}.png",
- :attribution => copyright,
- :maxZoom => max_zoom)
+ mode 0o644
+ content YAML.dump(:name => new_resource.layer,
+ :title => new_resource.title || new_resource.layer,
+ :url => "//{s}.#{new_resource.site}/layer/#{new_resource.layer}/{z}/{x}/{y}.png",
+ :attribution => new_resource.copyright,
+ :default => new_resource.default_layer,
+ :maxZoom => new_resource.max_zoom,
+ :overlay => new_resource.overlay)
end
- file "remove old layer yaml" do
- if new_resource.overlay
- path "/srv/imagery/layers/#{site}/#{layer}.yml" # remove layer if overlay
- else
- path "/srv/imagery/overlays/#{site}/#{layer}.yml" # remove overlay if layer
- end
- action :delete
- end
-
- template "/srv/imagery/mapserver/layer-#{layer}.map" do
+ template "/srv/imagery/mapserver/layer-#{new_resource.layer}.map" do
cookbook "imagery"
source "mapserver.map.erb"
owner "root"
group "root"
- mode 0644
+ mode 0o644
variables new_resource.to_hash
end
- systemd_service "mapserv-fcgi-#{layer}" do
- description "Map server for #{layer} layer"
- limit_nofile 16384
- environment "MS_MAPFILE" => "/srv/imagery/mapserver/layer-#{layer}.map",
- "MS_MAP_PATTERN" => "^/srv/imagery/mapserver/"
- user "imagery"
- group "imagery"
- exec_start_pre "/bin/rm -f /run/mapserver-fastcgi/layer-#{layer}.socket"
- exec_start "/usr/bin/spawn-fcgi -s /run/mapserver-fastcgi/layer-#{layer}.socket -M 0666 -P /run/mapserver-fastcgi/layer-#{layer}.pid -- /usr/bin/multiwatch -f 4 --signal=TERM -- /usr/lib/cgi-bin/mapserv"
- pid_file "/run/mapserver-fastcgi/layer-#{layer}.pid"
- type "forking"
- restart "always"
+ # Disable legacy service
+ service "mapserv-fcgi-#{new_resource.layer}" do
+ action [:stop, :disable]
end
- service "mapserv-fcgi-#{layer}" do
- action [:enable, :start]
- subscribes :restart, "template[/srv/imagery/mapserver/layer-#{layer}.map]"
- subscribes :restart, "systemd_service[mapserv-fcgi]"
+ # Remove legacy service
+ systemd_service "mapserv-fcgi-#{new_resource.layer}" do
+ action :delete
end
- directory "/srv/imagery/nginx/#{site}" do
+ directory "/srv/imagery/nginx/#{new_resource.site}" do
owner "root"
group "root"
- mode 0755
+ mode 0o755
recursive true
end
- template "/srv/imagery/nginx/#{site}/layer-#{layer}.conf" do
+ template "/srv/imagery/nginx/#{new_resource.site}/layer-#{new_resource.layer}.conf" do
cookbook "imagery"
source "nginx_imagery_layer_fragment.conf.erb"
owner "root"
group "root"
- mode 0644
+ mode 0o644
variables new_resource.to_hash
end
end
action :delete do
- service "mapserv-fcgi-layer-#{layer}" do
+ file "/srv/imagery/layers/#{new_resource.site}/#{new_resource.layer}.yml" do
+ action :delete
+ end
+
+ service "mapserv-fcgi-layer-#{new_resource.layer}" do
action [:stop, :disable]
end
- file "/srv/imagery/mapserver/layer-#{layer}.map" do
+ file "/srv/imagery/mapserver/layer-#{new_resource.layer}.map" do
action :delete
end
- systemd_service "mapserv-fcgi-#{layer}" do
+ systemd_service "mapserv-fcgi-#{new_resource.layer}" do
action :delete
end
- file "/srv/imagery/nginx/#{site}/layer-#{layer}.conf" do
+ file "/srv/imagery/nginx/#{new_resource.site}/layer-#{new_resource.layer}.conf" do
action :delete
end
end
def after_created
notifies :create, "imagery_site[#{site}]"
- notifies :restart, "service[nginx]"
+ notifies :reload, "service[nginx]"
+ # notifies :restart, "service[mapserv-fcgi-#{site}]"
end