# 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
+ 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/#{name}" do
- owner "root"
+ 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
- nginx_site "#{name}" do
+ 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}"
+ restart_nginx false
variables new_resource.to_hash
end
end
+
+def after_created
+ notifies :reload, "service[nginx]"
+end