X-Git-Url: https://git.openstreetmap.org./chef.git/blobdiff_plain/b5f1516eba7a79f6f3ec6d7eb5e3517f544cda3f..a449993c2f97f5bfa7c66e8bc1e453946fe25bc7:/cookbooks/imagery/resources/site.rb diff --git a/cookbooks/imagery/resources/site.rb b/cookbooks/imagery/resources/site.rb index 507293e54..f80f0407a 100644 --- a/cookbooks/imagery/resources/site.rb +++ b/cookbooks/imagery/resources/site.rb @@ -17,21 +17,75 @@ # limitations under the License. # +require "yaml" + default_action :create property :name, String +property :title, String, :required => true property :aliases, [String, Array], :default => [] -property :git_repository, String, :default => ["https://github.com/Firefishy/osm-imagery-default.git"] +property :bbox, Array, :required => true action :create do - git "/srv/#{name}" do - action :sync - repository "#{git_repository}" - revision "master" - enable_submodules true - retries 3 + 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 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 nginx_site name do @@ -43,5 +97,5 @@ action :create do end def after_created - notifies :restart, "service[nginx]" + notifies :reload, "service[nginx]" end