]> git.openstreetmap.org Git - chef.git/blobdiff - cookbooks/hardware/recipes/default.rb
Don't use ||= in attributes files as it doesn't work
[chef.git] / cookbooks / hardware / recipes / default.rb
index ad64ae56ba143de40a39e709415b213d231a888e..9fa225d2669d00145d9fd2e1f451f3f0225f9428 100644 (file)
@@ -106,7 +106,7 @@ unless unit.nil?
     provider Chef::Provider::Service::Upstart
     action [ :enable, :start ]
     supports :status => true, :restart => true, :reload => false
     provider Chef::Provider::Service::Upstart
     action [ :enable, :start ]
     supports :status => true, :restart => true, :reload => false
-    subscribes :restart, resources(:template => "/etc/init/ttyS#{unit}.conf")
+    subscribes :restart, "template[/etc/init/ttyS#{unit}.conf]"
   end
 end
 
   end
 end
 
@@ -122,7 +122,7 @@ if File.exist?("/etc/default/grub")
     group "root"
     mode 0644
     variables :unit => unit, :speed => speed
     group "root"
     mode 0644
     variables :unit => unit, :speed => speed
-    notifies :run, resources(:execute => "update-grub")
+    notifies :run, "execute[update-grub]"
   end
 end
 
   end
 end
 
@@ -142,30 +142,43 @@ template "/etc/initramfs-tools/conf.d/mdadm" do
 end
 
 tools_packages = []
 end
 
 tools_packages = []
-status_packages = []
+status_packages = {}
 
 node[:kernel][:modules].each_key do |modname|
   case modname
   when "cciss"
     tools_packages << "hpacucli"
 
 node[:kernel][:modules].each_key do |modname|
   case modname
   when "cciss"
     tools_packages << "hpacucli"
-    status_packages << "cciss-vol-status"
+    status_packages["cciss-vol-status"] ||= []
   when "hpsa"
     tools_packages << "hpacucli"
   when "hpsa"
     tools_packages << "hpacucli"
+    status_packages["cciss-vol-status"] ||= []
   when "mptsas"
     tools_packages << "lsiutil"
   when "mptsas"
     tools_packages << "lsiutil"
-    status_packages << "mpt-status"
+    #status_packages["mpt-status"] ||= []
   when "mpt2sas"
     tools_packages << "sas2ircu"
   when "mpt2sas"
     tools_packages << "sas2ircu"
-    status_packages << "sas2ircu-status"
+    status_packages["sas2ircu-status"] ||= []
   when "megaraid_mm"
     tools_packages << "megactl"
   when "megaraid_mm"
     tools_packages << "megactl"
-    status_packages << "megaraid-status"
+    status_packages["megaraid-status"] ||= []
   when "megaraid_sas"
     tools_packages << "megacli"
   when "megaraid_sas"
     tools_packages << "megacli"
-    status_packages << "megaclisas-status"
+    status_packages["megaclisas-status"] ||= []
   when "aacraid"
     tools_packages << "arcconf"
   when "aacraid"
     tools_packages << "arcconf"
-    status_packages << "aacraid-status"
+    status_packages["aacraid-status"] ||= []
+  end
+end
+
+node[:block_device].each do |name,attributes|
+  if attributes[:vendor] == "HP" and attributes[:model] == "LOGICAL VOLUME"
+    if name =~ /^cciss!(c[0-9]+)d[0-9]+$/
+      status_packages["cciss-vol-status"] |= [ "cciss/#{$1}d0" ]
+    else
+      Dir.glob("/sys/block/#{name}/device/scsi_generic/*").each do |sg|
+        status_packages["cciss-vol-status"] |= [ File.basename(sg) ]
+      end
+    end
   end
 end
 
   end
 end
 
@@ -188,6 +201,7 @@ end
       owner "root"
       group "root"
       mode 0644
       owner "root"
       group "root"
       mode 0644
+      variables :devices => status_packages[status_package]
     end
 
     service "#{status_package}d" do
     end
 
     service "#{status_package}d" do