X-Git-Url: https://git.openstreetmap.org/chef.git/blobdiff_plain/724d624cb25f8324009ddd4f655b8e1c944f17a3..6adfd52016f87f9622a750cea3e2e926e1f09d61:/cookbooks/imagery/resources/site.rb diff --git a/cookbooks/imagery/resources/site.rb b/cookbooks/imagery/resources/site.rb index 88b122097..f8ab66731 100644 --- a/cookbooks/imagery/resources/site.rb +++ b/cookbooks/imagery/resources/site.rb @@ -17,19 +17,84 @@ # 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/#{name}" do - owner "root" + 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 0755 + 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 0o644 + end + + 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) + + ssl_certificate new_resource.name do + domains base_domains.flat_map { |d| [d, "a.#{d}", "b.#{d}", "c.#{d}"] } end - nginx_site name do + nginx_site new_resource.name do template "nginx_imagery.conf.erb" directory "/srv/imagery/#{name}" restart_nginx false @@ -38,5 +103,5 @@ action :create do end def after_created - notifies :restart, "service[nginx]" + notifies :reload, "service[nginx]" end