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
@ -1,5 +1,5 @@
|
||||
# $FreeBSD$
|
||||
|
||||
SUBDIR= libbsnmp modules
|
||||
SUBDIR= libbsnmp
|
||||
|
||||
.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$
|
||||
|
||||
SUBDIR= gensnmptree \
|
||||
bsnmpd
|
||||
SUBDIR= gensnmptree \
|
||||
bsnmpd \
|
||||
modules
|
||||
|
||||
.include <bsd.subdir.mk>
|
||||
|
@ -1,5 +1,9 @@
|
||||
# $FreeBSD$
|
||||
|
||||
SHLIB_MAJOR= 2
|
||||
WARNS?= 6
|
||||
INCSDIR= ${INCLUDEDIR}/bsnmp
|
||||
|
||||
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
|
||||
@ -25,5 +29,3 @@ BMIBSDIR= ${SHAREDIR}/snmp/mibs
|
||||
MANFILTER= sed -e 's%@MODPATH@%${LIBDIR}/%g' \
|
||||
-e 's%@DEFPATH@%${DEFSDIR}/%g' \
|
||||
-e 's%@MIBSPATH@%${BMIBSDIR}/%g'
|
||||
|
||||
.include "../Makefile.inc"
|
||||
|
Loading…
Reference in New Issue
Block a user