]> git.openstreetmap.org Git - chef.git/blobdiff - cookbooks/rsyncd/recipes/default.rb
supybot: more aggressive init stop
[chef.git] / cookbooks / rsyncd / recipes / default.rb
index 5f090d1cece202d7adc4196959934be4f9b55a35..deaf9a0d26132cff92f4bbcfee8355e359d046da 100644 (file)
 
 include_recipe "networking"
 
+hosts_allow = {}
+hosts_deny = {}
+
+node[:rsyncd][:modules].each do |name, details|
+  hosts_allow[name] = details[:hosts_allow] || []
+
+  hosts_allow[name] |= search(:node, details[:nodes_allow]).collect do |n|
+    n.ipaddresses(:role => :external)
+  end.flatten if details[:nodes_allow]
+
+  hosts_deny[name] = details[:hosts_deny] || []
+
+  hosts_deny[name] |= search(:node, details[:nodes_deny]).collect do |n|
+    n.ipaddresses(:role => :external)
+  end.flatten if details[:nodes_deny]
+end
+
 package "rsync"
 
 service "rsync" do
-  action [ :enable, :start ]
+  action [:enable, :start]
   supports :status => true, :restart => true
 end
 
@@ -30,15 +47,16 @@ template "/etc/default/rsync" do
   source "rsync.erb"
   owner "root"
   group "root"
-  mode 0644
-  notifies :restart, resources(:service => "rsync")
+  mode 0o644
+  notifies :restart, "service[rsync]"
 end
 
 template "/etc/rsyncd.conf" do
   source "rsyncd.conf.erb"
   owner "root"
   group "root"
-  mode 0644
+  mode 0o644
+  variables :hosts_allow => hosts_allow, :hosts_deny => hosts_deny
 end
 
 firewall_rule "accept-rsync" do