|
Packit |
fcad23 |
/*
|
|
Packit |
fcad23 |
* DisMan Event MIB:
|
|
Packit |
fcad23 |
* Implementation of the mteTriggerTable MIB interface
|
|
Packit |
fcad23 |
* See 'mteTrigger.c' for active behaviour of this table.
|
|
Packit |
fcad23 |
*
|
|
Packit |
fcad23 |
* (based on mib2c.table_data.conf output)
|
|
Packit |
fcad23 |
*/
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
#include <net-snmp/net-snmp-config.h>
|
|
Packit |
fcad23 |
#include <net-snmp/net-snmp-features.h>
|
|
Packit |
fcad23 |
#include <net-snmp/net-snmp-features.h>
|
|
Packit |
fcad23 |
#include <net-snmp/net-snmp-includes.h>
|
|
Packit |
fcad23 |
#include <net-snmp/agent/net-snmp-agent-includes.h>
|
|
Packit |
fcad23 |
#include "utilities/iquery.h"
|
|
Packit |
fcad23 |
#include "disman/event/mteTrigger.h"
|
|
Packit |
fcad23 |
#include "disman/event/mteTriggerTable.h"
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
netsnmp_feature_require(iquery)
|
|
Packit |
fcad23 |
netsnmp_feature_require(table_tdata)
|
|
Packit |
fcad23 |
#ifndef NETSNMP_NO_WRITE_SUPPORT
|
|
Packit |
fcad23 |
netsnmp_feature_require(iquery_pdu_session)
|
|
Packit |
fcad23 |
netsnmp_feature_require(check_vb_type_and_max_size)
|
|
Packit |
fcad23 |
netsnmp_feature_require(check_vb_oid)
|
|
Packit |
fcad23 |
netsnmp_feature_require(check_vb_uint)
|
|
Packit |
fcad23 |
netsnmp_feature_require(mtetrigger_removeentry)
|
|
Packit |
fcad23 |
netsnmp_feature_require(check_vb_truthvalue)
|
|
Packit |
fcad23 |
netsnmp_feature_require(table_tdata_insert_row)
|
|
Packit |
fcad23 |
#endif /* NETSNMP_NO_WRITE_SUPPORT */
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
static netsnmp_table_registration_info *table_info;
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
/** Initializes the mteTriggerTable module */
|
|
Packit |
fcad23 |
void
|
|
Packit |
fcad23 |
init_mteTriggerTable(void)
|
|
Packit |
fcad23 |
{
|
|
Packit |
fcad23 |
static oid mteTriggerTable_oid[] = { 1, 3, 6, 1, 2, 1, 88, 1, 2, 2 };
|
|
Packit |
fcad23 |
size_t mteTriggerTable_oid_len = OID_LENGTH(mteTriggerTable_oid);
|
|
Packit |
fcad23 |
netsnmp_handler_registration *reg;
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
/*
|
|
Packit |
fcad23 |
* Ensure the (combined) table container is available...
|
|
Packit |
fcad23 |
*/
|
|
Packit |
fcad23 |
init_trigger_table_data();
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
/*
|
|
Packit |
fcad23 |
* ... then set up the MIB interface to the mteTriggerTable slice
|
|
Packit |
fcad23 |
*/
|
|
Packit |
fcad23 |
#ifndef NETSNMP_NO_WRITE_SUPPORT
|
|
Packit |
fcad23 |
reg = netsnmp_create_handler_registration("mteTriggerTable",
|
|
Packit |
fcad23 |
mteTriggerTable_handler,
|
|
Packit |
fcad23 |
mteTriggerTable_oid,
|
|
Packit |
fcad23 |
mteTriggerTable_oid_len,
|
|
Packit |
fcad23 |
HANDLER_CAN_RWRITE);
|
|
Packit |
fcad23 |
#else /* !NETSNMP_NO_WRITE_SUPPORT */
|
|
Packit |
fcad23 |
reg = netsnmp_create_handler_registration("mteTriggerTable",
|
|
Packit |
fcad23 |
mteTriggerTable_handler,
|
|
Packit |
fcad23 |
mteTriggerTable_oid,
|
|
Packit |
fcad23 |
mteTriggerTable_oid_len,
|
|
Packit |
fcad23 |
HANDLER_CAN_RONLY);
|
|
Packit |
fcad23 |
#endif /* !NETSNMP_NO_WRITE_SUPPORT */
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
table_info = SNMP_MALLOC_TYPEDEF(netsnmp_table_registration_info);
|
|
Packit |
fcad23 |
netsnmp_table_helper_add_indexes(table_info,
|
|
Packit |
fcad23 |
ASN_OCTET_STR, /* index: mteOwner */
|
|
Packit |
fcad23 |
/* index: mteTriggerName */
|
|
Packit |
fcad23 |
ASN_PRIV_IMPLIED_OCTET_STR,
|
|
Packit |
fcad23 |
0);
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
table_info->min_column = COLUMN_MTETRIGGERCOMMENT;
|
|
Packit |
fcad23 |
table_info->max_column = COLUMN_MTETRIGGERENTRYSTATUS;
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
/* Register this using the (common) trigger_table_data container */
|
|
Packit |
fcad23 |
netsnmp_tdata_register(reg, trigger_table_data, table_info);
|
|
Packit |
fcad23 |
DEBUGMSGTL(("disman:event:init", "Trigger Table\n"));
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
void
|
|
Packit |
fcad23 |
shutdown_mteTriggerTable(void)
|
|
Packit |
fcad23 |
{
|
|
Packit |
fcad23 |
if (table_info) {
|
|
Packit |
fcad23 |
netsnmp_table_registration_info_free(table_info);
|
|
Packit |
fcad23 |
table_info = NULL;
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
/** handles requests for the mteTriggerTable table */
|
|
Packit |
fcad23 |
int
|
|
Packit |
fcad23 |
mteTriggerTable_handler(netsnmp_mib_handler *handler,
|
|
Packit |
fcad23 |
netsnmp_handler_registration *reginfo,
|
|
Packit |
fcad23 |
netsnmp_agent_request_info *reqinfo,
|
|
Packit |
fcad23 |
netsnmp_request_info *requests)
|
|
Packit |
fcad23 |
{
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
netsnmp_request_info *request;
|
|
Packit |
fcad23 |
netsnmp_table_request_info *tinfo;
|
|
Packit |
fcad23 |
netsnmp_tdata_row *row;
|
|
Packit |
fcad23 |
struct mteTrigger *entry;
|
|
Packit |
fcad23 |
char mteOwner[MTE_STR1_LEN+1];
|
|
Packit |
fcad23 |
char mteTName[MTE_STR1_LEN+1];
|
|
Packit |
fcad23 |
long ret;
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
DEBUGMSGTL(("disman:event:mib", "Trigger Table handler (%d)\n",
|
|
Packit |
fcad23 |
reqinfo->mode));
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
switch (reqinfo->mode) {
|
|
Packit |
fcad23 |
/*
|
|
Packit |
fcad23 |
* Read-support (also covers GetNext requests)
|
|
Packit |
fcad23 |
*/
|
|
Packit |
fcad23 |
case MODE_GET:
|
|
Packit |
fcad23 |
for (request = requests; request; request = request->next) {
|
|
Packit |
fcad23 |
if (request->processed)
|
|
Packit |
fcad23 |
continue;
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
entry = (struct mteTrigger *) netsnmp_tdata_extract_entry(request);
|
|
Packit |
fcad23 |
tinfo = netsnmp_extract_table_info(request);
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
switch (tinfo->colnum) {
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERCOMMENT:
|
|
Packit |
fcad23 |
snmp_set_var_typed_value(request->requestvb, ASN_OCTET_STR,
|
|
Packit |
fcad23 |
entry->mteTriggerComment,
|
|
Packit |
fcad23 |
strlen(entry->mteTriggerComment));
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERTEST:
|
|
Packit |
fcad23 |
snmp_set_var_typed_value(request->requestvb, ASN_OCTET_STR,
|
|
Packit |
fcad23 |
&entry->mteTriggerTest, 1);
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERSAMPLETYPE:
|
|
Packit |
fcad23 |
ret = (entry->flags & MTE_TRIGGER_FLAG_DELTA ) ?
|
|
Packit |
fcad23 |
MTE_SAMPLE_DELTA : MTE_SAMPLE_ABSOLUTE;
|
|
Packit |
fcad23 |
snmp_set_var_typed_integer(request->requestvb, ASN_INTEGER, ret);
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERVALUEID:
|
|
Packit |
fcad23 |
snmp_set_var_typed_value(request->requestvb, ASN_OBJECT_ID,
|
|
Packit |
fcad23 |
(u_char *) entry->mteTriggerValueID,
|
|
Packit |
fcad23 |
entry->mteTriggerValueID_len*sizeof(oid));
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERVALUEIDWILDCARD:
|
|
Packit |
fcad23 |
ret = (entry->flags & MTE_TRIGGER_FLAG_VWILD ) ?
|
|
Packit |
fcad23 |
TV_TRUE : TV_FALSE;
|
|
Packit |
fcad23 |
snmp_set_var_typed_integer(request->requestvb, ASN_INTEGER, ret);
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERTARGETTAG:
|
|
Packit |
fcad23 |
snmp_set_var_typed_value(request->requestvb, ASN_OCTET_STR,
|
|
Packit |
fcad23 |
entry->mteTriggerTarget,
|
|
Packit |
fcad23 |
strlen(entry->mteTriggerTarget));
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERCONTEXTNAME:
|
|
Packit |
fcad23 |
snmp_set_var_typed_value(request->requestvb, ASN_OCTET_STR,
|
|
Packit |
fcad23 |
entry->mteTriggerContext,
|
|
Packit |
fcad23 |
strlen(entry->mteTriggerContext));
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERCONTEXTNAMEWILDCARD:
|
|
Packit |
fcad23 |
ret = (entry->flags & MTE_TRIGGER_FLAG_CWILD ) ?
|
|
Packit |
fcad23 |
TV_TRUE : TV_FALSE;
|
|
Packit |
fcad23 |
snmp_set_var_typed_integer(request->requestvb, ASN_INTEGER, ret);
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERFREQUENCY:
|
|
Packit |
fcad23 |
snmp_set_var_typed_integer(request->requestvb, ASN_UNSIGNED,
|
|
Packit |
fcad23 |
entry->mteTriggerFrequency);
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGEROBJECTSOWNER:
|
|
Packit |
fcad23 |
snmp_set_var_typed_value(request->requestvb, ASN_OCTET_STR,
|
|
Packit |
fcad23 |
entry->mteTriggerOOwner,
|
|
Packit |
fcad23 |
strlen(entry->mteTriggerOOwner));
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGEROBJECTS:
|
|
Packit |
fcad23 |
snmp_set_var_typed_value(request->requestvb, ASN_OCTET_STR,
|
|
Packit |
fcad23 |
entry->mteTriggerObjects,
|
|
Packit |
fcad23 |
strlen(entry->mteTriggerObjects));
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERENABLED:
|
|
Packit |
fcad23 |
ret = (entry->flags & MTE_TRIGGER_FLAG_ENABLED ) ?
|
|
Packit |
fcad23 |
TV_TRUE : TV_FALSE;
|
|
Packit |
fcad23 |
snmp_set_var_typed_integer(request->requestvb, ASN_INTEGER, ret);
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERENTRYSTATUS:
|
|
Packit |
fcad23 |
ret = (entry->flags & MTE_TRIGGER_FLAG_ACTIVE ) ?
|
|
Packit |
fcad23 |
RS_ACTIVE : RS_NOTINSERVICE;
|
|
Packit |
fcad23 |
snmp_set_var_typed_integer(request->requestvb, ASN_INTEGER, ret);
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
#ifndef NETSNMP_NO_WRITE_SUPPORT
|
|
Packit |
fcad23 |
/*
|
|
Packit |
fcad23 |
* Write-support
|
|
Packit |
fcad23 |
*/
|
|
Packit |
fcad23 |
case MODE_SET_RESERVE1:
|
|
Packit |
fcad23 |
for (request = requests; request; request = request->next) {
|
|
Packit |
fcad23 |
if (request->processed)
|
|
Packit |
fcad23 |
continue;
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
entry = (struct mteTrigger *) netsnmp_tdata_extract_entry(request);
|
|
Packit |
fcad23 |
tinfo = netsnmp_extract_table_info(request);
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
switch (tinfo->colnum) {
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERCOMMENT:
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERTARGETTAG:
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERCONTEXTNAME:
|
|
Packit |
fcad23 |
ret = netsnmp_check_vb_type_and_max_size(
|
|
Packit |
fcad23 |
request->requestvb, ASN_OCTET_STR, MTE_STR2_LEN);
|
|
Packit |
fcad23 |
if (ret != SNMP_ERR_NOERROR) {
|
|
Packit |
fcad23 |
netsnmp_set_request_error(reqinfo, request, ret);
|
|
Packit |
fcad23 |
return SNMP_ERR_NOERROR;
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERTEST:
|
|
Packit |
fcad23 |
ret = netsnmp_check_vb_type_and_size(
|
|
Packit |
fcad23 |
request->requestvb, ASN_OCTET_STR, 1);
|
|
Packit |
fcad23 |
if (ret != SNMP_ERR_NOERROR) {
|
|
Packit |
fcad23 |
netsnmp_set_request_error(reqinfo, request, ret);
|
|
Packit |
fcad23 |
return SNMP_ERR_NOERROR;
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERSAMPLETYPE:
|
|
Packit |
fcad23 |
ret = netsnmp_check_vb_int_range(request->requestvb,
|
|
Packit |
fcad23 |
MTE_SAMPLE_ABSOLUTE, MTE_SAMPLE_DELTA);
|
|
Packit |
fcad23 |
if (ret != SNMP_ERR_NOERROR) {
|
|
Packit |
fcad23 |
netsnmp_set_request_error(reqinfo, request, ret);
|
|
Packit |
fcad23 |
return SNMP_ERR_NOERROR;
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERVALUEID:
|
|
Packit |
fcad23 |
ret = netsnmp_check_vb_oid(request->requestvb);
|
|
Packit |
fcad23 |
if (ret != SNMP_ERR_NOERROR) {
|
|
Packit |
fcad23 |
netsnmp_set_request_error(reqinfo, request, ret);
|
|
Packit |
fcad23 |
return SNMP_ERR_NOERROR;
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERVALUEIDWILDCARD:
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERCONTEXTNAMEWILDCARD:
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERENABLED:
|
|
Packit |
fcad23 |
ret = netsnmp_check_vb_truthvalue(request->requestvb);
|
|
Packit |
fcad23 |
if (ret != SNMP_ERR_NOERROR) {
|
|
Packit |
fcad23 |
netsnmp_set_request_error(reqinfo, request, ret);
|
|
Packit |
fcad23 |
return SNMP_ERR_NOERROR;
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERFREQUENCY:
|
|
Packit |
fcad23 |
ret = netsnmp_check_vb_uint(request->requestvb);
|
|
Packit |
fcad23 |
if (ret != SNMP_ERR_NOERROR) {
|
|
Packit |
fcad23 |
netsnmp_set_request_error(reqinfo, request, ret);
|
|
Packit |
fcad23 |
return SNMP_ERR_NOERROR;
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGEROBJECTSOWNER:
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGEROBJECTS:
|
|
Packit |
fcad23 |
ret = netsnmp_check_vb_type_and_max_size(
|
|
Packit |
fcad23 |
request->requestvb, ASN_OCTET_STR, MTE_STR1_LEN);
|
|
Packit |
fcad23 |
if (ret != SNMP_ERR_NOERROR) {
|
|
Packit |
fcad23 |
netsnmp_set_request_error(reqinfo, request, ret);
|
|
Packit |
fcad23 |
return SNMP_ERR_NOERROR;
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERENTRYSTATUS:
|
|
Packit |
fcad23 |
ret = netsnmp_check_vb_rowstatus(request->requestvb,
|
|
Packit |
fcad23 |
(entry ? RS_ACTIVE : RS_NONEXISTENT));
|
|
Packit |
fcad23 |
if (ret != SNMP_ERR_NOERROR) {
|
|
Packit |
fcad23 |
netsnmp_set_request_error(reqinfo, request, ret);
|
|
Packit |
fcad23 |
return SNMP_ERR_NOERROR;
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
default:
|
|
Packit |
fcad23 |
netsnmp_set_request_error(reqinfo, request,
|
|
Packit |
fcad23 |
SNMP_ERR_NOTWRITABLE);
|
|
Packit |
fcad23 |
return SNMP_ERR_NOERROR;
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
/*
|
|
Packit |
fcad23 |
* Once a row has been made active, it cannot be
|
|
Packit |
fcad23 |
* modified except to delete it. There's no good
|
|
Packit |
fcad23 |
* reason for this, but that's what the MIB says.
|
|
Packit |
fcad23 |
*
|
|
Packit |
fcad23 |
* The published version of the Event MIB even forbids
|
|
Packit |
fcad23 |
* enabling (or disabling) an active row, which
|
|
Packit |
fcad23 |
* would make this object completely pointless!
|
|
Packit |
fcad23 |
* Fortunately this ludicrous decision has since been corrected.
|
|
Packit |
fcad23 |
*/
|
|
Packit |
fcad23 |
if (entry &&
|
|
Packit |
fcad23 |
entry->flags & MTE_TRIGGER_FLAG_ACTIVE ) {
|
|
Packit |
fcad23 |
/* check for the acceptable assignments */
|
|
Packit |
fcad23 |
if ((tinfo->colnum == COLUMN_MTETRIGGERENABLED) ||
|
|
Packit |
fcad23 |
(tinfo->colnum == COLUMN_MTETRIGGERENTRYSTATUS &&
|
|
Packit |
fcad23 |
*request->requestvb->val.integer != RS_NOTINSERVICE))
|
|
Packit |
fcad23 |
continue;
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
/* Otherwise, reject this request */
|
|
Packit |
fcad23 |
netsnmp_set_request_error(reqinfo, request,
|
|
Packit |
fcad23 |
SNMP_ERR_INCONSISTENTVALUE);
|
|
Packit |
fcad23 |
return SNMP_ERR_NOERROR;
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
case MODE_SET_RESERVE2:
|
|
Packit |
fcad23 |
for (request = requests; request; request = request->next) {
|
|
Packit |
fcad23 |
if (request->processed)
|
|
Packit |
fcad23 |
continue;
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
tinfo = netsnmp_extract_table_info(request);
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
switch (tinfo->colnum) {
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERENTRYSTATUS:
|
|
Packit |
fcad23 |
switch (*request->requestvb->val.integer) {
|
|
Packit |
fcad23 |
case RS_CREATEANDGO:
|
|
Packit |
fcad23 |
case RS_CREATEANDWAIT:
|
|
Packit |
fcad23 |
/*
|
|
Packit |
fcad23 |
* Create an (empty) new row structure
|
|
Packit |
fcad23 |
*/
|
|
Packit |
fcad23 |
memset(mteOwner, 0, sizeof(mteOwner));
|
|
Packit |
fcad23 |
memcpy(mteOwner, tinfo->indexes->val.string,
|
|
Packit |
fcad23 |
tinfo->indexes->val_len);
|
|
Packit |
fcad23 |
memset(mteTName, 0, sizeof(mteTName));
|
|
Packit |
fcad23 |
memcpy(mteTName,
|
|
Packit |
fcad23 |
tinfo->indexes->next_variable->val.string,
|
|
Packit |
fcad23 |
tinfo->indexes->next_variable->val_len);
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
row = mteTrigger_createEntry(mteOwner, mteTName, 0);
|
|
Packit |
fcad23 |
if (!row) {
|
|
Packit |
fcad23 |
netsnmp_set_request_error(reqinfo, request,
|
|
Packit |
fcad23 |
SNMP_ERR_RESOURCEUNAVAILABLE);
|
|
Packit |
fcad23 |
return SNMP_ERR_NOERROR;
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
netsnmp_insert_tdata_row( request, row );
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
case MODE_SET_FREE:
|
|
Packit |
fcad23 |
for (request = requests; request; request = request->next) {
|
|
Packit |
fcad23 |
if (request->processed)
|
|
Packit |
fcad23 |
continue;
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
tinfo = netsnmp_extract_table_info(request);
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
switch (tinfo->colnum) {
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERENTRYSTATUS:
|
|
Packit |
fcad23 |
switch (*request->requestvb->val.integer) {
|
|
Packit |
fcad23 |
case RS_CREATEANDGO:
|
|
Packit |
fcad23 |
case RS_CREATEANDWAIT:
|
|
Packit |
fcad23 |
/*
|
|
Packit |
fcad23 |
* Tidy up after a failed row creation request
|
|
Packit |
fcad23 |
*/
|
|
Packit |
fcad23 |
entry = (struct mteTrigger *)
|
|
Packit |
fcad23 |
netsnmp_tdata_extract_entry(request);
|
|
Packit |
fcad23 |
if (entry &&
|
|
Packit |
fcad23 |
!(entry->flags & MTE_TRIGGER_FLAG_VALID)) {
|
|
Packit |
fcad23 |
row = (netsnmp_tdata_row *)
|
|
Packit |
fcad23 |
netsnmp_tdata_extract_row(request);
|
|
Packit |
fcad23 |
mteTrigger_removeEntry( row );
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
case MODE_SET_ACTION:
|
|
Packit |
fcad23 |
for (request = requests; request; request = request->next) {
|
|
Packit |
fcad23 |
if (request->processed)
|
|
Packit |
fcad23 |
continue;
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
tinfo = netsnmp_extract_table_info(request);
|
|
Packit |
fcad23 |
entry = (struct mteTrigger *) netsnmp_tdata_extract_entry(request);
|
|
Packit |
fcad23 |
if (!entry) {
|
|
Packit |
fcad23 |
/*
|
|
Packit |
fcad23 |
* New rows must be created via the RowStatus column
|
|
Packit |
fcad23 |
*/
|
|
Packit |
fcad23 |
netsnmp_set_request_error(reqinfo, request,
|
|
Packit |
fcad23 |
SNMP_ERR_NOCREATION);
|
|
Packit |
fcad23 |
/* or inconsistentName? */
|
|
Packit |
fcad23 |
return SNMP_ERR_NOERROR;
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
case MODE_SET_UNDO:
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
case MODE_SET_COMMIT:
|
|
Packit |
fcad23 |
/*
|
|
Packit |
fcad23 |
* All these assignments are "unfailable", so it's
|
|
Packit |
fcad23 |
* (reasonably) safe to apply them in the Commit phase
|
|
Packit |
fcad23 |
*/
|
|
Packit |
fcad23 |
for (request = requests; request; request = request->next) {
|
|
Packit |
fcad23 |
if (request->processed)
|
|
Packit |
fcad23 |
continue;
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
entry = (struct mteTrigger *) netsnmp_tdata_extract_entry(request);
|
|
Packit |
fcad23 |
tinfo = netsnmp_extract_table_info(request);
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
switch (tinfo->colnum) {
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERCOMMENT:
|
|
Packit |
fcad23 |
memset(entry->mteTriggerComment, 0,
|
|
Packit |
fcad23 |
sizeof(entry->mteTriggerComment));
|
|
Packit |
fcad23 |
memcpy(entry->mteTriggerComment,
|
|
Packit |
fcad23 |
request->requestvb->val.string,
|
|
Packit |
fcad23 |
request->requestvb->val_len);
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERTEST:
|
|
Packit |
fcad23 |
entry->mteTriggerTest = request->requestvb->val.string[0];
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERSAMPLETYPE:
|
|
Packit |
fcad23 |
if (*request->requestvb->val.integer == MTE_SAMPLE_DELTA)
|
|
Packit |
fcad23 |
entry->flags |= MTE_TRIGGER_FLAG_DELTA;
|
|
Packit |
fcad23 |
else
|
|
Packit |
fcad23 |
entry->flags &= ~MTE_TRIGGER_FLAG_DELTA;
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERVALUEID:
|
|
Packit |
fcad23 |
memset(entry->mteTriggerValueID, 0,
|
|
Packit |
fcad23 |
sizeof(entry->mteTriggerValueID));
|
|
Packit |
fcad23 |
memcpy(entry->mteTriggerValueID,
|
|
Packit |
fcad23 |
request->requestvb->val.string,
|
|
Packit |
fcad23 |
request->requestvb->val_len);
|
|
Packit |
fcad23 |
entry->mteTriggerValueID_len = request->requestvb->val_len/sizeof(oid);
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERVALUEIDWILDCARD:
|
|
Packit |
fcad23 |
if (*request->requestvb->val.integer == TV_TRUE)
|
|
Packit |
fcad23 |
entry->flags |= MTE_TRIGGER_FLAG_VWILD;
|
|
Packit |
fcad23 |
else
|
|
Packit |
fcad23 |
entry->flags &= ~MTE_TRIGGER_FLAG_VWILD;
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERTARGETTAG:
|
|
Packit |
fcad23 |
memset(entry->mteTriggerTarget, 0,
|
|
Packit |
fcad23 |
sizeof(entry->mteTriggerTarget));
|
|
Packit |
fcad23 |
memcpy(entry->mteTriggerTarget,
|
|
Packit |
fcad23 |
request->requestvb->val.string,
|
|
Packit |
fcad23 |
request->requestvb->val_len);
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERCONTEXTNAME:
|
|
Packit |
fcad23 |
memset(entry->mteTriggerContext, 0,
|
|
Packit |
fcad23 |
sizeof(entry->mteTriggerContext));
|
|
Packit |
fcad23 |
memcpy(entry->mteTriggerContext,
|
|
Packit |
fcad23 |
request->requestvb->val.string,
|
|
Packit |
fcad23 |
request->requestvb->val_len);
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERCONTEXTNAMEWILDCARD:
|
|
Packit |
fcad23 |
if (*request->requestvb->val.integer == TV_TRUE)
|
|
Packit |
fcad23 |
entry->flags |= MTE_TRIGGER_FLAG_CWILD;
|
|
Packit |
fcad23 |
else
|
|
Packit |
fcad23 |
entry->flags &= ~MTE_TRIGGER_FLAG_CWILD;
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERFREQUENCY:
|
|
Packit |
fcad23 |
entry->mteTriggerFrequency = *request->requestvb->val.integer;
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGEROBJECTSOWNER:
|
|
Packit |
fcad23 |
memset(entry->mteTriggerOOwner, 0,
|
|
Packit |
fcad23 |
sizeof(entry->mteTriggerOOwner));
|
|
Packit |
fcad23 |
memcpy(entry->mteTriggerOOwner,
|
|
Packit |
fcad23 |
request->requestvb->val.string,
|
|
Packit |
fcad23 |
request->requestvb->val_len);
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGEROBJECTS:
|
|
Packit |
fcad23 |
memset(entry->mteTriggerObjects, 0,
|
|
Packit |
fcad23 |
sizeof(entry->mteTriggerObjects));
|
|
Packit |
fcad23 |
memcpy(entry->mteTriggerObjects,
|
|
Packit |
fcad23 |
request->requestvb->val.string,
|
|
Packit |
fcad23 |
request->requestvb->val_len);
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERENABLED:
|
|
Packit |
fcad23 |
if (*request->requestvb->val.integer == TV_TRUE)
|
|
Packit |
fcad23 |
entry->flags |= MTE_TRIGGER_FLAG_ENABLED;
|
|
Packit |
fcad23 |
else
|
|
Packit |
fcad23 |
entry->flags &= ~MTE_TRIGGER_FLAG_ENABLED;
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case COLUMN_MTETRIGGERENTRYSTATUS:
|
|
Packit |
fcad23 |
switch (*request->requestvb->val.integer) {
|
|
Packit |
fcad23 |
case RS_ACTIVE:
|
|
Packit |
fcad23 |
entry->flags |= MTE_TRIGGER_FLAG_ACTIVE;
|
|
Packit |
fcad23 |
mteTrigger_enable( entry );
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case RS_CREATEANDGO:
|
|
Packit |
fcad23 |
entry->flags |= MTE_TRIGGER_FLAG_ACTIVE;
|
|
Packit |
fcad23 |
entry->flags |= MTE_TRIGGER_FLAG_VALID;
|
|
Packit |
fcad23 |
entry->session =
|
|
Packit |
fcad23 |
netsnmp_iquery_pdu_session(reqinfo->asp->pdu);
|
|
Packit |
fcad23 |
mteTrigger_enable( entry );
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case RS_CREATEANDWAIT:
|
|
Packit |
fcad23 |
entry->flags |= MTE_TRIGGER_FLAG_VALID;
|
|
Packit |
fcad23 |
entry->session =
|
|
Packit |
fcad23 |
netsnmp_iquery_pdu_session(reqinfo->asp->pdu);
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
case RS_DESTROY:
|
|
Packit |
fcad23 |
row = (netsnmp_tdata_row *)
|
|
Packit |
fcad23 |
netsnmp_tdata_extract_row(request);
|
|
Packit |
fcad23 |
mteTrigger_removeEntry(row);
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
/** set up to save persistent store */
|
|
Packit |
fcad23 |
snmp_store_needed(NULL);
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
#endif /* !NETSNMP_NO_WRITE_SUPPORT */
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
return SNMP_ERR_NOERROR;
|
|
Packit |
fcad23 |
}
|