summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTheodore Nordsieck <theo@opscode.com>2013-09-10 08:45:27 -0700
committerTheodore Nordsieck <theo@opscode.com>2013-09-11 16:13:24 -0700
commitb46138fdd1c8565f360afafa6ca94b200d114592 (patch)
treec27711eb7af497c990220f0937e0f58b362d20d8
parentb0e275aacda191c962dcd3f5a8e41bf05abbe72d (diff)
downloadohai-b46138fdd1c8565f360afafa6ca94b200d114592.tar.gz
Converted plugins/openbsd/network to Mixlib::ShellOut.
-rw-r--r--lib/ohai/plugins/openbsd/network.rb132
1 files changed, 63 insertions, 69 deletions
diff --git a/lib/ohai/plugins/openbsd/network.rb b/lib/ohai/plugins/openbsd/network.rb
index 67c55181..d802f338 100644
--- a/lib/ohai/plugins/openbsd/network.rb
+++ b/lib/ohai/plugins/openbsd/network.rb
@@ -25,7 +25,8 @@ Ohai.plugin do
counters Mash.new unless counters
counters[:network] = Mash.new unless counters[:network]
- from("route -n get default").split("\n").each do |line|
+ so = shell_out("route -n get default")
+ so.stdout.lines do |line|
if line =~ /(\w+): ([\w\.]+)/
case $1
when "gateway"
@@ -37,62 +38,58 @@ Ohai.plugin do
end
iface = Mash.new
- popen4("#{ Ohai.abs_path( "/sbin/ifconfig" )} -a") do |pid, stdin, stdout, stderr|
- stdin.close
- cint = nil
- stdout.each do |line|
- if line =~ /^([0-9a-zA-Z\.]+):\s+/
- cint = $1
- iface[cint] = Mash.new
- if cint =~ /^(\w+)(\d+.*)/
- iface[cint][:type] = $1
- iface[cint][:number] = $2
- end
+ so = shell_out( "#{ Ohai.abs_path( "/sbin/ifconfig" ) } -a" )
+ cint = nil
+ so.stdout.lines do |line|
+ if line =~ /^([0-9a-zA-Z\.]+):\s+/
+ cint = $1
+ iface[cint] = Mash.new
+ if cint =~ /^(\w+)(\d+.*)/
+ iface[cint][:type] = $1
+ iface[cint][:number] = $2
end
- # call the family lladdr to match linux for consistency
- if line =~ /\s+lladdr (.+?)\s/
- iface[cint][:addresses] = Mash.new unless iface[cint][:addresses]
- iface[cint][:addresses][$1] = { "family" => "lladdr" }
- end
- if line =~ /\s+inet ([\d.]+) netmask ([\da-fx]+)\s*\w*\s*([\d.]*)/
- iface[cint][:addresses] = Mash.new unless iface[cint][:addresses]
- # convert the netmask to decimal for consistency
- netmask = "#{$2[2,2].hex}.#{$2[4,2].hex}.#{$2[6,2].hex}.#{$2[8,2].hex}"
- if $3.empty?
- iface[cint][:addresses][$1] = { "family" => "inet", "netmask" => netmask }
- else
- # found a broadcast address
- iface[cint][:addresses][$1] = { "family" => "inet", "netmask" => netmask, "broadcast" => $3 }
- end
- end
- if line =~ /\s+inet6 ([a-f0-9\:]+)%?(\w*)\s+prefixlen\s+(\d+)\s*\w*\s*([\da-fx]*)/
- iface[cint][:addresses] = Mash.new unless iface[cint][:addresses]
- if $4.empty?
- iface[cint][:addresses][$1] = { "family" => "inet6", "prefixlen" => $3 }
- else
- #found a zone_id / scope
- iface[cint][:addresses][$1] = { "family" => "inet6", "zoneid" => $2, "prefixlen" => $3, "scopeid" => $4 }
- end
- end
- if line =~ /flags=\d+<(.+)>/
- flags = $1.split(',')
- iface[cint][:flags] = flags if flags.length > 0
+ end
+ # call the family lladdr to match linux for consistency
+ if line =~ /\s+lladdr (.+?)\s/
+ iface[cint][:addresses] = Mash.new unless iface[cint][:addresses]
+ iface[cint][:addresses][$1] = { "family" => "lladdr" }
+ end
+ if line =~ /\s+inet ([\d.]+) netmask ([\da-fx]+)\s*\w*\s*([\d.]*)/
+ iface[cint][:addresses] = Mash.new unless iface[cint][:addresses]
+ # convert the netmask to decimal for consistency
+ netmask = "#{$2[2,2].hex}.#{$2[4,2].hex}.#{$2[6,2].hex}.#{$2[8,2].hex}"
+ if $3.empty?
+ iface[cint][:addresses][$1] = { "family" => "inet", "netmask" => netmask }
+ else
+ # found a broadcast address
+ iface[cint][:addresses][$1] = { "family" => "inet", "netmask" => netmask, "broadcast" => $3 }
end
- if line =~ /metric: (\d+) mtu: (\d+)/
- iface[cint][:metric] = $1
- iface[cint][:mtu] = $2
+ end
+ if line =~ /\s+inet6 ([a-f0-9\:]+)%?(\w*)\s+prefixlen\s+(\d+)\s*\w*\s*([\da-fx]*)/
+ iface[cint][:addresses] = Mash.new unless iface[cint][:addresses]
+ if $4.empty?
+ iface[cint][:addresses][$1] = { "family" => "inet6", "prefixlen" => $3 }
+ else
+ #found a zone_id / scope
+ iface[cint][:addresses][$1] = { "family" => "inet6", "zoneid" => $2, "prefixlen" => $3, "scopeid" => $4 }
end
end
+ if line =~ /flags=\d+<(.+)>/
+ flags = $1.split(',')
+ iface[cint][:flags] = flags if flags.length > 0
+ end
+ if line =~ /metric: (\d+) mtu: (\d+)/
+ iface[cint][:metric] = $1
+ iface[cint][:mtu] = $2
+ end
end
- popen4("arp -an") do |pid, stdin, stdout, stderr|
- stdin.close
- stdout.each do |line|
- if line =~ /\((\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})\) at ([a-fA-F0-9\:]+) on ([0-9a-zA-Z\.\:\-]+)/
- next unless iface[$3] # this should never happen
- iface[$3][:arp] = Mash.new unless iface[$3][:arp]
- iface[$3][:arp][$1] = $2.downcase
- end
+ so = shell_out("arp -an")
+ so.stdout.lines do |line|
+ if line =~ /\((\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})\) at ([a-fA-F0-9\:]+) on ([0-9a-zA-Z\.\:\-]+)/
+ next unless iface[$3] # this should never happen
+ iface[$3][:arp] = Mash.new unless iface[$3][:arp]
+ iface[$3][:arp][$1] = $2.downcase
end
end
@@ -103,24 +100,21 @@ Ohai.plugin do
# Show the state of all network interfaces or a single interface
# which have been auto-configured (interfaces statically configured
# into a system, but not located at boot time are not shown).
- popen4("netstat -idn") do |pid, stdin, stdout, stderr|
- stdin.close
- stdout.each do |line|
- # Name Mtu Network Address Ipkts Ierrs Opkts Oerrs Coll Drop
- # em0 1500 <Link> 00:11:25:2d:90:be 3719557 0 3369969 0 0 0
- # $1 $2 $3 $4 $5 $6 $7 $8
- if line =~ /^([\w\.\*]+)\s+\d+\s+<Link>\s+([\w:]*)\s*(\d+)\s+(\d+)\s+(\d+)\s+(\d+)\s+(\d+)\s+(\d+)/
- cint = $1
- net_counters[cint] = Mash.new unless net_counters[cint]
- net_counters[cint] = Mash.new unless net_counters[cint]["rx"]
- net_counters[cint] = Mash.new unless net_counters[cint]["tx"]
- net_counters[cint] = $3
- net_counters[cint] = $4
- net_counters[cint] = $5
- net_counters[cint] = $6
- net_counters[cint] = $7
- net_counters[cint] = $8
- end
+ so = shell_out("netstat -idn")
+ so.stdout.lines do |line|
+ # Name Mtu Network Address Ipkts Ierrs Opkts Oerrs Coll Drop
+ # em0 1500 <Link> 00:11:25:2d:90:be 3719557 0 3369969 0 0 0
+ # $1 $2 $3 $4 $5 $6 $7 $8
+ if line =~ /^([\w\.\*]+)\s+\d+\s+<Link>\s+([\w:]*)\s*(\d+)\s+(\d+)\s+(\d+)\s+(\d+)\s+(\d+)\s+(\d+)/
+ net_counters[$1] = Mash.new unless net_counters[$1]
+ net_counters[$1]["rx"] = Mash.new unless net_counters[$1]["rx"]
+ net_counters[$1]["tx"] = Mash.new unless net_counters[$1]["tx"]
+ net_counters[$1]["rx"]["packets"] = $3
+ net_counters[$1]["rx"]["errors"] = $4
+ net_counters[$1]["tx"]["packets"] = $5
+ net_counters[$1]["tx"]["errors"] = $6
+ net_counters[$1]["tx"]["collisions"] = $7
+ net_counters[$1]["tx"]["dropped"] = $8
end
end