lib/rex/post/meterpreter/extensions/stdapi/net/interface.rb in librex-0.0.68 vs lib/rex/post/meterpreter/extensions/stdapi/net/interface.rb in librex-0.0.70
- old
+ new
@@ -1,6 +1,5 @@
-#!/usr/bin/env ruby
# -*- coding: binary -*-
require 'ipaddr'
module Rex
@@ -16,115 +15,115 @@
# on the remote machine.
#
###
class Interface
- ##
- #
- # Constructor
- #
- ##
+ ##
+ #
+ # Constructor
+ #
+ ##
- #
- # Returns a logical interface and initializes it to the supplied
- # parameters.
- #
- def initialize(opts={})
- self.index = opts[:index] || -1
- self.mac_addr = opts[:mac_addr]
- self.mac_name = opts[:mac_name]
- self.mtu = opts[:mtu]
- self.flags = opts[:flags]
- self.addrs = opts[:addrs]
- self.netmasks = opts[:netmasks]
- self.scopes = opts[:scopes]
- end
+ #
+ # Returns a logical interface and initializes it to the supplied
+ # parameters.
+ #
+ def initialize(opts={})
+ self.index = opts[:index] || -1
+ self.mac_addr = opts[:mac_addr]
+ self.mac_name = opts[:mac_name]
+ self.mtu = opts[:mtu]
+ self.flags = opts[:flags]
+ self.addrs = opts[:addrs]
+ self.netmasks = opts[:netmasks]
+ self.scopes = opts[:scopes]
+ end
- #
- # Returns a pretty string representation of the interface's properties.
- #
- def pretty
- macocts = []
- mac_addr.each_byte { |o| macocts << o }
- macocts += [0] * (6 - macocts.size) if macocts.size < 6
+ #
+ # Returns a pretty string representation of the interface's properties.
+ #
+ def pretty
+ macocts = []
+ mac_addr.each_byte { |o| macocts << o }
+ macocts += [0] * (6 - macocts.size) if macocts.size < 6
- info = [
- ["Name" , mac_name ],
- ["Hardware MAC" , sprintf("%02x:%02x:%02x:%02x:%02x:%02x",
- macocts[0], macocts[1], macocts[2],
- macocts[3], macocts[4], macocts[5])],
- ["MTU" , mtu ],
- ["Flags" , flags ],
- ]
+ info = [
+ ["Name" , mac_name ],
+ ["Hardware MAC" , sprintf("%02x:%02x:%02x:%02x:%02x:%02x",
+ macocts[0], macocts[1], macocts[2],
+ macocts[3], macocts[4], macocts[5])],
+ ["MTU" , mtu ],
+ ["Flags" , flags ],
+ ]
- # If all went as planned, addrs and netmasks will have the same number
- # of elements and be properly ordered such that they match up
- # correctly.
- addr_masks = addrs.zip(netmasks)
+ # If all went as planned, addrs and netmasks will have the same number
+ # of elements and be properly ordered such that they match up
+ # correctly.
+ addr_masks = addrs.zip(netmasks)
- addr_masks.select { |a| Rex::Socket.is_ipv4?(a[0]) }.each { |a|
- info << [ "IPv4 Address", a[0] ]
- info << [ "IPv4 Netmask", a[1] ]
- }
- addr_masks.select { |a| Rex::Socket.is_ipv6?(a[0]) }.each { |a|
- info << [ "IPv6 Address", a[0] ]
- info << [ "IPv6 Netmask", a[1] ]
- }
+ addr_masks.select { |a| Rex::Socket.is_ipv4?(a[0]) }.each { |a|
+ info << [ "IPv4 Address", a[0] ]
+ info << [ "IPv4 Netmask", a[1] ]
+ }
+ addr_masks.select { |a| Rex::Socket.is_ipv6?(a[0]) }.each { |a|
+ info << [ "IPv6 Address", a[0] ]
+ info << [ "IPv6 Netmask", a[1] ]
+ }
- pad = info.map{|i| i[0] }.max_by{|k|k.length}.length
+ pad = info.map{|i| i[0] }.max_by{|k|k.length}.length
- ret = sprintf(
- "Interface %2d\n" +
- "============\n",
- index
- )
+ ret = sprintf(
+ "Interface %2d\n" +
+ "============\n",
+ index
+ )
- info.map {|k,v|
- next if v.nil?
- ret << k.ljust(pad) + " : #{v}\n"
- }
+ info.map {|k,v|
+ next if v.nil?
+ ret << k.ljust(pad) + " : #{v}\n"
+ }
- ret
- end
+ ret
+ end
- #
- # The first address associated with this Interface
- #
- def ip
- addrs.first
- end
+ #
+ # The first address associated with this Interface
+ #
+ def ip
+ addrs.first
+ end
- #
- # The index of the interface.
- #
- attr_accessor :index
- #
- # An Array of IP addresses bound to the Interface.
- #
- attr_accessor :addrs
- #
- # The physical (MAC) address of the NIC.
- #
- attr_accessor :mac_addr
- #
- # The name of the interface.
- #
- attr_accessor :mac_name
- #
- # The MTU associated with the interface.
- #
- attr_accessor :mtu
- #
- # The flags associated with the interface.
- #
- attr_accessor :flags
- #
- # An Array of netmasks. This will have the same number of elements as #addrs
- #
- attr_accessor :netmasks
- #
- # An Array of IPv6 address scopes. This will have the same number of elements as #addrs
- #
- attr_accessor :scopes
+ #
+ # The index of the interface.
+ #
+ attr_accessor :index
+ #
+ # An Array of IP addresses bound to the Interface.
+ #
+ attr_accessor :addrs
+ #
+ # The physical (MAC) address of the NIC.
+ #
+ attr_accessor :mac_addr
+ #
+ # The name of the interface.
+ #
+ attr_accessor :mac_name
+ #
+ # The MTU associated with the interface.
+ #
+ attr_accessor :mtu
+ #
+ # The flags associated with the interface.
+ #
+ attr_accessor :flags
+ #
+ # An Array of netmasks. This will have the same number of elements as #addrs
+ #
+ attr_accessor :netmasks
+ #
+ # An Array of IPv6 address scopes. This will have the same number of elements as #addrs
+ #
+ attr_accessor :scopes
end
end; end; end; end; end; end