]> git.openstreetmap.org Git - chef.git/blobdiff - cookbooks/imagery/resources/site.rb
imagery: NEW add za_ngi_topo
[chef.git] / cookbooks / imagery / resources / site.rb
index 88b122097753bd5afe9e50b079a555eeeec1d76a..84151ae66e17a752a6eba0011c2943a21a0a1e28 100644 (file)
 # limitations under the License.
 #
 
 # limitations under the License.
 #
 
+require "yaml"
+
 default_action :create
 
 property :name, String
 default_action :create
 
 property :name, String
+property :title, String, :required => true
 property :aliases, [String, Array], :default => []
 property :aliases, [String, Array], :default => []
+property :bbox, Array, :required => true
 
 action :create do
   directory "/srv/#{name}" do
 
 action :create do
   directory "/srv/#{name}" do
-    owner "root"
+    user "root"
     group "root"
     mode 0755
   end
 
     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
     template "nginx_imagery.conf.erb"
     directory "/srv/imagery/#{name}"
   nginx_site name do
     template "nginx_imagery.conf.erb"
     directory "/srv/imagery/#{name}"
@@ -38,5 +97,5 @@ action :create do
 end
 
 def after_created
 end
 
 def after_created
-  notifies :restart, "service[nginx]"
+  notifies :reload, "service[nginx]"
 end
 end