/usr/include/net-snmp/agent/table_array.h is in libsnmp-dev 5.7.2~dfsg-8.1ubuntu3.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 | /*
* table_array.h
* $Id$
*/
#ifndef _TABLE_ARRAY_HANDLER_H_
#define _TABLE_ARRAY_HANDLER_H_
#ifdef __cplusplus
extern "C" {
#endif
/*
* The table array helper is designed to simplify the task of
* writing a table handler for the net-snmp agent when the data being
* accessed is in an oid sorted form and must be accessed externally.
*
* Functionally, it is a specialized version of the more
* generic table helper but easies the burden of GETNEXT processing by
* retrieving the appropriate row for ead index through
* function calls which should be supplied by the module that wishes
* help. The module the table_array helps should, afterwards,
* never be called for the case of "MODE_GETNEXT" and only for the GET
* and SET related modes instead.
*/
#include <net-snmp/library/container.h>
#include <net-snmp/agent/table.h>
#define TABLE_ARRAY_NAME "table_array"
/*
* group_item is to allow us to keep a list of requests without
* disrupting the actual netsnmp_request_info list.
*/
typedef struct netsnmp_request_group_item_s {
netsnmp_request_info *ri;
netsnmp_table_request_info *tri;
struct netsnmp_request_group_item_s *next;
} netsnmp_request_group_item;
/*
* structure to keep a list of requests for each unique index
*/
typedef struct netsnmp_request_group_s {
/*
* index for this row. points to someone else's memory, so
* don't free it!
*/
netsnmp_index index;
/*
* container in which rows belong
*/
netsnmp_container *table;
/*
* actual old and new rows
*/
netsnmp_index *existing_row;
netsnmp_index *undo_info;
/*
* flags
*/
char row_created;
char row_deleted;
char fill1;
char fill2;
/*
* requests for this row
*/
netsnmp_request_group_item *list;
int status;
void *rg_void;
} netsnmp_request_group;
typedef int (Netsnmp_User_Row_Operation_c) (const void *lhs,
const void *rhs);
typedef int (Netsnmp_User_Row_Operation) (void *lhs, void *rhs);
typedef int (Netsnmp_User_Get_Processor) (netsnmp_request_info *,
netsnmp_index
*,
netsnmp_table_request_info
*);
typedef netsnmp_index
*(UserRowMethod) (netsnmp_index *);
typedef int (Netsnmp_User_Row_Action) (netsnmp_index *,
netsnmp_index *,
netsnmp_request_group *);
typedef void (Netsnmp_User_Group_Method) (netsnmp_request_group *);
/*
* structure for array callbacks
*/
typedef struct netsnmp_table_array_callbacks_s {
Netsnmp_User_Row_Operation *row_copy;
Netsnmp_User_Row_Operation_c *row_compare;
Netsnmp_User_Get_Processor *get_value;
Netsnmp_User_Row_Action *can_activate;
Netsnmp_User_Row_Action *activated;
Netsnmp_User_Row_Action *can_deactivate;
Netsnmp_User_Row_Action *deactivated;
Netsnmp_User_Row_Action *can_delete;
UserRowMethod *create_row;
UserRowMethod *duplicate_row;
UserRowMethod *delete_row; /* always returns NULL */
Netsnmp_User_Group_Method *set_reserve1;
Netsnmp_User_Group_Method *set_reserve2;
Netsnmp_User_Group_Method *set_action;
Netsnmp_User_Group_Method *set_commit;
Netsnmp_User_Group_Method *set_free;
Netsnmp_User_Group_Method *set_undo;
/** not callbacks, but this is a useful place for them... */
netsnmp_container* container;
char can_set;
} netsnmp_table_array_callbacks;
int
netsnmp_table_container_register(netsnmp_handler_registration *reginfo,
netsnmp_table_registration_info
*tabreq,
netsnmp_table_array_callbacks *cb,
netsnmp_container *container,
int group_rows);
int netsnmp_table_array_register(netsnmp_handler_registration *reginfo,
netsnmp_table_registration_info *tabreq,
netsnmp_table_array_callbacks *cb,
netsnmp_container *container,
int group_rows);
netsnmp_container * netsnmp_extract_array_context(netsnmp_request_info *);
Netsnmp_Node_Handler netsnmp_table_array_helper_handler;
int
netsnmp_table_array_check_row_status(netsnmp_table_array_callbacks *cb,
netsnmp_request_group *ag,
long *rs_new, long *rs_old);
#ifdef __cplusplus
}
#endif
#endif /* _TABLE_ARRAY_HANDLER_H_ */
|