Class: PacketGen::Header::OSPFv2::Hello
- Inherits:
-
Base
- Object
- Types::Fields
- Base
- PacketGen::Header::OSPFv2::Hello
- Defined in:
- lib/packetgen/header/ospfv2/hello.rb
Overview
This class handles OSPFv2 HELLO packets payload. The HELLO payload has the following format:
0 1 2 3
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Network Mask |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| HelloInterval | Options | Rtr Pri |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| RouterDeadInterval |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Designated Router |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Backup Designated Router |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Neighbor |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| ... |
A HELLO payload consists of:
-
a #network_mask field (IP::Addr),
-
a #hello_interval field (Types::Int16),
-
an #options field (Types::Int8),
-
a #priority field (Types::Int8),
-
a #dead_interval field (Types::Int32),
-
a #designated_router field (IP::Addr),
-
a #backup_designated_router field (IP::Addr),
-
a #neighbors array containing neighbors as IP::Addr.
Create a HELLO payload
# standalone
hello = PacketGen::Header::OSPFv2::Hello.new
# in a packet
pkt = PacketGen.gen('IP', src: source_ip).add('OSPFv2').add('OSPFv2::Hello')
# make IP header correct for OSPF
pkt.ospfize
# access to Hello payload
pkt.ospfv2_hello # => PacketGen::Header::OSPFv2::Hello
HELLO attributes
hello.network_mask = '255.255.255.0'
hello.hello_interval = 10
hello. = 0
hello.priority = 1
hello.dead_interval = 300
hello.designated_router = '10.0.0.1'
hello.backup_designated_router = '0.0.0.0'
# set neighbors identifiers
hello.neighbors << '10.0.1.1'
hello.neighbors << '10.0.2.1'
Instance Attribute Summary collapse
-
#backup_designated_router ⇒ String
The identity of the Backup Designated Router for this network, in the view of the sending router.
-
#dc_opt ⇒ Boolean
This bit describes the router’s handling of demand circuits.
-
#dead_interval ⇒ Integer
The number of seconds before declaring a silent router down.
-
#designated_router ⇒ String
The identity of the Designated Router for this network, in the view of the sending router.
- #dn_opt ⇒ Boolean
-
#e_opt ⇒ Boolean
This bit describes the way AS-external-LSAs are flooded.
-
#hello_interval ⇒ Integer
The number of seconds between this router’s Hello packets.
-
#l_opt ⇒ Boolean
This specifies if a LLS Data block is present.
-
#mc_opt ⇒ Boolean
This bit describes whether IP multicast datagrams are forwarded.
- #mt_opt ⇒ Boolean
-
#n_opt ⇒ Boolean
This bit specifies if NSSA is supported.
-
#neighbors ⇒ IP::ArrayOfAddr
Array of neighbors.
-
#network_mask ⇒ String
The network mask associated with this interface.
- #o_opt ⇒ Boolean
-
#options ⇒ Integer
8-bit options field.
-
#priority ⇒ Integer
This router’s Router Priority.
Method Summary
Methods inherited from Base
bind, calculate_and_set_length, #header_id, inherited, #initialize, #ip_header, #ll_header
Methods included from PacketGen::Headerable
#added_to_packet, included, #method_name, #packet, #packet=, #parse?, #protocol_name, #read
Methods inherited from Types::Fields
#[], #[]=, #bits_on, define_bit_fields_on, define_field, define_field_after, define_field_before, #fields, fields, inherited, #initialize, #inspect, #offset_of, #optional?, #optional_fields, #present?, #read, remove_bit_fields_on, remove_field, #sz, #to_h, #to_s, update_field
Constructor Details
This class inherits a constructor from PacketGen::Header::Base
Instance Attribute Details
#backup_designated_router ⇒ String
The identity of the Backup Designated Router for this network, in the view of the sending router.
93 |
# File 'lib/packetgen/header/ospfv2/hello.rb', line 93 define_field :backup_designated_router, IP::Addr |
#dc_opt ⇒ Boolean
This bit describes the router’s handling of demand circuits.
73 |
# File 'lib/packetgen/header/ospfv2/hello.rb', line 73 OSPFv2.(self) |
#dead_interval ⇒ Integer
The number of seconds before declaring a silent router down.
83 |
# File 'lib/packetgen/header/ospfv2/hello.rb', line 83 define_field :dead_interval, Types::Int32 |
#designated_router ⇒ String
The identity of the Designated Router for this network, in the view of the sending router.
88 |
# File 'lib/packetgen/header/ospfv2/hello.rb', line 88 define_field :designated_router, IP::Addr |
#e_opt ⇒ Boolean
This bit describes the way AS-external-LSAs are flooded.
73 |
# File 'lib/packetgen/header/ospfv2/hello.rb', line 73 OSPFv2.(self) |
#hello_interval ⇒ Integer
The number of seconds between this router’s Hello packets.
70 |
# File 'lib/packetgen/header/ospfv2/hello.rb', line 70 define_field :hello_interval, Types::Int16 |
#l_opt ⇒ Boolean
This specifies if a LLS Data block is present.
73 |
# File 'lib/packetgen/header/ospfv2/hello.rb', line 73 OSPFv2.(self) |
#mc_opt ⇒ Boolean
This bit describes whether IP multicast datagrams are forwarded.
73 |
# File 'lib/packetgen/header/ospfv2/hello.rb', line 73 OSPFv2.(self) |
#n_opt ⇒ Boolean
This bit specifies if NSSA is supported.
73 |
# File 'lib/packetgen/header/ospfv2/hello.rb', line 73 OSPFv2.(self) |
#neighbors ⇒ IP::ArrayOfAddr
Array of neighbors
97 |
# File 'lib/packetgen/header/ospfv2/hello.rb', line 97 define_field :neighbors, IP::ArrayOfAddr |
#network_mask ⇒ String
The network mask associated with this interface.
66 |
# File 'lib/packetgen/header/ospfv2/hello.rb', line 66 define_field :network_mask, IP::Addr |
#options ⇒ Integer
73 |
# File 'lib/packetgen/header/ospfv2/hello.rb', line 73 OSPFv2.(self) |