X-Git-Url: https://git.openstreetmap.org./chef.git/blobdiff_plain/a738464353e5824384383ee95b9701f81f0af6fe..bd2c6e857ae00b3df208280e81f4f7e7a9a503dd:/cookbooks/imagery/resources/site.rb diff --git a/cookbooks/imagery/resources/site.rb b/cookbooks/imagery/resources/site.rb index 1bbfe82cb..84151ae66 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 0755 + end + + directory "/srv/imagery/layers/#{name}" do + user "root" + group "root" + mode 0755 + recursive true + end + + directory "/srv/imagery/overlays/#{name}" do + user "root" + group "root" + mode 0755 + recursive true + end + + template "/srv/#{name}/index.html" do + source "index.html.erb" + user "root" + group "root" + mode 0644 + variables :title => title + end + + cookbook_file "/srv/#{name}/imagery.css" do + source "imagery.css" + user "root" + group "root" + mode 0644 + end + + cookbook_file "/srv/#{name}/clientaccesspolicy.xml" do + source "clientaccesspolicy.xml" + user "root" + group "root" + mode 0644 + end + + cookbook_file "/srv/#{name}/crossdomain.xml" do + source "crossdomain.xml" + user "root" + group "root" + mode 0644 + end + + layers = Dir.glob("/srv/imagery/layers/#{name}/*.yml").collect do |path| + YAML.load(::File.read(path)) + end + + template "/srv/#{name}/imagery.js" do + source "imagery.js.erb" user "root" group "root" + mode 0644 + 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