# limitations under the License.
#
+require "yaml"
+
default_action :create
property :name, String
+property :title, String, :required => true
+property :aliases, [String, Array], :default => []
+property :bbox, Array, :required => true
action :create do
- directory "/srv/imagery/#{name}" do
- owner "root"
+ directory "/srv/#{name}" do
+ user "root"
+ group "root"
+ mode 0o755
+ end
+
+ directory "/srv/imagery/layers/#{name}" do
+ user "root"
+ group "root"
+ mode 0o755
+ recursive true
+ end
+
+ directory "/srv/imagery/overlays/#{name}" do
+ user "root"
+ group "root"
+ mode 0o755
+ recursive true
+ end
+
+ template "/srv/#{name}/index.html" do
+ source "index.html.erb"
+ user "root"
+ group "root"
+ mode 0o644
+ variables :title => title
+ end
+
+ cookbook_file "/srv/#{name}/imagery.css" do
+ source "imagery.css"
+ user "root"
+ group "root"
+ mode 0o644
+ end
+
+ cookbook_file "/srv/#{name}/clientaccesspolicy.xml" do
+ source "clientaccesspolicy.xml"
+ user "root"
group "root"
- mode 0755
+ mode 0o644
end
- nginx_site name do
+ cookbook_file "/srv/#{name}/crossdomain.xml" do
+ source "crossdomain.xml"
+ user "root"
+ group "root"
+ mode 0o644
+ end
+
+ layers = Dir.glob("/srv/imagery/layers/#{name}/*.yml").collect do |path|
+ YAML.safe_load(::File.read(path), [Symbol])
+ end
+
+ template "/srv/#{name}/imagery.js" do
+ source "imagery.js.erb"
+ user "root"
+ group "root"
+ mode 0o644
+ variables :bbox => bbox, :layers => layers
+ end
+
+ base_domains = [name] + Array(aliases)
+ tile_domains = base_domains.flat_map { |d| [d, "a.#{d}", "b.#{d}", "c.#{d}"] }
+
+ ssl_certificate new_resource.name do
+ domains tile_domains
+ end
+
+ resolvers = node[:networking][:nameservers].map do |resolver|
+ IPAddr.new(resolver).ipv6? ? "[#{resolver}]" : resolver
+ end
+
+ nginx_site new_resource.name do
template "nginx_imagery.conf.erb"
directory "/srv/imagery/#{name}"
- variables new_resource.to_hash
+ restart_nginx false
+ variables new_resource.to_hash.merge(:resolvers => resolvers)
end
end
+
+def after_created
+ notifies :reload, "service[nginx]"
+end