blob: 7fc482880772c9d7ed5686f5d4dfc305e7e22f53 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
|
module openconfig-rib-bgp {
yang-version "1";
// namespace
namespace "http://openconfig.net/yang/rib/bgp";
prefix "oc-rib-bgp";
// import some basic types
import openconfig-bgp-types { prefix oc-bgpt; }
import openconfig-extensions { prefix oc-ext; }
// include RIB submodules
// structure for LOC-RIB and Adj-RIB tables
include openconfig-rib-bgp-tables;
// structure of shared attribute groups
include openconfig-rib-bgp-shared-attributes;
// groupings of attributes in three categories:
// - shared across multiple routes
// - common to LOC-RIB and Adj-RIB, but not shared across routes
// - specific to LOC-RIB or Adj-RIB
include openconfig-rib-bgp-attributes;
// groupings of annotations for each route or table
include openconfig-rib-bgp-table-attributes;
// meta
organization "OpenConfig working group";
contact
"OpenConfig working group
www.openconfig.net";
description
"Defines a data model for representing BGP routing table (RIB)
contents. The model supports 5 logical RIBs per address family:
loc-rib: This is the main BGP routing table for the local routing
instance, containing best-path selections for each prefix. The
loc-rib table may contain multiple routes for a given prefix,
with an attribute to indicate which was selected as the best
path. Note that multiple paths may be used or advertised even if
only one path is marked as best, e.g., when using BGP
add-paths. An implementation may choose to mark multiple
paths in the RIB as best path by setting the flag to true for
multiple entries.
adj-rib-in-pre: This is a per-neighbor table containing the NLRI
updates received from the neighbor before any local input policy
rules or filters have been applied. This can be considered the
'raw' updates from a given neighbor.
adj-rib-in-post: This is a per-neighbor table containing the
routes received from the neighbor that are eligible for
best-path selection after local input policy rules have been
applied.
adj-rib-out-pre: This is a per-neighbor table containing routes
eligible for sending (advertising) to the neighbor before output
policy rules have been applied.
adj-rib-out-post: This is a per-neighbor table containing routes
eligible for sending (advertising) to the neighbor after output
policy rules have been applied.";
oc-ext:openconfig-version "0.3.0";
revision "2016-10-17" {
description
"OpenConfig BGP RIB refactor";
reference "0.3.0";
}
revision "2016-04-11" {
description
"OpenConfig public release";
reference "0.2.0";
}
// grouping statements
grouping bgp-rib-state {
description
"Operational state data for the top level BGP RIB";
leaf afi-safi-name {
type identityref {
base oc-bgpt:AFI_SAFI_TYPE;
}
description "AFI,SAFI";
}
}
grouping bgp-rib-top {
description
"Top-level grouping for the BGP RIB";
container bgp-rib {
config false;
description
"Top level container for BGP RIBs";
uses attribute-sets-top;
uses community-sets-top;
uses ext-community-sets-top;
container afi-safis {
config false;
description
"Enclosing container for address family list";
list afi-safi {
key "afi-safi-name";
description
"list of afi-safi types";
leaf afi-safi-name {
type leafref {
path "../state/afi-safi-name";
}
description
"Reference to the list key";
}
container state {
config false;
description
"Operational state data for the BGP list";
uses bgp-rib-state;
}
container ipv4-unicast {
when "../afi-safi-name = 'oc-bgpt:IPV4_UNICAST'" {
description
"Include this container for IPv4 unicast RIB";
}
description
"Routing tables for IPv4 unicast -- active when the
afi-safi name is ipv4-unicast";
uses ipv4-loc-rib-top;
uses ipv4-adj-rib-top;
}
container ipv6-unicast {
when "../afi-safi-name = 'oc-bgpt:IPV6_UNICAST'" {
description
"Include this container for IPv6 unicast RIB";
}
description
"Routing tables for IPv6 unicast -- active when the
afi-safi name is ipv6-unicast";
uses ipv6-loc-rib-top;
uses ipv6-adj-rib-top;
}
container ipv4-srte-policy {
when "../afi-safi-name = 'oc-bgpt:SRTE_POLICY_IPV4'" {
description
"Include this container only for the IPv4 AFI, SR-TE Policy
SAFI.";
}
description
"Routing tables for the IPv4 Unicast, SR-TE Policy SAFI.";
uses ipvX-srte-policy-locrib-top;
uses ipvX-srte-policy-adjrib-top;
}
container ipv6-srte-policy {
when "../afi-safi-name = 'oc-bgpt:SRTE_POLICY_IPV6'" {
description
"Include this container only for the IPv6 AFI, SR-TE Policy
SAFI.";
}
description
"Routing tables for the IPv6 Unicast, SR-TE Policy SAFI.";
uses ipvX-srte-policy-locrib-top;
uses ipvX-srte-policy-adjrib-top;
}
}
}
}
}
// data definition statements
uses bgp-rib-top;
// augment statements
// rpc statements
// notification statements
}
|