telemetry-snmp 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (131) hide show
  1. checksums.yaml +7 -0
  2. data/.github/workflows/rspec.yml +44 -0
  3. data/.github/workflows/rubocop.yml +28 -0
  4. data/.github/workflows/sourcehawk-scan.yml +20 -0
  5. data/.gitignore +14 -0
  6. data/.rspec +4 -0
  7. data/.rubocop.yml +26 -0
  8. data/CHANGELOG.md +4 -0
  9. data/CODE_OF_CONDUCT.md +75 -0
  10. data/CONTRIBUTING.md +54 -0
  11. data/Gemfile +10 -0
  12. data/INDIVIDUAL_CONTRIBUTOR_LICENSE.md +30 -0
  13. data/LICENSE +201 -0
  14. data/NOTICE.txt +9 -0
  15. data/README.md +54 -0
  16. data/attribution.txt +1 -0
  17. data/config.ru +15 -0
  18. data/exe/snmp_collector +55 -0
  19. data/lib/telemetry/snmp.rb +23 -0
  20. data/lib/telemetry/snmp/api.rb +55 -0
  21. data/lib/telemetry/snmp/auth.rb +54 -0
  22. data/lib/telemetry/snmp/auth/defaults.rb +41 -0
  23. data/lib/telemetry/snmp/client.rb +104 -0
  24. data/lib/telemetry/snmp/controllers/device_creds.rb +105 -0
  25. data/lib/telemetry/snmp/controllers/devices.rb +94 -0
  26. data/lib/telemetry/snmp/controllers/oid_groups.rb +71 -0
  27. data/lib/telemetry/snmp/controllers/oids.rb +80 -0
  28. data/lib/telemetry/snmp/controllers/users.rb +81 -0
  29. data/lib/telemetry/snmp/controllers/walks.rb +89 -0
  30. data/lib/telemetry/snmp/data.rb +69 -0
  31. data/lib/telemetry/snmp/data/default_opts.rb +73 -0
  32. data/lib/telemetry/snmp/data/migrations/001_device_creds.rb +19 -0
  33. data/lib/telemetry/snmp/data/migrations/002_create_devices_table.rb +31 -0
  34. data/lib/telemetry/snmp/data/migrations/003_create_oids_tables.rb +16 -0
  35. data/lib/telemetry/snmp/data/migrations/004_create_oid_groups.rb +15 -0
  36. data/lib/telemetry/snmp/data/migrations/005_create_oids_oid_groups.rb +17 -0
  37. data/lib/telemetry/snmp/data/migrations/006_device_to_oid_group.rb +15 -0
  38. data/lib/telemetry/snmp/data/migrations/007_create_users.rb +20 -0
  39. data/lib/telemetry/snmp/data/migrations/008_create_walks_table.rb +14 -0
  40. data/lib/telemetry/snmp/data/migrations/009_create_tag_name_column.rb +7 -0
  41. data/lib/telemetry/snmp/data/migrations/010_create_user_audit_table.rb +18 -0
  42. data/lib/telemetry/snmp/data/models/device.rb +11 -0
  43. data/lib/telemetry/snmp/data/models/device_cred.rb +11 -0
  44. data/lib/telemetry/snmp/data/models/oid.rb +10 -0
  45. data/lib/telemetry/snmp/data/models/oid_group.rb +10 -0
  46. data/lib/telemetry/snmp/data/models/oid_oid_groups.rb +10 -0
  47. data/lib/telemetry/snmp/data/models/oid_walk.rb +10 -0
  48. data/lib/telemetry/snmp/data/models/user.rb +10 -0
  49. data/lib/telemetry/snmp/data/models/user_audit_log.rb +19 -0
  50. data/lib/telemetry/snmp/mibs/AGENTX-MIB.txt +527 -0
  51. data/lib/telemetry/snmp/mibs/AIRPORT-BASESTATION-3-MIB.txt +461 -0
  52. data/lib/telemetry/snmp/mibs/BRIDGE-MIB.txt +1472 -0
  53. data/lib/telemetry/snmp/mibs/DISMAN-EVENT-MIB.txt +1882 -0
  54. data/lib/telemetry/snmp/mibs/DISMAN-SCHEDULE-MIB.txt +699 -0
  55. data/lib/telemetry/snmp/mibs/DISMAN-SCRIPT-MIB.txt +1764 -0
  56. data/lib/telemetry/snmp/mibs/EtherLike-MIB.txt +1862 -0
  57. data/lib/telemetry/snmp/mibs/HCNUM-TC.txt +118 -0
  58. data/lib/telemetry/snmp/mibs/HOST-RESOURCES-MIB.txt +1540 -0
  59. data/lib/telemetry/snmp/mibs/HOST-RESOURCES-TYPES.txt +389 -0
  60. data/lib/telemetry/snmp/mibs/IANA-ADDRESS-FAMILY-NUMBERS-MIB.txt +123 -0
  61. data/lib/telemetry/snmp/mibs/IANA-LANGUAGE-MIB.txt +123 -0
  62. data/lib/telemetry/snmp/mibs/IANA-RTPROTO-MIB.txt +91 -0
  63. data/lib/telemetry/snmp/mibs/IANAifType-MIB.txt +619 -0
  64. data/lib/telemetry/snmp/mibs/IF-INVERTED-STACK-MIB.txt +149 -0
  65. data/lib/telemetry/snmp/mibs/IF-MIB.txt +1814 -0
  66. data/lib/telemetry/snmp/mibs/INET-ADDRESS-MIB.txt +402 -0
  67. data/lib/telemetry/snmp/mibs/IP-FORWARD-MIB.txt +1277 -0
  68. data/lib/telemetry/snmp/mibs/IP-MIB.txt +4993 -0
  69. data/lib/telemetry/snmp/mibs/IPV6-FLOW-LABEL-MIB.txt +58 -0
  70. data/lib/telemetry/snmp/mibs/IPV6-ICMP-MIB.txt +529 -0
  71. data/lib/telemetry/snmp/mibs/IPV6-MIB.txt +1443 -0
  72. data/lib/telemetry/snmp/mibs/IPV6-TC.txt +67 -0
  73. data/lib/telemetry/snmp/mibs/IPV6-TCP-MIB.txt +211 -0
  74. data/lib/telemetry/snmp/mibs/IPV6-UDP-MIB.txt +141 -0
  75. data/lib/telemetry/snmp/mibs/NET-SNMP-AGENT-MIB.txt +554 -0
  76. data/lib/telemetry/snmp/mibs/NET-SNMP-EXAMPLES-MIB.txt +285 -0
  77. data/lib/telemetry/snmp/mibs/NET-SNMP-EXTEND-MIB.txt +325 -0
  78. data/lib/telemetry/snmp/mibs/NET-SNMP-MIB.txt +67 -0
  79. data/lib/telemetry/snmp/mibs/NET-SNMP-PASS-MIB.txt +124 -0
  80. data/lib/telemetry/snmp/mibs/NET-SNMP-TC.txt +128 -0
  81. data/lib/telemetry/snmp/mibs/NET-SNMP-VACM-MIB.txt +154 -0
  82. data/lib/telemetry/snmp/mibs/NOTIFICATION-LOG-MIB.txt +753 -0
  83. data/lib/telemetry/snmp/mibs/PAN-COMMON-MIB.md5 +1 -0
  84. data/lib/telemetry/snmp/mibs/PAN-COMMON-MIB.my +2293 -0
  85. data/lib/telemetry/snmp/mibs/PAN-ENTITY-EXT-MIB.md5 +1 -0
  86. data/lib/telemetry/snmp/mibs/PAN-ENTITY-EXT-MIB.my +293 -0
  87. data/lib/telemetry/snmp/mibs/PAN-GLOBAL-REG-MIB.md5 +1 -0
  88. data/lib/telemetry/snmp/mibs/PAN-GLOBAL-REG-MIB.my +84 -0
  89. data/lib/telemetry/snmp/mibs/PAN-GLOBAL-TC-MIB.md5 +1 -0
  90. data/lib/telemetry/snmp/mibs/PAN-GLOBAL-TC-MIB.my +68 -0
  91. data/lib/telemetry/snmp/mibs/PAN-LC-MIB.md5 +1 -0
  92. data/lib/telemetry/snmp/mibs/PAN-LC-MIB.my +204 -0
  93. data/lib/telemetry/snmp/mibs/PAN-PRODUCT-MIB.md5 +1 -0
  94. data/lib/telemetry/snmp/mibs/PAN-PRODUCT-MIB.my +305 -0
  95. data/lib/telemetry/snmp/mibs/PAN-TRAPS.md5 +1 -0
  96. data/lib/telemetry/snmp/mibs/PAN-TRAPS.my +7809 -0
  97. data/lib/telemetry/snmp/mibs/RFC-1215.txt +38 -0
  98. data/lib/telemetry/snmp/mibs/RFC1155-SMI.txt +119 -0
  99. data/lib/telemetry/snmp/mibs/RFC1213-MIB.txt +2613 -0
  100. data/lib/telemetry/snmp/mibs/RMON-MIB.txt +3980 -0
  101. data/lib/telemetry/snmp/mibs/SCTP-MIB.txt +1342 -0
  102. data/lib/telemetry/snmp/mibs/SMUX-MIB.txt +160 -0
  103. data/lib/telemetry/snmp/mibs/SNMP-COMMUNITY-MIB.txt +429 -0
  104. data/lib/telemetry/snmp/mibs/SNMP-FRAMEWORK-MIB.txt +526 -0
  105. data/lib/telemetry/snmp/mibs/SNMP-MPD-MIB.txt +145 -0
  106. data/lib/telemetry/snmp/mibs/SNMP-NOTIFICATION-MIB.txt +589 -0
  107. data/lib/telemetry/snmp/mibs/SNMP-PROXY-MIB.txt +294 -0
  108. data/lib/telemetry/snmp/mibs/SNMP-TARGET-MIB.txt +660 -0
  109. data/lib/telemetry/snmp/mibs/SNMP-USER-BASED-SM-MIB.txt +912 -0
  110. data/lib/telemetry/snmp/mibs/SNMP-USM-AES-MIB.txt +62 -0
  111. data/lib/telemetry/snmp/mibs/SNMP-USM-DH-OBJECTS-MIB.txt +532 -0
  112. data/lib/telemetry/snmp/mibs/SNMP-VIEW-BASED-ACM-MIB.txt +830 -0
  113. data/lib/telemetry/snmp/mibs/SNMPv2-CONF.txt +322 -0
  114. data/lib/telemetry/snmp/mibs/SNMPv2-MIB.txt +854 -0
  115. data/lib/telemetry/snmp/mibs/SNMPv2-SMI.txt +344 -0
  116. data/lib/telemetry/snmp/mibs/SNMPv2-TC.txt +772 -0
  117. data/lib/telemetry/snmp/mibs/SNMPv2-TM.txt +176 -0
  118. data/lib/telemetry/snmp/mibs/TCP-MIB.txt +785 -0
  119. data/lib/telemetry/snmp/mibs/TRANSPORT-ADDRESS-MIB.txt +421 -0
  120. data/lib/telemetry/snmp/mibs/TUNNEL-MIB.txt +738 -0
  121. data/lib/telemetry/snmp/mibs/UCD-DEMO-MIB.txt +74 -0
  122. data/lib/telemetry/snmp/mibs/UCD-DISKIO-MIB.txt +171 -0
  123. data/lib/telemetry/snmp/mibs/UCD-DLMOD-MIB.txt +124 -0
  124. data/lib/telemetry/snmp/mibs/UCD-IPFWACC-MIB.txt +327 -0
  125. data/lib/telemetry/snmp/mibs/UCD-SNMP-MIB.txt +1712 -0
  126. data/lib/telemetry/snmp/mibs/UDP-MIB.txt +549 -0
  127. data/lib/telemetry/snmp/publisher.rb +130 -0
  128. data/lib/telemetry/snmp/version.rb +7 -0
  129. data/sourcehawk.yml +4 -0
  130. data/telemetry-snmp.gemspec +48 -0
  131. metadata +456 -0
@@ -0,0 +1,402 @@
1
+ INET-ADDRESS-MIB DEFINITIONS ::= BEGIN
2
+
3
+ IMPORTS
4
+ MODULE-IDENTITY, mib-2, Unsigned32 FROM SNMPv2-SMI
5
+ TEXTUAL-CONVENTION FROM SNMPv2-TC;
6
+
7
+ inetAddressMIB MODULE-IDENTITY
8
+ LAST-UPDATED "200502040000Z"
9
+ ORGANIZATION
10
+ "IETF Operations and Management Area"
11
+ CONTACT-INFO
12
+ "Juergen Schoenwaelder (Editor)
13
+ International University Bremen
14
+ P.O. Box 750 561
15
+ 28725 Bremen, Germany
16
+
17
+ Phone: +49 421 200-3587
18
+ EMail: j.schoenwaelder@iu-bremen.de
19
+
20
+ Send comments to <ietfmibs@ops.ietf.org>."
21
+ DESCRIPTION
22
+ "This MIB module defines textual conventions for
23
+ representing Internet addresses. An Internet
24
+ address can be an IPv4 address, an IPv6 address,
25
+ or a DNS domain name. This module also defines
26
+ textual conventions for Internet port numbers,
27
+ autonomous system numbers, and the length of an
28
+ Internet address prefix.
29
+
30
+ Copyright (C) The Internet Society (2005). This version
31
+ of this MIB module is part of RFC 4001, see the RFC
32
+ itself for full legal notices."
33
+ REVISION "200502040000Z"
34
+ DESCRIPTION
35
+ "Third version, published as RFC 4001. This revision
36
+ introduces the InetZoneIndex, InetScopeType, and
37
+ InetVersion textual conventions."
38
+ REVISION "200205090000Z"
39
+ DESCRIPTION
40
+ "Second version, published as RFC 3291. This
41
+ revision contains several clarifications and
42
+ introduces several new textual conventions:
43
+ InetAddressPrefixLength, InetPortNumber,
44
+ InetAutonomousSystemNumber, InetAddressIPv4z,
45
+ and InetAddressIPv6z."
46
+ REVISION "200006080000Z"
47
+ DESCRIPTION
48
+ "Initial version, published as RFC 2851."
49
+ ::= { mib-2 76 }
50
+
51
+ InetAddressType ::= TEXTUAL-CONVENTION
52
+ STATUS current
53
+ DESCRIPTION
54
+ "A value that represents a type of Internet address.
55
+
56
+ unknown(0) An unknown address type. This value MUST
57
+ be used if the value of the corresponding
58
+ InetAddress object is a zero-length string.
59
+ It may also be used to indicate an IP address
60
+ that is not in one of the formats defined
61
+ below.
62
+
63
+ ipv4(1) An IPv4 address as defined by the
64
+ InetAddressIPv4 textual convention.
65
+
66
+ ipv6(2) An IPv6 address as defined by the
67
+ InetAddressIPv6 textual convention.
68
+
69
+ ipv4z(3) A non-global IPv4 address including a zone
70
+ index as defined by the InetAddressIPv4z
71
+ textual convention.
72
+
73
+ ipv6z(4) A non-global IPv6 address including a zone
74
+ index as defined by the InetAddressIPv6z
75
+ textual convention.
76
+
77
+ dns(16) A DNS domain name as defined by the
78
+ InetAddressDNS textual convention.
79
+
80
+ Each definition of a concrete InetAddressType value must be
81
+ accompanied by a definition of a textual convention for use
82
+ with that InetAddressType.
83
+
84
+ To support future extensions, the InetAddressType textual
85
+ convention SHOULD NOT be sub-typed in object type definitions.
86
+ It MAY be sub-typed in compliance statements in order to
87
+ require only a subset of these address types for a compliant
88
+ implementation.
89
+
90
+ Implementations must ensure that InetAddressType objects
91
+ and any dependent objects (e.g., InetAddress objects) are
92
+ consistent. An inconsistentValue error must be generated
93
+ if an attempt to change an InetAddressType object would,
94
+ for example, lead to an undefined InetAddress value. In
95
+
96
+ particular, InetAddressType/InetAddress pairs must be
97
+ changed together if the address type changes (e.g., from
98
+ ipv6(2) to ipv4(1))."
99
+ SYNTAX INTEGER {
100
+ unknown(0),
101
+ ipv4(1),
102
+ ipv6(2),
103
+ ipv4z(3),
104
+ ipv6z(4),
105
+ dns(16)
106
+ }
107
+
108
+ InetAddress ::= TEXTUAL-CONVENTION
109
+ STATUS current
110
+ DESCRIPTION
111
+ "Denotes a generic Internet address.
112
+
113
+ An InetAddress value is always interpreted within the context
114
+ of an InetAddressType value. Every usage of the InetAddress
115
+ textual convention is required to specify the InetAddressType
116
+ object that provides the context. It is suggested that the
117
+ InetAddressType object be logically registered before the
118
+ object(s) that use the InetAddress textual convention, if
119
+ they appear in the same logical row.
120
+
121
+ The value of an InetAddress object must always be
122
+ consistent with the value of the associated InetAddressType
123
+ object. Attempts to set an InetAddress object to a value
124
+ inconsistent with the associated InetAddressType
125
+ must fail with an inconsistentValue error.
126
+
127
+ When this textual convention is used as the syntax of an
128
+ index object, there may be issues with the limit of 128
129
+ sub-identifiers specified in SMIv2, STD 58. In this case,
130
+ the object definition MUST include a 'SIZE' clause to
131
+ limit the number of potential instance sub-identifiers;
132
+ otherwise the applicable constraints MUST be stated in
133
+ the appropriate conceptual row DESCRIPTION clauses, or
134
+ in the surrounding documentation if there is no single
135
+ DESCRIPTION clause that is appropriate."
136
+ SYNTAX OCTET STRING (SIZE (0..255))
137
+
138
+ InetAddressIPv4 ::= TEXTUAL-CONVENTION
139
+ DISPLAY-HINT "1d.1d.1d.1d"
140
+ STATUS current
141
+ DESCRIPTION
142
+ "Represents an IPv4 network address:
143
+
144
+ Octets Contents Encoding
145
+ 1-4 IPv4 address network-byte order
146
+
147
+ The corresponding InetAddressType value is ipv4(1).
148
+
149
+ This textual convention SHOULD NOT be used directly in object
150
+ definitions, as it restricts addresses to a specific format.
151
+ However, if it is used, it MAY be used either on its own or in
152
+ conjunction with InetAddressType, as a pair."
153
+ SYNTAX OCTET STRING (SIZE (4))
154
+
155
+ InetAddressIPv6 ::= TEXTUAL-CONVENTION
156
+ DISPLAY-HINT "2x:2x:2x:2x:2x:2x:2x:2x"
157
+ STATUS current
158
+ DESCRIPTION
159
+ "Represents an IPv6 network address:
160
+
161
+ Octets Contents Encoding
162
+ 1-16 IPv6 address network-byte order
163
+
164
+ The corresponding InetAddressType value is ipv6(2).
165
+
166
+ This textual convention SHOULD NOT be used directly in object
167
+ definitions, as it restricts addresses to a specific format.
168
+ However, if it is used, it MAY be used either on its own or in
169
+ conjunction with InetAddressType, as a pair."
170
+ SYNTAX OCTET STRING (SIZE (16))
171
+
172
+ InetAddressIPv4z ::= TEXTUAL-CONVENTION
173
+ DISPLAY-HINT "1d.1d.1d.1d%4d"
174
+ STATUS current
175
+ DESCRIPTION
176
+ "Represents a non-global IPv4 network address, together
177
+ with its zone index:
178
+
179
+ Octets Contents Encoding
180
+ 1-4 IPv4 address network-byte order
181
+ 5-8 zone index network-byte order
182
+
183
+ The corresponding InetAddressType value is ipv4z(3).
184
+
185
+ The zone index (bytes 5-8) is used to disambiguate identical
186
+ address values on nodes that have interfaces attached to
187
+ different zones of the same scope. The zone index may contain
188
+ the special value 0, which refers to the default zone for each
189
+ scope.
190
+
191
+ This textual convention SHOULD NOT be used directly in object
192
+
193
+ definitions, as it restricts addresses to a specific format.
194
+ However, if it is used, it MAY be used either on its own or in
195
+ conjunction with InetAddressType, as a pair."
196
+ SYNTAX OCTET STRING (SIZE (8))
197
+
198
+ InetAddressIPv6z ::= TEXTUAL-CONVENTION
199
+ DISPLAY-HINT "2x:2x:2x:2x:2x:2x:2x:2x%4d"
200
+ STATUS current
201
+ DESCRIPTION
202
+ "Represents a non-global IPv6 network address, together
203
+ with its zone index:
204
+
205
+ Octets Contents Encoding
206
+ 1-16 IPv6 address network-byte order
207
+ 17-20 zone index network-byte order
208
+
209
+ The corresponding InetAddressType value is ipv6z(4).
210
+
211
+ The zone index (bytes 17-20) is used to disambiguate
212
+ identical address values on nodes that have interfaces
213
+ attached to different zones of the same scope. The zone index
214
+ may contain the special value 0, which refers to the default
215
+ zone for each scope.
216
+
217
+ This textual convention SHOULD NOT be used directly in object
218
+ definitions, as it restricts addresses to a specific format.
219
+ However, if it is used, it MAY be used either on its own or in
220
+ conjunction with InetAddressType, as a pair."
221
+ SYNTAX OCTET STRING (SIZE (20))
222
+
223
+ InetAddressDNS ::= TEXTUAL-CONVENTION
224
+ DISPLAY-HINT "255a"
225
+ STATUS current
226
+ DESCRIPTION
227
+ "Represents a DNS domain name. The name SHOULD be fully
228
+ qualified whenever possible.
229
+
230
+ The corresponding InetAddressType is dns(16).
231
+
232
+ The DESCRIPTION clause of InetAddress objects that may have
233
+ InetAddressDNS values MUST fully describe how (and when)
234
+ these names are to be resolved to IP addresses.
235
+
236
+ The resolution of an InetAddressDNS value may require to
237
+ query multiple DNS records (e.g., A for IPv4 and AAAA for
238
+ IPv6). The order of the resolution process and which DNS
239
+ record takes precedence depends on the configuration of the
240
+ resolver.
241
+
242
+ This textual convention SHOULD NOT be used directly in object
243
+ definitions, as it restricts addresses to a specific format.
244
+ However, if it is used, it MAY be used either on its own or in
245
+ conjunction with InetAddressType, as a pair."
246
+ SYNTAX OCTET STRING (SIZE (1..255))
247
+
248
+ InetAddressPrefixLength ::= TEXTUAL-CONVENTION
249
+ DISPLAY-HINT "d"
250
+ STATUS current
251
+ DESCRIPTION
252
+ "Denotes the length of a generic Internet network address
253
+ prefix. A value of n corresponds to an IP address mask
254
+ that has n contiguous 1-bits from the most significant
255
+ bit (MSB), with all other bits set to 0.
256
+
257
+ An InetAddressPrefixLength value is always interpreted within
258
+ the context of an InetAddressType value. Every usage of the
259
+ InetAddressPrefixLength textual convention is required to
260
+ specify the InetAddressType object that provides the
261
+ context. It is suggested that the InetAddressType object be
262
+ logically registered before the object(s) that use the
263
+ InetAddressPrefixLength textual convention, if they appear
264
+ in the same logical row.
265
+
266
+ InetAddressPrefixLength values larger than
267
+ the maximum length of an IP address for a specific
268
+ InetAddressType are treated as the maximum significant
269
+ value applicable for the InetAddressType. The maximum
270
+ significant value is 32 for the InetAddressType
271
+ 'ipv4(1)' and 'ipv4z(3)' and 128 for the InetAddressType
272
+ 'ipv6(2)' and 'ipv6z(4)'. The maximum significant value
273
+ for the InetAddressType 'dns(16)' is 0.
274
+
275
+ The value zero is object-specific and must be defined as
276
+ part of the description of any object that uses this
277
+ syntax. Examples of the usage of zero might include
278
+ situations where the Internet network address prefix
279
+ is unknown or does not apply.
280
+
281
+ The upper bound of the prefix length has been chosen to
282
+ be consistent with the maximum size of an InetAddress."
283
+ SYNTAX Unsigned32 (0..2040)
284
+
285
+ InetPortNumber ::= TEXTUAL-CONVENTION
286
+ DISPLAY-HINT "d"
287
+ STATUS current
288
+ DESCRIPTION
289
+ "Represents a 16 bit port number of an Internet transport
290
+
291
+ layer protocol. Port numbers are assigned by IANA. A
292
+ current list of all assignments is available from
293
+ <http://www.iana.org/>.
294
+
295
+ The value zero is object-specific and must be defined as
296
+ part of the description of any object that uses this
297
+ syntax. Examples of the usage of zero might include
298
+ situations where a port number is unknown, or when the
299
+ value zero is used as a wildcard in a filter."
300
+ REFERENCE "STD 6 (RFC 768), STD 7 (RFC 793) and RFC 2960"
301
+ SYNTAX Unsigned32 (0..65535)
302
+
303
+ InetAutonomousSystemNumber ::= TEXTUAL-CONVENTION
304
+ DISPLAY-HINT "d"
305
+ STATUS current
306
+ DESCRIPTION
307
+ "Represents an autonomous system number that identifies an
308
+ Autonomous System (AS). An AS is a set of routers under a
309
+ single technical administration, using an interior gateway
310
+ protocol and common metrics to route packets within the AS,
311
+ and using an exterior gateway protocol to route packets to
312
+ other ASes'. IANA maintains the AS number space and has
313
+ delegated large parts to the regional registries.
314
+
315
+ Autonomous system numbers are currently limited to 16 bits
316
+ (0..65535). There is, however, work in progress to enlarge the
317
+ autonomous system number space to 32 bits. Therefore, this
318
+ textual convention uses an Unsigned32 value without a
319
+ range restriction in order to support a larger autonomous
320
+ system number space."
321
+ REFERENCE "RFC 1771, RFC 1930"
322
+ SYNTAX Unsigned32
323
+
324
+ InetScopeType ::= TEXTUAL-CONVENTION
325
+ STATUS current
326
+ DESCRIPTION
327
+ "Represents a scope type. This textual convention can be used
328
+ in cases where a MIB has to represent different scope types
329
+ and there is no context information, such as an InetAddress
330
+ object, that implicitly defines the scope type.
331
+
332
+ Note that not all possible values have been assigned yet, but
333
+ they may be assigned in future revisions of this specification.
334
+ Applications should therefore be able to deal with values
335
+ not yet assigned."
336
+ REFERENCE "RFC 3513"
337
+ SYNTAX INTEGER {
338
+ -- reserved(0),
339
+ interfaceLocal(1),
340
+ linkLocal(2),
341
+ subnetLocal(3),
342
+ adminLocal(4),
343
+ siteLocal(5), -- site-local unicast addresses
344
+ -- have been deprecated by RFC 3879
345
+ -- unassigned(6),
346
+ -- unassigned(7),
347
+ organizationLocal(8),
348
+ -- unassigned(9),
349
+ -- unassigned(10),
350
+ -- unassigned(11),
351
+ -- unassigned(12),
352
+ -- unassigned(13),
353
+ global(14)
354
+ -- reserved(15)
355
+ }
356
+
357
+ InetZoneIndex ::= TEXTUAL-CONVENTION
358
+ DISPLAY-HINT "d"
359
+ STATUS current
360
+ DESCRIPTION
361
+ "A zone index identifies an instance of a zone of a
362
+ specific scope.
363
+
364
+ The zone index MUST disambiguate identical address
365
+ values. For link-local addresses, the zone index will
366
+ typically be the interface index (ifIndex as defined in the
367
+ IF-MIB) of the interface on which the address is configured.
368
+
369
+ The zone index may contain the special value 0, which refers
370
+ to the default zone. The default zone may be used in cases
371
+ where the valid zone index is not known (e.g., when a
372
+ management application has to write a link-local IPv6
373
+ address without knowing the interface index value). The
374
+ default zone SHOULD NOT be used as an easy way out in
375
+ cases where the zone index for a non-global IPv6 address
376
+ is known."
377
+ REFERENCE "RFC4007"
378
+ SYNTAX Unsigned32
379
+
380
+ InetVersion ::= TEXTUAL-CONVENTION
381
+ STATUS current
382
+ DESCRIPTION
383
+ "A value representing a version of the IP protocol.
384
+
385
+ unknown(0) An unknown or unspecified version of the IP
386
+ protocol.
387
+
388
+ ipv4(1) The IPv4 protocol as defined in RFC 791 (STD 5).
389
+
390
+ ipv6(2) The IPv6 protocol as defined in RFC 2460.
391
+
392
+ Note that this textual convention SHOULD NOT be used to
393
+ distinguish different address types associated with IP
394
+ protocols. The InetAddressType has been designed for this
395
+ purpose."
396
+ REFERENCE "RFC 791, RFC 2460"
397
+ SYNTAX INTEGER {
398
+ unknown(0),
399
+ ipv4(1),
400
+ ipv6(2)
401
+ }
402
+ END
@@ -0,0 +1,1277 @@
1
+ IP-FORWARD-MIB DEFINITIONS ::= BEGIN
2
+
3
+ IMPORTS
4
+ MODULE-IDENTITY, OBJECT-TYPE,
5
+ IpAddress, Integer32, Gauge32,
6
+ Counter32 FROM SNMPv2-SMI
7
+ RowStatus FROM SNMPv2-TC
8
+
9
+ MODULE-COMPLIANCE, OBJECT-GROUP FROM SNMPv2-CONF
10
+ InterfaceIndexOrZero FROM IF-MIB
11
+ ip FROM IP-MIB
12
+ IANAipRouteProtocol FROM IANA-RTPROTO-MIB
13
+ InetAddress, InetAddressType,
14
+ InetAddressPrefixLength,
15
+ InetAutonomousSystemNumber FROM INET-ADDRESS-MIB;
16
+
17
+ ipForward MODULE-IDENTITY
18
+ LAST-UPDATED "200602010000Z"
19
+ ORGANIZATION
20
+ "IETF IPv6 Working Group
21
+ http://www.ietf.org/html.charters/ipv6-charter.html"
22
+ CONTACT-INFO
23
+ "Editor:
24
+ Brian Haberman
25
+ Johns Hopkins University - Applied Physics Laboratory
26
+ Mailstop 17-S442
27
+ 11100 Johns Hopkins Road
28
+ Laurel MD, 20723-6099 USA
29
+
30
+ Phone: +1-443-778-1319
31
+ Email: brian@innovationslab.net
32
+
33
+ Send comments to <ipv6@ietf.org>"
34
+ DESCRIPTION
35
+ "The MIB module for the management of CIDR multipath IP
36
+ Routes.
37
+
38
+ Copyright (C) The Internet Society (2006). This version
39
+ of this MIB module is a part of RFC 4292; see the RFC
40
+ itself for full legal notices."
41
+
42
+ REVISION "200602010000Z"
43
+ DESCRIPTION
44
+ "IPv4/v6 version-independent revision. Minimal changes
45
+ were made to the original RFC 2096 MIB to allow easy
46
+ upgrade of existing IPv4 implementations to the
47
+ version-independent MIB. These changes include:
48
+
49
+ Adding inetCidrRouteDiscards as a replacement for the
50
+ deprecated ipRoutingDiscards and ipv6DiscardedRoutes
51
+ objects.
52
+
53
+ Adding a new conformance statement to support the
54
+ implementation of the IP Forwarding MIB in a
55
+ read-only mode.
56
+
57
+ The inetCidrRouteTable replaces the IPv4-specific
58
+ ipCidrRouteTable, its related objects, and related
59
+ conformance statements.
60
+
61
+ Published as RFC 4292."
62
+
63
+ REVISION "199609190000Z"
64
+ DESCRIPTION
65
+ "Revised to support CIDR routes.
66
+ Published as RFC 2096."
67
+
68
+ REVISION "199207022156Z"
69
+ DESCRIPTION
70
+ "Initial version, published as RFC 1354."
71
+ ::= { ip 24 }
72
+
73
+ inetCidrRouteNumber OBJECT-TYPE
74
+ SYNTAX Gauge32
75
+ MAX-ACCESS read-only
76
+ STATUS current
77
+ DESCRIPTION
78
+ "The number of current inetCidrRouteTable entries that
79
+ are not invalid."
80
+ ::= { ipForward 6 }
81
+
82
+ inetCidrRouteDiscards OBJECT-TYPE
83
+ SYNTAX Counter32
84
+ MAX-ACCESS read-only
85
+ STATUS current
86
+ DESCRIPTION
87
+ "The number of valid route entries discarded from the
88
+ inetCidrRouteTable. Discarded route entries do not
89
+ appear in the inetCidrRouteTable. One possible reason
90
+ for discarding an entry would be to free-up buffer space
91
+ for other route table entries."
92
+ ::= { ipForward 8 }
93
+
94
+ -- Inet CIDR Route Table
95
+
96
+ -- The Inet CIDR Route Table deprecates and replaces the
97
+ -- ipCidrRoute Table currently in the IP Forwarding Table MIB.
98
+ -- It adds IP protocol independence.
99
+
100
+ inetCidrRouteTable OBJECT-TYPE
101
+ SYNTAX SEQUENCE OF InetCidrRouteEntry
102
+ MAX-ACCESS not-accessible
103
+ STATUS current
104
+ DESCRIPTION
105
+ "This entity's IP Routing table."
106
+ REFERENCE
107
+ "RFC 1213 Section 6.6, The IP Group"
108
+ ::= { ipForward 7 }
109
+
110
+ inetCidrRouteEntry OBJECT-TYPE
111
+ SYNTAX InetCidrRouteEntry
112
+ MAX-ACCESS not-accessible
113
+ STATUS current
114
+ DESCRIPTION
115
+ "A particular route to a particular destination, under a
116
+ particular policy (as reflected in the
117
+ inetCidrRoutePolicy object).
118
+
119
+ Dynamically created rows will survive an agent reboot.
120
+
121
+ Implementers need to be aware that if the total number
122
+ of elements (octets or sub-identifiers) in
123
+ inetCidrRouteDest, inetCidrRoutePolicy, and
124
+ inetCidrRouteNextHop exceeds 111, then OIDs of column
125
+ instances in this table will have more than 128 sub-
126
+ identifiers and cannot be accessed using SNMPv1,
127
+ SNMPv2c, or SNMPv3."
128
+ INDEX {
129
+ inetCidrRouteDestType,
130
+ inetCidrRouteDest,
131
+ inetCidrRoutePfxLen,
132
+ inetCidrRoutePolicy,
133
+ inetCidrRouteNextHopType,
134
+ inetCidrRouteNextHop
135
+ }
136
+ ::= { inetCidrRouteTable 1 }
137
+
138
+ InetCidrRouteEntry ::= SEQUENCE {
139
+ inetCidrRouteDestType InetAddressType,
140
+ inetCidrRouteDest InetAddress,
141
+ inetCidrRoutePfxLen InetAddressPrefixLength,
142
+ inetCidrRoutePolicy OBJECT IDENTIFIER,
143
+ inetCidrRouteNextHopType InetAddressType,
144
+ inetCidrRouteNextHop InetAddress,
145
+ inetCidrRouteIfIndex InterfaceIndexOrZero,
146
+ inetCidrRouteType INTEGER,
147
+ inetCidrRouteProto IANAipRouteProtocol,
148
+ inetCidrRouteAge Gauge32,
149
+ inetCidrRouteNextHopAS InetAutonomousSystemNumber,
150
+ inetCidrRouteMetric1 Integer32,
151
+ inetCidrRouteMetric2 Integer32,
152
+ inetCidrRouteMetric3 Integer32,
153
+ inetCidrRouteMetric4 Integer32,
154
+ inetCidrRouteMetric5 Integer32,
155
+ inetCidrRouteStatus RowStatus
156
+ }
157
+
158
+ inetCidrRouteDestType OBJECT-TYPE
159
+ SYNTAX InetAddressType
160
+ MAX-ACCESS not-accessible
161
+ STATUS current
162
+ DESCRIPTION
163
+ "The type of the inetCidrRouteDest address, as defined
164
+ in the InetAddress MIB.
165
+
166
+ Only those address types that may appear in an actual
167
+ routing table are allowed as values of this object."
168
+ REFERENCE "RFC 4001"
169
+ ::= { inetCidrRouteEntry 1 }
170
+
171
+ inetCidrRouteDest OBJECT-TYPE
172
+ SYNTAX InetAddress
173
+ MAX-ACCESS not-accessible
174
+ STATUS current
175
+ DESCRIPTION
176
+ "The destination IP address of this route.
177
+
178
+ The type of this address is determined by the value of
179
+ the inetCidrRouteDestType object.
180
+
181
+ The values for the index objects inetCidrRouteDest and
182
+ inetCidrRoutePfxLen must be consistent. When the value
183
+ of inetCidrRouteDest (excluding the zone index, if one
184
+ is present) is x, then the bitwise logical-AND
185
+ of x with the value of the mask formed from the
186
+ corresponding index object inetCidrRoutePfxLen MUST be
187
+ equal to x. If not, then the index pair is not
188
+ consistent and an inconsistentName error must be
189
+ returned on SET or CREATE requests."
190
+ ::= { inetCidrRouteEntry 2 }
191
+
192
+ inetCidrRoutePfxLen OBJECT-TYPE
193
+ SYNTAX InetAddressPrefixLength
194
+ MAX-ACCESS not-accessible
195
+ STATUS current
196
+ DESCRIPTION
197
+ "Indicates the number of leading one bits that form the
198
+ mask to be logical-ANDed with the destination address
199
+ before being compared to the value in the
200
+
201
+ inetCidrRouteDest field.
202
+
203
+ The values for the index objects inetCidrRouteDest and
204
+ inetCidrRoutePfxLen must be consistent. When the value
205
+ of inetCidrRouteDest (excluding the zone index, if one
206
+ is present) is x, then the bitwise logical-AND
207
+ of x with the value of the mask formed from the
208
+ corresponding index object inetCidrRoutePfxLen MUST be
209
+ equal to x. If not, then the index pair is not
210
+ consistent and an inconsistentName error must be
211
+ returned on SET or CREATE requests."
212
+ ::= { inetCidrRouteEntry 3 }
213
+
214
+ inetCidrRoutePolicy OBJECT-TYPE
215
+ SYNTAX OBJECT IDENTIFIER
216
+ MAX-ACCESS not-accessible
217
+ STATUS current
218
+ DESCRIPTION
219
+ "This object is an opaque object without any defined
220
+ semantics. Its purpose is to serve as an additional
221
+ index that may delineate between multiple entries to
222
+ the same destination. The value { 0 0 } shall be used
223
+ as the default value for this object."
224
+ ::= { inetCidrRouteEntry 4 }
225
+
226
+ inetCidrRouteNextHopType OBJECT-TYPE
227
+ SYNTAX InetAddressType
228
+ MAX-ACCESS not-accessible
229
+ STATUS current
230
+ DESCRIPTION
231
+ "The type of the inetCidrRouteNextHop address, as
232
+ defined in the InetAddress MIB.
233
+
234
+ Value should be set to unknown(0) for non-remote
235
+ routes.
236
+
237
+ Only those address types that may appear in an actual
238
+ routing table are allowed as values of this object."
239
+ REFERENCE "RFC 4001"
240
+ ::= { inetCidrRouteEntry 5 }
241
+
242
+ inetCidrRouteNextHop OBJECT-TYPE
243
+ SYNTAX InetAddress
244
+ MAX-ACCESS not-accessible
245
+ STATUS current
246
+ DESCRIPTION
247
+ "On remote routes, the address of the next system en
248
+
249
+ route. For non-remote routes, a zero length string.
250
+
251
+ The type of this address is determined by the value of
252
+ the inetCidrRouteNextHopType object."
253
+ ::= { inetCidrRouteEntry 6 }
254
+
255
+ inetCidrRouteIfIndex OBJECT-TYPE
256
+ SYNTAX InterfaceIndexOrZero
257
+ MAX-ACCESS read-create
258
+ STATUS current
259
+ DESCRIPTION
260
+ "The ifIndex value that identifies the local interface
261
+ through which the next hop of this route should be
262
+ reached. A value of 0 is valid and represents the
263
+ scenario where no interface is specified."
264
+ ::= { inetCidrRouteEntry 7 }
265
+
266
+ inetCidrRouteType OBJECT-TYPE
267
+ SYNTAX INTEGER {
268
+ other (1), -- not specified by this MIB
269
+ reject (2), -- route that discards traffic and
270
+ -- returns ICMP notification
271
+ local (3), -- local interface
272
+ remote (4), -- remote destination
273
+ blackhole(5) -- route that discards traffic
274
+ -- silently
275
+ }
276
+ MAX-ACCESS read-create
277
+ STATUS current
278
+ DESCRIPTION
279
+ "The type of route. Note that local(3) refers to a
280
+ route for which the next hop is the final destination;
281
+ remote(4) refers to a route for which the next hop is
282
+ not the final destination.
283
+
284
+ Routes that do not result in traffic forwarding or
285
+ rejection should not be displayed, even if the
286
+ implementation keeps them stored internally.
287
+
288
+ reject(2) refers to a route that, if matched, discards
289
+ the message as unreachable and returns a notification
290
+ (e.g., ICMP error) to the message sender. This is used
291
+ in some protocols as a means of correctly aggregating
292
+ routes.
293
+
294
+ blackhole(5) refers to a route that, if matched,
295
+ discards the message silently."
296
+ ::= { inetCidrRouteEntry 8 }
297
+
298
+ inetCidrRouteProto OBJECT-TYPE
299
+ SYNTAX IANAipRouteProtocol
300
+ MAX-ACCESS read-only
301
+ STATUS current
302
+ DESCRIPTION
303
+ "The routing mechanism via which this route was learned.
304
+ Inclusion of values for gateway routing protocols is
305
+ not intended to imply that hosts should support those
306
+ protocols."
307
+ ::= { inetCidrRouteEntry 9 }
308
+
309
+ inetCidrRouteAge OBJECT-TYPE
310
+ SYNTAX Gauge32
311
+ MAX-ACCESS read-only
312
+ STATUS current
313
+ DESCRIPTION
314
+ "The number of seconds since this route was last updated
315
+ or otherwise determined to be correct. Note that no
316
+ semantics of 'too old' can be implied, except through
317
+ knowledge of the routing protocol by which the route
318
+ was learned."
319
+ ::= { inetCidrRouteEntry 10 }
320
+
321
+ inetCidrRouteNextHopAS OBJECT-TYPE
322
+ SYNTAX InetAutonomousSystemNumber
323
+ MAX-ACCESS read-create
324
+ STATUS current
325
+ DESCRIPTION
326
+ "The Autonomous System Number of the Next Hop. The
327
+ semantics of this object are determined by the routing-
328
+ protocol specified in the route's inetCidrRouteProto
329
+ value. When this object is unknown or not relevant, its
330
+ value should be set to zero."
331
+ DEFVAL { 0 }
332
+ ::= { inetCidrRouteEntry 11 }
333
+
334
+ inetCidrRouteMetric1 OBJECT-TYPE
335
+ SYNTAX Integer32
336
+ MAX-ACCESS read-create
337
+ STATUS current
338
+ DESCRIPTION
339
+ "The primary routing metric for this route. The
340
+ semantics of this metric are determined by the routing-
341
+ protocol specified in the route's inetCidrRouteProto
342
+ value. If this metric is not used, its value should be
343
+ set to -1."
344
+ DEFVAL { -1 }
345
+ ::= { inetCidrRouteEntry 12 }
346
+
347
+ inetCidrRouteMetric2 OBJECT-TYPE
348
+ SYNTAX Integer32
349
+ MAX-ACCESS read-create
350
+ STATUS current
351
+ DESCRIPTION
352
+ "An alternate routing metric for this route. The
353
+ semantics of this metric are determined by the routing-
354
+ protocol specified in the route's inetCidrRouteProto
355
+ value. If this metric is not used, its value should be
356
+ set to -1."
357
+ DEFVAL { -1 }
358
+ ::= { inetCidrRouteEntry 13 }
359
+
360
+ inetCidrRouteMetric3 OBJECT-TYPE
361
+ SYNTAX Integer32
362
+ MAX-ACCESS read-create
363
+ STATUS current
364
+ DESCRIPTION
365
+ "An alternate routing metric for this route. The
366
+ semantics of this metric are determined by the routing-
367
+ protocol specified in the route's inetCidrRouteProto
368
+ value. If this metric is not used, its value should be
369
+ set to -1."
370
+ DEFVAL { -1 }
371
+ ::= { inetCidrRouteEntry 14 }
372
+
373
+ inetCidrRouteMetric4 OBJECT-TYPE
374
+ SYNTAX Integer32
375
+ MAX-ACCESS read-create
376
+ STATUS current
377
+ DESCRIPTION
378
+ "An alternate routing metric for this route. The
379
+ semantics of this metric are determined by the routing-
380
+ protocol specified in the route's inetCidrRouteProto
381
+ value. If this metric is not used, its value should be
382
+ set to -1."
383
+ DEFVAL { -1 }
384
+ ::= { inetCidrRouteEntry 15 }
385
+
386
+ inetCidrRouteMetric5 OBJECT-TYPE
387
+ SYNTAX Integer32
388
+ MAX-ACCESS read-create
389
+ STATUS current
390
+ DESCRIPTION
391
+ "An alternate routing metric for this route. The
392
+ semantics of this metric are determined by the routing-
393
+
394
+ protocol specified in the route's inetCidrRouteProto
395
+ value. If this metric is not used, its value should be
396
+ set to -1."
397
+ DEFVAL { -1 }
398
+ ::= { inetCidrRouteEntry 16 }
399
+
400
+ inetCidrRouteStatus OBJECT-TYPE
401
+ SYNTAX RowStatus
402
+ MAX-ACCESS read-create
403
+ STATUS current
404
+ DESCRIPTION
405
+ "The row status variable, used according to row
406
+ installation and removal conventions.
407
+
408
+ A row entry cannot be modified when the status is
409
+ marked as active(1)."
410
+ ::= { inetCidrRouteEntry 17 }
411
+
412
+ -- Conformance information
413
+
414
+ ipForwardConformance
415
+ OBJECT IDENTIFIER ::= { ipForward 5 }
416
+
417
+ ipForwardGroups
418
+ OBJECT IDENTIFIER ::= { ipForwardConformance 1 }
419
+
420
+ ipForwardCompliances
421
+ OBJECT IDENTIFIER ::= { ipForwardConformance 2 }
422
+
423
+ -- Compliance statements
424
+
425
+ ipForwardFullCompliance MODULE-COMPLIANCE
426
+ STATUS current
427
+ DESCRIPTION
428
+ "When this MIB is implemented for read-create, the
429
+ implementation can claim full compliance.
430
+
431
+ There are a number of INDEX objects that cannot be
432
+ represented in the form of OBJECT clauses in SMIv2,
433
+ but for which there are compliance requirements,
434
+ expressed in OBJECT clause form in this description:
435
+
436
+ -- OBJECT inetCidrRouteDestType
437
+ -- SYNTAX InetAddressType (ipv4(1), ipv6(2),
438
+ -- ipv4z(3), ipv6z(4))
439
+ -- DESCRIPTION
440
+ -- This MIB requires support for global and
441
+ -- non-global ipv4 and ipv6 addresses.
442
+
443
+ --
444
+ -- OBJECT inetCidrRouteDest
445
+ -- SYNTAX InetAddress (SIZE (4 | 8 | 16 | 20))
446
+ -- DESCRIPTION
447
+ -- This MIB requires support for global and
448
+ -- non-global IPv4 and IPv6 addresses.
449
+ --
450
+ -- OBJECT inetCidrRouteNextHopType
451
+ -- SYNTAX InetAddressType (unknown(0), ipv4(1),
452
+ -- ipv6(2), ipv4z(3)
453
+ -- ipv6z(4))
454
+ -- DESCRIPTION
455
+ -- This MIB requires support for global and
456
+ -- non-global ipv4 and ipv6 addresses.
457
+ --
458
+ -- OBJECT inetCidrRouteNextHop
459
+ -- SYNTAX InetAddress (SIZE (0 | 4 | 8 | 16 | 20))
460
+ -- DESCRIPTION
461
+ -- This MIB requires support for global and
462
+ -- non-global IPv4 and IPv6 addresses.
463
+ "
464
+
465
+ MODULE -- this module
466
+ MANDATORY-GROUPS { inetForwardCidrRouteGroup }
467
+
468
+ OBJECT inetCidrRouteStatus
469
+ SYNTAX RowStatus { active(1), notInService (2) }
470
+ WRITE-SYNTAX RowStatus { active(1), notInService (2),
471
+ createAndGo(4), destroy(6) }
472
+ DESCRIPTION "Support for createAndWait is not required."
473
+ ::= { ipForwardCompliances 3 }
474
+
475
+ ipForwardReadOnlyCompliance MODULE-COMPLIANCE
476
+ STATUS current
477
+ DESCRIPTION
478
+ "When this MIB is implemented without support for read-
479
+ create (i.e., in read-only mode), the implementation can
480
+ claim read-only compliance."
481
+ MODULE -- this module
482
+ MANDATORY-GROUPS { inetForwardCidrRouteGroup }
483
+
484
+ OBJECT inetCidrRouteIfIndex
485
+ MIN-ACCESS read-only
486
+ DESCRIPTION
487
+ "Write access is not required."
488
+
489
+ OBJECT inetCidrRouteType
490
+ MIN-ACCESS read-only
491
+ DESCRIPTION
492
+ "Write access is not required."
493
+
494
+ OBJECT inetCidrRouteNextHopAS
495
+ MIN-ACCESS read-only
496
+ DESCRIPTION
497
+ "Write access is not required."
498
+
499
+ OBJECT inetCidrRouteMetric1
500
+ MIN-ACCESS read-only
501
+ DESCRIPTION
502
+ "Write access is not required."
503
+
504
+ OBJECT inetCidrRouteMetric2
505
+ MIN-ACCESS read-only
506
+ DESCRIPTION
507
+ "Write access is not required."
508
+
509
+ OBJECT inetCidrRouteMetric3
510
+ MIN-ACCESS read-only
511
+ DESCRIPTION
512
+ "Write access is not required."
513
+
514
+ OBJECT inetCidrRouteMetric4
515
+ MIN-ACCESS read-only
516
+ DESCRIPTION
517
+ "Write access is not required."
518
+
519
+ OBJECT inetCidrRouteMetric5
520
+ MIN-ACCESS read-only
521
+ DESCRIPTION
522
+ "Write access is not required."
523
+
524
+ OBJECT inetCidrRouteStatus
525
+ SYNTAX RowStatus { active(1) }
526
+ MIN-ACCESS read-only
527
+ DESCRIPTION
528
+ "Write access is not required."
529
+ ::= { ipForwardCompliances 4 }
530
+
531
+ -- units of conformance
532
+
533
+ inetForwardCidrRouteGroup OBJECT-GROUP
534
+ OBJECTS { inetCidrRouteDiscards,
535
+ inetCidrRouteIfIndex, inetCidrRouteType,
536
+ inetCidrRouteProto, inetCidrRouteAge,
537
+ inetCidrRouteNextHopAS, inetCidrRouteMetric1,
538
+ inetCidrRouteMetric2, inetCidrRouteMetric3,
539
+ inetCidrRouteMetric4, inetCidrRouteMetric5,
540
+ inetCidrRouteStatus, inetCidrRouteNumber
541
+ }
542
+ STATUS current
543
+ DESCRIPTION
544
+ "The IP version-independent CIDR Route Table."
545
+ ::= { ipForwardGroups 4 }
546
+
547
+ -- Deprecated Objects
548
+
549
+ ipCidrRouteNumber OBJECT-TYPE
550
+ SYNTAX Gauge32
551
+ MAX-ACCESS read-only
552
+ STATUS deprecated
553
+ DESCRIPTION
554
+ "The number of current ipCidrRouteTable entries that are
555
+ not invalid. This object is deprecated in favor of
556
+ inetCidrRouteNumber and the inetCidrRouteTable."
557
+ ::= { ipForward 3 }
558
+
559
+ -- IP CIDR Route Table
560
+
561
+ -- The IP CIDR Route Table obsoletes and replaces the ipRoute
562
+ -- Table current in MIB-I and MIB-II and the IP Forwarding Table.
563
+ -- It adds knowledge of the autonomous system of the next hop,
564
+ -- multiple next hops, policy routing, and Classless
565
+ -- Inter-Domain Routing.
566
+
567
+ ipCidrRouteTable OBJECT-TYPE
568
+ SYNTAX SEQUENCE OF IpCidrRouteEntry
569
+ MAX-ACCESS not-accessible
570
+ STATUS deprecated
571
+ DESCRIPTION
572
+ "This entity's IP Routing table. This table has been
573
+ deprecated in favor of the IP version neutral
574
+ inetCidrRouteTable."
575
+ REFERENCE
576
+ "RFC 1213 Section 6.6, The IP Group"
577
+ ::= { ipForward 4 }
578
+
579
+ ipCidrRouteEntry OBJECT-TYPE
580
+ SYNTAX IpCidrRouteEntry
581
+ MAX-ACCESS not-accessible
582
+ STATUS deprecated
583
+ DESCRIPTION
584
+ "A particular route to a particular destination, under a
585
+
586
+ particular policy."
587
+ INDEX {
588
+ ipCidrRouteDest,
589
+ ipCidrRouteMask,
590
+ ipCidrRouteTos,
591
+ ipCidrRouteNextHop
592
+ }
593
+ ::= { ipCidrRouteTable 1 }
594
+
595
+ IpCidrRouteEntry ::= SEQUENCE {
596
+ ipCidrRouteDest IpAddress,
597
+ ipCidrRouteMask IpAddress,
598
+ ipCidrRouteTos Integer32,
599
+ ipCidrRouteNextHop IpAddress,
600
+ ipCidrRouteIfIndex Integer32,
601
+ ipCidrRouteType INTEGER,
602
+ ipCidrRouteProto INTEGER,
603
+ ipCidrRouteAge Integer32,
604
+ ipCidrRouteInfo OBJECT IDENTIFIER,
605
+ ipCidrRouteNextHopAS Integer32,
606
+ ipCidrRouteMetric1 Integer32,
607
+ ipCidrRouteMetric2 Integer32,
608
+ ipCidrRouteMetric3 Integer32,
609
+ ipCidrRouteMetric4 Integer32,
610
+ ipCidrRouteMetric5 Integer32,
611
+ ipCidrRouteStatus RowStatus
612
+ }
613
+
614
+ ipCidrRouteDest OBJECT-TYPE
615
+ SYNTAX IpAddress
616
+ MAX-ACCESS read-only
617
+ STATUS deprecated
618
+ DESCRIPTION
619
+ "The destination IP address of this route.
620
+
621
+ This object may not take a Multicast (Class D) address
622
+ value.
623
+
624
+ Any assignment (implicit or otherwise) of an instance
625
+ of this object to a value x must be rejected if the
626
+ bitwise logical-AND of x with the value of the
627
+ corresponding instance of the ipCidrRouteMask object is
628
+ not equal to x."
629
+ ::= { ipCidrRouteEntry 1 }
630
+
631
+ ipCidrRouteMask OBJECT-TYPE
632
+ SYNTAX IpAddress
633
+ MAX-ACCESS read-only
634
+ STATUS deprecated
635
+ DESCRIPTION
636
+ "Indicate the mask to be logical-ANDed with the
637
+ destination address before being compared to the value
638
+ in the ipCidrRouteDest field. For those systems that
639
+ do not support arbitrary subnet masks, an agent
640
+ constructs the value of the ipCidrRouteMask by
641
+ reference to the IP Address Class.
642
+
643
+ Any assignment (implicit or otherwise) of an instance
644
+ of this object to a value x must be rejected if the
645
+ bitwise logical-AND of x with the value of the
646
+ corresponding instance of the ipCidrRouteDest object is
647
+ not equal to ipCidrRouteDest."
648
+ ::= { ipCidrRouteEntry 2 }
649
+
650
+ -- The following convention is included for specification
651
+ -- of TOS Field contents. At this time, the Host Requirements
652
+ -- and the Router Requirements documents disagree on the width
653
+ -- of the TOS field. This mapping describes the Router
654
+ -- Requirements mapping, and leaves room to widen the TOS field
655
+ -- without impact to fielded systems.
656
+
657
+ ipCidrRouteTos OBJECT-TYPE
658
+ SYNTAX Integer32 (0..2147483647)
659
+ MAX-ACCESS read-only
660
+ STATUS deprecated
661
+ DESCRIPTION
662
+ "The policy specifier is the IP TOS Field. The encoding
663
+ of IP TOS is as specified by the following convention.
664
+ Zero indicates the default path if no more specific
665
+ policy applies.
666
+
667
+ +-----+-----+-----+-----+-----+-----+-----+-----+
668
+ | | | |
669
+ | PRECEDENCE | TYPE OF SERVICE | 0 |
670
+ | | | |
671
+ +-----+-----+-----+-----+-----+-----+-----+-----+
672
+
673
+ IP TOS IP TOS
674
+ Field Policy Field Policy
675
+ Contents Code Contents Code
676
+ 0 0 0 0 ==> 0 0 0 0 1 ==> 2
677
+ 0 0 1 0 ==> 4 0 0 1 1 ==> 6
678
+ 0 1 0 0 ==> 8 0 1 0 1 ==> 10
679
+ 0 1 1 0 ==> 12 0 1 1 1 ==> 14
680
+ 1 0 0 0 ==> 16 1 0 0 1 ==> 18
681
+ 1 0 1 0 ==> 20 1 0 1 1 ==> 22
682
+
683
+ 1 1 0 0 ==> 24 1 1 0 1 ==> 26
684
+ 1 1 1 0 ==> 28 1 1 1 1 ==> 30"
685
+ ::= { ipCidrRouteEntry 3 }
686
+
687
+ ipCidrRouteNextHop OBJECT-TYPE
688
+ SYNTAX IpAddress
689
+ MAX-ACCESS read-only
690
+ STATUS deprecated
691
+ DESCRIPTION
692
+ "On remote routes, the address of the next system en
693
+ route; Otherwise, 0.0.0.0."
694
+ ::= { ipCidrRouteEntry 4 }
695
+
696
+ ipCidrRouteIfIndex OBJECT-TYPE
697
+ SYNTAX Integer32
698
+ MAX-ACCESS read-create
699
+ STATUS deprecated
700
+ DESCRIPTION
701
+ "The ifIndex value that identifies the local interface
702
+ through which the next hop of this route should be
703
+ reached."
704
+ DEFVAL { 0 }
705
+ ::= { ipCidrRouteEntry 5 }
706
+
707
+ ipCidrRouteType OBJECT-TYPE
708
+ SYNTAX INTEGER {
709
+ other (1), -- not specified by this MIB
710
+ reject (2), -- route that discards traffic
711
+ local (3), -- local interface
712
+ remote (4) -- remote destination
713
+ }
714
+ MAX-ACCESS read-create
715
+ STATUS deprecated
716
+ DESCRIPTION
717
+ "The type of route. Note that local(3) refers to a
718
+ route for which the next hop is the final destination;
719
+ remote(4) refers to a route for which the next hop is
720
+ not the final destination.
721
+
722
+ Routes that do not result in traffic forwarding or
723
+ rejection should not be displayed, even if the
724
+ implementation keeps them stored internally.
725
+
726
+ reject (2) refers to a route that, if matched,
727
+ discards the message as unreachable. This is used in
728
+ some protocols as a means of correctly aggregating
729
+ routes."
730
+ ::= { ipCidrRouteEntry 6 }
731
+
732
+ ipCidrRouteProto OBJECT-TYPE
733
+ SYNTAX INTEGER {
734
+ other (1), -- not specified
735
+ local (2), -- local interface
736
+ netmgmt (3), -- static route
737
+ icmp (4), -- result of ICMP Redirect
738
+
739
+ -- the following are all dynamic
740
+ -- routing protocols
741
+ egp (5), -- Exterior Gateway Protocol
742
+ ggp (6), -- Gateway-Gateway Protocol
743
+ hello (7), -- FuzzBall HelloSpeak
744
+ rip (8), -- Berkeley RIP or RIP-II
745
+ isIs (9), -- Dual IS-IS
746
+ esIs (10), -- ISO 9542
747
+ ciscoIgrp (11), -- Cisco IGRP
748
+ bbnSpfIgp (12), -- BBN SPF IGP
749
+ ospf (13), -- Open Shortest Path First
750
+ bgp (14), -- Border Gateway Protocol
751
+ idpr (15), -- InterDomain Policy Routing
752
+ ciscoEigrp (16) -- Cisco EIGRP
753
+ }
754
+ MAX-ACCESS read-only
755
+ STATUS deprecated
756
+ DESCRIPTION
757
+ "The routing mechanism via which this route was learned.
758
+ Inclusion of values for gateway routing protocols is
759
+ not intended to imply that hosts should support those
760
+ protocols."
761
+ ::= { ipCidrRouteEntry 7 }
762
+
763
+ ipCidrRouteAge OBJECT-TYPE
764
+ SYNTAX Integer32
765
+ MAX-ACCESS read-only
766
+ STATUS deprecated
767
+ DESCRIPTION
768
+ "The number of seconds since this route was last updated
769
+ or otherwise determined to be correct. Note that no
770
+ semantics of `too old' can be implied, except through
771
+ knowledge of the routing protocol by which the route
772
+ was learned."
773
+ DEFVAL { 0 }
774
+ ::= { ipCidrRouteEntry 8 }
775
+
776
+ ipCidrRouteInfo OBJECT-TYPE
777
+ SYNTAX OBJECT IDENTIFIER
778
+ MAX-ACCESS read-create
779
+ STATUS deprecated
780
+ DESCRIPTION
781
+ "A reference to MIB definitions specific to the
782
+ particular routing protocol that is responsible for
783
+ this route, as determined by the value specified in the
784
+ route's ipCidrRouteProto value. If this information is
785
+ not present, its value should be set to the OBJECT
786
+ IDENTIFIER { 0 0 }, which is a syntactically valid
787
+ object identifier, and any implementation conforming to
788
+ ASN.1 and the Basic Encoding Rules must be able to
789
+ generate and recognize this value."
790
+ ::= { ipCidrRouteEntry 9 }
791
+
792
+ ipCidrRouteNextHopAS OBJECT-TYPE
793
+ SYNTAX Integer32
794
+ MAX-ACCESS read-create
795
+ STATUS deprecated
796
+ DESCRIPTION
797
+ "The Autonomous System Number of the Next Hop. The
798
+ semantics of this object are determined by the routing-
799
+ protocol specified in the route's ipCidrRouteProto
800
+ value. When this object is unknown or not relevant, its
801
+ value should be set to zero."
802
+ DEFVAL { 0 }
803
+ ::= { ipCidrRouteEntry 10 }
804
+
805
+ ipCidrRouteMetric1 OBJECT-TYPE
806
+ SYNTAX Integer32
807
+ MAX-ACCESS read-create
808
+ STATUS deprecated
809
+ DESCRIPTION
810
+ "The primary routing metric for this route. The
811
+ semantics of this metric are determined by the routing-
812
+ protocol specified in the route's ipCidrRouteProto
813
+ value. If this metric is not used, its value should be
814
+ set to -1."
815
+ DEFVAL { -1 }
816
+ ::= { ipCidrRouteEntry 11 }
817
+
818
+ ipCidrRouteMetric2 OBJECT-TYPE
819
+ SYNTAX Integer32
820
+ MAX-ACCESS read-create
821
+ STATUS deprecated
822
+ DESCRIPTION
823
+ "An alternate routing metric for this route. The
824
+ semantics of this metric are determined by the routing-
825
+ protocol specified in the route's ipCidrRouteProto
826
+ value. If this metric is not used, its value should be
827
+
828
+ set to -1."
829
+ DEFVAL { -1 }
830
+ ::= { ipCidrRouteEntry 12 }
831
+
832
+ ipCidrRouteMetric3 OBJECT-TYPE
833
+ SYNTAX Integer32
834
+ MAX-ACCESS read-create
835
+ STATUS deprecated
836
+ DESCRIPTION
837
+ "An alternate routing metric for this route. The
838
+ semantics of this metric are determined by the routing-
839
+ protocol specified in the route's ipCidrRouteProto
840
+ value. If this metric is not used, its value should be
841
+ set to -1."
842
+ DEFVAL { -1 }
843
+ ::= { ipCidrRouteEntry 13 }
844
+
845
+ ipCidrRouteMetric4 OBJECT-TYPE
846
+ SYNTAX Integer32
847
+ MAX-ACCESS read-create
848
+ STATUS deprecated
849
+ DESCRIPTION
850
+ "An alternate routing metric for this route. The
851
+ semantics of this metric are determined by the routing-
852
+ protocol specified in the route's ipCidrRouteProto
853
+ value. If this metric is not used, its value should be
854
+ set to -1."
855
+ DEFVAL { -1 }
856
+ ::= { ipCidrRouteEntry 14 }
857
+
858
+ ipCidrRouteMetric5 OBJECT-TYPE
859
+ SYNTAX Integer32
860
+ MAX-ACCESS read-create
861
+ STATUS deprecated
862
+ DESCRIPTION
863
+ "An alternate routing metric for this route. The
864
+ semantics of this metric are determined by the routing-
865
+ protocol specified in the route's ipCidrRouteProto
866
+ value. If this metric is not used, its value should be
867
+ set to -1."
868
+ DEFVAL { -1 }
869
+ ::= { ipCidrRouteEntry 15 }
870
+
871
+ ipCidrRouteStatus OBJECT-TYPE
872
+ SYNTAX RowStatus
873
+ MAX-ACCESS read-create
874
+ STATUS deprecated
875
+ DESCRIPTION
876
+ "The row status variable, used according to row
877
+ installation and removal conventions."
878
+ ::= { ipCidrRouteEntry 16 }
879
+
880
+ -- compliance statements
881
+
882
+ ipForwardCompliance MODULE-COMPLIANCE
883
+ STATUS deprecated
884
+ DESCRIPTION
885
+ "The compliance statement for SNMPv2 entities that
886
+ implement the ipForward MIB.
887
+
888
+ This compliance statement has been deprecated and
889
+ replaced with ipForwardFullCompliance and
890
+ ipForwardReadOnlyCompliance."
891
+
892
+ MODULE -- this module
893
+ MANDATORY-GROUPS { ipForwardCidrRouteGroup }
894
+ ::= { ipForwardCompliances 1 }
895
+
896
+ -- units of conformance
897
+
898
+ ipForwardCidrRouteGroup OBJECT-GROUP
899
+ OBJECTS { ipCidrRouteNumber,
900
+ ipCidrRouteDest, ipCidrRouteMask, ipCidrRouteTos,
901
+ ipCidrRouteNextHop, ipCidrRouteIfIndex,
902
+ ipCidrRouteType, ipCidrRouteProto, ipCidrRouteAge,
903
+ ipCidrRouteInfo,ipCidrRouteNextHopAS,
904
+ ipCidrRouteMetric1, ipCidrRouteMetric2,
905
+ ipCidrRouteMetric3, ipCidrRouteMetric4,
906
+ ipCidrRouteMetric5, ipCidrRouteStatus
907
+ }
908
+ STATUS deprecated
909
+ DESCRIPTION
910
+ "The CIDR Route Table.
911
+
912
+ This group has been deprecated and replaced with
913
+ inetForwardCidrRouteGroup."
914
+ ::= { ipForwardGroups 3 }
915
+
916
+ -- Obsoleted Definitions - Objects
917
+
918
+ ipForwardNumber OBJECT-TYPE
919
+ SYNTAX Gauge32
920
+ MAX-ACCESS read-only
921
+ STATUS obsolete
922
+ DESCRIPTION
923
+ "The number of current ipForwardTable entries that are
924
+ not invalid."
925
+ ::= { ipForward 1 }
926
+
927
+ -- IP Forwarding Table
928
+
929
+ -- The IP Forwarding Table obsoletes and replaces the ipRoute
930
+ -- Table current in MIB-I and MIB-II. It adds knowledge of
931
+ -- the autonomous system of the next hop, multiple next hop
932
+ -- support, and policy routing support.
933
+
934
+ ipForwardTable OBJECT-TYPE
935
+ SYNTAX SEQUENCE OF IpForwardEntry
936
+ MAX-ACCESS not-accessible
937
+ STATUS obsolete
938
+ DESCRIPTION
939
+ "This entity's IP Routing table."
940
+ REFERENCE
941
+ "RFC 1213 Section 6.6, The IP Group"
942
+ ::= { ipForward 2 }
943
+
944
+ ipForwardEntry OBJECT-TYPE
945
+ SYNTAX IpForwardEntry
946
+ MAX-ACCESS not-accessible
947
+ STATUS obsolete
948
+ DESCRIPTION
949
+ "A particular route to a particular destination, under a
950
+ particular policy."
951
+ INDEX {
952
+ ipForwardDest,
953
+ ipForwardProto,
954
+ ipForwardPolicy,
955
+ ipForwardNextHop
956
+ }
957
+ ::= { ipForwardTable 1 }
958
+
959
+ IpForwardEntry ::= SEQUENCE {
960
+ ipForwardDest IpAddress,
961
+ ipForwardMask IpAddress,
962
+ ipForwardPolicy Integer32,
963
+ ipForwardNextHop IpAddress,
964
+ ipForwardIfIndex Integer32,
965
+ ipForwardType INTEGER,
966
+ ipForwardProto INTEGER,
967
+ ipForwardAge Integer32,
968
+ ipForwardInfo OBJECT IDENTIFIER,
969
+ ipForwardNextHopAS Integer32,
970
+ ipForwardMetric1 Integer32,
971
+ ipForwardMetric2 Integer32,
972
+ ipForwardMetric3 Integer32,
973
+ ipForwardMetric4 Integer32,
974
+ ipForwardMetric5 Integer32
975
+ }
976
+
977
+ ipForwardDest OBJECT-TYPE
978
+ SYNTAX IpAddress
979
+ MAX-ACCESS read-only
980
+ STATUS obsolete
981
+ DESCRIPTION
982
+ "The destination IP address of this route. An entry
983
+ with a value of 0.0.0.0 is considered a default route.
984
+
985
+ This object may not take a Multicast (Class D) address
986
+ value.
987
+
988
+ Any assignment (implicit or otherwise) of an instance
989
+ of this object to a value x must be rejected if the
990
+ bitwise logical-AND of x with the value of the
991
+ corresponding instance of the ipForwardMask object is
992
+ not equal to x."
993
+ ::= { ipForwardEntry 1 }
994
+
995
+ ipForwardMask OBJECT-TYPE
996
+ SYNTAX IpAddress
997
+ MAX-ACCESS read-create
998
+ STATUS obsolete
999
+ DESCRIPTION
1000
+ "Indicate the mask to be logical-ANDed with the
1001
+ destination address before being compared to the value
1002
+ in the ipForwardDest field. For those systems that do
1003
+ not support arbitrary subnet masks, an agent constructs
1004
+ the value of the ipForwardMask by reference to the IP
1005
+ Address Class.
1006
+
1007
+ Any assignment (implicit or otherwise) of an instance
1008
+ of this object to a value x must be rejected if the
1009
+ bitwise logical-AND of x with the value of the
1010
+ corresponding instance of the ipForwardDest object is
1011
+ not equal to ipForwardDest."
1012
+ DEFVAL { '00000000'H } -- 0.0.0.0
1013
+ ::= { ipForwardEntry 2 }
1014
+
1015
+ -- The following convention is included for specification
1016
+ -- of TOS Field contents. At this time, the Host Requirements
1017
+ -- and the Router Requirements documents disagree on the width
1018
+ -- of the TOS field. This mapping describes the Router
1019
+
1020
+ -- Requirements mapping, and leaves room to widen the TOS field
1021
+ -- without impact to fielded systems.
1022
+
1023
+ ipForwardPolicy OBJECT-TYPE
1024
+ SYNTAX Integer32 (0..2147483647)
1025
+ MAX-ACCESS read-only
1026
+ STATUS obsolete
1027
+ DESCRIPTION
1028
+ "The general set of conditions that would cause
1029
+ the selection of one multipath route (set of
1030
+ next hops for a given destination) is referred
1031
+ to as 'policy'.
1032
+
1033
+ Unless the mechanism indicated by ipForwardProto
1034
+ specifies otherwise, the policy specifier is
1035
+ the IP TOS Field. The encoding of IP TOS is as
1036
+ specified by the following convention. Zero
1037
+ indicates the default path if no more specific
1038
+ policy applies.
1039
+
1040
+ +-----+-----+-----+-----+-----+-----+-----+-----+
1041
+ | | | |
1042
+ | PRECEDENCE | TYPE OF SERVICE | 0 |
1043
+ | | | |
1044
+ +-----+-----+-----+-----+-----+-----+-----+-----+
1045
+
1046
+ IP TOS IP TOS
1047
+ Field Policy Field Policy
1048
+ Contents Code Contents Code
1049
+ 0 0 0 0 ==> 0 0 0 0 1 ==> 2
1050
+ 0 0 1 0 ==> 4 0 0 1 1 ==> 6
1051
+ 0 1 0 0 ==> 8 0 1 0 1 ==> 10
1052
+ 0 1 1 0 ==> 12 0 1 1 1 ==> 14
1053
+ 1 0 0 0 ==> 16 1 0 0 1 ==> 18
1054
+ 1 0 1 0 ==> 20 1 0 1 1 ==> 22
1055
+ 1 1 0 0 ==> 24 1 1 0 1 ==> 26
1056
+ 1 1 1 0 ==> 28 1 1 1 1 ==> 30
1057
+
1058
+ Protocols defining 'policy' otherwise must either
1059
+ define a set of values that are valid for
1060
+ this object or must implement an integer-instanced
1061
+ policy table for which this object's
1062
+ value acts as an index."
1063
+ ::= { ipForwardEntry 3 }
1064
+
1065
+ ipForwardNextHop OBJECT-TYPE
1066
+ SYNTAX IpAddress
1067
+ MAX-ACCESS read-only
1068
+ STATUS obsolete
1069
+ DESCRIPTION
1070
+ "On remote routes, the address of the next system en
1071
+ route; otherwise, 0.0.0.0."
1072
+ ::= { ipForwardEntry 4 }
1073
+
1074
+ ipForwardIfIndex OBJECT-TYPE
1075
+ SYNTAX Integer32
1076
+ MAX-ACCESS read-create
1077
+ STATUS obsolete
1078
+ DESCRIPTION
1079
+ "The ifIndex value that identifies the local interface
1080
+ through which the next hop of this route should be
1081
+ reached."
1082
+ DEFVAL { 0 }
1083
+ ::= { ipForwardEntry 5 }
1084
+
1085
+ ipForwardType OBJECT-TYPE
1086
+ SYNTAX INTEGER {
1087
+ other (1), -- not specified by this MIB
1088
+ invalid (2), -- logically deleted
1089
+ local (3), -- local interface
1090
+ remote (4) -- remote destination
1091
+ }
1092
+ MAX-ACCESS read-create
1093
+ STATUS obsolete
1094
+ DESCRIPTION
1095
+ "The type of route. Note that local(3) refers to a
1096
+ route for which the next hop is the final destination;
1097
+ remote(4) refers to a route for which the next hop is
1098
+ not the final destination.
1099
+
1100
+ Setting this object to the value invalid(2) has the
1101
+ effect of invalidating the corresponding entry in the
1102
+ ipForwardTable object. That is, it effectively
1103
+ disassociates the destination identified with said
1104
+ entry from the route identified with said entry. It is
1105
+ an implementation-specific matter as to whether the
1106
+ agent removes an invalidated entry from the table.
1107
+ Accordingly, management stations must be prepared to
1108
+ receive tabular information from agents that
1109
+ corresponds to entries not currently in use. Proper
1110
+ interpretation of such entries requires examination of
1111
+ the relevant ipForwardType object."
1112
+ DEFVAL { invalid }
1113
+ ::= { ipForwardEntry 6 }
1114
+
1115
+ ipForwardProto OBJECT-TYPE
1116
+ SYNTAX INTEGER {
1117
+ other (1), -- not specified
1118
+ local (2), -- local interface
1119
+ netmgmt (3), -- static route
1120
+ icmp (4), -- result of ICMP Redirect
1121
+
1122
+ -- the following are all dynamic
1123
+ -- routing protocols
1124
+ egp (5), -- Exterior Gateway Protocol
1125
+ ggp (6), -- Gateway-Gateway Protocol
1126
+ hello (7), -- FuzzBall HelloSpeak
1127
+ rip (8), -- Berkeley RIP or RIP-II
1128
+ is-is (9), -- Dual IS-IS
1129
+ es-is (10), -- ISO 9542
1130
+ ciscoIgrp (11), -- Cisco IGRP
1131
+ bbnSpfIgp (12), -- BBN SPF IGP
1132
+ ospf (13), -- Open Shortest Path First
1133
+ bgp (14), -- Border Gateway Protocol
1134
+ idpr (15) -- InterDomain Policy Routing
1135
+ }
1136
+ MAX-ACCESS read-only
1137
+ STATUS obsolete
1138
+ DESCRIPTION
1139
+ "The routing mechanism via which this route was learned.
1140
+ Inclusion of values for gateway routing protocols is
1141
+ not intended to imply that hosts should support those
1142
+ protocols."
1143
+ ::= { ipForwardEntry 7 }
1144
+
1145
+ ipForwardAge OBJECT-TYPE
1146
+ SYNTAX Integer32
1147
+ MAX-ACCESS read-only
1148
+ STATUS obsolete
1149
+ DESCRIPTION
1150
+ "The number of seconds since this route was last updated
1151
+ or otherwise determined to be correct. Note that no
1152
+ semantics of `too old' can be implied except through
1153
+ knowledge of the routing protocol by which the route
1154
+ was learned."
1155
+ DEFVAL { 0 }
1156
+ ::= { ipForwardEntry 8 }
1157
+
1158
+ ipForwardInfo OBJECT-TYPE
1159
+ SYNTAX OBJECT IDENTIFIER
1160
+ MAX-ACCESS read-create
1161
+ STATUS obsolete
1162
+ DESCRIPTION
1163
+ "A reference to MIB definitions specific to the
1164
+ particular routing protocol that is responsible for
1165
+ this route, as determined by the value specified in the
1166
+ route's ipForwardProto value. If this information is
1167
+ not present, its value should be set to the OBJECT
1168
+ IDENTIFIER { 0 0 }, which is a syntactically valid
1169
+ object identifier, and any implementation conforming to
1170
+ ASN.1 and the Basic Encoding Rules must be able to
1171
+ generate and recognize this value."
1172
+ ::= { ipForwardEntry 9 }
1173
+
1174
+ ipForwardNextHopAS OBJECT-TYPE
1175
+ SYNTAX Integer32
1176
+ MAX-ACCESS read-create
1177
+ STATUS obsolete
1178
+ DESCRIPTION
1179
+ "The Autonomous System Number of the Next Hop. When
1180
+ this is unknown or not relevant to the protocol
1181
+ indicated by ipForwardProto, zero."
1182
+ DEFVAL { 0 }
1183
+ ::= { ipForwardEntry 10 }
1184
+
1185
+ ipForwardMetric1 OBJECT-TYPE
1186
+ SYNTAX Integer32
1187
+ MAX-ACCESS read-create
1188
+ STATUS obsolete
1189
+ DESCRIPTION
1190
+ "The primary routing metric for this route. The
1191
+ semantics of this metric are determined by the routing-
1192
+ protocol specified in the route's ipForwardProto value.
1193
+ If this metric is not used, its value should be set to
1194
+ -1."
1195
+ DEFVAL { -1 }
1196
+ ::= { ipForwardEntry 11 }
1197
+
1198
+ ipForwardMetric2 OBJECT-TYPE
1199
+ SYNTAX Integer32
1200
+ MAX-ACCESS read-create
1201
+ STATUS obsolete
1202
+ DESCRIPTION
1203
+ "An alternate routing metric for this route. The
1204
+ semantics of this metric are determined by the routing-
1205
+ protocol specified in the route's ipForwardProto value.
1206
+ If this metric is not used, its value should be set to
1207
+ -1."
1208
+ DEFVAL { -1 }
1209
+ ::= { ipForwardEntry 12 }
1210
+
1211
+ ipForwardMetric3 OBJECT-TYPE
1212
+ SYNTAX Integer32
1213
+ MAX-ACCESS read-create
1214
+ STATUS obsolete
1215
+ DESCRIPTION
1216
+ "An alternate routing metric for this route. The
1217
+ semantics of this metric are determined by the routing-
1218
+ protocol specified in the route's ipForwardProto value.
1219
+ If this metric is not used, its value should be set to
1220
+ -1."
1221
+ DEFVAL { -1 }
1222
+ ::= { ipForwardEntry 13 }
1223
+
1224
+ ipForwardMetric4 OBJECT-TYPE
1225
+ SYNTAX Integer32
1226
+ MAX-ACCESS read-create
1227
+ STATUS obsolete
1228
+ DESCRIPTION
1229
+ "An alternate routing metric for this route. The
1230
+ semantics of this metric are determined by the routing-
1231
+ protocol specified in the route's ipForwardProto value.
1232
+ If this metric is not used, its value should be set to
1233
+ -1."
1234
+ DEFVAL { -1 }
1235
+ ::= { ipForwardEntry 14 }
1236
+
1237
+ ipForwardMetric5 OBJECT-TYPE
1238
+ SYNTAX Integer32
1239
+ MAX-ACCESS read-create
1240
+ STATUS obsolete
1241
+ DESCRIPTION
1242
+ "An alternate routing metric for this route. The
1243
+ semantics of this metric are determined by the routing-
1244
+ protocol specified in the route's ipForwardProto value.
1245
+ If this metric is not used, its value should be set to
1246
+ -1."
1247
+ DEFVAL { -1 }
1248
+ ::= { ipForwardEntry 15 }
1249
+
1250
+ -- Obsoleted Definitions - Groups
1251
+ -- compliance statements
1252
+
1253
+ ipForwardOldCompliance MODULE-COMPLIANCE
1254
+ STATUS obsolete
1255
+ DESCRIPTION
1256
+ "The compliance statement for SNMP entities that
1257
+ implement the ipForward MIB."
1258
+
1259
+ MODULE -- this module
1260
+ MANDATORY-GROUPS { ipForwardMultiPathGroup }
1261
+ ::= { ipForwardCompliances 2 }
1262
+
1263
+ ipForwardMultiPathGroup OBJECT-GROUP
1264
+ OBJECTS { ipForwardNumber,
1265
+ ipForwardDest, ipForwardMask, ipForwardPolicy,
1266
+ ipForwardNextHop, ipForwardIfIndex, ipForwardType,
1267
+ ipForwardProto, ipForwardAge, ipForwardInfo,
1268
+ ipForwardNextHopAS,
1269
+ ipForwardMetric1, ipForwardMetric2, ipForwardMetric3,
1270
+ ipForwardMetric4, ipForwardMetric5
1271
+ }
1272
+ STATUS obsolete
1273
+ DESCRIPTION
1274
+ "IP Multipath Route Table."
1275
+ ::= { ipForwardGroups 2 }
1276
+
1277
+ END