1Net::BGP::Update(3) User Contributed Perl Documentation Net::BGP::Update(3)
2
3
4
6 "Net::BGP::Update" - Class encapsulating BGP-4 UPDATE message
7
9 use Net::BGP::Update qw( :origin );
10
11 # Constructor
12 $update = Net::BGP::Update->new(
13 NLRI => [ qw( 10/8 172.168/16 ) ],
14 Withdraw => [ qw( 192.168.1/24 172.10/16 192.168.2.1/32 ) ],
15 # For Net::BGP::NLRI
16 Aggregator => [ 64512, '10.0.0.1' ],
17 AsPath => [ 64512, 64513, 64514 ],
18 AtomicAggregate => 1,
19 Communities => [ qw( 64512:10000 64512:10001 ) ],
20 LocalPref => 100,
21 MED => 200,
22 NextHop => '10.0.0.1',
23 Origin => INCOMPLETE,
24 );
25
26 # Construction from a NLRI object:
27 $nlri = Net::BGP::NLRI->new( ... );
28 $update = Net::BGP::Update->new($nlri,$nlri_ref,$withdrawn_ref);
29
30 # Object Copy
31 $clone = $update->clone();
32
33 # Accessor Methods
34 $nlri_ref = $update->nlri($nlri_ref);
35 $withdrawn_ref = $update->withdrawn($withdrawn_ref);
36 $prefix_hash_ref = $update->ashash;
37
38 # Comparison
39 if ($update1 eq $update2) { ... }
40 if ($update1 ne $update2) { ... }
41
43 This module encapsulates the data contained in a BGP-4 UPDATE message.
44 It provides a constructor, and accessor methods for each of the message
45 fields and well-known path attributes of an UPDATE. Whenever a
46 Net::BGP::Peer sends an UPDATE message to its peer, it does so by
47 passing a "Net::BGP::Update" object to the peer object's update()
48 method. Similarly, when the peer receives an UPDATE message from its
49 peer, the UPDATE callback is called and passed a reference to a
50 "Net::BGP::Update" object. The callback function can then examine the
51 UPDATE message fields by means of the accessor methods.
52
54 new() - create a new "Net::BGP::Update" object
55
56 $update = Net::BGP::Update->new(
57 NLRI => [ qw( 10/8 172.168/16 ) ],
58 Withdraw => [ qw( 192.168.1/24 172.10/16 192.168.2.1/32 ) ],
59 # For Net::BGP::NLRI
60 Aggregator => [ 64512, '10.0.0.1' ],
61 AsPath => [ 64512, 64513, 64514 ],
62 AtomicAggregate => 1,
63 Communities => [ qw( 64512:10000 64512:10001 ) ],
64 LocalPref => 100,
65 MED => 200,
66 NextHop => '10.0.0.1',
67 Origin => INCOMPLETE,
68 );
69
70 This is the constructor for "Net::BGP::Update" objects. It returns a
71 reference to the newly created object. The following named parameters
72 may be passed to the constructor. See RFC 1771 for the semantics of
73 each path attribute.
74
75 An alternative is to construct an object from a Net::BGP::NLRI object:
76
77 $nlri = Net::BGP::NLRI->new( ... );
78 $nlri_ref = [ qw( 10/8 172.168/16 ) ];
79 $withdrawn_ref = [ qw( 192.168.1/24 172.10/16 192.168.2.1/32 ) ];
80 $update = Net::BGP::Update->new($nlri,$nlri_ref,$withdrawn_ref);
81
82 The NLRI object will not be modified in any way.
83
84 NLRI
85 This parameter corresponds to the Network Layer Reachability
86 Information (NLRI) field of an UPDATE message. It represents the
87 route(s) being advertised in this particular UPDATE. It is expressed as
88 an array reference of route prefixes which are encoded in a special
89 format as perl strings: XXX.XXX.XXX.XXX/XX. The part preceding the
90 slash is a dotted-decimal notation IP prefix. Only as many octets as
91 are significant according to the mask need to be specified. The part
92 following the slash is the mask which is an integer in the range [0,32]
93 which indicates how many bits are significant in the prefix. At least
94 one of either the NLRI or Withdraw parameters is mandatory and must
95 always be provided to the constructor.
96
97 Withdraw
98 This parameter corresponds to the Withdrawn Routes field of an UPDATE
99 message. It represents route(s) advertised by a previous UPDATE message
100 which are now being withdrawn by this UPDATE. It is expressed in the
101 same way as the NLRI parameter. At least one of either the NLRI or
102 Withdraw parameters is mandatory and must always be provided to the
103 constructor.
104
106 clone() - clone a "Net::BGP::Update" object
107
108 $clone = $update->clone();
109
110 This method creates an exact copy of the "Net::BGP::Update object",
111 with Withdrawn Routes, Path Attributes, and NLRI fields matching those
112 of the original object. This is useful for propagating a modified
113 UPDATE message when the original object needs to remain unchanged.
114
116 nlri()
117
118 withdrawn()
119
120 These accessor methods return the value(s) of the associated UPDATE
121 message field if called with no arguments. If called with arguments,
122 they set the associated field. The representation of parameters and
123 return values is the same as described for the corresponding named
124 constructor parameters above.
125
126 ashash()
127
128 This method returns a hash reference index on the prefixes found in the
129 NLRI and Withdraw fields. Withdrawn networks are set to "undef", while
130 NLRI prefixes all have the same reference to the Net::BGP::NLRI object
131 matching the Update object itself.
132
134 This module does not export anything.
135
137 Net::BGP
138 Net::BGP::Process
139 Net::BGP::Peer
140 Net::BGP::Refresh
141 Net::BGP::ASPath
142 Net::BGP::NLRI
143 Net::BGP::Notification
144
146 Stephen J. Scheck <sscheck@cpan.org>
147
148
149
150perl v5.36.0 2022-07-22 Net::BGP::Update(3)