1DEFAULT_STORE(3)                   Net-SNMP                   DEFAULT_STORE(3)
2
3
4

NAME

6       default_store - generic storage of global data.
7

SYNOPSIS

9       #include <net-snmp/net-snmp-config.h>
10       #include <net-snmp/config_api.h>
11
12       int netsnmp_ds_set_boolean(int store, int which, int val);
13       int netsnmp_ds_get_boolean(int store, int which);
14       int netsnmp_ds_set_int(int store, int which, int val);
15       int netsnmp_ds_get_int(int store, int which);
16       int netsnmp_ds_set_string(int store, int which,
17                                 const char *val);
18       char *netsnmp_ds_get_string(int store, int which);
19       int netsnmp_ds_register_config(u_char type,
20                                      const char *ftype,
21                                      const char *token,
22                                      int store, int which);
23       int netsnmp_ds_register_premib(u_char type,
24                                      const char *ftype,
25                                      const char *token,
26                                      int store, int which);
27       void netsnmp_ds_shutdown(void);
28

DESCRIPTION

30       The purpose of the default storage is three-fold:
31
32       1)     To  create a global storage space without creating a whole bunch
33              of globally accessible variables or  a  whole  bunch  of  access
34              functions to work with more privately restricted variables.
35
36       2)     To  provide  a single location where the thread locking needs to
37              be implemented. At the time of  this  writing,  however,  thread
38              locking is not yet in place.
39
40       3)     To  reduce  the number of cross dependencies between code pieces
41              that may or may not be linked together in  the  long  run.  This
42              provides  for a single location in which configuration data, for
43              example, can be stored for a separate section of code  that  may
44              not be linked in to the application in question.
45
46       The functions defined here implement these goals.
47
48       Currently,  three  data  types  are  supported: booleans, integers, and
49       strings. Each of these data types  have  separate  storage  spaces.  In
50       addition,  the  storage  space for each data type is divided further by
51       the application level.   Currently, there are two storage  spaces.  The
52       first  is  reserved for the SNMP library itself. The second is intended
53       for use in applications and is not modified or checked by the  library,
54       and, therefore, this is the space usable by you.
55
56       You can think of these storage spaces as being 3 arrays, something like
57       bool_storage[storeid][which],     int_storage[storeid][which],      and
58       string_storage[storeid][which].   The data is then accessed through the
59       functions defined below.  For data you wish to store, you should use  a
60       store parameter of NETSNMP_DS_APPLICATION_ID.
61
62       The storage space used by the library (for which the store parameter is
63       NETSNMP_DS_LIBRARY_ID) is defined in the  default_store.h  file,  which
64       currently contains the following defines:
65
66            */
67       /**
68        * @def NETSNMP_DS_LIBRARY_ID
69        * These definitions correspond with the "storid" argument to the API.
70        */
71       #define NETSNMP_DS_LIBRARY_ID     0
72       #define NETSNMP_DS_APPLICATION_ID 1
73       #define NETSNMP_DS_TOKEN_ID       2
74
75           /*
76            * These definitions correspond with the "which" argument to the API,
77            * when the storeid argument is NETSNMP_DS_LIBRARY_ID
78            */
79           /*
80            * library booleans
81            */
82       #define NETSNMP_DS_LIB_MIB_ERRORS          0
83       #define NETSNMP_DS_LIB_SAVE_MIB_DESCRS     1
84       #define NETSNMP_DS_LIB_MIB_COMMENT_TERM    2
85       #define NETSNMP_DS_LIB_MIB_PARSE_LABEL     3
86       #define NETSNMP_DS_LIB_DUMP_PACKET         4
87       #define NETSNMP_DS_LIB_LOG_TIMESTAMP       5
88       #define NETSNMP_DS_LIB_DONT_READ_CONFIGS   6    /* don't read normal config files */
89       #define NETSNMP_DS_LIB_DISABLE_CONFIG_LOAD      NETSNMP_DS_LIB_DONT_READ_CONFIGS
90       #define NETSNMP_DS_LIB_MIB_REPLACE         7    /* replace objects from latest module */
91       #define NETSNMP_DS_LIB_PRINT_NUMERIC_ENUM  8    /* print only numeric enum values */
92       #define NETSNMP_DS_LIB_PRINT_NUMERIC_OIDS  9    /* print only numeric enum values */
93       #define NETSNMP_DS_LIB_DONT_BREAKDOWN_OIDS 10   /* dont print oid indexes specially */
94       #define NETSNMP_DS_LIB_ALARM_DONT_USE_SIG  11   /* don't use the alarm() signal */
95       #define NETSNMP_DS_LIB_PRINT_FULL_OID      12   /* print fully qualified oids */
96       #define NETSNMP_DS_LIB_QUICK_PRINT         13   /* print very brief output for parsing */
97       #define NETSNMP_DS_LIB_RANDOM_ACCESS       14   /* random access to oid labels */
98       #define NETSNMP_DS_LIB_REGEX_ACCESS        15   /* regex matching to oid labels */
99       #define NETSNMP_DS_LIB_DONT_CHECK_RANGE    16   /* don't check values for ranges on send */
100       #define NETSNMP_DS_LIB_NO_TOKEN_WARNINGS   17   /* no warn about unknown config tokens */
101       #define NETSNMP_DS_LIB_NUMERIC_TIMETICKS   18   /* print timeticks as a number */
102       #define NETSNMP_DS_LIB_ESCAPE_QUOTES       19   /* shell escape quote marks in oids */
103       #define NETSNMP_DS_LIB_REVERSE_ENCODE      20   /* encode packets from back to front */
104       #define NETSNMP_DS_LIB_PRINT_BARE_VALUE    21   /* just print value (not OID = value) */
105       #define NETSNMP_DS_LIB_EXTENDED_INDEX      22   /* print extended index format [x1][x2] */
106       #define NETSNMP_DS_LIB_PRINT_HEX_TEXT      23   /* print ASCII text along with hex strings */
107       #define NETSNMP_DS_LIB_PRINT_UCD_STYLE_OID 24   /* print OID's using the UCD-style prefix suppression */
108       #define NETSNMP_DS_LIB_READ_UCD_STYLE_OID  25   /* require top-level OIDs to be prefixed with a dot */
109       #define NETSNMP_DS_LIB_HAVE_READ_PREMIB_CONFIG 26       /* have the pre-mib parsing config tokens been processed */
110       #define NETSNMP_DS_LIB_HAVE_READ_CONFIG    27   /* have the config tokens been processed */
111       #define NETSNMP_DS_LIB_QUICKE_PRINT        28
112       #define NETSNMP_DS_LIB_DONT_PRINT_UNITS    29 /* don't print UNITS suffix */
113       #define NETSNMP_DS_LIB_NO_DISPLAY_HINT     30 /* don't apply DISPLAY-HINTs */
114       #define NETSNMP_DS_LIB_16BIT_IDS           31   /* restrict requestIDs, etc to 16-bit values */
115       #define NETSNMP_DS_LIB_DONT_PERSIST_STATE  32     /* don't load config and don't load/save persistent file */
116       #define NETSNMP_DS_LIB_2DIGIT_HEX_OUTPUT   33     /* print a leading 0 on hex values <= 'f' */
117       #define NETSNMP_DS_LIB_IGNORE_NO_COMMUNITY 34     /* don't complain if no community is specified in the command arguments */
118       #define NETSNMP_DS_LIB_DISABLE_PERSISTENT_LOAD  35 /* don't load persistent file */
119       #define NETSNMP_DS_LIB_DISABLE_PERSISTENT_SAVE  36 /* don't save persistent file */
120       #define NETSNMP_DS_LIB_APPEND_LOGFILES     37 /* append, don't overwrite, log files */
121       #define NETSNMP_DS_LIB_NO_DISCOVERY        38 /* don't support RFC5343 contextEngineID discovery */
122       #define NETSNMP_DS_LIB_TSM_USE_PREFIX      39 /* TSM's simple security name mapping */
123       #define NETSNMP_DS_LIB_DONT_LOAD_HOST_FILES 40 /* don't read host.conf files */
124       #define NETSNMP_DS_LIB_DNSSEC_WARN_ONLY     41 /* tread DNSSEC errors as warnings */
125       #define NETSNMP_DS_LIB_CLIENT_ADDR_USES_PORT 42 /* NETSNMP_DS_LIB_CLIENT_ADDR includes address and also port */
126       #define NETSNMP_DS_LIB_MAX_BOOL_ID          48 /* match NETSNMP_DS_MAX_SUBIDS */
127
128           /*
129            * library integers
130            */
131       #define NETSNMP_DS_LIB_MIB_WARNINGS         0
132       #define NETSNMP_DS_LIB_SECLEVEL             1
133       #define NETSNMP_DS_LIB_SNMPVERSION          2
134       #define NETSNMP_DS_LIB_DEFAULT_PORT         3
135       #define NETSNMP_DS_LIB_OID_OUTPUT_FORMAT    4
136       #define NETSNMP_DS_LIB_PRINT_SUFFIX_ONLY    NETSNMP_DS_LIB_OID_OUTPUT_FORMAT
137       #define NETSNMP_DS_LIB_STRING_OUTPUT_FORMAT 5
138       #define NETSNMP_DS_LIB_HEX_OUTPUT_LENGTH    6
139       #define NETSNMP_DS_LIB_SERVERSENDBUF        7 /* send buffer (server) */
140       #define NETSNMP_DS_LIB_SERVERRECVBUF        8 /* receive buffer (server) */
141       #define NETSNMP_DS_LIB_CLIENTSENDBUF        9 /* send buffer (client) */
142       #define NETSNMP_DS_LIB_CLIENTRECVBUF       10 /* receive buffer (client) */
143       #define NETSNMP_DS_SSHDOMAIN_SOCK_PERM     11
144       #define NETSNMP_DS_SSHDOMAIN_DIR_PERM      12
145       #define NETSNMP_DS_SSHDOMAIN_SOCK_USER     12
146       #define NETSNMP_DS_SSHDOMAIN_SOCK_GROUP    13
147       #define NETSNMP_DS_LIB_TIMEOUT             14
148       #define NETSNMP_DS_LIB_RETRIES             15
149       #define NETSNMP_DS_LIB_MAX_INT_ID          48 /* match NETSNMP_DS_MAX_SUBIDS */
150
151           /*
152            * special meanings for the default SNMP version slot (NETSNMP_DS_LIB_SNMPVERSION)
153            */
154       #ifndef NETSNMP_DISABLE_SNMPV1
155       #define NETSNMP_DS_SNMP_VERSION_1    128        /* bogus */
156       #endif
157       #ifndef NETSNMP_DISABLE_SNMPV2C
158       #define NETSNMP_DS_SNMP_VERSION_2c   1  /* real */
159       #endif
160       #define NETSNMP_DS_SNMP_VERSION_3    3  /* real */
161
162
163           /*
164            * library strings
165            */
166       #define NETSNMP_DS_LIB_SECNAME           0
167       #define NETSNMP_DS_LIB_CONTEXT           1
168       #define NETSNMP_DS_LIB_PASSPHRASE        2
169       #define NETSNMP_DS_LIB_AUTHPASSPHRASE    3
170       #define NETSNMP_DS_LIB_PRIVPASSPHRASE    4
171       #define NETSNMP_DS_LIB_OPTIONALCONFIG    5
172       #define NETSNMP_DS_LIB_APPTYPE           6
173       #define NETSNMP_DS_LIB_COMMUNITY         7
174       #define NETSNMP_DS_LIB_PERSISTENT_DIR    8
175       #define NETSNMP_DS_LIB_CONFIGURATION_DIR 9
176       #define NETSNMP_DS_LIB_SECMODEL          10
177       #define NETSNMP_DS_LIB_MIBDIRS           11
178       #define NETSNMP_DS_LIB_OIDSUFFIX         12
179       #define NETSNMP_DS_LIB_OIDPREFIX         13
180       #define NETSNMP_DS_LIB_CLIENT_ADDR       14
181       #define NETSNMP_DS_LIB_TEMP_FILE_PATTERN 15
182       #define NETSNMP_DS_LIB_AUTHMASTERKEY     16
183       #define NETSNMP_DS_LIB_PRIVMASTERKEY     17
184       #define NETSNMP_DS_LIB_AUTHLOCALIZEDKEY  18
185       #define NETSNMP_DS_LIB_PRIVLOCALIZEDKEY  19
186       #define NETSNMP_DS_LIB_APPTYPES          20
187       #define NETSNMP_DS_LIB_KSM_KEYTAB        21
188       #define NETSNMP_DS_LIB_KSM_SERVICE_NAME  22
189       #define NETSNMP_DS_LIB_X509_CLIENT_PUB   23
190       #define NETSNMP_DS_LIB_X509_SERVER_PUB   24
191       #define NETSNMP_DS_LIB_SSHTOSNMP_SOCKET  25
192       #define NETSNMP_DS_LIB_CERT_EXTRA_SUBDIR 26
193       #define NETSNMP_DS_LIB_HOSTNAME          27
194       #define NETSNMP_DS_LIB_X509_CRL_FILE     28
195       #define NETSNMP_DS_LIB_TLS_ALGORITMS     29
196       #define NETSNMP_DS_LIB_TLS_LOCAL_CERT    30
197       #define NETSNMP_DS_LIB_TLS_PEER_CERT     31
198       #define NETSNMP_DS_LIB_SSH_USERNAME      32
199       #define NETSNMP_DS_LIB_SSH_PUBKEY        33
200       #define NETSNMP_DS_LIB_SSH_PRIVKEY       34
201       #define NETSNMP_DS_LIB_MAX_STR_ID        48 /* match NETSNMP_DS_MAX_SUBIDS */
202
203           /*
204

FUNCTIONS

206       int netsnmp_ds_set_boolean(int store, int which, int val);
207              Stores  TRUE  if  val  !=  0  or  else FALSE into the bool_stor‐
208              age[store][which] slot.  Returns SNMPERR_GENERR if the store and
209              which  parameters  do  not  correspond  to a valid slot, or SNM‐
210              PERR_SUCCESS otherwise.
211
212       int netsnmp_ds_get_boolean(int store, int which);
213              Returns 1 if bool_storage[store][which] is TRUE  or  0  if  not.
214              May also return SNMPERR_GENERR if the store and which parameters
215              do not correspond to a valid slot.
216
217       int netsnmp_ds_set_string(int store, int which, const char *val);
218              Stores val into the string_storage[store][which] slot.   Returns
219              SNMPERR_SUCCESS  normally,  or  SNMPERR_GENERR  if the store and
220              which parameters do not correspond to a valid slot.
221
222       char *netsnmp_ds_get_string(int store, int which);
223              Returns the string which has been  stored  in  the  string_stor‐
224              age[store][which]  slot,  or NULL if the store and which parame‐
225              ters do not correspond to a valid slot.
226
227       netsnmp_ds_set_int(int store, int which, int val);
228              Stores val into  the  int_storage[store][which]  slot.   Returns
229              SNMPERR_GENERR  if  the store and which parameters do not corre‐
230              spond to a valid slot, or SNMPERR_SUCCESS otherwise.
231
232       int netsnmp_ds_get_int(int store, int which);
233              Returns the integer which  has  been  stored  in  the  int_stor‐
234              age[store][which] slot, or SNMPERR_GENERR if the store and which
235              parameters do not correspond to a valid slot.
236
237       void netsnmp_ds_shutdown(void);
238              Reclaims memory  used  to  hold  information  gathered  by  net‐
239              snmp_ds_register_config and netsnmp_ds_register_premib.
240
241       int  netsnmp_ds_register_config(u_char  type,  const char *ftype, const
242       char *token, int store, int which);
243              Registers a configuration file directive token and  attaches  it
244              to  a  default  storage  type and slot.  Specifically, store and
245              which indicate the storage slot in the data  type  indicated  by
246              type, where type is one of the following constants: ASN_BOOLEAN,
247              ASN_INTEGER, or ASN_OCTET_STR.  The ftype variable indicates the
248              file name base string searched for the token keyword.  For exam‐
249              ple, the following call:
250
251                     netsnmp_ds_register_config(ASN_INTEGER, "snmp",  "testto‐
252                     ken", DS_APPLICATION_ID, 5)
253
254              would  indicate  that  when the snmp.conf file(s) were found and
255              parsed, that any line beginning with the word "testtoken" should
256              be  read  and  the value after "testtoken" should be stored into
257              the int_storage[DS_APPLICATION_ID][5]  slot.   For  example  the
258              following line in the configuration file:
259
260                     testtoken 502
261
262              would  set  int_storage[DS_APPLICATION_ID][5] = 502.  This func‐
263              tion returns SNMPERR_SUCCESS if the registration was  made  suc‐
264              cessfully,  or  SNMPERR_GENERR  if the registration was not made
265              (perhaps because the store and which parameters  do  not  corre‐
266              spond  to  a valid slot, or because of a memory allocation fail‐
267              ure).
268
269       int netsnmp_ds_register_premib(u_char type, const  char  *ftype,  const
270       char *token, int store, int which);
271              Analogous  to the preceding function, but the token is processed
272              before MIBs are read (this is therefore useful  for  controlling
273              MIB processing options).
274

SEE ALSO

276       snmp_config(5), netsnmp_config_api(3)
277
278
279
280
281V5.7.2                            25 Jun 2002                 DEFAULT_STORE(3)
Impressum