Mistake on this page?
Report an issue in GitHub or email us
snmpv3.h
Go to the documentation of this file.
1 /**
2  * @file
3  * Additional SNMPv3 functionality RFC3414 and RFC3826.
4  */
5 
6 /*
7  * Copyright (c) 2016 Elias Oenal.
8  * All rights reserved.
9  *
10  * Redistribution and use in source and binary forms, with or without modification,
11  * are permitted provided that the following conditions are met:
12  *
13  * 1. Redistributions of source code must retain the above copyright notice,
14  * this list of conditions and the following disclaimer.
15  * 2. Redistributions in binary form must reproduce the above copyright notice,
16  * this list of conditions and the following disclaimer in the documentation
17  * and/or other materials provided with the distribution.
18  * 3. The name of the author may not be used to endorse or promote products
19  * derived from this software without specific prior written permission.
20  *
21  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
22  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
23  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT
24  * SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
25  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
26  * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
27  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
28  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
29  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY
30  * OF SUCH DAMAGE.
31  *
32  * Author: Elias Oenal <lwip@eliasoenal.com>
33  */
34 
35 #ifndef LWIP_HDR_APPS_SNMP_V3_H
36 #define LWIP_HDR_APPS_SNMP_V3_H
37 
38 #include "lwip/apps/snmp_opts.h"
39 #include "lwip/err.h"
40 
41 #ifdef __cplusplus
42 extern "C" {
43 #endif
44 
45 #if LWIP_SNMP && LWIP_SNMP_V3
46 
47 typedef enum
48 {
49  SNMP_V3_AUTH_ALGO_INVAL = 0,
50  SNMP_V3_AUTH_ALGO_MD5 = 1,
51  SNMP_V3_AUTH_ALGO_SHA = 2
52 } snmpv3_auth_algo_t;
53 
54 typedef enum
55 {
56  SNMP_V3_PRIV_ALGO_INVAL = 0,
57  SNMP_V3_PRIV_ALGO_DES = 1,
58  SNMP_V3_PRIV_ALGO_AES = 2
59 } snmpv3_priv_algo_t;
60 
61 typedef enum
62 {
63  SNMP_V3_USER_STORAGETYPE_OTHER = 1,
64  SNMP_V3_USER_STORAGETYPE_VOLATILE = 2,
65  SNMP_V3_USER_STORAGETYPE_NONVOLATILE = 3,
66  SNMP_V3_USER_STORAGETYPE_PERMANENT = 4,
67  SNMP_V3_USER_STORAGETYPE_READONLY = 5
68 } snmpv3_user_storagetype_t;
69 
70 /*
71  * The following callback functions must be implemented by the application.
72  * There is a dummy implementation in snmpv3_dummy.c.
73  */
74 
75 void snmpv3_get_engine_id(const char **id, u8_t *len);
76 err_t snmpv3_set_engine_id(const char* id, u8_t len);
77 
78 u32_t snmpv3_get_engine_boots(void);
79 void snmpv3_set_engine_boots(u32_t boots);
80 
81 u32_t snmpv3_get_engine_time(void);
82 void snmpv3_reset_engine_time(void);
83 
84 err_t snmpv3_get_user(const char* username, snmpv3_auth_algo_t *auth_algo, u8_t *auth_key, snmpv3_priv_algo_t *priv_algo, u8_t *priv_key);
85 u8_t snmpv3_get_amount_of_users(void);
86 err_t snmpv3_get_user_storagetype(const char *username, snmpv3_user_storagetype_t *storagetype);
87 err_t snmpv3_get_username(char *username, u8_t index);
88 
89 /* The following functions are provided by the SNMPv3 agent */
90 
91 void snmpv3_engine_id_changed(void);
92 s32_t snmpv3_get_engine_time_internal(void);
93 
94 void snmpv3_password_to_key_md5(
95  const u8_t *password, /* IN */
96  size_t passwordlen, /* IN */
97  const u8_t *engineID, /* IN - pointer to snmpEngineID */
98  u8_t engineLength, /* IN - length of snmpEngineID */
99  u8_t *key); /* OUT - pointer to caller 16-octet buffer */
100 
101 void snmpv3_password_to_key_sha(
102  const u8_t *password, /* IN */
103  size_t passwordlen, /* IN */
104  const u8_t *engineID, /* IN - pointer to snmpEngineID */
105  u8_t engineLength, /* IN - length of snmpEngineID */
106  u8_t *key); /* OUT - pointer to caller 20-octet buffer */
107 
108 #endif
109 
110 #ifdef __cplusplus
111 }
112 #endif
113 
114 #endif /* LWIP_HDR_APPS_SNMP_V3_H */
lwIP Error codes
SNMP server options list.
Important Information for this Arm website

This site uses cookies to store information on your computer. By continuing to use our site, you consent to our cookies. If you are not happy with the use of these cookies, please review our Cookie Policy to learn how they can be disabled. By disabling cookies, some features of the site will not work.