Module: NetAddr
- Defined in:
- lib/ipv4.rb,
lib/ipv6.rb,
lib/util.rb,
lib/eui48.rb,
lib/eui64.rb,
lib/mask32.rb,
lib/ipv4net.rb,
lib/ipv6net.rb,
lib/mask128.rb,
lib/netaddr.rb
Defined Under Namespace
Classes: EUI48, EUI64, IPv4, IPv4Net, IPv6, IPv6Net, Mask128, Mask32, Util, ValidationError
Constant Summary collapse
- F32 =
32 bits worth of ‘1’
2**32-1
- F128 =
128 bits worth of ‘1’
2**128-1
Class Method Summary collapse
-
.ipv4_prefix_len(size) ⇒ Object
ipv4_prefix_len returns the prefix length needed to hold the number of IP addresses specified by “size”.
-
.parse_ip(ip) ⇒ Object
parse_ip parses a string into an IPv4 or IPv6.
-
.parse_net(net) ⇒ Object
parse_net parses a string into an IPv4Net or IPv6Net.
-
.sort_IPv4(list) ⇒ Object
sort_IPv4 sorts a list of IPv4 objects in ascending order.
-
.sort_IPv4Net(list) ⇒ Object
sort_IPv4Net sorts a list of IPv4Net objects in ascending order.
-
.sort_IPv6(list) ⇒ Object
sort_IPv6 sorts a list of IPv6 objects in ascending order.
-
.sort_IPv6Net(list) ⇒ Object
sort_IPv6Net sorts a list of IPv6Net objects in ascending order.
-
.summ_IPv4Net(list) ⇒ Object
summ_IPv4Net summarizes a list of IPv4Net objects as much as possible.
-
.summ_IPv6Net(list) ⇒ Object
summ_IPv6Net summarizes a list of IPv6Net objects as much as possible.
Class Method Details
.ipv4_prefix_len(size) ⇒ Object
ipv4_prefix_len returns the prefix length needed to hold the number of IP addresses specified by “size”.
26 27 28 29 30 31 32 33 34 35 36 37 |
# File 'lib/netaddr.rb', line 26 def ipv4_prefix_len(size) prefix_len = 32 32.downto(0) do |i| hostbits = 32 - prefix_len max = 1 << hostbits if (size <= max) break end prefix_len -= 1 end return prefix_len end |
.parse_ip(ip) ⇒ Object
parse_ip parses a string into an IPv4 or IPv6
41 42 43 44 45 46 |
# File 'lib/netaddr.rb', line 41 def parse_ip(ip) if (ip.include?(":")) return IPv6.parse(ip) end return IPv4.parse(ip) end |
.parse_net(net) ⇒ Object
parse_net parses a string into an IPv4Net or IPv6Net
50 51 52 53 54 55 |
# File 'lib/netaddr.rb', line 50 def parse_net(net) if (net.include?(".")) # ipv4 return IPv4Net.parse(net) end return IPv6Net.parse(net) end |
.sort_IPv4(list) ⇒ Object
sort_IPv4 sorts a list of IPv4 objects in ascending order. It will return a new list with any non IPv4 objects removed.
60 61 62 63 64 65 66 |
# File 'lib/netaddr.rb', line 60 def sort_IPv4(list) if ( !list.kind_of?(Array) ) raise ArgumentError, "Expected an Array for 'list' but got a #{list.class}." end filtered = Util.filter_IPv4(list) return Util.quick_sort(filtered) end |
.sort_IPv4Net(list) ⇒ Object
sort_IPv4Net sorts a list of IPv4Net objects in ascending order. It will return a new list with any non IPv4Net objects removed.
82 83 84 85 86 87 88 |
# File 'lib/netaddr.rb', line 82 def sort_IPv4Net(list) if ( !list.kind_of?(Array) ) raise ArgumentError, "Expected an Array for 'list' but got a #{list.class}." end filtered = Util.filter_IPv4Net(list) return Util.quick_sort(filtered) end |
.sort_IPv6(list) ⇒ Object
sort_IPv6 sorts a list of IPv6 objects in ascending order. It will return a new list with any non IPv6 objects removed.
71 72 73 74 75 76 77 |
# File 'lib/netaddr.rb', line 71 def sort_IPv6(list) if ( !list.kind_of?(Array) ) raise ArgumentError, "Expected an Array for 'list' but got a #{list.class}." end filtered = Util.filter_IPv6(list) return Util.quick_sort(filtered) end |
.sort_IPv6Net(list) ⇒ Object
sort_IPv6Net sorts a list of IPv6Net objects in ascending order. It will return a new list with any non IPv6Net objects removed.
93 94 95 96 97 98 99 |
# File 'lib/netaddr.rb', line 93 def sort_IPv6Net(list) if ( !list.kind_of?(Array) ) raise ArgumentError, "Expected an Array for 'list' but got a #{list.class}." end filtered = Util.filter_IPv6Net(list) return Util.quick_sort(filtered) end |
.summ_IPv4Net(list) ⇒ Object
summ_IPv4Net summarizes a list of IPv4Net objects as much as possible. It will return a new list with any non IPv4Net objects removed.
104 105 106 107 108 109 110 111 |
# File 'lib/netaddr.rb', line 104 def summ_IPv4Net(list) list = Util.filter_IPv4Net(list) if (list.length>1) list = Util.discard_subnets(list) return Util.summ_peers(list) end return [].concat(list) end |
.summ_IPv6Net(list) ⇒ Object
summ_IPv6Net summarizes a list of IPv6Net objects as much as possible. It will return a new list with any non IPv6Net objects removed.
116 117 118 119 120 121 122 123 |
# File 'lib/netaddr.rb', line 116 def summ_IPv6Net(list) list = Util.filter_IPv6Net(list) if (list.length>1) list = Util.discard_subnets(list) return Util.summ_peers(list) end return [].concat(list) end |