ohai 6.24.2 → 7.0.0.rc.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (259) hide show
  1. data/lib/ohai.rb +1 -1
  2. data/lib/ohai/application.rb +5 -12
  3. data/lib/ohai/common/dmi.rb +126 -0
  4. data/lib/ohai/config.rb +9 -9
  5. data/lib/ohai/{plugins/darwin/hostname.rb → dsl.rb} +7 -7
  6. data/lib/ohai/dsl/plugin.rb +186 -0
  7. data/lib/ohai/dsl/plugin/versionvi.rb +62 -0
  8. data/lib/ohai/dsl/plugin/versionvii.rb +106 -0
  9. data/lib/ohai/exception.rb +11 -2
  10. data/lib/ohai/hints.rb +48 -0
  11. data/lib/ohai/loader.rb +205 -0
  12. data/lib/ohai/mixin/command.rb +14 -18
  13. data/lib/ohai/mixin/constant_helper.rb +53 -0
  14. data/lib/ohai/mixin/gce_metadata.rb +0 -2
  15. data/lib/ohai/{plugins/freebsd/uptime.rb → mixin/network_constants.rb} +15 -13
  16. data/lib/ohai/mixin/os.rb +59 -0
  17. data/lib/ohai/mixin/seconds_to_human.rb +48 -0
  18. data/lib/ohai/plugins/aix/cpu.rb +26 -22
  19. data/lib/ohai/plugins/aix/filesystem.rb +47 -48
  20. data/lib/ohai/plugins/aix/kernel.rb +11 -7
  21. data/lib/ohai/plugins/aix/memory.rb +8 -4
  22. data/lib/ohai/plugins/aix/network.rb +73 -82
  23. data/lib/ohai/plugins/aix/platform.rb +9 -6
  24. data/lib/ohai/plugins/aix/uptime.rb +14 -12
  25. data/lib/ohai/plugins/azure.rb +33 -11
  26. data/lib/ohai/plugins/c.rb +103 -78
  27. data/lib/ohai/plugins/chef.rb +20 -8
  28. data/lib/ohai/plugins/cloud.rb +234 -230
  29. data/lib/ohai/plugins/command.rb +6 -2
  30. data/lib/ohai/plugins/darwin/cpu.rb +10 -4
  31. data/lib/ohai/plugins/darwin/filesystem.rb +32 -32
  32. data/lib/ohai/plugins/darwin/network.rb +157 -154
  33. data/lib/ohai/plugins/darwin/platform.rb +18 -16
  34. data/lib/ohai/plugins/darwin/system_profiler.rb +49 -46
  35. data/lib/ohai/plugins/dmi.rb +102 -102
  36. data/lib/ohai/plugins/ec2.rb +30 -28
  37. data/lib/ohai/plugins/erlang.rb +19 -16
  38. data/lib/ohai/plugins/eucalyptus.rb +37 -36
  39. data/lib/ohai/plugins/freebsd/cpu.rb +34 -29
  40. data/lib/ohai/plugins/freebsd/filesystem.rb +32 -32
  41. data/lib/ohai/plugins/freebsd/memory.rb +35 -25
  42. data/lib/ohai/plugins/freebsd/network.rb +94 -89
  43. data/lib/ohai/plugins/freebsd/platform.rb +10 -4
  44. data/lib/ohai/plugins/freebsd/virtualization.rb +62 -61
  45. data/lib/ohai/plugins/gce.rb +30 -36
  46. data/lib/ohai/plugins/groovy.rb +14 -11
  47. data/lib/ohai/plugins/hostname.rb +132 -10
  48. data/lib/ohai/plugins/ip_scopes.rb +31 -16
  49. data/lib/ohai/plugins/java.rb +45 -21
  50. data/lib/ohai/plugins/kernel.rb +186 -19
  51. data/lib/ohai/plugins/keys.rb +6 -2
  52. data/lib/ohai/plugins/languages.rb +6 -2
  53. data/lib/ohai/plugins/linode.rb +38 -30
  54. data/lib/ohai/plugins/linux/block_device.rb +19 -15
  55. data/lib/ohai/plugins/linux/cpu.rb +42 -38
  56. data/lib/ohai/plugins/linux/filesystem.rb +70 -130
  57. data/lib/ohai/plugins/linux/lsb.rb +35 -35
  58. data/lib/ohai/plugins/linux/memory.rb +65 -61
  59. data/lib/ohai/plugins/linux/network.rb +343 -362
  60. data/lib/ohai/plugins/linux/platform.rb +90 -88
  61. data/lib/ohai/plugins/linux/virtualization.rb +95 -90
  62. data/lib/ohai/plugins/lua.rb +14 -10
  63. data/lib/ohai/plugins/mono.rb +17 -13
  64. data/lib/ohai/plugins/netbsd/cpu.rb +25 -23
  65. data/lib/ohai/plugins/netbsd/filesystem.rb +32 -32
  66. data/lib/ohai/plugins/netbsd/memory.rb +59 -59
  67. data/lib/ohai/plugins/netbsd/network.rb +92 -88
  68. data/lib/ohai/plugins/netbsd/platform.rb +10 -3
  69. data/lib/ohai/plugins/netbsd/virtualization.rb +41 -38
  70. data/lib/ohai/plugins/network.rb +131 -130
  71. data/lib/ohai/plugins/network_listeners.rb +26 -22
  72. data/lib/ohai/plugins/nodejs.rb +14 -10
  73. data/lib/ohai/plugins/ohai.rb +11 -6
  74. data/lib/ohai/plugins/ohai_time.rb +6 -2
  75. data/lib/ohai/plugins/openbsd/cpu.rb +20 -15
  76. data/lib/ohai/plugins/openbsd/filesystem.rb +32 -32
  77. data/lib/ohai/plugins/openbsd/memory.rb +59 -59
  78. data/lib/ohai/plugins/openbsd/network.rb +92 -88
  79. data/lib/ohai/plugins/openbsd/platform.rb +10 -4
  80. data/lib/ohai/plugins/openbsd/virtualization.rb +41 -39
  81. data/lib/ohai/plugins/openstack.rb +23 -21
  82. data/lib/ohai/plugins/os.rb +8 -32
  83. data/lib/ohai/plugins/passwd.rb +27 -22
  84. data/lib/ohai/plugins/perl.rb +21 -16
  85. data/lib/ohai/plugins/php.rb +15 -12
  86. data/lib/ohai/plugins/platform.rb +9 -9
  87. data/lib/ohai/plugins/{linux/kernel.rb → ps.rb} +13 -12
  88. data/lib/ohai/plugins/python.rb +16 -12
  89. data/lib/ohai/plugins/rackspace.rb +82 -77
  90. data/lib/ohai/plugins/root_group.rb +13 -9
  91. data/lib/ohai/plugins/ruby.rb +50 -48
  92. data/lib/ohai/plugins/sigar/cpu.rb +21 -17
  93. data/lib/ohai/plugins/sigar/filesystem.rb +26 -23
  94. data/lib/ohai/plugins/sigar/memory.rb +17 -14
  95. data/lib/ohai/plugins/sigar/network.rb +133 -67
  96. data/lib/ohai/plugins/sigar/network_route.rb +33 -28
  97. data/lib/ohai/plugins/sigar/platform.rb +10 -6
  98. data/lib/ohai/plugins/solaris2/cpu.rb +41 -33
  99. data/lib/ohai/plugins/solaris2/dmi.rb +146 -146
  100. data/lib/ohai/plugins/solaris2/filesystem.rb +74 -77
  101. data/lib/ohai/plugins/{aix/hostname.rb → solaris2/memory.rb} +7 -4
  102. data/lib/ohai/plugins/solaris2/network.rb +91 -86
  103. data/lib/ohai/plugins/solaris2/platform.rb +40 -36
  104. data/lib/ohai/plugins/solaris2/virtualization.rb +54 -59
  105. data/lib/ohai/plugins/solaris2/zpools.rb +38 -38
  106. data/lib/ohai/plugins/ssh_host_key.rb +49 -45
  107. data/lib/ohai/plugins/uptime.rb +87 -25
  108. data/lib/ohai/plugins/virtualization.rb +59 -55
  109. data/lib/ohai/plugins/windows/cpu.rb +44 -40
  110. data/lib/ohai/plugins/windows/filesystem.rb +28 -22
  111. data/lib/ohai/plugins/windows/network.rb +88 -79
  112. data/lib/ohai/plugins/windows/platform.rb +10 -3
  113. data/lib/ohai/provides_map.rb +184 -0
  114. data/lib/ohai/runner.rb +109 -0
  115. data/lib/ohai/system.rb +103 -184
  116. data/lib/ohai/version.rb +4 -3
  117. data/spec/data/plugins/___lib64___libc.so.6.output +135 -0
  118. data/spec/data/plugins/___lib___libc.so.6.output +135 -0
  119. data/spec/data/plugins/cc.output +135 -0
  120. data/spec/data/plugins/cl.output +135 -0
  121. data/spec/data/plugins/devenv.com.output +135 -0
  122. data/spec/data/plugins/env.output +71 -0
  123. data/spec/data/plugins/erl.output +144 -0
  124. data/spec/data/plugins/gcc.output +135 -0
  125. data/spec/data/plugins/groovy.output +159 -0
  126. data/spec/data/plugins/java.output +143 -0
  127. data/spec/data/plugins/lua.output +143 -0
  128. data/spec/data/plugins/messages.rb +8 -0
  129. data/spec/data/plugins/node.output +143 -0
  130. data/spec/data/plugins/perl.output +143 -0
  131. data/spec/data/plugins/php.output +143 -0
  132. data/spec/data/plugins/python.output +143 -0
  133. data/spec/data/plugins/uname.output +71 -0
  134. data/spec/data/plugins/v6message.rb +2 -0
  135. data/spec/data/plugins/v7message.rb +7 -0
  136. data/spec/data/plugins/what.output +135 -0
  137. data/spec/data/plugins/xlc.output +135 -0
  138. data/spec/spec_helper.rb +52 -18
  139. data/spec/support/integration_helper.rb +44 -0
  140. data/spec/unit/dsl/plugin_spec.rb +298 -0
  141. data/spec/unit/hints_spec.rb +65 -0
  142. data/spec/unit/loader_spec.rb +226 -0
  143. data/spec/unit/mixin/ec2_metadata_spec.rb +9 -9
  144. data/spec/unit/plugins/aix/cpu_spec.rb +17 -18
  145. data/spec/unit/plugins/aix/filesystem_spec.rb +20 -18
  146. data/spec/unit/plugins/aix/hostname_spec.rb +8 -4
  147. data/spec/unit/plugins/aix/kernel_spec.rb +13 -12
  148. data/spec/unit/plugins/aix/network_spec.rb +66 -45
  149. data/spec/unit/plugins/aix/platform_spec.rb +11 -10
  150. data/spec/unit/plugins/aix/uptime_spec.rb +7 -8
  151. data/spec/unit/plugins/azure_spec.rb +20 -21
  152. data/spec/unit/plugins/c_spec.rb +88 -87
  153. data/spec/unit/plugins/chef_spec.rb +5 -6
  154. data/spec/unit/plugins/cloud_spec.rb +81 -82
  155. data/spec/unit/plugins/darwin/cpu_spec.rb +8 -9
  156. data/spec/unit/plugins/darwin/hostname_spec.rb +23 -11
  157. data/spec/unit/plugins/darwin/kernel_spec.rb +39 -16
  158. data/spec/unit/plugins/darwin/network_spec.rb +375 -378
  159. data/spec/unit/plugins/darwin/platform_spec.rb +23 -50
  160. data/spec/unit/plugins/darwin/system_profiler_spec.rb +7 -8
  161. data/spec/unit/plugins/dmi_spec.rb +7 -12
  162. data/spec/unit/plugins/ec2_spec.rb +70 -59
  163. data/spec/unit/plugins/erlang_spec.rb +18 -20
  164. data/spec/unit/plugins/eucalyptus_spec.rb +37 -33
  165. data/spec/unit/plugins/fail_spec.rb +276 -23
  166. data/spec/unit/plugins/freebsd/hostname_spec.rb +11 -9
  167. data/spec/unit/plugins/freebsd/kernel_spec.rb +8 -8
  168. data/spec/unit/plugins/freebsd/platform_spec.rb +9 -10
  169. data/spec/unit/plugins/freebsd/virtualization_spec.rb +32 -32
  170. data/spec/unit/plugins/gce_spec.rb +19 -25
  171. data/spec/unit/plugins/groovy_spec.rb +10 -16
  172. data/spec/unit/plugins/hostname_spec.rb +45 -20
  173. data/spec/unit/plugins/ip_scopes_spec.rb +97 -0
  174. data/spec/unit/plugins/java_spec.rb +145 -99
  175. data/spec/unit/plugins/kernel_spec.rb +51 -15
  176. data/spec/unit/plugins/linode_spec.rb +31 -29
  177. data/spec/unit/plugins/linux/cpu_spec.rb +42 -43
  178. data/spec/unit/plugins/linux/filesystem_spec.rb +143 -324
  179. data/spec/unit/plugins/linux/hostname_spec.rb +16 -23
  180. data/spec/unit/plugins/linux/kernel_spec.rb +22 -8
  181. data/spec/unit/plugins/linux/lsb_spec.rb +54 -56
  182. data/spec/unit/plugins/linux/network_spec.rb +196 -238
  183. data/spec/unit/plugins/linux/platform_spec.rb +186 -205
  184. data/spec/unit/plugins/linux/uptime_spec.rb +13 -25
  185. data/spec/unit/plugins/linux/virtualization_spec.rb +149 -129
  186. data/spec/unit/plugins/lua_spec.rb +12 -15
  187. data/spec/unit/plugins/mono_spec.rb +10 -15
  188. data/spec/unit/plugins/netbsd/hostname_spec.rb +17 -7
  189. data/spec/unit/plugins/netbsd/kernel_spec.rb +8 -8
  190. data/spec/unit/plugins/netbsd/platform_spec.rb +8 -10
  191. data/spec/unit/plugins/network_spec.rb +358 -235
  192. data/spec/unit/plugins/nodejs_spec.rb +13 -15
  193. data/spec/unit/plugins/ohai_spec.rb +3 -4
  194. data/spec/unit/plugins/ohai_time_spec.rb +8 -9
  195. data/spec/unit/plugins/openbsd/hostname_spec.rb +21 -11
  196. data/spec/unit/plugins/openbsd/kernel_spec.rb +8 -8
  197. data/spec/unit/plugins/openbsd/platform_spec.rb +6 -12
  198. data/spec/unit/plugins/openstack_spec.rb +214 -0
  199. data/spec/unit/plugins/os_spec.rb +13 -16
  200. data/spec/unit/plugins/passwd_spec.rb +12 -13
  201. data/spec/unit/plugins/perl_spec.rb +20 -44
  202. data/spec/unit/plugins/php_spec.rb +20 -15
  203. data/spec/unit/plugins/platform_spec.rb +24 -29
  204. data/spec/unit/plugins/python_spec.rb +13 -17
  205. data/spec/unit/plugins/rackspace_spec.rb +90 -57
  206. data/spec/unit/plugins/root_group_spec.rb +17 -19
  207. data/spec/unit/plugins/ruby_spec.rb +15 -16
  208. data/spec/unit/plugins/sigar/network_route_spec.rb +12 -13
  209. data/spec/unit/plugins/solaris2/cpu_spec.rb +82 -0
  210. data/spec/unit/plugins/solaris2/hostname_spec.rb +12 -13
  211. data/spec/unit/plugins/solaris2/kernel_spec.rb +11 -15
  212. data/{lib/ohai/plugins/openbsd/uptime.rb → spec/unit/plugins/solaris2/memory_spec.rb} +10 -12
  213. data/spec/unit/plugins/solaris2/network_spec.rb +44 -20
  214. data/spec/unit/plugins/solaris2/platform_spec.rb +13 -22
  215. data/spec/unit/plugins/solaris2/virtualization_spec.rb +37 -45
  216. data/spec/unit/plugins/ssh_host_keys_spec.rb +11 -15
  217. data/spec/unit/provides_map_spec.rb +208 -0
  218. data/spec/unit/runner_spec.rb +488 -0
  219. data/spec/unit/system_spec.rb +639 -104
  220. metadata +151 -87
  221. checksums.yaml +0 -7
  222. data/lib/ohai/mixin/from_file.rb +0 -36
  223. data/lib/ohai/plugins/aix/ps.rb +0 -23
  224. data/lib/ohai/plugins/darwin/kernel.rb +0 -37
  225. data/lib/ohai/plugins/darwin/ps.rb +0 -23
  226. data/lib/ohai/plugins/darwin/uptime.rb +0 -32
  227. data/lib/ohai/plugins/dmi_common.rb +0 -121
  228. data/lib/ohai/plugins/freebsd/hostname.rb +0 -22
  229. data/lib/ohai/plugins/freebsd/kernel.rb +0 -37
  230. data/lib/ohai/plugins/freebsd/ps.rb +0 -24
  231. data/lib/ohai/plugins/hpux/cpu.rb +0 -19
  232. data/lib/ohai/plugins/hpux/filesystem.rb +0 -19
  233. data/lib/ohai/plugins/hpux/hostname.rb +0 -19
  234. data/lib/ohai/plugins/hpux/memory.rb +0 -19
  235. data/lib/ohai/plugins/hpux/network.rb +0 -19
  236. data/lib/ohai/plugins/hpux/platform.rb +0 -19
  237. data/lib/ohai/plugins/hpux/ps.rb +0 -23
  238. data/lib/ohai/plugins/hpux/uptime.rb +0 -19
  239. data/lib/ohai/plugins/linux/hostname.rb +0 -40
  240. data/lib/ohai/plugins/linux/ps.rb +0 -23
  241. data/lib/ohai/plugins/linux/uptime.rb +0 -28
  242. data/lib/ohai/plugins/netbsd/hostname.rb +0 -22
  243. data/lib/ohai/plugins/netbsd/kernel.rb +0 -35
  244. data/lib/ohai/plugins/netbsd/ps.rb +0 -24
  245. data/lib/ohai/plugins/netbsd/uptime.rb +0 -31
  246. data/lib/ohai/plugins/openbsd/hostname.rb +0 -22
  247. data/lib/ohai/plugins/openbsd/kernel.rb +0 -35
  248. data/lib/ohai/plugins/openbsd/ps.rb +0 -24
  249. data/lib/ohai/plugins/sigar/hostname.rb +0 -28
  250. data/lib/ohai/plugins/sigar/uptime.rb +0 -27
  251. data/lib/ohai/plugins/solaris2/hostname.rb +0 -34
  252. data/lib/ohai/plugins/solaris2/kernel.rb +0 -40
  253. data/lib/ohai/plugins/solaris2/ps.rb +0 -23
  254. data/lib/ohai/plugins/solaris2/uptime.rb +0 -36
  255. data/lib/ohai/plugins/windows/hostname.rb +0 -33
  256. data/lib/ohai/plugins/windows/kernel.rb +0 -58
  257. data/lib/ohai/plugins/windows/kernel_devices.rb +0 -39
  258. data/lib/ohai/plugins/windows/uptime.rb +0 -23
  259. data/spec/unit/mixin/from_file_spec.rb +0 -53
@@ -16,86 +16,83 @@
16
16
  # limitations under the License.
17
17
  #
18
18
 
19
- provides "filesystem"
19
+ Ohai.plugin(:Filesystem) do
20
+ provides "filesystem"
20
21
 
21
- fs = Mash.new
22
+ collect_data(:solaris2) do
23
+ fs = Mash.new
22
24
 
23
- # Grab filesystem data from df
24
- popen4("df -Pka") do |pid, stdin, stdout, stderr|
25
- stdin.close
26
- stdout.each do |line|
27
- case line
28
- when /^Filesystem\s+kbytes/
29
- next
30
- when /^(.+?)\s+(\d+)\s+(\d+)\s+(\d+)\s+(\d+\%)\s+(.+)$/
31
- filesystem = $1
32
- fs[filesystem] = Mash.new
33
- fs[filesystem][:kb_size] = $2
34
- fs[filesystem][:kb_used] = $3
35
- fs[filesystem][:kb_available] = $4
36
- fs[filesystem][:percent_used] = $5
37
- fs[filesystem][:mount] = $6
38
- end
39
- end
40
- end
25
+ # Grab filesystem data from df
26
+ so = shell_out("df -Pka")
27
+ so.stdout.lines do |line|
28
+ case line
29
+ when /^Filesystem\s+kbytes/
30
+ next
31
+ when /^(.+?)\s+(\d+)\s+(\d+)\s+(\d+)\s+(\d+\%)\s+(.+)$/
32
+ filesystem = $1
33
+ fs[filesystem] = Mash.new
34
+ fs[filesystem][:kb_size] = $2
35
+ fs[filesystem][:kb_used] = $3
36
+ fs[filesystem][:kb_available] = $4
37
+ fs[filesystem][:percent_used] = $5
38
+ fs[filesystem][:mount] = $6
39
+ end
40
+ end
41
41
 
42
- # Grab file system type from df (must be done separately)
43
- popen4("df -na") do |pid, stdin, stdout, stderr|
44
- stdin.close
45
- stdout.each do |line|
46
- next unless (line =~ /^(.+?)\s*: (\S+)\s*$/)
47
- mount = $1
48
- fs.each { |filesystem,fs_attributes|
49
- next unless (fs_attributes[:mount] == mount)
50
- fs[filesystem][:fs_type] = $2
51
- }
52
- end
53
- end
42
+ # Grab file system type from df (must be done separately)
43
+ so = shell_out("df -na")
44
+ so.stdout.lines do |line|
45
+ next unless (line =~ /^(.+?)\s*: (\S+)\s*$/)
46
+ mount = $1
47
+ fs.each { |filesystem,fs_attributes|
48
+ next unless (fs_attributes[:mount] == mount)
49
+ fs[filesystem][:fs_type] = $2
50
+ }
51
+ end
54
52
 
55
- # Grab mount information from /bin/mount
56
- popen4("mount") do |pid, stdin, stdout, stderr|
57
- stdin.close
58
- stdout.each do |line|
59
- next unless (line =~ /^(.+?) on (.+?) (.+?) on (.+?)$/)
60
- filesystem = $2
61
- fs[filesystem] = Mash.new unless fs.has_key?(filesystem)
62
- fs[filesystem][:mount] = $1
63
- fs[filesystem][:mount_time] = $4 # $4 must come before "split", else it becomes nil
64
- fs[filesystem][:mount_options] = $3.split("/")
65
- end
66
- end
53
+ # Grab mount information from /bin/mount
54
+ so = shell_out("mount")
55
+ so.stdout.lines do |line|
56
+ next unless (line =~ /^(.+?) on (.+?) (.+?) on (.+?)$/)
57
+ filesystem = $2
58
+ fs[filesystem] = Mash.new unless fs.has_key?(filesystem)
59
+ fs[filesystem][:mount] = $1
60
+ fs[filesystem][:mount_time] = $4 # $4 must come before "split", else it becomes nil
61
+ fs[filesystem][:mount_options] = $3.split("/")
62
+ end
67
63
 
68
- # Grab any zfs data from "zfs get"
69
- zfs = Mash.new
70
- popen4("zfs get -p -H all") do |pid, stdin, stdout, stderr|
71
- stdin.close
72
- stdout.each do |line|
73
- next unless (line =~ /^([^\t]+)\t([^\t]+)\t([^\t]+)\t([^\t]+)$/)
74
- filesystem = $1
75
- zfs[filesystem] = Mash.new unless zfs.has_key?(filesystem)
76
- zfs[filesystem][:values] = Mash.new unless zfs[filesystem].has_key?('values')
77
- zfs[filesystem][:sources] = Mash.new unless zfs[filesystem].has_key?('sources')
78
- zfs[filesystem][:values][$2] = $3
79
- zfs[filesystem][:sources][$2] = $4.chomp
80
- end
81
- end
82
- zfs.each { |filesystem, attributes|
83
- fs[filesystem] = Mash.new unless fs.has_key?(filesystem)
84
- fs[filesystem][:fs_type] = 'zfs'
85
- fs[filesystem][:mount] = attributes[:values][:mountpoint] if attributes[:values].has_key?('mountpoint')
86
- fs[filesystem][:zfs_values] = attributes[:values]
87
- fs[filesystem][:zfs_sources] = attributes[:sources]
88
- # find all zfs parents
89
- parents = filesystem.split('/')
90
- zfs_parents = []
91
- (0 .. parents.length - 1).to_a.each { |parent_indexes|
92
- next_parent = parents[0 .. parent_indexes].join('/')
93
- zfs_parents.push(next_parent)
94
- }
95
- zfs_parents.pop
96
- fs[filesystem][:zfs_parents] = zfs_parents
97
- fs[filesystem][:zfs_zpool] = (zfs_parents.length == 0)
98
- }
64
+ # Grab any zfs data from "zfs get"
65
+ zfs = Mash.new
66
+ so = shell_out("zfs get -p -H all")
67
+ so.stdout.lines do |line|
68
+ next unless (line =~ /^([^\t]+)\t([^\t]+)\t([^\t]+)\t([^\t]+)$/)
69
+ filesystem = $1
70
+ zfs[filesystem] = Mash.new unless zfs.has_key?(filesystem)
71
+ zfs[filesystem][:values] = Mash.new unless zfs[filesystem].has_key?('values')
72
+ zfs[filesystem][:sources] = Mash.new unless zfs[filesystem].has_key?('sources')
73
+ zfs[filesystem][:values][$2] = $3
74
+ zfs[filesystem][:sources][$2] = $4.chomp
75
+ end
76
+
77
+ zfs.each { |filesystem, attributes|
78
+ fs[filesystem] = Mash.new unless fs.has_key?(filesystem)
79
+ fs[filesystem][:fs_type] = 'zfs'
80
+ fs[filesystem][:mount] = attributes[:values][:mountpoint] if attributes[:values].has_key?('mountpoint')
81
+ fs[filesystem][:zfs_values] = attributes[:values]
82
+ fs[filesystem][:zfs_sources] = attributes[:sources]
83
+ # find all zfs parents
84
+ parents = filesystem.split('/')
85
+ zfs_parents = []
86
+ (0 .. parents.length - 1).to_a.each { |parent_indexes|
87
+ next_parent = parents[0 .. parent_indexes].join('/')
88
+ zfs_parents.push(next_parent)
89
+ }
90
+ zfs_parents.pop
91
+ fs[filesystem][:zfs_parents] = zfs_parents
92
+ fs[filesystem][:zfs_zpool] = (zfs_parents.length == 0)
93
+ }
99
94
 
100
- # Set the filesystem data
101
- filesystem fs
95
+ # Set the filesystem data
96
+ filesystem fs
97
+ end
98
+ end
@@ -1,6 +1,4 @@
1
1
  #
2
- # Author:: Doug MacEachern <dougm@vmware.com>
3
- # Copyright:: Copyright (c) 2010 VMware, Inc.
4
2
  # License:: Apache License, Version 2.0
5
3
  #
6
4
  # Licensed under the Apache License, Version 2.0 (the "License");
@@ -16,6 +14,11 @@
16
14
  # limitations under the License.
17
15
  #
18
16
 
19
- provides "hostname"
17
+ Ohai.plugin(:Memory) do
18
+ provides "memory"
20
19
 
21
- hostname from("hostname")
20
+ collect_data(:solaris2) do
21
+ memory Mash.new
22
+ memory[:total] = shell_out("prtconf -m").stdout.to_i
23
+ end
24
+ end
@@ -53,108 +53,113 @@
53
53
  # srcof qfe1
54
54
  # inet6 fe80::203:baff:fe17:4444/128
55
55
 
56
- provides "network"
56
+ Ohai.plugin(:Network) do
57
+ provides "network", "network/interfaces"
58
+ provides "counters/network", "counters/network/interfaces"
57
59
 
58
- require 'scanf'
60
+ def solaris_encaps_lookup(ifname)
61
+ return "Ethernet" if ifname.eql?("e1000g")
62
+ return "Ethernet" if ifname.eql?("eri")
63
+ return "Ethernet" if ifname.eql?("net")
64
+ return "Loopback" if ifname.eql?("lo")
65
+ "Unknown"
66
+ end
59
67
 
60
- def encaps_lookup(ifname)
61
- return "Ethernet" if ifname.eql?("e1000g")
62
- return "Ethernet" if ifname.eql?("eri")
63
- return "Ethernet" if ifname.eql?("net")
64
- return "Loopback" if ifname.eql?("lo")
65
- "Unknown"
66
- end
68
+ def arpname_to_ifname(iface, arpname)
69
+ iface.keys.each do |ifn|
70
+ return ifn if ifn.split(':')[0].eql?(arpname)
71
+ end
67
72
 
68
- def arpname_to_ifname(iface, arpname)
69
- iface.keys.each do |ifn|
70
- return ifn if ifn.split(':')[0].eql?(arpname)
73
+ nil
71
74
  end
72
75
 
73
- nil
74
- end
76
+ collect_data(:solaris2) do
77
+ require 'scanf'
75
78
 
76
- iface = Mash.new
77
- popen4("ifconfig -a") do |pid, stdin, stdout, stderr|
78
- stdin.close
79
- cint = nil
80
- stdout.each do |line|
81
- if line =~ /^([0-9a-zA-Z\.\:\-]+): \S+ mtu (\d+) index (\d+)/
82
- cint = $1
83
- iface[cint] = Mash.new unless iface[cint]
84
- iface[cint][:mtu] = $2
85
- iface[cint][:index] = $3
86
- if line =~ / flags\=\d+\<((ADDRCONF|ANYCAST|BROADCAST|CoS|DEPRECATED|DHCP|DUPLICATE|FAILED|FIXEDMTU|INACTIVE|L3PROTECT|LOOPBACK|MIP|MULTI_BCAST|MULTICAST|NOARP|NOFAILOVER|NOLOCAL|NONUD|NORTEXCH|NOXMIT|OFFLINE|POINTOPOINT|PREFERRED|PRIVATE|ROUTER|RUNNING|STANDBY|TEMPORARY|UNNUMBERED|UP|VIRTUAL|XRESOLV|IPv4|IPv6|,)+)\>\s/
87
- flags = $1.split(',')
88
- else
89
- flags = Array.new
79
+ iface = Mash.new
80
+ network Mash.new unless network
81
+ network[:interfaces] = Mash.new unless network[:interfaces]
82
+ counters Mash.new unless counters
83
+ counters[:network] = Mash.new unless counters[:network]
84
+
85
+ so = shell_out("ifconfig -a")
86
+ cint = nil
87
+
88
+ so.stdout.lines do |line|
89
+ if line =~ /^([0-9a-zA-Z\.\:\-]+): \S+ mtu (\d+) index (\d+)/
90
+ cint = $1
91
+ iface[cint] = Mash.new unless iface[cint]
92
+ iface[cint][:mtu] = $2
93
+ iface[cint][:index] = $3
94
+ if line =~ / flags\=\d+\<((ADDRCONF|ANYCAST|BROADCAST|CoS|DEPRECATED|DHCP|DUPLICATE|FAILED|FIXEDMTU|INACTIVE|L3PROTECT|LOOPBACK|MIP|MULTI_BCAST|MULTICAST|NOARP|NOFAILOVER|NOLOCAL|NONUD|NORTEXCH|NOXMIT|OFFLINE|POINTOPOINT|PREFERRED|PRIVATE|ROUTER|RUNNING|STANDBY|TEMPORARY|UNNUMBERED|UP|VIRTUAL|XRESOLV|IPv4|IPv6|,)+)\>\s/
95
+ flags = $1.split(',')
96
+ else
97
+ flags = Array.new
98
+ end
99
+ iface[cint][:flags] = flags.flatten
100
+ if cint =~ /^(\w+)(\d+.*)/
101
+ iface[cint][:type] = $1
102
+ iface[cint][:number] = $2
103
+ iface[cint][:encapsulation] = solaris_encaps_lookup($1)
104
+ end
90
105
  end
91
- iface[cint][:flags] = flags.flatten
92
- if cint =~ /^(\w+)(\d+.*)/
93
- iface[cint][:type] = $1
94
- iface[cint][:number] = $2
95
- iface[cint][:encapsulation] = encaps_lookup($1)
106
+ if line =~ /\s+inet (\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}) netmask (([0-9a-f]){1,8})\s*$/
107
+ iface[cint][:addresses] = Mash.new unless iface[cint][:addresses]
108
+ iface[cint][:addresses][$1] = { "family" => "inet", "netmask" => $2.scanf('%2x'*4)*"."}
109
+ end
110
+ if line =~ /\s+inet (\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}) netmask (([0-9a-f]){1,8}) broadcast (\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})/
111
+ iface[cint][:addresses] = Mash.new unless iface[cint][:addresses]
112
+ iface[cint][:addresses][$1] = { "family" => "inet", "netmask" => $2.scanf('%2x'*4)*".", "broadcast" => $4 }
113
+ end
114
+ if line =~ /\s+inet6 ([a-f0-9\:]+)(\s*|(\%[a-z0-9]+)\s*)\/(\d+)\s*$/
115
+ iface[cint][:addresses] = Mash.new unless iface[cint][:addresses]
116
+ iface[cint][:addresses][$1] = { "family" => "inet6", "prefixlen" => $4 }
96
117
  end
97
118
  end
98
- if line =~ /\s+inet (\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}) netmask (([0-9a-f]){1,8})\s*$/
99
- iface[cint][:addresses] = Mash.new unless iface[cint][:addresses]
100
- iface[cint][:addresses][$1] = { "family" => "inet", "netmask" => $2.scanf('%2x'*4)*"."}
101
- end
102
- if line =~ /\s+inet (\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}) netmask (([0-9a-f]){1,8}) broadcast (\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})/
103
- iface[cint][:addresses] = Mash.new unless iface[cint][:addresses]
104
- iface[cint][:addresses][$1] = { "family" => "inet", "netmask" => $2.scanf('%2x'*4)*".", "broadcast" => $4 }
105
- end
106
- if line =~ /\s+inet6 ([a-f0-9\:]+)(\s*|(\%[a-z0-9]+)\s*)\/(\d+)\s*$/
107
- iface[cint][:addresses] = Mash.new unless iface[cint][:addresses]
108
- iface[cint][:addresses][$1] = { "family" => "inet6", "prefixlen" => $4 }
109
- end
110
- end
111
- end
112
-
113
- popen4("arp -an") do |pid, stdin, stdout, stderr|
114
- stdin.close
115
- stdout.each do |line|
116
- if line =~ /([0-9a-zA-Z]+)\s+(\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})\s+(\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})\s+(\w+)\s+([a-zA-Z0-9\.\:\-]+)/
117
- next unless iface[arpname_to_ifname(iface, $1)] # this should never happen, except on solaris because sun hates you.
118
- iface[arpname_to_ifname(iface, $1)][:arp] = Mash.new unless iface[arpname_to_ifname(iface, $1)][:arp]
119
- iface[arpname_to_ifname(iface, $1)][:arp][$2] = $5
120
- end
121
- end
122
- end
123
119
 
124
- iface.keys.each do |ifn|
125
- iaddr = nil
126
- if iface[ifn][:encapsulation].eql?("Ethernet")
127
- iface[ifn][:addresses].keys.each do |addr|
128
- if iface[ifn][:addresses][addr]["family"].eql?("inet")
129
- iaddr = addr
130
- break
120
+ so = shell_out("arp -an")
121
+ so.stdout.lines do |line|
122
+ if line =~ /([0-9a-zA-Z]+)\s+(\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})\s+(\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})\s+(\w+)\s+([a-zA-Z0-9\.\:\-]+)/
123
+ next unless iface[arpname_to_ifname(iface, $1)] # this should never happen, except on solaris because sun hates you.
124
+ iface[arpname_to_ifname(iface, $1)][:arp] = Mash.new unless iface[arpname_to_ifname(iface, $1)][:arp]
125
+ iface[arpname_to_ifname(iface, $1)][:arp][$2] = $5
131
126
  end
132
127
  end
133
- if iface[ifn][:arp]
134
- iface[ifn][:arp].keys.each do |addr|
135
- if addr.eql?(iaddr)
136
- iface[ifn][:addresses][iface[ifn][:arp][iaddr]] = { "family" => "lladdr" }
137
- break
128
+
129
+ iface.keys.each do |ifn|
130
+ iaddr = nil
131
+ if iface[ifn][:encapsulation].eql?("Ethernet")
132
+ iface[ifn][:addresses].keys.each do |addr|
133
+ if iface[ifn][:addresses][addr]["family"].eql?("inet")
134
+ iaddr = addr
135
+ break
136
+ end
137
+ end
138
+ if iface[ifn][:arp]
139
+ iface[ifn][:arp].keys.each do |addr|
140
+ if addr.eql?(iaddr)
141
+ iface[ifn][:addresses][iface[ifn][:arp][iaddr]] = { "family" => "lladdr" }
142
+ break
143
+ end
144
+ end
138
145
  end
139
146
  end
140
147
  end
141
- end
142
- end
143
148
 
144
- network[:interfaces] = iface
149
+ network[:interfaces] = iface
145
150
 
146
- popen4("route -n get default") do |pid, stdin, stdout, stderr|
147
- stdin.close
148
- route_get = stdout.read
149
- matches = /interface: (\S+)/.match(route_get)
150
- if matches
151
- Ohai::Log.debug("found gateway device: #{$1}")
152
- network[:default_interface] = matches[1]
153
- end
154
- matches = /gateway: (\S+)/.match(route_get)
155
- if matches
156
- Ohai::Log.debug("found gateway: #{$1}")
157
- network[:default_gateway] = matches[1]
151
+ so = shell_out("route -n get default")
152
+ so.stdout.lines do |line|
153
+ matches = /interface: (\S+)/.match(line)
154
+ if matches
155
+ Ohai::Log.debug("found gateway device: #{$1}")
156
+ network[:default_interface] = matches[1]
157
+ end
158
+ matches = /gateway: (\S+)/.match(line)
159
+ if matches
160
+ Ohai::Log.debug("found gateway: #{$1}")
161
+ network[:default_gateway] = matches[1]
162
+ end
163
+ end
158
164
  end
159
165
  end
160
-
@@ -16,46 +16,50 @@
16
16
  # limitations under the License.
17
17
  #
18
18
 
19
- provides "platform", "platform_version", "platform_build"
19
+ Ohai.plugin(:Platform) do
20
+ provides "platform", "platform_version", "platform_build", "platform_family"
20
21
 
21
- if File.exists?("/sbin/uname")
22
- uname_exec = "/sbin/uname"
23
- else
24
- uname_exec = "uname"
25
- end
22
+ collect_data(:solaris2) do
23
+ if File.exists?("/sbin/uname")
24
+ uname_exec = "/sbin/uname"
25
+ else
26
+ uname_exec = "uname"
27
+ end
26
28
 
27
- popen4("#{uname_exec} -X") do |pid, stdin, stdout, stderr|
28
- stdin.close
29
- stdout.each do |line|
30
- case line
31
- when /^Release =\s+(.+)$/
32
- platform_version $1
33
- when /^KernelID =\s+(.+)$/
34
- platform_build $1
29
+ so = shell_out("#{uname_exec} -X")
30
+ so.stdout.lines do |line|
31
+ case line
32
+ when /^Release =\s+(.+)$/
33
+ platform_version $1
34
+ when /^KernelID =\s+(.+)$/
35
+ platform_build $1
36
+ end
35
37
  end
36
- end
37
- end
38
38
 
39
- File.open("/etc/release") do |file|
40
- while line = file.gets
41
- case line
42
- when /^.*(SmartOS).*$/
43
- platform "smartos"
44
- when /^\s*(OmniOS).*r(\d+).*$/
45
- platform "omnios"
46
- platform_version $2
47
- when /^\s*(OpenIndiana).*oi_(\d+).*$/
48
- platform "openindiana"
49
- platform_version $2
50
- when /^\s*(OpenSolaris).*snv_(\d+).*$/
51
- platform "opensolaris"
52
- platform_version $2
53
- when /^\s*(Oracle Solaris) (\d+)\s.*$/
54
- platform "solaris2"
55
- when /^\s*(Solaris)\s.*$/
56
- platform "solaris2"
57
- when /^\s*(NexentaCore)\s.*$/
58
- platform "nexentacore"
39
+ File.open("/etc/release") do |file|
40
+ while line = file.gets
41
+ case line
42
+ when /^.*(SmartOS).*$/
43
+ platform "smartos"
44
+ when /^\s*(OmniOS).*r(\d+).*$/
45
+ platform "omnios"
46
+ platform_version $2
47
+ when /^\s*(OpenIndiana).*oi_(\d+).*$/
48
+ platform "openindiana"
49
+ platform_version $2
50
+ when /^\s*(OpenSolaris).*snv_(\d+).*$/
51
+ platform "opensolaris"
52
+ platform_version $2
53
+ when /^\s*(Oracle Solaris) (\d+)\s.*$/
54
+ platform "solaris2"
55
+ when /^\s*(Solaris)\s.*$/
56
+ platform "solaris2"
57
+ when /^\s*(NexentaCore)\s.*$/
58
+ platform "nexentacore"
59
+ end
60
+ end
59
61
  end
62
+
63
+ platform_family platform
60
64
  end
61
65
  end