blob: 3dbfb5875192956c074bf7cb66cc6429bc2e1e10 [file] [log] [blame]
paul07661cb2003-03-18 00:03:05 +00001/* FIB SNMP.
paul718e3742002-12-13 20:15:29 +00002 * Copyright (C) 1999 Kunihiro Ishiguro
3 *
4 * This file is part of GNU Zebra.
5 *
6 * GNU Zebra is free software; you can redistribute it and/or modify it
7 * under the terms of the GNU General Public License as published by the
8 * Free Software Foundation; either version 2, or (at your option) any
9 * later version.
10 *
11 * GNU Zebra is distributed in the hope that it will be useful, but
12 * WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with GNU Zebra; see the file COPYING. If not, write to the Free
18 * Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
19 * 02111-1307, USA.
20 */
21
22#include <zebra.h>
23
24#ifdef HAVE_SNMP
paul07661cb2003-03-18 00:03:05 +000025#include <net-snmp/net-snmp-config.h>
Joakim Tjernlundfb62a3c2008-05-13 20:03:32 +020026#include <net-snmp/net-snmp-includes.h>
paul718e3742002-12-13 20:15:29 +000027
28#include "if.h"
29#include "log.h"
30#include "prefix.h"
31#include "command.h"
32#include "smux.h"
33#include "table.h"
34
35#include "zebra/rib.h"
pauldd488a72003-06-19 01:21:07 +000036#include "zebra/zserv.h"
paul718e3742002-12-13 20:15:29 +000037
38#define IPFWMIB 1,3,6,1,2,1,4,24
paul718e3742002-12-13 20:15:29 +000039
40/* ipForwardTable */
41#define IPFORWARDDEST 1
42#define IPFORWARDMASK 2
43#define IPFORWARDPOLICY 3
44#define IPFORWARDNEXTHOP 4
45#define IPFORWARDIFINDEX 5
46#define IPFORWARDTYPE 6
47#define IPFORWARDPROTO 7
48#define IPFORWARDAGE 8
49#define IPFORWARDINFO 9
50#define IPFORWARDNEXTHOPAS 10
51#define IPFORWARDMETRIC1 11
52#define IPFORWARDMETRIC2 12
53#define IPFORWARDMETRIC3 13
54#define IPFORWARDMETRIC4 14
55#define IPFORWARDMETRIC5 15
56
57/* ipCidrRouteTable */
58#define IPCIDRROUTEDEST 1
59#define IPCIDRROUTEMASK 2
60#define IPCIDRROUTETOS 3
61#define IPCIDRROUTENEXTHOP 4
62#define IPCIDRROUTEIFINDEX 5
63#define IPCIDRROUTETYPE 6
64#define IPCIDRROUTEPROTO 7
65#define IPCIDRROUTEAGE 8
66#define IPCIDRROUTEINFO 9
67#define IPCIDRROUTENEXTHOPAS 10
68#define IPCIDRROUTEMETRIC1 11
69#define IPCIDRROUTEMETRIC2 12
70#define IPCIDRROUTEMETRIC3 13
71#define IPCIDRROUTEMETRIC4 14
72#define IPCIDRROUTEMETRIC5 15
73#define IPCIDRROUTESTATUS 16
74
75#define INTEGER32 ASN_INTEGER
76#define GAUGE32 ASN_GAUGE
77#define ENUMERATION ASN_INTEGER
78#define ROWSTATUS ASN_INTEGER
79#define IPADDRESS ASN_IPADDRESS
80#define OBJECTIDENTIFIER ASN_OBJECT_ID
81
pauldd488a72003-06-19 01:21:07 +000082extern struct zebra_t zebrad;
83
paul718e3742002-12-13 20:15:29 +000084oid ipfw_oid [] = { IPFWMIB };
paul718e3742002-12-13 20:15:29 +000085
86/* Hook functions. */
Chris Caputo0be8dfb2009-06-02 18:40:07 +010087static u_char * ipFwNumber (struct variable *, oid [], size_t *,
88 int, size_t *, WriteMethod **);
89static u_char * ipFwTable (struct variable *, oid [], size_t *,
90 int, size_t *, WriteMethod **);
91static u_char * ipCidrNumber (struct variable *, oid [], size_t *,
92 int, size_t *, WriteMethod **);
93static u_char * ipCidrTable (struct variable *, oid [], size_t *,
94 int, size_t *, WriteMethod **);
paul718e3742002-12-13 20:15:29 +000095
96struct variable zebra_variables[] =
paul07661cb2003-03-18 00:03:05 +000097 {
98 {0, GAUGE32, RONLY, ipFwNumber, 1, {1}},
99 {IPFORWARDDEST, IPADDRESS, RONLY, ipFwTable, 3, {2, 1, 1}},
100 {IPFORWARDMASK, IPADDRESS, RONLY, ipFwTable, 3, {2, 1, 2}},
101 {IPFORWARDPOLICY, INTEGER32, RONLY, ipFwTable, 3, {2, 1, 3}},
102 {IPFORWARDNEXTHOP, IPADDRESS, RONLY, ipFwTable, 3, {2, 1, 4}},
103 {IPFORWARDIFINDEX, INTEGER32, RONLY, ipFwTable, 3, {2, 1, 5}},
104 {IPFORWARDTYPE, ENUMERATION, RONLY, ipFwTable, 3, {2, 1, 6}},
105 {IPFORWARDPROTO, ENUMERATION, RONLY, ipFwTable, 3, {2, 1, 7}},
106 {IPFORWARDAGE, INTEGER32, RONLY, ipFwTable, 3, {2, 1, 8}},
107 {IPFORWARDINFO, OBJECTIDENTIFIER, RONLY, ipFwTable, 3, {2, 1, 9}},
108 {IPFORWARDNEXTHOPAS, INTEGER32, RONLY, ipFwTable, 3, {2, 1, 10}},
109 {IPFORWARDMETRIC1, INTEGER32, RONLY, ipFwTable, 3, {2, 1, 11}},
110 {IPFORWARDMETRIC2, INTEGER32, RONLY, ipFwTable, 3, {2, 1, 12}},
111 {IPFORWARDMETRIC3, INTEGER32, RONLY, ipFwTable, 3, {2, 1, 13}},
112 {IPFORWARDMETRIC4, INTEGER32, RONLY, ipFwTable, 3, {2, 1, 14}},
113 {IPFORWARDMETRIC5, INTEGER32, RONLY, ipFwTable, 3, {2, 1, 15}},
114 {0, GAUGE32, RONLY, ipCidrNumber, 1, {3}},
115 {IPCIDRROUTEDEST, IPADDRESS, RONLY, ipCidrTable, 3, {4, 1, 1}},
116 {IPCIDRROUTEMASK, IPADDRESS, RONLY, ipCidrTable, 3, {4, 1, 2}},
117 {IPCIDRROUTETOS, INTEGER32, RONLY, ipCidrTable, 3, {4, 1, 3}},
118 {IPCIDRROUTENEXTHOP, IPADDRESS, RONLY, ipCidrTable, 3, {4, 1, 4}},
119 {IPCIDRROUTEIFINDEX, INTEGER32, RONLY, ipCidrTable, 3, {4, 1, 5}},
120 {IPCIDRROUTETYPE, ENUMERATION, RONLY, ipCidrTable, 3, {4, 1, 6}},
121 {IPCIDRROUTEPROTO, ENUMERATION, RONLY, ipCidrTable, 3, {4, 1, 7}},
122 {IPCIDRROUTEAGE, INTEGER32, RONLY, ipCidrTable, 3, {4, 1, 8}},
123 {IPCIDRROUTEINFO, OBJECTIDENTIFIER, RONLY, ipCidrTable, 3, {4, 1, 9}},
124 {IPCIDRROUTENEXTHOPAS, INTEGER32, RONLY, ipCidrTable, 3, {4, 1, 10}},
125 {IPCIDRROUTEMETRIC1, INTEGER32, RONLY, ipCidrTable, 3, {4, 1, 11}},
126 {IPCIDRROUTEMETRIC2, INTEGER32, RONLY, ipCidrTable, 3, {4, 1, 12}},
127 {IPCIDRROUTEMETRIC3, INTEGER32, RONLY, ipCidrTable, 3, {4, 1, 13}},
128 {IPCIDRROUTEMETRIC4, INTEGER32, RONLY, ipCidrTable, 3, {4, 1, 14}},
129 {IPCIDRROUTEMETRIC5, INTEGER32, RONLY, ipCidrTable, 3, {4, 1, 15}},
130 {IPCIDRROUTESTATUS, ROWSTATUS, RONLY, ipCidrTable, 3, {4, 1, 16}}
131 };
paul718e3742002-12-13 20:15:29 +0000132
133
Chris Caputo0be8dfb2009-06-02 18:40:07 +0100134static u_char *
paul718e3742002-12-13 20:15:29 +0000135ipFwNumber (struct variable *v, oid objid[], size_t *objid_len,
136 int exact, size_t *val_len, WriteMethod **write_method)
137{
138 static int result;
paul07661cb2003-03-18 00:03:05 +0000139 struct route_table *table;
140 struct route_node *rn;
paul718e3742002-12-13 20:15:29 +0000141 struct rib *rib;
142
143 if (smux_header_generic(v, objid, objid_len, exact, val_len, write_method) == MATCH_FAILED)
144 return NULL;
145
paul07661cb2003-03-18 00:03:05 +0000146 table = vrf_table (AFI_IP, SAFI_UNICAST, 0);
147 if (! table)
148 return NULL;
149
paul718e3742002-12-13 20:15:29 +0000150 /* Return number of routing entries. */
151 result = 0;
paul07661cb2003-03-18 00:03:05 +0000152 for (rn = route_top (table); rn; rn = route_next (rn))
153 for (rib = rn->info; rib; rib = rib->next)
paul718e3742002-12-13 20:15:29 +0000154 result++;
155
156 return (u_char *)&result;
157}
158
Chris Caputo0be8dfb2009-06-02 18:40:07 +0100159static u_char *
paul718e3742002-12-13 20:15:29 +0000160ipCidrNumber (struct variable *v, oid objid[], size_t *objid_len,
paul07661cb2003-03-18 00:03:05 +0000161 int exact, size_t *val_len, WriteMethod **write_method)
paul718e3742002-12-13 20:15:29 +0000162{
163 static int result;
paul07661cb2003-03-18 00:03:05 +0000164 struct route_table *table;
165 struct route_node *rn;
paul718e3742002-12-13 20:15:29 +0000166 struct rib *rib;
167
168 if (smux_header_generic(v, objid, objid_len, exact, val_len, write_method) == MATCH_FAILED)
169 return NULL;
170
paul07661cb2003-03-18 00:03:05 +0000171 table = vrf_table (AFI_IP, SAFI_UNICAST, 0);
172 if (! table)
173 return 0;
174
paul718e3742002-12-13 20:15:29 +0000175 /* Return number of routing entries. */
176 result = 0;
paul07661cb2003-03-18 00:03:05 +0000177 for (rn = route_top (table); rn; rn = route_next (rn))
178 for (rib = rn->info; rib; rib = rib->next)
paul718e3742002-12-13 20:15:29 +0000179 result++;
180
181 return (u_char *)&result;
182}
183
Chris Caputo0be8dfb2009-06-02 18:40:07 +0100184static int
paul718e3742002-12-13 20:15:29 +0000185in_addr_cmp(u_char *p1, u_char *p2)
186{
187 int i;
188
189 for (i=0; i<4; i++)
190 {
191 if (*p1 < *p2)
192 return -1;
193 if (*p1 > *p2)
194 return 1;
195 p1++; p2++;
196 }
197 return 0;
198}
199
Chris Caputo0be8dfb2009-06-02 18:40:07 +0100200static int
paul718e3742002-12-13 20:15:29 +0000201in_addr_add(u_char *p, int num)
202{
203 int i, ip0;
204
205 ip0 = *p;
206 p += 4;
207 for (i = 3; 0 <= i; i--) {
208 p--;
209 if (*p + num > 255) {
paul07661cb2003-03-18 00:03:05 +0000210 *p += num;
211 num = 1;
paul718e3742002-12-13 20:15:29 +0000212 } else {
paul07661cb2003-03-18 00:03:05 +0000213 *p += num;
214 return 1;
paul718e3742002-12-13 20:15:29 +0000215 }
216 }
217 if (ip0 > *p) {
paul07661cb2003-03-18 00:03:05 +0000218 /* ip + num > 0xffffffff */
219 return 0;
paul718e3742002-12-13 20:15:29 +0000220 }
221
222 return 1;
223}
224
Chris Caputo0be8dfb2009-06-02 18:40:07 +0100225static int
226proto_trans(int type)
paul718e3742002-12-13 20:15:29 +0000227{
228 switch (type)
229 {
paul07661cb2003-03-18 00:03:05 +0000230 case ZEBRA_ROUTE_SYSTEM:
231 return 1; /* other */
232 case ZEBRA_ROUTE_KERNEL:
233 return 1; /* other */
234 case ZEBRA_ROUTE_CONNECT:
235 return 2; /* local interface */
236 case ZEBRA_ROUTE_STATIC:
237 return 3; /* static route */
238 case ZEBRA_ROUTE_RIP:
239 return 8; /* rip */
240 case ZEBRA_ROUTE_RIPNG:
241 return 1; /* shouldn't happen */
242 case ZEBRA_ROUTE_OSPF:
243 return 13; /* ospf */
244 case ZEBRA_ROUTE_OSPF6:
245 return 1; /* shouldn't happen */
246 case ZEBRA_ROUTE_BGP:
247 return 14; /* bgp */
248 default:
249 return 1; /* other */
paul718e3742002-12-13 20:15:29 +0000250 }
251}
252
Chris Caputo0be8dfb2009-06-02 18:40:07 +0100253static void
paul718e3742002-12-13 20:15:29 +0000254check_replace(struct route_node *np2, struct rib *rib2,
255 struct route_node **np, struct rib **rib)
256{
257 int proto, proto2;
258
259 if (!*np)
260 {
261 *np = np2;
262 *rib = rib2;
263 return;
264 }
265
266 if (in_addr_cmp(&(*np)->p.u.prefix, &np2->p.u.prefix) < 0)
267 return;
268 if (in_addr_cmp(&(*np)->p.u.prefix, &np2->p.u.prefix) > 0)
269 {
270 *np = np2;
271 *rib = rib2;
272 return;
273 }
274
275 proto = proto_trans((*rib)->type);
276 proto2 = proto_trans(rib2->type);
277
278 if (proto2 > proto)
279 return;
280 if (proto2 < proto)
281 {
282 *np = np2;
283 *rib = rib2;
284 return;
285 }
286
287 if (in_addr_cmp((u_char *)&(*rib)->nexthop->gate.ipv4,
288 (u_char *)&rib2->nexthop->gate.ipv4) <= 0)
289 return;
290
291 *np = np2;
292 *rib = rib2;
293 return;
294}
295
Chris Caputo0be8dfb2009-06-02 18:40:07 +0100296static void
paul718e3742002-12-13 20:15:29 +0000297get_fwtable_route_node(struct variable *v, oid objid[], size_t *objid_len,
298 int exact, struct route_node **np, struct rib **rib)
299{
300 struct in_addr dest;
paul07661cb2003-03-18 00:03:05 +0000301 struct route_table *table;
paul718e3742002-12-13 20:15:29 +0000302 struct route_node *np2;
303 struct rib *rib2;
304 int proto;
305 int policy;
306 struct in_addr nexthop;
307 u_char *pnt;
308 int i;
309
paul07661cb2003-03-18 00:03:05 +0000310 /* Init index variables */
paul718e3742002-12-13 20:15:29 +0000311
312 pnt = (u_char *) &dest;
313 for (i = 0; i < 4; i++)
314 *pnt++ = 0;
315
316 pnt = (u_char *) &nexthop;
317 for (i = 0; i < 4; i++)
318 *pnt++ = 0;
319
320 proto = 0;
321 policy = 0;
322
paul07661cb2003-03-18 00:03:05 +0000323 /* Init return variables */
paul718e3742002-12-13 20:15:29 +0000324
325 *np = NULL;
326 *rib = NULL;
327
paul07661cb2003-03-18 00:03:05 +0000328 /* Short circuit exact matches of wrong length */
paul718e3742002-12-13 20:15:29 +0000329
hasso39db97e2004-10-12 20:50:58 +0000330 if (exact && (*objid_len != (unsigned) v->namelen + 10))
paul718e3742002-12-13 20:15:29 +0000331 return;
332
paul07661cb2003-03-18 00:03:05 +0000333 table = vrf_table (AFI_IP, SAFI_UNICAST, 0);
334 if (! table)
335 return;
336
337 /* Get INDEX information out of OID.
338 * ipForwardDest, ipForwardProto, ipForwardPolicy, ipForwardNextHop
339 */
paul718e3742002-12-13 20:15:29 +0000340
Chris Caputo0be8dfb2009-06-02 18:40:07 +0100341 if (*objid_len > (unsigned) v->namelen)
paul718e3742002-12-13 20:15:29 +0000342 oid2in_addr (objid + v->namelen, MIN(4, *objid_len - v->namelen), &dest);
343
hasso39db97e2004-10-12 20:50:58 +0000344 if (*objid_len > (unsigned) v->namelen + 4)
paul718e3742002-12-13 20:15:29 +0000345 proto = objid[v->namelen + 4];
346
hasso39db97e2004-10-12 20:50:58 +0000347 if (*objid_len > (unsigned) v->namelen + 5)
paul718e3742002-12-13 20:15:29 +0000348 policy = objid[v->namelen + 5];
349
hasso39db97e2004-10-12 20:50:58 +0000350 if (*objid_len > (unsigned) v->namelen + 6)
paul718e3742002-12-13 20:15:29 +0000351 oid2in_addr (objid + v->namelen + 6, MIN(4, *objid_len - v->namelen - 6),
paul07661cb2003-03-18 00:03:05 +0000352 &nexthop);
paul718e3742002-12-13 20:15:29 +0000353
354 /* Apply GETNEXT on not exact search */
355
hasso39db97e2004-10-12 20:50:58 +0000356 if (!exact && (*objid_len >= (unsigned) v->namelen + 10))
paul718e3742002-12-13 20:15:29 +0000357 {
358 if (! in_addr_add((u_char *) &nexthop, 1))
359 return;
360 }
361
362 /* For exact: search matching entry in rib table. */
363
364 if (exact)
365 {
366 if (policy) /* Not supported (yet?) */
367 return;
paul07661cb2003-03-18 00:03:05 +0000368 for (*np = route_top (table); *np; *np = route_next (*np))
paul718e3742002-12-13 20:15:29 +0000369 {
370 if (!in_addr_cmp(&(*np)->p.u.prefix, (u_char *)&dest))
371 {
372 for (*rib = (*np)->info; *rib; *rib = (*rib)->next)
373 {
374 if (!in_addr_cmp((u_char *)&(*rib)->nexthop->gate.ipv4,
paul07661cb2003-03-18 00:03:05 +0000375 (u_char *)&nexthop))
paul718e3742002-12-13 20:15:29 +0000376 if (proto == proto_trans((*rib)->type))
377 return;
378 }
379 }
380 }
381 return;
382 }
383
paul07661cb2003-03-18 00:03:05 +0000384 /* Search next best entry */
paul718e3742002-12-13 20:15:29 +0000385
paul07661cb2003-03-18 00:03:05 +0000386 for (np2 = route_top (table); np2; np2 = route_next (np2))
paul718e3742002-12-13 20:15:29 +0000387 {
388
389 /* Check destination first */
390 if (in_addr_cmp(&np2->p.u.prefix, (u_char *)&dest) > 0)
391 for (rib2 = np2->info; rib2; rib2 = rib2->next)
392 check_replace(np2, rib2, np, rib);
393
394 if (in_addr_cmp(&np2->p.u.prefix, (u_char *)&dest) == 0)
395 { /* have to look at each rib individually */
396 for (rib2 = np2->info; rib2; rib2 = rib2->next)
397 {
398 int proto2, policy2;
399
400 proto2 = proto_trans(rib2->type);
401 policy2 = 0;
402
403 if ((policy < policy2)
404 || ((policy == policy2) && (proto < proto2))
405 || ((policy == policy2) && (proto == proto2)
406 && (in_addr_cmp((u_char *)&rib2->nexthop->gate.ipv4,
407 (u_char *) &nexthop) >= 0)
408 ))
409 check_replace(np2, rib2, np, rib);
410 }
411 }
412 }
413
414 if (!*rib)
415 return;
416
417 policy = 0;
418 proto = proto_trans((*rib)->type);
419
420 *objid_len = v->namelen + 10;
421 pnt = (u_char *) &(*np)->p.u.prefix;
422 for (i = 0; i < 4; i++)
423 objid[v->namelen + i] = *pnt++;
424
425 objid[v->namelen + 4] = proto;
426 objid[v->namelen + 5] = policy;
427
428 {
429 struct nexthop *nexthop;
430
431 nexthop = (*rib)->nexthop;
432 if (nexthop)
433 {
434 pnt = (u_char *) &nexthop->gate.ipv4;
435 for (i = 0; i < 4; i++)
436 objid[i + v->namelen + 6] = *pnt++;
437 }
438 }
439
440 return;
441}
442
Chris Caputo0be8dfb2009-06-02 18:40:07 +0100443static u_char *
paul718e3742002-12-13 20:15:29 +0000444ipFwTable (struct variable *v, oid objid[], size_t *objid_len,
445 int exact, size_t *val_len, WriteMethod **write_method)
446{
447 struct route_node *np;
448 struct rib *rib;
449 static int result;
450 static int resarr[2];
451 static struct in_addr netmask;
452 struct nexthop *nexthop;
453
454 get_fwtable_route_node(v, objid, objid_len, exact, &np, &rib);
455 if (!np)
456 return NULL;
457
458 nexthop = rib->nexthop;
459 if (! nexthop)
460 return NULL;
461
462 switch (v->magic)
463 {
464 case IPFORWARDDEST:
465 *val_len = 4;
466 return &np->p.u.prefix;
467 break;
468 case IPFORWARDMASK:
469 masklen2ip(np->p.prefixlen, &netmask);
470 *val_len = 4;
471 return (u_char *)&netmask;
472 break;
473 case IPFORWARDPOLICY:
474 result = 0;
475 *val_len = sizeof(int);
476 return (u_char *)&result;
477 break;
478 case IPFORWARDNEXTHOP:
479 *val_len = 4;
480 return (u_char *)&nexthop->gate.ipv4;
481 break;
482 case IPFORWARDIFINDEX:
483 *val_len = sizeof(int);
484 return (u_char *)&nexthop->ifindex;
485 break;
486 case IPFORWARDTYPE:
487 if (nexthop->type == NEXTHOP_TYPE_IFINDEX
488 || nexthop->type == NEXTHOP_TYPE_IFNAME)
489 result = 3;
490 else
491 result = 4;
492 *val_len = sizeof(int);
493 return (u_char *)&result;
494 break;
495 case IPFORWARDPROTO:
496 result = proto_trans(rib->type);
497 *val_len = sizeof(int);
498 return (u_char *)&result;
499 break;
500 case IPFORWARDAGE:
501 result = 0;
502 *val_len = sizeof(int);
503 return (u_char *)&result;
504 break;
505 case IPFORWARDINFO:
506 resarr[0] = 0;
507 resarr[1] = 0;
508 *val_len = 2 * sizeof(int);
509 return (u_char *)resarr;
510 break;
511 case IPFORWARDNEXTHOPAS:
512 result = -1;
513 *val_len = sizeof(int);
514 return (u_char *)&result;
515 break;
516 case IPFORWARDMETRIC1:
517 result = 0;
518 *val_len = sizeof(int);
519 return (u_char *)&result;
520 break;
521 case IPFORWARDMETRIC2:
522 result = 0;
523 *val_len = sizeof(int);
524 return (u_char *)&result;
525 break;
526 case IPFORWARDMETRIC3:
527 result = 0;
528 *val_len = sizeof(int);
529 return (u_char *)&result;
530 break;
531 case IPFORWARDMETRIC4:
532 result = 0;
533 *val_len = sizeof(int);
534 return (u_char *)&result;
535 break;
536 case IPFORWARDMETRIC5:
537 result = 0;
538 *val_len = sizeof(int);
539 return (u_char *)&result;
540 break;
541 default:
542 return NULL;
543 break;
544 }
545 return NULL;
546}
547
Chris Caputo0be8dfb2009-06-02 18:40:07 +0100548static u_char *
paul718e3742002-12-13 20:15:29 +0000549ipCidrTable (struct variable *v, oid objid[], size_t *objid_len,
paul07661cb2003-03-18 00:03:05 +0000550 int exact, size_t *val_len, WriteMethod **write_method)
paul718e3742002-12-13 20:15:29 +0000551{
552 switch (v->magic)
553 {
554 case IPCIDRROUTEDEST:
555 break;
556 default:
557 return NULL;
558 break;
559 }
560 return NULL;
561}
562
563void
564zebra_snmp_init ()
565{
hassoc75105a2004-10-13 10:33:26 +0000566 smux_init (zebrad.master);
paul718e3742002-12-13 20:15:29 +0000567 REGISTER_MIB("mibII/ipforward", zebra_variables, variable, ipfw_oid);
paul718e3742002-12-13 20:15:29 +0000568}
569#endif /* HAVE_SNMP */