Finish repo-copy of lib/libbsnmp/modules to usr.sbin/bsnmpd/modules.
These modules are modules for the daemon, not for the library so they should be where the daemon is.
This commit is contained in:
parent
f321cf01e1
commit
1c80835774
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=143601
@ -1,5 +1,5 @@
|
|||||||
# $FreeBSD$
|
# $FreeBSD$
|
||||||
|
|
||||||
SUBDIR= libbsnmp modules
|
SUBDIR= libbsnmp
|
||||||
|
|
||||||
.include <bsd.subdir.mk>
|
.include <bsd.subdir.mk>
|
||||||
|
@ -1,16 +0,0 @@
|
|||||||
# $FreeBSD$
|
|
||||||
|
|
||||||
.PATH: ${.CURDIR}/../../../contrib/bsnmp/snmpd
|
|
||||||
|
|
||||||
.if !defined(NO_ATM)
|
|
||||||
_snmp_atm= snmp_atm
|
|
||||||
.endif
|
|
||||||
|
|
||||||
SUBDIR= ${_snmp_atm} \
|
|
||||||
snmp_mibII \
|
|
||||||
snmp_netgraph
|
|
||||||
|
|
||||||
INCS= snmpmod.h
|
|
||||||
INCSDIR= ${INCLUDEDIR}/bsnmp
|
|
||||||
|
|
||||||
.include <bsd.prog.mk>
|
|
@ -1,29 +0,0 @@
|
|||||||
# $FreeBSD$
|
|
||||||
|
|
||||||
SHLIB_NAME= snmp_${MOD}.so.${SHLIB_MAJOR}
|
|
||||||
SRCS+= ${MOD}_oid.h ${MOD}_tree.c ${MOD}_tree.h
|
|
||||||
CLEANFILES+= ${MOD}_oid.h ${MOD}_tree.c ${MOD}_tree.h
|
|
||||||
CFLAGS+= -I${CONTRIB}/lib -I${CONTRIB}/snmpd -I.
|
|
||||||
|
|
||||||
${MOD}_oid.h: ${MOD}_tree.def ${EXTRAMIBDEFS}
|
|
||||||
cat ${.ALLSRC} | gensnmptree -e ${XSYM} > ${.TARGET}
|
|
||||||
|
|
||||||
.ORDER: ${MOD}_tree.c ${MOD}_tree.h
|
|
||||||
${MOD}_tree.c ${MOD}_tree.h: ${MOD}_tree.def ${EXTRAMIBDEFS}
|
|
||||||
cat ${.ALLSRC} | gensnmptree -l -p ${MOD}_
|
|
||||||
|
|
||||||
.if defined(DEFS)
|
|
||||||
FILESGROUPS+= DEFS
|
|
||||||
.endif
|
|
||||||
DEFSDIR= ${SHAREDIR}/snmp/defs
|
|
||||||
|
|
||||||
.if defined(BMIBS)
|
|
||||||
FILESGROUPS+= BMIBS
|
|
||||||
.endif
|
|
||||||
BMIBSDIR= ${SHAREDIR}/snmp/mibs
|
|
||||||
|
|
||||||
MANFILTER= sed -e 's%@MODPATH@%${LIBDIR}/%g' \
|
|
||||||
-e 's%@DEFPATH@%${DEFSDIR}/%g' \
|
|
||||||
-e 's%@MIBSPATH@%${BMIBSDIR}/%g'
|
|
||||||
|
|
||||||
.include "../Makefile.inc"
|
|
@ -1,99 +0,0 @@
|
|||||||
--
|
|
||||||
-- Copyright (c) 2004
|
|
||||||
-- Hartmut Brandt.
|
|
||||||
-- All rights reserved.
|
|
||||||
--
|
|
||||||
-- Author: Hartmut Brandt <harti@freebsd.org>
|
|
||||||
--
|
|
||||||
-- Redistribution and use in source and binary forms, with or without
|
|
||||||
-- modification, are permitted provided that the following conditions
|
|
||||||
-- are met:
|
|
||||||
-- 1. Redistributions of source code must retain the above copyright
|
|
||||||
-- notice, this list of conditions and the following disclaimer.
|
|
||||||
-- 2. Redistributions in binary form must reproduce the above copyright
|
|
||||||
-- notice, this list of conditions and the following disclaimer in the
|
|
||||||
-- documentation and/or other materials provided with the distribution.
|
|
||||||
--
|
|
||||||
-- THIS SOFTWARE IS PROVIDED BY AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
||||||
-- ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
-- IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
-- ARE DISCLAIMED. IN NO EVENT SHALL AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
||||||
-- FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
||||||
-- DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
||||||
-- OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
||||||
-- HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
||||||
-- LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
||||||
-- OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
||||||
-- SUCH DAMAGE.
|
|
||||||
--
|
|
||||||
-- $FreeBSD$
|
|
||||||
--
|
|
||||||
-- Private Begemot MIB for ATM interfaces on FreeBSD
|
|
||||||
--
|
|
||||||
BEGEMOT-ATM-FREEBSD-MIB DEFINITIONS ::= BEGIN
|
|
||||||
|
|
||||||
IMPORTS
|
|
||||||
MODULE-IDENTITY, OBJECT-TYPE
|
|
||||||
FROM SNMPv2-SMI
|
|
||||||
NgNodeIdOrZero
|
|
||||||
FROM BEGEMOT-NETGRAPH-MIB
|
|
||||||
begemotAtmSysGroup, begemotAtmIfEntry
|
|
||||||
FROM BEGEMOT-ATM-MIB;
|
|
||||||
|
|
||||||
begemotAtmFreeBSDGroup MODULE-IDENTITY
|
|
||||||
LAST-UPDATED "200408060000Z"
|
|
||||||
ORGANIZATION "German Aerospace Centre"
|
|
||||||
CONTACT-INFO
|
|
||||||
" Hartmut Brandt
|
|
||||||
|
|
||||||
Postal: German Aerospace Centre (DLR)
|
|
||||||
Institute of Communications and Navigation
|
|
||||||
82234 Wessling
|
|
||||||
Germany
|
|
||||||
|
|
||||||
Fax: +49 8153 28 2844
|
|
||||||
|
|
||||||
E-mail: harti@freebsd.org"
|
|
||||||
DESCRIPTION
|
|
||||||
"The FreeBSD specific Begemot MIB for ATM interfaces."
|
|
||||||
|
|
||||||
::= { begemotAtmSysGroup 1 }
|
|
||||||
|
|
||||||
-- Netgraph
|
|
||||||
begemotAtmNgGroup OBJECT IDENTIFIER ::= { begemotAtmFreeBSDGroup 1 }
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Interfaces table
|
|
||||||
--
|
|
||||||
begemotAtmNgIfTable OBJECT-TYPE
|
|
||||||
SYNTAX SEQUENCE OF BegemotAtmNgIfEntry
|
|
||||||
MAX-ACCESS not-accessible
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"This table contains an entry for each hardware ATM
|
|
||||||
interface. The table is indexed by the interface index."
|
|
||||||
::= { begemotAtmNgGroup 1 }
|
|
||||||
|
|
||||||
begemotAtmNgIfEntry OBJECT-TYPE
|
|
||||||
SYNTAX BegemotAtmNgIfEntry
|
|
||||||
MAX-ACCESS not-accessible
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"This is a table entry describing one ATM hardware interface."
|
|
||||||
AUGMENTS { begemotAtmIfEntry }
|
|
||||||
::= { begemotAtmNgIfTable 1 }
|
|
||||||
|
|
||||||
BegemotAtmNgIfEntry ::= SEQUENCE {
|
|
||||||
begemotAtmNgIfNodeId NgNodeIdOrZero
|
|
||||||
}
|
|
||||||
|
|
||||||
begemotAtmNgIfNodeId OBJECT-TYPE
|
|
||||||
SYNTAX NgNodeIdOrZero
|
|
||||||
MAX-ACCESS read-only
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"The netgraph node id of the interface. If there is no
|
|
||||||
node corresponding to the interface, this is 0."
|
|
||||||
::= { begemotAtmNgIfEntry 1 }
|
|
||||||
|
|
||||||
END
|
|
@ -1,22 +0,0 @@
|
|||||||
# $FreeBSD$
|
|
||||||
#
|
|
||||||
# Author: Harti Brandt <harti@freebsd.org>
|
|
||||||
|
|
||||||
CONTRIB=${.CURDIR}/../../../../contrib/bsnmp
|
|
||||||
SNMP_ATM=${.CURDIR}/../../../../contrib/ngatm/snmp_atm
|
|
||||||
.PATH: ${SNMP_ATM}
|
|
||||||
|
|
||||||
MOD= atm
|
|
||||||
SRCS= snmp_atm.c atm_sys.c
|
|
||||||
XSYM= begemotAtm
|
|
||||||
MAN= snmp_atm.3
|
|
||||||
|
|
||||||
BMIBS= BEGEMOT-ATM.txt BEGEMOT-ATM-FREEBSD-MIB.txt
|
|
||||||
DEFS= ${MOD}_tree.def atm_freebsd.def
|
|
||||||
INCS= snmp_${MOD}.h
|
|
||||||
|
|
||||||
EXTRAMIBDEFS= atm_freebsd.def
|
|
||||||
|
|
||||||
CFLAGS+= -I${SNMP_ATM}
|
|
||||||
|
|
||||||
.include <bsd.lib.mk>
|
|
@ -1,56 +0,0 @@
|
|||||||
#
|
|
||||||
# Copyright (c) 2004
|
|
||||||
# Hartmut Brandt.
|
|
||||||
# All rights reserved.
|
|
||||||
#
|
|
||||||
# Author: Hartmut Brandt <harti@freebsd.org>
|
|
||||||
#
|
|
||||||
# Redistribution and use in source and binary forms, with or without
|
|
||||||
# modification, are permitted provided that the following conditions
|
|
||||||
# are met:
|
|
||||||
# 1. Redistributions of source code must retain the above copyright
|
|
||||||
# notice, this list of conditions and the following disclaimer.
|
|
||||||
# 2. Redistributions in binary form must reproduce the above copyright
|
|
||||||
# notice, this list of conditions and the following disclaimer in the
|
|
||||||
# documentation and/or other materials provided with the distribution.
|
|
||||||
#
|
|
||||||
# THIS SOFTWARE IS PROVIDED BY AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
||||||
# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
# ARE DISCLAIMED. IN NO EVENT SHALL AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
||||||
# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
||||||
# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
||||||
# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
||||||
# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
||||||
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
||||||
# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
||||||
# SUCH DAMAGE.
|
|
||||||
#
|
|
||||||
# $FreeBSD$
|
|
||||||
#
|
|
||||||
# SNMP module for ATM hardware interfaces.
|
|
||||||
#
|
|
||||||
# $Begemot: libunimsg/snmp_atm/atm_tree.def,v 1.2 2004/08/05 07:14:22 brandt Exp $
|
|
||||||
#
|
|
||||||
(1 internet
|
|
||||||
(4 private
|
|
||||||
(1 enterprises
|
|
||||||
(12325 fokus
|
|
||||||
(1 begemot
|
|
||||||
(101 begemotAtm
|
|
||||||
(1 begemotAtmObjects
|
|
||||||
(4 begemotAtmSysGroup
|
|
||||||
(1 begemotAtmFreeBSDGroup
|
|
||||||
(1 begemotAtmNgGroup
|
|
||||||
(1 begemotAtmNgIfTable
|
|
||||||
(1 begemotAtmNgIfEntry : INTEGER op_atmif_ng
|
|
||||||
(1 begemotAtmIfNodeId UNSIGNED32 GET)
|
|
||||||
))
|
|
||||||
)
|
|
||||||
)
|
|
||||||
)
|
|
||||||
)
|
|
||||||
))
|
|
||||||
)
|
|
||||||
)
|
|
||||||
))
|
|
@ -1,301 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (c) 2001-2002
|
|
||||||
* Fraunhofer Institute for Open Communication Systems (FhG Fokus).
|
|
||||||
* All rights reserved.
|
|
||||||
* Copyright (c) 2003-2004
|
|
||||||
* Hartmut Brandt.
|
|
||||||
* All rights reserved.
|
|
||||||
*
|
|
||||||
* Author: Hartmut Brandt <harti@freebsd.org>
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions
|
|
||||||
* are met:
|
|
||||||
* 1. Redistributions of source code must retain the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer.
|
|
||||||
* 2. Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
||||||
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
||||||
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
||||||
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
||||||
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
||||||
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
||||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
||||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
||||||
* SUCH DAMAGE.
|
|
||||||
*
|
|
||||||
* $FreeBSD$
|
|
||||||
*
|
|
||||||
* SNMP module for ATM hardware interfaces - FreeBSD/Ng specific part.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "atm.h"
|
|
||||||
#include "atm_tree.h"
|
|
||||||
#include "atm_oid.h"
|
|
||||||
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <syslog.h>
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
#include <net/if_atm.h>
|
|
||||||
|
|
||||||
#include <bsnmp/snmp_netgraph.h>
|
|
||||||
#include <netgraph/ng_message.h>
|
|
||||||
#include <netgraph/atm/ng_atm.h>
|
|
||||||
|
|
||||||
static const struct hwinfo {
|
|
||||||
const char *device;
|
|
||||||
const char *vendor;
|
|
||||||
} hwinfo[] = {
|
|
||||||
ATM_DEVICE_NAMES
|
|
||||||
};
|
|
||||||
|
|
||||||
struct atmif_sys {
|
|
||||||
ng_ID_t atm_node;
|
|
||||||
void *regc; /* cookie registration */
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Find the interface for a given node
|
|
||||||
*/
|
|
||||||
struct atmif *
|
|
||||||
atm_node2if(u_int node)
|
|
||||||
{
|
|
||||||
struct atmif_priv *aif;
|
|
||||||
|
|
||||||
if (node != 0)
|
|
||||||
TAILQ_FOREACH(aif, &atmif_list, link)
|
|
||||||
if (aif->sys->atm_node == node)
|
|
||||||
return (&aif->pub);
|
|
||||||
return (NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
u_int
|
|
||||||
atm_if2node(struct atmif *pub)
|
|
||||||
{
|
|
||||||
struct atmif_priv *aif = (struct atmif_priv *)pub;
|
|
||||||
|
|
||||||
return (aif->sys->atm_node);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Destroy system dependend stuff.
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
atmif_sys_destroy(struct atmif_priv *aif)
|
|
||||||
{
|
|
||||||
|
|
||||||
ng_unregister_cookie(aif->sys->regc);
|
|
||||||
free(aif->sys);
|
|
||||||
free(aif->pub.mib);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Handle a message from the ATM node
|
|
||||||
*/
|
|
||||||
static void
|
|
||||||
handle_atm_message(const struct ng_mesg *mesg, const char *path __unused,
|
|
||||||
ng_ID_t node, void *uarg)
|
|
||||||
{
|
|
||||||
struct atmif_priv *aif = uarg;
|
|
||||||
enum atmif_carrier_state ost;
|
|
||||||
|
|
||||||
switch (mesg->header.cmd) {
|
|
||||||
|
|
||||||
case NGM_ATM_IF_CHANGE:
|
|
||||||
{
|
|
||||||
const struct ngm_atm_if_change *arg;
|
|
||||||
|
|
||||||
ost = aif->pub.carrier;
|
|
||||||
if (mesg->header.arglen != sizeof(*arg)) {
|
|
||||||
syslog(LOG_ERR, "ATM_IF_CHANGE: wrong size");
|
|
||||||
atmif_check_carrier(aif);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
arg = (const struct ngm_atm_if_change *)
|
|
||||||
(const void *)mesg->data;
|
|
||||||
|
|
||||||
if (arg->carrier)
|
|
||||||
aif->pub.carrier = ATMIF_CARRIER_ON;
|
|
||||||
else
|
|
||||||
aif->pub.carrier = ATMIF_CARRIER_OFF;
|
|
||||||
|
|
||||||
if (ost != aif->pub.carrier)
|
|
||||||
atmif_send_notification(aif, ATMIF_NOTIFY_CARRIER,
|
|
||||||
(uintptr_t)ost);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
case NGM_ATM_VCC_CHANGE:
|
|
||||||
{
|
|
||||||
const struct ngm_atm_vcc_change *arg;
|
|
||||||
|
|
||||||
if (mesg->header.arglen != sizeof(*arg)) {
|
|
||||||
syslog(LOG_ERR, "ATM_VCC_CHANGE: wrong size");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
arg = (const struct ngm_atm_vcc_change *)
|
|
||||||
(const void *)mesg->data;
|
|
||||||
atmif_send_notification(aif, ATMIF_NOTIFY_VCC,
|
|
||||||
(uintptr_t)(((arg->vpi & 0xff) << 24) |
|
|
||||||
((arg->vci & 0xffff) << 8) | (arg->state & 1)));
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
syslog(LOG_WARNING, "spurious message %u from node [%x]",
|
|
||||||
mesg->header.cmd, node);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Attach to an ATM interface
|
|
||||||
*/
|
|
||||||
int
|
|
||||||
atmif_sys_attach_if(struct atmif_priv *aif)
|
|
||||||
{
|
|
||||||
struct ng_mesg *resp, *resp1;
|
|
||||||
struct namelist *list;
|
|
||||||
u_int i;
|
|
||||||
|
|
||||||
if ((aif->sys = malloc(sizeof(*aif->sys))) == NULL) {
|
|
||||||
syslog(LOG_CRIT, "out of memory");
|
|
||||||
return (-1);
|
|
||||||
}
|
|
||||||
memset(aif->sys, 0, sizeof(*aif->sys));
|
|
||||||
|
|
||||||
if ((aif->pub.mib = malloc(sizeof(*aif->pub.mib))) == NULL) {
|
|
||||||
free(aif->sys);
|
|
||||||
syslog(LOG_CRIT, "out of memory");
|
|
||||||
return (-1);
|
|
||||||
}
|
|
||||||
|
|
||||||
atmif_sys_fill_mib(aif);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Get ATM node Id. Must do it the hard way by scanning all nodes
|
|
||||||
* because the name may be wrong.
|
|
||||||
*/
|
|
||||||
if ((resp = ng_dialog_id(snmp_node, NGM_GENERIC_COOKIE, NGM_LISTNODES,
|
|
||||||
NULL, 0)) == NULL) {
|
|
||||||
syslog(LOG_ERR, "cannot fetch node list: %m");
|
|
||||||
free(aif->sys);
|
|
||||||
return (-1);
|
|
||||||
}
|
|
||||||
list = (struct namelist *)(void *)resp->data;
|
|
||||||
|
|
||||||
for (i = 0; i < list->numnames; i++) {
|
|
||||||
if (strcmp(list->nodeinfo[i].type, NG_ATM_NODE_TYPE) != 0)
|
|
||||||
continue;
|
|
||||||
if ((resp1 = ng_dialog_id(list->nodeinfo[i].id,
|
|
||||||
NGM_ATM_COOKIE, NGM_ATM_GET_IFNAME, NULL, 0)) == NULL)
|
|
||||||
continue;
|
|
||||||
if (strcmp(resp1->data, aif->pub.ifp->name) == 0) {
|
|
||||||
free(resp1);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
free(resp1);
|
|
||||||
}
|
|
||||||
if (i == list->numnames)
|
|
||||||
aif->sys->atm_node = 0;
|
|
||||||
else
|
|
||||||
aif->sys->atm_node = list->nodeinfo[i].id;
|
|
||||||
|
|
||||||
free(resp);
|
|
||||||
|
|
||||||
if ((aif->sys->regc = ng_register_cookie(module, NGM_ATM_COOKIE,
|
|
||||||
aif->sys->atm_node, handle_atm_message, aif)) == NULL) {
|
|
||||||
syslog(LOG_ERR, "cannot register cookie: %m");
|
|
||||||
free(aif->sys);
|
|
||||||
return (-1);
|
|
||||||
}
|
|
||||||
return (0);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Table of all ATM interfaces - Ng part
|
|
||||||
*/
|
|
||||||
int
|
|
||||||
op_atmif_ng(struct snmp_context *ctx __unused, struct snmp_value *value,
|
|
||||||
u_int sub, u_int vindex __unused, enum snmp_op op)
|
|
||||||
{
|
|
||||||
struct atmif_priv *aif;
|
|
||||||
int err;
|
|
||||||
|
|
||||||
if ((err = atmif_get_aif(value, sub, op, &aif)) != SNMP_ERR_NOERROR)
|
|
||||||
return (err);
|
|
||||||
|
|
||||||
if (op == SNMP_OP_SET) {
|
|
||||||
switch (value->var.subs[sub - 1]) {
|
|
||||||
|
|
||||||
default:
|
|
||||||
return (SNMP_ERR_NOT_WRITEABLE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
switch (value->var.subs[sub - 1]) {
|
|
||||||
|
|
||||||
case LEAF_begemotAtmIfNodeId:
|
|
||||||
value->v.uint32 = aif->sys->atm_node;
|
|
||||||
return (SNMP_ERR_NOERROR);
|
|
||||||
}
|
|
||||||
abort();
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Get vendor string
|
|
||||||
*/
|
|
||||||
int
|
|
||||||
atm_sys_get_hw_vendor(struct atmif_priv *aif, struct snmp_value *value)
|
|
||||||
{
|
|
||||||
|
|
||||||
if (aif->pub.mib->device >= sizeof(hwinfo) / sizeof(hwinfo[0]))
|
|
||||||
return (string_get(value, "unknown", -1));
|
|
||||||
return (string_get(value, hwinfo[aif->pub.mib->device].vendor, -1));
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Get device string
|
|
||||||
*/
|
|
||||||
int
|
|
||||||
atm_sys_get_hw_device(struct atmif_priv *aif, struct snmp_value *value)
|
|
||||||
{
|
|
||||||
|
|
||||||
if (aif->pub.mib->device >= sizeof(hwinfo) / sizeof(hwinfo[0]))
|
|
||||||
return (string_get(value, "unknown", -1));
|
|
||||||
return (string_get(value, hwinfo[aif->pub.mib->device].device, -1));
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Extract the ATM MIB from the interface's private MIB
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
atmif_sys_fill_mib(struct atmif_priv *aif)
|
|
||||||
{
|
|
||||||
struct ifatm_mib *mib;
|
|
||||||
|
|
||||||
if (aif->pub.ifp->specmiblen != sizeof(struct ifatm_mib)) {
|
|
||||||
syslog(LOG_ERR, "atmif MIB has wrong size %zu",
|
|
||||||
aif->pub.ifp->specmiblen);
|
|
||||||
memset(aif->pub.mib, 0, sizeof(*aif->pub.mib));
|
|
||||||
aif->pub.mib->version = 0;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
mib = (struct ifatm_mib *)aif->pub.ifp->specmib;
|
|
||||||
|
|
||||||
aif->pub.mib->device = mib->device;
|
|
||||||
aif->pub.mib->serial = mib->serial;
|
|
||||||
aif->pub.mib->hw_version = mib->hw_version;
|
|
||||||
aif->pub.mib->sw_version = mib->sw_version;
|
|
||||||
aif->pub.mib->media = mib->media;
|
|
||||||
|
|
||||||
memcpy(aif->pub.mib->esi, mib->esi, 6);
|
|
||||||
aif->pub.mib->pcr = mib->pcr;
|
|
||||||
aif->pub.mib->vpi_bits = mib->vpi_bits;
|
|
||||||
aif->pub.mib->vci_bits = mib->vci_bits;
|
|
||||||
aif->pub.mib->max_vpcs = mib->max_vpcs;
|
|
||||||
aif->pub.mib->max_vccs = mib->max_vccs;
|
|
||||||
}
|
|
@ -1,19 +0,0 @@
|
|||||||
# $FreeBSD$
|
|
||||||
#
|
|
||||||
# Author: Harti Brandt <harti@freebsd.org>
|
|
||||||
|
|
||||||
CONTRIB=${.CURDIR}/../../../../contrib/bsnmp
|
|
||||||
.PATH: ${CONTRIB}/snmp_mibII
|
|
||||||
|
|
||||||
MOD= mibII
|
|
||||||
SRCS= mibII.c mibII_ifmib.c mibII_ip.c mibII_interfaces.c \
|
|
||||||
mibII_ipaddr.c mibII_ifstack.c mibII_rcvaddr.c \
|
|
||||||
mibII_nettomedia.c mibII_tcp.c mibII_udp.c mibII_route.c
|
|
||||||
XSYM= ipAddrTable ifTable ifRcvAddressEntry ifMIB ipMIB tcpMIB udpMIB \
|
|
||||||
ipForward ifIndex linkDown linkUp
|
|
||||||
MAN= snmp_mibII.3
|
|
||||||
|
|
||||||
DEFS= ${MOD}_tree.def
|
|
||||||
INCS= snmp_${MOD}.h
|
|
||||||
|
|
||||||
.include <bsd.lib.mk>
|
|
@ -1,398 +0,0 @@
|
|||||||
--
|
|
||||||
-- Copyright (c) 2001-2003
|
|
||||||
-- Fraunhofer Institute for Open Communication Systems (FhG Fokus).
|
|
||||||
-- All rights reserved.
|
|
||||||
--
|
|
||||||
-- Author: Harti Brandt <harti@freebsd.org>
|
|
||||||
--
|
|
||||||
-- Redistribution of this software and documentation and use in source and
|
|
||||||
-- binary forms, with or without modification, are permitted provided that
|
|
||||||
-- the following conditions are met:
|
|
||||||
--
|
|
||||||
-- 1. Redistributions of source code or documentation must retain the above
|
|
||||||
-- copyright notice, this list of conditions and the following disclaimer.
|
|
||||||
-- 2. Redistributions in binary form must reproduce the above copyright
|
|
||||||
-- notice, this list of conditions and the following disclaimer in the
|
|
||||||
-- documentation and/or other materials provided with the distribution.
|
|
||||||
--
|
|
||||||
-- THIS SOFTWARE AND DOCUMENTATION IS PROVIDED BY FRAUNHOFER FOKUS
|
|
||||||
-- AND ITS CONTRIBUTORS ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
|
|
||||||
-- INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
|
||||||
-- FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
|
|
||||||
-- FRAUNHOFER FOKUS OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
||||||
-- INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
-- LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,
|
|
||||||
-- OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
|
||||||
-- LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
|
||||||
-- NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
|
|
||||||
-- EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
--
|
|
||||||
-- $FreeBSD$
|
|
||||||
--
|
|
||||||
-- Private MIB for netgraph part of Begemot SNMP daemon.
|
|
||||||
--
|
|
||||||
BEGEMOT-NETGRAPH-MIB DEFINITIONS ::= BEGIN
|
|
||||||
|
|
||||||
IMPORTS
|
|
||||||
MODULE-IDENTITY, OBJECT-TYPE, Counter32, Unsigned32
|
|
||||||
FROM SNMPv2-SMI
|
|
||||||
TEXTUAL-CONVENTION, TruthValue
|
|
||||||
FROM SNMPv2-TC
|
|
||||||
MODULE-COMPLIANCE, OBJECT-GROUP
|
|
||||||
FROM SNMPv2-CONF
|
|
||||||
begemot
|
|
||||||
FROM BEGEMOT-MIB;
|
|
||||||
|
|
||||||
begemotNg MODULE-IDENTITY
|
|
||||||
LAST-UPDATED "200311140000Z"
|
|
||||||
ORGANIZATION "Fraunhofer FOKUS, CATS"
|
|
||||||
CONTACT-INFO
|
|
||||||
" Hartmut Brandt
|
|
||||||
|
|
||||||
Postal: Fraunhofer Institute for Open Communication Systems
|
|
||||||
Kaiserin-Augusta-Allee 31
|
|
||||||
10589 Berlin
|
|
||||||
Germany
|
|
||||||
|
|
||||||
Fax: +49 30 3463 7352
|
|
||||||
|
|
||||||
E-mail: harti@freebsd.org"
|
|
||||||
DESCRIPTION
|
|
||||||
"The MIB for the NetGraph access module for SNMP."
|
|
||||||
::= { begemot 2 }
|
|
||||||
|
|
||||||
begemotNgObjects OBJECT IDENTIFIER ::= { begemotNg 1 }
|
|
||||||
|
|
||||||
-- --------------------------------------------------------------------------
|
|
||||||
|
|
||||||
NgTypeName ::= TEXTUAL-CONVENTION
|
|
||||||
DISPLAY-HINT "31a"
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"Name of a netgraph type."
|
|
||||||
SYNTAX OCTET STRING (SIZE(1..31))
|
|
||||||
|
|
||||||
NgNodeName ::= TEXTUAL-CONVENTION
|
|
||||||
DISPLAY-HINT "31a"
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"Name of a netgraph node."
|
|
||||||
SYNTAX OCTET STRING (SIZE(1..31))
|
|
||||||
|
|
||||||
NgNodeNameOrEmpty ::= TEXTUAL-CONVENTION
|
|
||||||
DISPLAY-HINT "31a"
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"Name of a netgraph node."
|
|
||||||
SYNTAX OCTET STRING (SIZE(0..31))
|
|
||||||
|
|
||||||
NgHookName ::= TEXTUAL-CONVENTION
|
|
||||||
DISPLAY-HINT "31a"
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"Name of a netgraph hook."
|
|
||||||
SYNTAX OCTET STRING (SIZE(1..31))
|
|
||||||
|
|
||||||
NgNodeId ::= TEXTUAL-CONVENTION
|
|
||||||
DISPLAY-HINT "x"
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"Node identifier."
|
|
||||||
SYNTAX Unsigned32 (1..4294967295)
|
|
||||||
|
|
||||||
NgNodeIdOrZero ::= TEXTUAL-CONVENTION
|
|
||||||
DISPLAY-HINT "x"
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"Node identifier or 0 for 'no-node'."
|
|
||||||
SYNTAX Unsigned32 (0..4294967295)
|
|
||||||
|
|
||||||
-- --------------------------------------------------------------------------
|
|
||||||
--
|
|
||||||
-- Configuration parameters
|
|
||||||
--
|
|
||||||
begemotNgConfig OBJECT IDENTIFIER ::= { begemotNgObjects 1 }
|
|
||||||
|
|
||||||
begemotNgControlNodeName OBJECT-TYPE
|
|
||||||
SYNTAX NgNodeName
|
|
||||||
MAX-ACCESS read-only
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"The name of the netgraph node of this daemon. The name is
|
|
||||||
writeable during initialisation. If the name is set from
|
|
||||||
the empty string to the non-empty string, the netgraph socket
|
|
||||||
is created. Once set it cannot be changed."
|
|
||||||
::= { begemotNgConfig 1 }
|
|
||||||
|
|
||||||
begemotNgResBufSiz OBJECT-TYPE
|
|
||||||
SYNTAX INTEGER (1024..65536)
|
|
||||||
MAX-ACCESS read-write
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"The size of the receive buffers for netgraph messages."
|
|
||||||
DEFVAL { 20000 }
|
|
||||||
::= { begemotNgConfig 2 }
|
|
||||||
|
|
||||||
begemotNgTimeout OBJECT-TYPE
|
|
||||||
SYNTAX INTEGER (10..10000)
|
|
||||||
UNITS "milliseconds"
|
|
||||||
MAX-ACCESS read-write
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"The maximum time to wait for a response to a netgraph message."
|
|
||||||
DEFVAL { 1000 }
|
|
||||||
::= { begemotNgConfig 3 }
|
|
||||||
|
|
||||||
begemotNgDebugLevel OBJECT-TYPE
|
|
||||||
SYNTAX Unsigned32
|
|
||||||
MAX-ACCESS read-write
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"The netgraph library debug level. This should be set only
|
|
||||||
if the daemon is run with a terminal attached."
|
|
||||||
DEFVAL { 0 }
|
|
||||||
::= { begemotNgConfig 4 }
|
|
||||||
|
|
||||||
-- --------------------------------------------------------------------------
|
|
||||||
--
|
|
||||||
-- The STATISTICS Group
|
|
||||||
--
|
|
||||||
begemotNgStats OBJECT IDENTIFIER ::= { begemotNgObjects 2 }
|
|
||||||
|
|
||||||
begemotNgNoMems OBJECT-TYPE
|
|
||||||
SYNTAX Counter32
|
|
||||||
MAX-ACCESS read-only
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"Number of times a memory allocation has failed for buffers
|
|
||||||
or the message queue."
|
|
||||||
::= { begemotNgStats 1 }
|
|
||||||
|
|
||||||
begemotNgMsgReadErrs OBJECT-TYPE
|
|
||||||
SYNTAX Counter32
|
|
||||||
MAX-ACCESS read-only
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"Number of times reading a netgraph message has failed."
|
|
||||||
::= { begemotNgStats 2 }
|
|
||||||
|
|
||||||
begemotNgTooLargeMsgs OBJECT-TYPE
|
|
||||||
SYNTAX Counter32
|
|
||||||
MAX-ACCESS read-only
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"Number of times a netgraph message was too large for
|
|
||||||
the buffer. Try increasing begemotNgResBufSiz if
|
|
||||||
this happens."
|
|
||||||
::= { begemotNgStats 3 }
|
|
||||||
|
|
||||||
begemotNgDataReadErrs OBJECT-TYPE
|
|
||||||
SYNTAX Counter32
|
|
||||||
MAX-ACCESS read-only
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"Number of times reading a netgraph data message has failed."
|
|
||||||
::= { begemotNgStats 4 }
|
|
||||||
|
|
||||||
begemotNgTooLargeDatas OBJECT-TYPE
|
|
||||||
SYNTAX Counter32
|
|
||||||
MAX-ACCESS read-only
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"Number of times a netgraph data message was too large.
|
|
||||||
You need to increase begemotNgResBufSiz."
|
|
||||||
::= { begemotNgStats 5 }
|
|
||||||
|
|
||||||
-- -----------------------------------------------------
|
|
||||||
--
|
|
||||||
-- The NODE table
|
|
||||||
--
|
|
||||||
begemotNgTypeTable OBJECT-TYPE
|
|
||||||
SYNTAX SEQUENCE OF BegemotNgTypeEntry
|
|
||||||
MAX-ACCESS not-accessible
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"A table containing information about all netgraph node types."
|
|
||||||
::= { begemotNgObjects 3 }
|
|
||||||
|
|
||||||
begemotNgTypeEntry OBJECT-TYPE
|
|
||||||
SYNTAX BegemotNgTypeEntry
|
|
||||||
MAX-ACCESS not-accessible
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"Table entry that describes one netgraph node."
|
|
||||||
INDEX { begemotNgTypeName }
|
|
||||||
::= { begemotNgTypeTable 1 }
|
|
||||||
|
|
||||||
BegemotNgTypeEntry ::= SEQUENCE {
|
|
||||||
begemotNgTypeName NgTypeName,
|
|
||||||
begemotNgTypeStatus INTEGER
|
|
||||||
}
|
|
||||||
|
|
||||||
begemotNgTypeName OBJECT-TYPE
|
|
||||||
SYNTAX NgTypeName
|
|
||||||
MAX-ACCESS not-accessible
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"The name of the type. Used as index."
|
|
||||||
::= { begemotNgTypeEntry 1 }
|
|
||||||
|
|
||||||
begemotNgTypeStatus OBJECT-TYPE
|
|
||||||
SYNTAX INTEGER { loaded(1), unloaded(2) }
|
|
||||||
MAX-ACCESS read-create
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"If loaded then the node type is available. A type can be load
|
|
||||||
by setting this field to loaded. It is unload if the field is
|
|
||||||
set to unloaded. Note, that a type cannot be unloaded if it
|
|
||||||
is compiled into the kernel or has nodes of this type. The name
|
|
||||||
of the file containing the type implementation is constructed by
|
|
||||||
prepending ng_ to the type name."
|
|
||||||
::= { begemotNgTypeEntry 2 }
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Node table
|
|
||||||
--
|
|
||||||
begemotNgNodeTable OBJECT-TYPE
|
|
||||||
SYNTAX SEQUENCE OF BegemotNgNodeEntry
|
|
||||||
MAX-ACCESS not-accessible
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"A table containing information about all netgraph nodes."
|
|
||||||
::= { begemotNgObjects 4 }
|
|
||||||
|
|
||||||
begemotNgNodeEntry OBJECT-TYPE
|
|
||||||
SYNTAX BegemotNgNodeEntry
|
|
||||||
MAX-ACCESS not-accessible
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"Table entry that describes one netgraph node."
|
|
||||||
INDEX { begemotNgNodeId }
|
|
||||||
::= { begemotNgNodeTable 1 }
|
|
||||||
|
|
||||||
BegemotNgNodeEntry ::= SEQUENCE {
|
|
||||||
begemotNgNodeId NgNodeId,
|
|
||||||
begemotNgNodeStatus INTEGER,
|
|
||||||
begemotNgNodeName NgNodeNameOrEmpty,
|
|
||||||
begemotNgNodeType NgTypeName,
|
|
||||||
begemotNgNodeHooks Unsigned32
|
|
||||||
}
|
|
||||||
|
|
||||||
begemotNgNodeId OBJECT-TYPE
|
|
||||||
SYNTAX NgNodeId
|
|
||||||
MAX-ACCESS not-accessible
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"The 32bit node id of this node. 0 is an illegal value."
|
|
||||||
::= { begemotNgNodeEntry 1 }
|
|
||||||
|
|
||||||
begemotNgNodeStatus OBJECT-TYPE
|
|
||||||
SYNTAX INTEGER { valid(1), invalid(2) }
|
|
||||||
MAX-ACCESS read-only
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"Indicates whether the node exists or not."
|
|
||||||
::= { begemotNgNodeEntry 2 }
|
|
||||||
|
|
||||||
begemotNgNodeName OBJECT-TYPE
|
|
||||||
SYNTAX NgNodeNameOrEmpty
|
|
||||||
MAX-ACCESS read-only
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"Name of the node (if any)."
|
|
||||||
::= { begemotNgNodeEntry 3 }
|
|
||||||
|
|
||||||
begemotNgNodeType OBJECT-TYPE
|
|
||||||
SYNTAX NgTypeName
|
|
||||||
MAX-ACCESS read-only
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"Type name of the node."
|
|
||||||
::= { begemotNgNodeEntry 4 }
|
|
||||||
|
|
||||||
begemotNgNodeHooks OBJECT-TYPE
|
|
||||||
SYNTAX Unsigned32
|
|
||||||
MAX-ACCESS read-only
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"Number of hooks on this node."
|
|
||||||
::= { begemotNgNodeEntry 5 }
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Hook table
|
|
||||||
--
|
|
||||||
begemotNgHookTable OBJECT-TYPE
|
|
||||||
SYNTAX SEQUENCE OF BegemotNgHookEntry
|
|
||||||
MAX-ACCESS not-accessible
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"A table containing information about all netgraph hooks."
|
|
||||||
::= { begemotNgObjects 5 }
|
|
||||||
|
|
||||||
begemotNgHookEntry OBJECT-TYPE
|
|
||||||
SYNTAX BegemotNgHookEntry
|
|
||||||
MAX-ACCESS not-accessible
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"Table entry that describes one netgraph node."
|
|
||||||
INDEX { begemotNgHookNodeId, begemotNgHookHook }
|
|
||||||
::= { begemotNgHookTable 1 }
|
|
||||||
|
|
||||||
BegemotNgHookEntry ::= SEQUENCE {
|
|
||||||
begemotNgHookNodeId NgNodeId,
|
|
||||||
begemotNgHookHook NgHookName,
|
|
||||||
begemotNgHookStatus INTEGER,
|
|
||||||
begemotNgHookPeerNodeId NgNodeId,
|
|
||||||
begemotNgHookPeerHook NgHookName,
|
|
||||||
begemotNgHookPeerType NgTypeName
|
|
||||||
}
|
|
||||||
|
|
||||||
begemotNgHookNodeId OBJECT-TYPE
|
|
||||||
SYNTAX NgNodeId
|
|
||||||
MAX-ACCESS not-accessible
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"The 32bit node id of this node."
|
|
||||||
::= { begemotNgHookEntry 1 }
|
|
||||||
|
|
||||||
begemotNgHookHook OBJECT-TYPE
|
|
||||||
SYNTAX NgHookName
|
|
||||||
MAX-ACCESS read-only
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"Name of the hook."
|
|
||||||
::= { begemotNgHookEntry 2 }
|
|
||||||
|
|
||||||
begemotNgHookStatus OBJECT-TYPE
|
|
||||||
SYNTAX INTEGER { valid(1), invalid(2) }
|
|
||||||
MAX-ACCESS read-only
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"Indicates whether the hook exists or not."
|
|
||||||
::= { begemotNgHookEntry 3 }
|
|
||||||
|
|
||||||
begemotNgHookPeerNodeId OBJECT-TYPE
|
|
||||||
SYNTAX NgNodeId
|
|
||||||
MAX-ACCESS read-only
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"The 32bit node id of the peer node of this hook."
|
|
||||||
::= { begemotNgHookEntry 4 }
|
|
||||||
|
|
||||||
begemotNgHookPeerHook OBJECT-TYPE
|
|
||||||
SYNTAX NgHookName
|
|
||||||
MAX-ACCESS read-only
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"Name of the peer hook."
|
|
||||||
::= { begemotNgHookEntry 5 }
|
|
||||||
|
|
||||||
begemotNgHookPeerType OBJECT-TYPE
|
|
||||||
SYNTAX NgTypeName
|
|
||||||
MAX-ACCESS read-only
|
|
||||||
STATUS current
|
|
||||||
DESCRIPTION
|
|
||||||
"Name of the peer type."
|
|
||||||
::= { begemotNgHookEntry 6 }
|
|
||||||
|
|
||||||
END
|
|
@ -1,19 +0,0 @@
|
|||||||
# $FreeBSD$
|
|
||||||
#
|
|
||||||
# Author: Harti Brandt <harti@freebsd.org>
|
|
||||||
|
|
||||||
CONTRIB=${.CURDIR}/../../../../contrib/bsnmp
|
|
||||||
|
|
||||||
MOD= netgraph
|
|
||||||
SRCS= snmp_netgraph.c
|
|
||||||
XSYM= begemotNg
|
|
||||||
MAN= snmp_netgraph.3
|
|
||||||
|
|
||||||
BMIBS= BEGEMOT-NETGRAPH.txt
|
|
||||||
DEFS= ${MOD}_tree.def
|
|
||||||
INCS= snmp_${MOD}.h
|
|
||||||
|
|
||||||
DPADD= ${LIBNETGRAPH}
|
|
||||||
LDADD= -lnetgraph
|
|
||||||
|
|
||||||
.include <bsd.lib.mk>
|
|
@ -1,78 +0,0 @@
|
|||||||
#
|
|
||||||
# Copyright (c) 2001-2003
|
|
||||||
# Fraunhofer Institute for Open Communication Systems (FhG Fokus).
|
|
||||||
# All rights reserved.
|
|
||||||
#
|
|
||||||
# Author: Harti Brandt <harti@freebsd.org>
|
|
||||||
#
|
|
||||||
# Redistribution of this software and documentation and use in source and
|
|
||||||
# binary forms, with or without modification, are permitted provided that
|
|
||||||
# the following conditions are met:
|
|
||||||
#
|
|
||||||
# 1. Redistributions of source code or documentation must retain the above
|
|
||||||
# copyright notice, this list of conditions and the following disclaimer.
|
|
||||||
# 2. Redistributions in binary form must reproduce the above copyright
|
|
||||||
# notice, this list of conditions and the following disclaimer in the
|
|
||||||
# documentation and/or other materials provided with the distribution.
|
|
||||||
#
|
|
||||||
# THIS SOFTWARE AND DOCUMENTATION IS PROVIDED BY FRAUNHOFER FOKUS
|
|
||||||
# AND ITS CONTRIBUTORS ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
|
|
||||||
# INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
|
||||||
# FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
|
|
||||||
# FRAUNHOFER FOKUS OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
||||||
# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,
|
|
||||||
# OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
|
||||||
# LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
|
||||||
# NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
|
|
||||||
# EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
#
|
|
||||||
# $FreeBSD$
|
|
||||||
#
|
|
||||||
# Definition of the tree implemented by snmp_netgraph.
|
|
||||||
#
|
|
||||||
(1 internet
|
|
||||||
(4 private
|
|
||||||
(1 enterprises
|
|
||||||
(12325 fokus
|
|
||||||
(1 begemot
|
|
||||||
(2 begemotNg
|
|
||||||
(1 begemotNgObjects
|
|
||||||
(1 begemotNgConfig
|
|
||||||
(1 begemotNgControlNodeName OCTETSTRING op_ng_config GET SET)
|
|
||||||
(2 begemotNgResBufSiz INTEGER op_ng_config GET SET)
|
|
||||||
(3 begemotNgTimeout INTEGER op_ng_config GET SET)
|
|
||||||
(4 begemotNgDebugLevel UNSIGNED32 op_ng_config GET SET)
|
|
||||||
)
|
|
||||||
# Change definition of stats array if you change StatsGroup
|
|
||||||
(2 begemotNgStats
|
|
||||||
(1 begemotNgNoMems COUNTER op_ng_stats GET)
|
|
||||||
(2 begemotNgMsgReadErrs COUNTER op_ng_stats GET)
|
|
||||||
(3 begemotNgTooLargeMsgs COUNTER op_ng_stats GET)
|
|
||||||
(4 begemotNgDataReadErrs COUNTER op_ng_stats GET)
|
|
||||||
(5 begemotNgTooLargeDatas COUNTER op_ng_stats GET)
|
|
||||||
)
|
|
||||||
(3 begemotNgTypeTable
|
|
||||||
(1 begemotNgTypeEntry : OCTETSTRING op_ng_type
|
|
||||||
(1 begemotNgTypeName OCTETSTRING)
|
|
||||||
(2 begemotNgTypeStatus INTEGER GET SET)
|
|
||||||
))
|
|
||||||
(4 begemotNgNodeTable
|
|
||||||
(1 begemotNgNodeEntry : INTEGER op_ng_node
|
|
||||||
(1 begemotNgNodeId UNSIGNED32)
|
|
||||||
(2 begemotNgNodeStatus INTEGER GET)
|
|
||||||
(3 begemotNgNodeName OCTETSTRING GET)
|
|
||||||
(4 begemotNgNodeType OCTETSTRING GET)
|
|
||||||
(5 begemotNgNodeHooks UNSIGNED32 GET)
|
|
||||||
))
|
|
||||||
(5 begemotNgHookTable
|
|
||||||
(1 begemotNgHookEntry : UNSIGNED32 OCTETSTRING op_ng_hook
|
|
||||||
(1 begemotNgHookNodeId UNSIGNED32)
|
|
||||||
(2 begemotNgHookHook OCTETSTRING)
|
|
||||||
(3 begemotNgHookStatus INTEGER GET)
|
|
||||||
(4 begemotNgHookPeerNodeId UNSIGNED32 GET)
|
|
||||||
(5 begemotNgHookPeerHook OCTETSTRING GET)
|
|
||||||
(6 begemotNgHookPeerType OCTETSTRING GET)
|
|
||||||
))
|
|
||||||
))
|
|
||||||
)))))
|
|
@ -1,436 +0,0 @@
|
|||||||
.\"
|
|
||||||
.\" Copyright (c) 2001-2003
|
|
||||||
.\" Fraunhofer Institute for Open Communication Systems (FhG Fokus).
|
|
||||||
.\" All rights reserved.
|
|
||||||
.\"
|
|
||||||
.\" Author: Harti Brandt <harti@freebsd.org>
|
|
||||||
.\"
|
|
||||||
.\" Redistribution of this software and documentation and use in source and
|
|
||||||
.\" binary forms, with or without modification, are permitted provided that
|
|
||||||
.\" the following conditions are met:
|
|
||||||
.\"
|
|
||||||
.\" 1. Redistributions of source code or documentation must retain the above
|
|
||||||
.\" copyright notice, this list of conditions and the following disclaimer.
|
|
||||||
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
||||||
.\" notice, this list of conditions and the following disclaimer in the
|
|
||||||
.\" documentation and/or other materials provided with the distribution.
|
|
||||||
.\"
|
|
||||||
.\" THIS SOFTWARE AND DOCUMENTATION IS PROVIDED BY FRAUNHOFER FOKUS
|
|
||||||
.\" AND ITS CONTRIBUTORS ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
|
|
||||||
.\" INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
|
||||||
.\" FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
|
|
||||||
.\" FRAUNHOFER FOKUS OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
||||||
.\" INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
.\" LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,
|
|
||||||
.\" OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
|
||||||
.\" LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
|
||||||
.\" NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
|
|
||||||
.\" EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
.\"
|
|
||||||
.\" $FreeBSD$
|
|
||||||
.\"
|
|
||||||
.Dd November 14, 2003
|
|
||||||
.Dt snmp_netgraph 3
|
|
||||||
.Os
|
|
||||||
.Sh NAME
|
|
||||||
.Nm snmp_netgraph ,
|
|
||||||
.Nm snmp_node ,
|
|
||||||
.Nm snmp_nodename ,
|
|
||||||
.Nm ng_cookie_f ,
|
|
||||||
.Nm ng_hook_f ,
|
|
||||||
.Nm ng_register_cookie ,
|
|
||||||
.Nm ng_unregister_cookie ,
|
|
||||||
.Nm ng_register_hook ,
|
|
||||||
.Nm ng_unregister_hook ,
|
|
||||||
.Nm ng_unregister_module ,
|
|
||||||
.Nm ng_output ,
|
|
||||||
.Nm ng_output_node ,
|
|
||||||
.Nm ng_output_id ,
|
|
||||||
.Nm ng_dialog ,
|
|
||||||
.Nm ng_dialog_node ,
|
|
||||||
.Nm ng_dialog_id ,
|
|
||||||
.Nm ng_send_data ,
|
|
||||||
.Nm ng_mkpeer_id ,
|
|
||||||
.Nm ng_connect_node ,
|
|
||||||
.Nm ng_connect_id ,
|
|
||||||
.Nm ng_connect2_id ,
|
|
||||||
.Nm ng_connect2_tee_id ,
|
|
||||||
.Nm ng_rmhook ,
|
|
||||||
.Nm ng_rmhook_id ,
|
|
||||||
.Nm ng_rmhook_tee_id ,
|
|
||||||
.Nm ng_shutdown_id ,
|
|
||||||
.Nm ng_next_node_id ,
|
|
||||||
.Nm ng_node_id ,
|
|
||||||
.Nm ng_node_id_node ,
|
|
||||||
.Nm ng_node_name ,
|
|
||||||
.Nm ng_node_type ,
|
|
||||||
.Nm ng_peer_hook_id
|
|
||||||
.Nd "netgraph module for snmpd.
|
|
||||||
.Sh LIBRARY
|
|
||||||
.Pq begemotSnmpdModulePath."netgraph" = "/usr/lib/snmp_netgraph.so"
|
|
||||||
.Sh SYNOPSIS
|
|
||||||
.In bsnmp/snmpmod.h
|
|
||||||
.In bsnmp/snmp_netgraph.h
|
|
||||||
.Vt extern ng_ID_t snmp_node ;
|
|
||||||
.Vt extern u_char *snmp_nodename ;
|
|
||||||
.Ft typedef void
|
|
||||||
.Fn ng_cookie_f "const struct ng_mesg *mesg" "const char *path" "ng_ID_t id" "void *uarg"
|
|
||||||
.Ft typedef void
|
|
||||||
.Fn ng_hook_f "const char *hook" "const u_char *mesg" "size_t len" "void *uarg"
|
|
||||||
.Ft void *
|
|
||||||
.Fn ng_register_cookie "const struct lmodule *mod" "u_int32_t cookie" "ng_ID_t id" "ng_cookie_f *func" "void *uarg"
|
|
||||||
.Ft void
|
|
||||||
.Fn ng_unregister_cookie "void *reg"
|
|
||||||
.Ft void *
|
|
||||||
.Fn ng_register_hook "const struct lmodule *mod" "const char *hook" "ng_hook_f *func" "void *uarg"
|
|
||||||
.Ft void
|
|
||||||
.Fn ng_unregister_hook "void *reg"
|
|
||||||
.Ft void
|
|
||||||
.Fn ng_unregister_module "const struct lmodule *mod"
|
|
||||||
.Ft int
|
|
||||||
.Fn ng_output "const char *path" "u_int cookie" "u_int opcode" "const void *arg" "size_t arglen"
|
|
||||||
.Ft int
|
|
||||||
.Fn ng_output_node "const char *node" "u_int cookie" "u_int opcode" "const void *arg" "size_t arglen" "
|
|
||||||
.Ft int
|
|
||||||
.Fn ng_output_id "ng_ID_t node" "u_int cookie" "u_int opcode" "const void *arg" "size_t arglen" "
|
|
||||||
.Ft struct ng_mesg *
|
|
||||||
.Fn ng_dialog "const char *path" "u_int cookie" "u_int opcode" "const void *arg" "size_t arglen"
|
|
||||||
.Ft struct ng_mesg *
|
|
||||||
.Fn ng_dialog_node "const char *node" "u_int cookie" "u_int opcode" "const void *arg" "size_t arglen" "
|
|
||||||
.Ft struct ng_mesg *
|
|
||||||
.Fn ng_dialog_id "ng_ID_t id" "u_int cookie" "u_int opcode" "const void *arg" "size_t arglen" "
|
|
||||||
.Ft int
|
|
||||||
.Fn ng_send_data "const char *hook" "const void *sndbuf" "size_t sndlen"
|
|
||||||
.Ft ng_ID_t
|
|
||||||
.Fn ng_mkpeer_id "ng_ID_t id" "const char *name" "const char *type" "const char *hook" "const char *peerhook"
|
|
||||||
.Ft int
|
|
||||||
.Fn ng_connect_node "const char *node" "const char *ourhook" "const char *peerhook"
|
|
||||||
.Ft int
|
|
||||||
.Fn ng_connect_id "ng_ID_t id" "const char *ourhook" "const char *peerhook"
|
|
||||||
.Ft int
|
|
||||||
.Fn ng_connect2_id "ng_ID_t id" "ng_ID_t peer" "const char *ourhook" "const char *peerhook"
|
|
||||||
.Ft int
|
|
||||||
.Fn ng_connect2_tee_id "ng_ID_t id" "ng_ID_t peer" "const char *ourhook" "const char *peerhook"
|
|
||||||
.Ft int
|
|
||||||
.Fn ng_rmhook "const char *ourhook"
|
|
||||||
.Ft int
|
|
||||||
.Fn ng_rmhook_id "ng_ID_t id" "const char *hook"
|
|
||||||
.Ft int
|
|
||||||
.Fn ng_rmhook_tee_id "ng_ID_t id" "const char *hook"
|
|
||||||
.Ft int
|
|
||||||
.Fn ng_shutdown_id "ng_ID_t id"
|
|
||||||
.Ft ng_ID_t
|
|
||||||
.Fn ng_next_node_id "ng_ID_t node, const char *type, const char *hook);
|
|
||||||
.Ft ng_ID_t
|
|
||||||
.Fn ng_node_id "const char *path"
|
|
||||||
.Ft ng_ID_t
|
|
||||||
.Fn ng_node_id_node "const char *node"
|
|
||||||
.Ft ng_ID_t
|
|
||||||
.Fn ng_node_name "ng_ID_t id, char *name"
|
|
||||||
.Ft ng_ID_t
|
|
||||||
.Fn ng_node_type "ng_ID_t id, char *type"
|
|
||||||
.Ft int
|
|
||||||
.Fn ng_peer_hook_id "ng_ID_t id" "const char *hook" "char *peerhook"
|
|
||||||
.Sh DESCRIPTION
|
|
||||||
The
|
|
||||||
.Nm snmp_netgraph
|
|
||||||
module implements a number of tables and scalars that enable remote access to
|
|
||||||
the netgraph subsystem.
|
|
||||||
It also exports a number of global variables and
|
|
||||||
functions, that allow other modules to easily use the netgraph system.
|
|
||||||
.Pp
|
|
||||||
If upon start up of the module the variable
|
|
||||||
.Va begemotNgControlNodeName
|
|
||||||
is not empty the module opens a netgraph socket and names that socket node.
|
|
||||||
If the variable is empty, the socket is created, as soon as the variable is
|
|
||||||
written with a non-empty name.
|
|
||||||
The socket can be closed by writing an empty
|
|
||||||
string to the variable.
|
|
||||||
The socket itself and its name are available in
|
|
||||||
.Va snmp_node
|
|
||||||
and
|
|
||||||
.Va snmp_nodename .
|
|
||||||
.Ss SENDING AND RECEIVING MESSAGES AND DATA
|
|
||||||
There are three functions for sending control message:
|
|
||||||
.Bl -tag -width ".It Fn ng_output_node"
|
|
||||||
.It Fn ng_output
|
|
||||||
sends a control message along the given
|
|
||||||
.Fa path .
|
|
||||||
.It Fn ng_output_node
|
|
||||||
sends a control message to the node with name
|
|
||||||
.Fa node
|
|
||||||
and
|
|
||||||
.It Fn ng_output_id
|
|
||||||
sends a control message to the node with node id
|
|
||||||
.Fa id .
|
|
||||||
.El
|
|
||||||
.Pp
|
|
||||||
Each of these functions takes the following arguments:
|
|
||||||
.Bl -tag -width ".It Fa cookie"
|
|
||||||
.It Fa cookie
|
|
||||||
is the node specific command cookie,
|
|
||||||
.It Fa opcode
|
|
||||||
is the node specific code for the operation to performa,
|
|
||||||
.It Fa arg
|
|
||||||
is a pointer to the message itself.
|
|
||||||
This message must start with a
|
|
||||||
.Vt struct ng_mesg .
|
|
||||||
.It Fa arglen
|
|
||||||
is the overall length of the message (header plus arguments).
|
|
||||||
.El
|
|
||||||
The functions return the message id that can be used to match incoming responses
|
|
||||||
or -1 if an error occurs.
|
|
||||||
.Pp
|
|
||||||
Another class of functions is used to send a control message and to wait for
|
|
||||||
a matching response.
|
|
||||||
Note, that this operation blocks the daemon, so use it
|
|
||||||
only if you are sure that the response will happen.
|
|
||||||
There is a maximum timeout
|
|
||||||
that is configurable in the MIB variable
|
|
||||||
.Va begemotNgTimeout .
|
|
||||||
Other messages arriving while the functions are waiting for the response are
|
|
||||||
queued and delivered on the next call to the module's idle function.
|
|
||||||
.Bl -tag -width ".It Fn ng_output_node"
|
|
||||||
.It Fn ng_dialog
|
|
||||||
sends a control message along the given
|
|
||||||
.Fa path
|
|
||||||
and waits for a matching response.
|
|
||||||
.It Fn ng_dialog_node
|
|
||||||
sends a control message to the node with name
|
|
||||||
.Fa node
|
|
||||||
and waits for a matching response.
|
|
||||||
.It Fn ng_dialog_id
|
|
||||||
sends a control message to the node with id
|
|
||||||
.Fa id
|
|
||||||
and waits for a matching response.
|
|
||||||
.El
|
|
||||||
.Pp
|
|
||||||
All three functions take the same arguments as the
|
|
||||||
.Fn ng_output*
|
|
||||||
functions.
|
|
||||||
The functions return the reponse message in a buffer allocated by
|
|
||||||
.Xr malloc 3
|
|
||||||
or NULL in case of an error.
|
|
||||||
The maximum size of the response buffer can be
|
|
||||||
configured in the variable
|
|
||||||
.Va begemotNgResBufSiz .
|
|
||||||
.Pp
|
|
||||||
A data message can be send with the function
|
|
||||||
.Fn ng_send_data .
|
|
||||||
This function takes the name of the
|
|
||||||
.Va snmp_node Ns 's
|
|
||||||
hook through which to send the data, a pointer to the message buffer and
|
|
||||||
the size of the message.
|
|
||||||
It returns -1 if an error happens.
|
|
||||||
.Ss ASYNCHRONOUS CONTROL AND DATA MESSAGES
|
|
||||||
A module can register functions to asynchronuosly receive control and data
|
|
||||||
message.
|
|
||||||
.Pp
|
|
||||||
The function
|
|
||||||
.Fn ng_register_cookie
|
|
||||||
registers a control message receive function.
|
|
||||||
If a control message is
|
|
||||||
received, that is not consumed by the dialog functions, the list of registerred
|
|
||||||
control message receive functions is scanned.
|
|
||||||
If the cookie in the received
|
|
||||||
message is the same as the
|
|
||||||
.Fa cookie
|
|
||||||
argument to the
|
|
||||||
.Fn ng_register_cookie
|
|
||||||
call and the
|
|
||||||
.Fa id
|
|
||||||
argument to the
|
|
||||||
.Fn ng_register_cookie
|
|
||||||
call was either 0 or equals the node id which sent the control message, the
|
|
||||||
handler function
|
|
||||||
.Fa func
|
|
||||||
is called with a pointer to the received message, the hook on which the
|
|
||||||
message was received (or NULL if it was received not on a hook), the id
|
|
||||||
of the sender's node and the
|
|
||||||
.Fa uarg
|
|
||||||
argument of the registration call.
|
|
||||||
The handler function should not modify
|
|
||||||
the contents of the message, because more than one function may be registered
|
|
||||||
to the same cookie and node id.
|
|
||||||
.Pp
|
|
||||||
A control message registration can be undone by calling
|
|
||||||
.Fn ng_unregister_cookie
|
|
||||||
with the return value of the registration call.
|
|
||||||
If an error occures while registering,
|
|
||||||
.Fn ng_register_cookie
|
|
||||||
returns NULL.
|
|
||||||
.Pp
|
|
||||||
A module can call
|
|
||||||
.Fn ng_register_hook
|
|
||||||
to register a callback for data messages on one of the
|
|
||||||
.Va snmp_node Ns 's
|
|
||||||
hooks.
|
|
||||||
If a data message is received on that hook, the callback function
|
|
||||||
.Fa func
|
|
||||||
is called with the hook name, a pointer to the data message, the size of
|
|
||||||
the message and the argument
|
|
||||||
.Fa uarg
|
|
||||||
to the registration function.
|
|
||||||
The message should be treated as read-only.
|
|
||||||
A data message registration can be undone by calling
|
|
||||||
.Fn ng_unregister_hook
|
|
||||||
with the return value of the registration call.
|
|
||||||
If an error occures while registering,
|
|
||||||
.Fn ng_register_hook
|
|
||||||
returns NULL.
|
|
||||||
.Pp
|
|
||||||
The function
|
|
||||||
.Fn ng_unregister_module
|
|
||||||
removes all control and data registrations for that module.
|
|
||||||
.Ss FINDING NODES AND NODE CHARACTERISTICS
|
|
||||||
.Pp
|
|
||||||
The function
|
|
||||||
.Fn ng_node_id
|
|
||||||
returns the id of the node addressed by
|
|
||||||
.Fa path
|
|
||||||
or 0 if the node does not exists.
|
|
||||||
.Pp
|
|
||||||
The function
|
|
||||||
.Fn ng_node_id_node
|
|
||||||
returns the id of the node with name
|
|
||||||
.Fa node
|
|
||||||
or 0 if the node does not exist.
|
|
||||||
.Pp
|
|
||||||
The function
|
|
||||||
.Fn ng_node_node
|
|
||||||
retrieves the name of the node with id
|
|
||||||
.Fa id
|
|
||||||
and writes it to the buffer pointed to by
|
|
||||||
.Fa name .
|
|
||||||
This buffer should be at least
|
|
||||||
.Li NG_NODESIZ
|
|
||||||
bytes long.
|
|
||||||
The function returns the node id or 0 if the
|
|
||||||
node is not found
|
|
||||||
.Pp
|
|
||||||
The function
|
|
||||||
.Fn ng_node_type
|
|
||||||
retrieves the name of the node with id
|
|
||||||
.Fa id
|
|
||||||
and writes it to the buffer pointed to by
|
|
||||||
.Fa type .
|
|
||||||
This buffer should be at least
|
|
||||||
.Li NG_TYPESIZ
|
|
||||||
bytes long.
|
|
||||||
The function returns the node id or 0 if the
|
|
||||||
node is not found.
|
|
||||||
.Pp
|
|
||||||
The function
|
|
||||||
.Fn ng_peer_hook_id
|
|
||||||
writes the name of the peer hook of the hook
|
|
||||||
.Fa hook
|
|
||||||
on the node with
|
|
||||||
.Fa id
|
|
||||||
to the buffer pointed to by
|
|
||||||
.Fa peer_hook .
|
|
||||||
The buffer should be at least
|
|
||||||
.Li NG_HOOKSIZ
|
|
||||||
bytes long.
|
|
||||||
The function returns 0 if the node and the hook is found, -1
|
|
||||||
otherwise.
|
|
||||||
The function skips intermediate tee nodes (see
|
|
||||||
.Xr ng_tee 4 ) .
|
|
||||||
.Pp
|
|
||||||
The function
|
|
||||||
.Fn ng_next_node_id
|
|
||||||
returns the node id of the peer node that is on the other side of hook
|
|
||||||
.Fa hook
|
|
||||||
of node
|
|
||||||
.Fa id .
|
|
||||||
If
|
|
||||||
.Fa type
|
|
||||||
is not NULL, the function checks, that the peer node's type is
|
|
||||||
.Fa type .
|
|
||||||
The function skips intermediate tee nodes (see
|
|
||||||
.Xr ng_tee 4 ) .
|
|
||||||
It returns the node id of the peer node or 0 if an error occurres or the
|
|
||||||
types do not match.
|
|
||||||
.Ss CHANGING THE GRAPH
|
|
||||||
A number of functions can be used to create or destroy nodes and hooks.
|
|
||||||
.Pp
|
|
||||||
The function
|
|
||||||
.Fn ng_mkpeer_id
|
|
||||||
creates a new node of type
|
|
||||||
.Fa type
|
|
||||||
whose hook
|
|
||||||
.Fa peerhook
|
|
||||||
will be connected to
|
|
||||||
.Fa hook
|
|
||||||
of node
|
|
||||||
.Fa id .
|
|
||||||
If
|
|
||||||
.Fa name
|
|
||||||
is not NULL the new node is named with this name.
|
|
||||||
The function returns
|
|
||||||
The node id of the new node or 0 if an error happens.
|
|
||||||
.Pp
|
|
||||||
The functions
|
|
||||||
.Fn ng_connect_node
|
|
||||||
and
|
|
||||||
.Fn ng_connect_id
|
|
||||||
make a new hook connecting
|
|
||||||
.Fa ourhook
|
|
||||||
of the modules socket node
|
|
||||||
.Va snmp_node
|
|
||||||
to
|
|
||||||
.Fa peerhook
|
|
||||||
of the node identified by id
|
|
||||||
.Fa id
|
|
||||||
or name
|
|
||||||
.Fa node .
|
|
||||||
The functions return 0 on success or -1 otherwise.
|
|
||||||
.Pp
|
|
||||||
The function
|
|
||||||
.Fn ng_connect2_id
|
|
||||||
connects hook
|
|
||||||
.Fa ourhook
|
|
||||||
of the node with id
|
|
||||||
.Fa id
|
|
||||||
to hook
|
|
||||||
.Fa peerhook
|
|
||||||
of the node with id
|
|
||||||
.Fa peer .
|
|
||||||
The functions return 0 on success or -1 otherwise.
|
|
||||||
The function
|
|
||||||
.Fn ng_connect2_tee_id does the same as
|
|
||||||
.Fn ng_connect2_id
|
|
||||||
except, that it puts an unnamed tee node between the two nodes.
|
|
||||||
.Pp
|
|
||||||
The function
|
|
||||||
.Fn ng_rmhook
|
|
||||||
removes hook
|
|
||||||
.Fa hook
|
|
||||||
on the module's
|
|
||||||
.Va snmp_node .
|
|
||||||
The function
|
|
||||||
.Fn ng_rmhook_id
|
|
||||||
removes hook
|
|
||||||
.Fa hook
|
|
||||||
on the node with id
|
|
||||||
.Fa id .
|
|
||||||
The function
|
|
||||||
.Fn ng_rmhook_tee_id
|
|
||||||
additionally shuts down all tee nodes between the node and the first non-tee
|
|
||||||
peer.
|
|
||||||
.Pp
|
|
||||||
The function
|
|
||||||
.Fn ng_shutdown_id
|
|
||||||
destroys the given node.
|
|
||||||
.Sh FILES
|
|
||||||
.Bl -tag -width "XXXXXXXXX"
|
|
||||||
.It Pa /usr/share/bsnmp/defs/netgraph_tree.def
|
|
||||||
The description of the MIB tree implemented by
|
|
||||||
.Nm .
|
|
||||||
.It Pa /usr/share/bsnmp/mibs/BEGEMOT-NETGRAPH.txt
|
|
||||||
This is the MIB that is implemented by this module.
|
|
||||||
.El
|
|
||||||
.Sh SEE ALSO
|
|
||||||
.Xr gensnmptree 1 ,
|
|
||||||
.Xr snmpmod 3
|
|
||||||
.Sh AUTHORS
|
|
||||||
.An Hartmut Brandt Aq harti@freebsd.org
|
|
File diff suppressed because it is too large
Load Diff
@ -1,91 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (c) 2001-2003
|
|
||||||
* Fraunhofer Institute for Open Communication Systems (FhG Fokus).
|
|
||||||
* All rights reserved.
|
|
||||||
*
|
|
||||||
* Author: Harti Brandt <harti@freebsd.org>
|
|
||||||
*
|
|
||||||
* Redistribution of this software and documentation and use in source and
|
|
||||||
* binary forms, with or without modification, are permitted provided that
|
|
||||||
* the following conditions are met:
|
|
||||||
*
|
|
||||||
* 1. Redistributions of source code or documentation must retain the above
|
|
||||||
* copyright notice, this list of conditions and the following disclaimer.
|
|
||||||
* 2. Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE AND DOCUMENTATION IS PROVIDED BY FRAUNHOFER FOKUS
|
|
||||||
* AND ITS CONTRIBUTORS ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
|
|
||||||
* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
|
||||||
* FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
|
|
||||||
* FRAUNHOFER FOKUS OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
||||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,
|
|
||||||
* OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
|
||||||
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
|
||||||
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
|
|
||||||
* EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
*
|
|
||||||
* $FreeBSD$
|
|
||||||
*
|
|
||||||
* Netgraph interface for SNMPd. Exported stuff.
|
|
||||||
*/
|
|
||||||
#ifndef SNMP_NETGRAPH_H_
|
|
||||||
#define SNMP_NETGRAPH_H_
|
|
||||||
|
|
||||||
#include <netgraph/ng_message.h>
|
|
||||||
|
|
||||||
extern ng_ID_t snmp_node;
|
|
||||||
extern u_char *snmp_nodename;
|
|
||||||
|
|
||||||
typedef void ng_cookie_f(const struct ng_mesg *, const char *, ng_ID_t, void *);
|
|
||||||
typedef void ng_hook_f(const char *, const u_char *, size_t, void *);
|
|
||||||
|
|
||||||
void *ng_register_cookie(const struct lmodule *, u_int32_t cookie,
|
|
||||||
ng_ID_t, ng_cookie_f *, void *);
|
|
||||||
void ng_unregister_cookie(void *reg);
|
|
||||||
|
|
||||||
void *ng_register_hook(const struct lmodule *, const char *,
|
|
||||||
ng_hook_f *, void *);
|
|
||||||
void ng_unregister_hook(void *reg);
|
|
||||||
|
|
||||||
void ng_unregister_module(const struct lmodule *);
|
|
||||||
|
|
||||||
int ng_output(const char *path, u_int cookie, u_int opcode,
|
|
||||||
const void *arg, size_t arglen);
|
|
||||||
int ng_output_node(const char *node, u_int cookie, u_int opcode,
|
|
||||||
const void *arg, size_t arglen);
|
|
||||||
int ng_output_id(ng_ID_t node, u_int cookie, u_int opcode,
|
|
||||||
const void *arg, size_t arglen);
|
|
||||||
|
|
||||||
struct ng_mesg *ng_dialog(const char *path, u_int cookie, u_int opcode,
|
|
||||||
const void *arg, size_t arglen);
|
|
||||||
struct ng_mesg *ng_dialog_node(const char *node, u_int cookie, u_int opcode,
|
|
||||||
const void *arg, size_t arglen);
|
|
||||||
struct ng_mesg *ng_dialog_id(ng_ID_t id, u_int cookie, u_int opcode,
|
|
||||||
const void *arg, size_t arglen);
|
|
||||||
|
|
||||||
int ng_send_data(const char *hook, const void *sndbuf, size_t sndlen);
|
|
||||||
|
|
||||||
ng_ID_t ng_mkpeer_id(ng_ID_t, const char *name, const char *type,
|
|
||||||
const char *hook, const char *peerhook);
|
|
||||||
int ng_connect_node(const char *node, const char *ourhook, const char *peerhook);
|
|
||||||
int ng_connect_id(ng_ID_t id, const char *ourhook, const char *peerhook);
|
|
||||||
int ng_connect2_id(ng_ID_t id, ng_ID_t peer, const char *ourhook,
|
|
||||||
const char *peerhook);
|
|
||||||
int ng_connect2_tee_id(ng_ID_t id, ng_ID_t peer, const char *ourhook,
|
|
||||||
const char *peerhook);
|
|
||||||
int ng_rmhook(const char *ourhook);
|
|
||||||
int ng_rmhook_id(ng_ID_t, const char *);
|
|
||||||
int ng_rmhook_tee_id(ng_ID_t, const char *);
|
|
||||||
int ng_shutdown_id(ng_ID_t);
|
|
||||||
|
|
||||||
ng_ID_t ng_next_node_id(ng_ID_t node, const char *type, const char *hook);
|
|
||||||
ng_ID_t ng_node_id(const char *path);
|
|
||||||
ng_ID_t ng_node_id_node(const char *node);
|
|
||||||
ng_ID_t ng_node_name(ng_ID_t, char *);
|
|
||||||
ng_ID_t ng_node_type(ng_ID_t, char *);
|
|
||||||
int ng_peer_hook_id(ng_ID_t, const char *, char *);
|
|
||||||
|
|
||||||
#endif
|
|
@ -1,6 +1,7 @@
|
|||||||
# $FreeBSD$
|
# $FreeBSD$
|
||||||
|
|
||||||
SUBDIR= gensnmptree \
|
SUBDIR= gensnmptree \
|
||||||
bsnmpd
|
bsnmpd \
|
||||||
|
modules
|
||||||
|
|
||||||
.include <bsd.subdir.mk>
|
.include <bsd.subdir.mk>
|
||||||
|
@ -1,5 +1,9 @@
|
|||||||
# $FreeBSD$
|
# $FreeBSD$
|
||||||
|
|
||||||
|
SHLIB_MAJOR= 2
|
||||||
|
WARNS?= 6
|
||||||
|
INCSDIR= ${INCLUDEDIR}/bsnmp
|
||||||
|
|
||||||
SHLIB_NAME= snmp_${MOD}.so.${SHLIB_MAJOR}
|
SHLIB_NAME= snmp_${MOD}.so.${SHLIB_MAJOR}
|
||||||
SRCS+= ${MOD}_oid.h ${MOD}_tree.c ${MOD}_tree.h
|
SRCS+= ${MOD}_oid.h ${MOD}_tree.c ${MOD}_tree.h
|
||||||
CLEANFILES+= ${MOD}_oid.h ${MOD}_tree.c ${MOD}_tree.h
|
CLEANFILES+= ${MOD}_oid.h ${MOD}_tree.c ${MOD}_tree.h
|
||||||
@ -25,5 +29,3 @@ BMIBSDIR= ${SHAREDIR}/snmp/mibs
|
|||||||
MANFILTER= sed -e 's%@MODPATH@%${LIBDIR}/%g' \
|
MANFILTER= sed -e 's%@MODPATH@%${LIBDIR}/%g' \
|
||||||
-e 's%@DEFPATH@%${DEFSDIR}/%g' \
|
-e 's%@DEFPATH@%${DEFSDIR}/%g' \
|
||||||
-e 's%@MIBSPATH@%${BMIBSDIR}/%g'
|
-e 's%@MIBSPATH@%${BMIBSDIR}/%g'
|
||||||
|
|
||||||
.include "../Makefile.inc"
|
|
||||||
|
Loading…
Reference in New Issue
Block a user