xref: /minix3/minix/lib/liblwip/dist/src/apps/snmp/snmp_msg.h (revision 5d5fbe79c1b60734f34c69330aec5496644e8651)
1*5d5fbe79SDavid van Moolenbroek /**
2*5d5fbe79SDavid van Moolenbroek  * @file
3*5d5fbe79SDavid van Moolenbroek  * SNMP Agent message handling structures (internal API, do not use in client code).
4*5d5fbe79SDavid van Moolenbroek  */
5*5d5fbe79SDavid van Moolenbroek 
6*5d5fbe79SDavid van Moolenbroek /*
7*5d5fbe79SDavid van Moolenbroek  * Copyright (c) 2006 Axon Digital Design B.V., The Netherlands.
8*5d5fbe79SDavid van Moolenbroek  * Copyright (c) 2016 Elias Oenal.
9*5d5fbe79SDavid van Moolenbroek  * All rights reserved.
10*5d5fbe79SDavid van Moolenbroek  *
11*5d5fbe79SDavid van Moolenbroek  * Redistribution and use in source and binary forms, with or without modification,
12*5d5fbe79SDavid van Moolenbroek  * are permitted provided that the following conditions are met:
13*5d5fbe79SDavid van Moolenbroek  *
14*5d5fbe79SDavid van Moolenbroek  * 1. Redistributions of source code must retain the above copyright notice,
15*5d5fbe79SDavid van Moolenbroek  *    this list of conditions and the following disclaimer.
16*5d5fbe79SDavid van Moolenbroek  * 2. Redistributions in binary form must reproduce the above copyright notice,
17*5d5fbe79SDavid van Moolenbroek  *    this list of conditions and the following disclaimer in the documentation
18*5d5fbe79SDavid van Moolenbroek  *    and/or other materials provided with the distribution.
19*5d5fbe79SDavid van Moolenbroek  * 3. The name of the author may not be used to endorse or promote products
20*5d5fbe79SDavid van Moolenbroek  *    derived from this software without specific prior written permission.
21*5d5fbe79SDavid van Moolenbroek  *
22*5d5fbe79SDavid van Moolenbroek  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
23*5d5fbe79SDavid van Moolenbroek  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
24*5d5fbe79SDavid van Moolenbroek  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT
25*5d5fbe79SDavid van Moolenbroek  * SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
26*5d5fbe79SDavid van Moolenbroek  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
27*5d5fbe79SDavid van Moolenbroek  * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
28*5d5fbe79SDavid van Moolenbroek  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
29*5d5fbe79SDavid van Moolenbroek  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
30*5d5fbe79SDavid van Moolenbroek  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY
31*5d5fbe79SDavid van Moolenbroek  * OF SUCH DAMAGE.
32*5d5fbe79SDavid van Moolenbroek  *
33*5d5fbe79SDavid van Moolenbroek  * Author: Christiaan Simons <christiaan.simons@axon.tv>
34*5d5fbe79SDavid van Moolenbroek  *         Martin Hentschel <info@cl-soft.de>
35*5d5fbe79SDavid van Moolenbroek  *         Elias Oenal <lwip@eliasoenal.com>
36*5d5fbe79SDavid van Moolenbroek  */
37*5d5fbe79SDavid van Moolenbroek 
38*5d5fbe79SDavid van Moolenbroek #ifndef LWIP_HDR_APPS_SNMP_MSG_H
39*5d5fbe79SDavid van Moolenbroek #define LWIP_HDR_APPS_SNMP_MSG_H
40*5d5fbe79SDavid van Moolenbroek 
41*5d5fbe79SDavid van Moolenbroek #include "lwip/apps/snmp_opts.h"
42*5d5fbe79SDavid van Moolenbroek 
43*5d5fbe79SDavid van Moolenbroek #if LWIP_SNMP
44*5d5fbe79SDavid van Moolenbroek 
45*5d5fbe79SDavid van Moolenbroek #include "lwip/apps/snmp.h"
46*5d5fbe79SDavid van Moolenbroek #include "lwip/apps/snmp_core.h"
47*5d5fbe79SDavid van Moolenbroek #include "snmp_pbuf_stream.h"
48*5d5fbe79SDavid van Moolenbroek #include "lwip/ip_addr.h"
49*5d5fbe79SDavid van Moolenbroek #include "lwip/err.h"
50*5d5fbe79SDavid van Moolenbroek 
51*5d5fbe79SDavid van Moolenbroek #if LWIP_SNMP_V3
52*5d5fbe79SDavid van Moolenbroek #include "snmpv3_priv.h"
53*5d5fbe79SDavid van Moolenbroek #endif
54*5d5fbe79SDavid van Moolenbroek 
55*5d5fbe79SDavid van Moolenbroek 
56*5d5fbe79SDavid van Moolenbroek #ifdef __cplusplus
57*5d5fbe79SDavid van Moolenbroek extern "C" {
58*5d5fbe79SDavid van Moolenbroek #endif
59*5d5fbe79SDavid van Moolenbroek 
60*5d5fbe79SDavid van Moolenbroek /* The listen port of the SNMP agent. Clients have to make their requests to
61*5d5fbe79SDavid van Moolenbroek    this port. Most standard clients won't work if you change this! */
62*5d5fbe79SDavid van Moolenbroek #ifndef SNMP_IN_PORT
63*5d5fbe79SDavid van Moolenbroek #define SNMP_IN_PORT 161
64*5d5fbe79SDavid van Moolenbroek #endif
65*5d5fbe79SDavid van Moolenbroek /* The remote port the SNMP agent sends traps to. Most standard trap sinks won't
66*5d5fbe79SDavid van Moolenbroek    work if you change this! */
67*5d5fbe79SDavid van Moolenbroek #ifndef SNMP_TRAP_PORT
68*5d5fbe79SDavid van Moolenbroek #define SNMP_TRAP_PORT 162
69*5d5fbe79SDavid van Moolenbroek #endif
70*5d5fbe79SDavid van Moolenbroek 
71*5d5fbe79SDavid van Moolenbroek /* version defines used in PDU */
72*5d5fbe79SDavid van Moolenbroek #define SNMP_VERSION_1  0
73*5d5fbe79SDavid van Moolenbroek #define SNMP_VERSION_2c 1
74*5d5fbe79SDavid van Moolenbroek #define SNMP_VERSION_3  3
75*5d5fbe79SDavid van Moolenbroek 
76*5d5fbe79SDavid van Moolenbroek struct snmp_varbind_enumerator
77*5d5fbe79SDavid van Moolenbroek {
78*5d5fbe79SDavid van Moolenbroek   struct snmp_pbuf_stream pbuf_stream;
79*5d5fbe79SDavid van Moolenbroek   u16_t varbind_count;
80*5d5fbe79SDavid van Moolenbroek };
81*5d5fbe79SDavid van Moolenbroek 
82*5d5fbe79SDavid van Moolenbroek typedef enum {
83*5d5fbe79SDavid van Moolenbroek   SNMP_VB_ENUMERATOR_ERR_OK            = 0,
84*5d5fbe79SDavid van Moolenbroek   SNMP_VB_ENUMERATOR_ERR_EOVB          = 1,
85*5d5fbe79SDavid van Moolenbroek   SNMP_VB_ENUMERATOR_ERR_ASN1ERROR     = 2,
86*5d5fbe79SDavid van Moolenbroek   SNMP_VB_ENUMERATOR_ERR_INVALIDLENGTH = 3
87*5d5fbe79SDavid van Moolenbroek } snmp_vb_enumerator_err_t;
88*5d5fbe79SDavid van Moolenbroek 
89*5d5fbe79SDavid van Moolenbroek void snmp_vb_enumerator_init(struct snmp_varbind_enumerator* enumerator, struct pbuf* p, u16_t offset, u16_t length);
90*5d5fbe79SDavid van Moolenbroek snmp_vb_enumerator_err_t snmp_vb_enumerator_get_next(struct snmp_varbind_enumerator* enumerator, struct snmp_varbind* varbind);
91*5d5fbe79SDavid van Moolenbroek 
92*5d5fbe79SDavid van Moolenbroek struct snmp_request
93*5d5fbe79SDavid van Moolenbroek {
94*5d5fbe79SDavid van Moolenbroek   /* Communication handle */
95*5d5fbe79SDavid van Moolenbroek   void *handle;
96*5d5fbe79SDavid van Moolenbroek   /* source IP address */
97*5d5fbe79SDavid van Moolenbroek   const ip_addr_t *source_ip;
98*5d5fbe79SDavid van Moolenbroek   /* source UDP port */
99*5d5fbe79SDavid van Moolenbroek   u16_t source_port;
100*5d5fbe79SDavid van Moolenbroek   /* incoming snmp version */
101*5d5fbe79SDavid van Moolenbroek   u8_t version;
102*5d5fbe79SDavid van Moolenbroek   /* community name (zero terminated) */
103*5d5fbe79SDavid van Moolenbroek   u8_t community[SNMP_MAX_COMMUNITY_STR_LEN + 1];
104*5d5fbe79SDavid van Moolenbroek   /* community string length (exclusive zero term) */
105*5d5fbe79SDavid van Moolenbroek   u16_t community_strlen;
106*5d5fbe79SDavid van Moolenbroek   /* request type */
107*5d5fbe79SDavid van Moolenbroek   u8_t request_type;
108*5d5fbe79SDavid van Moolenbroek   /* request ID */
109*5d5fbe79SDavid van Moolenbroek   s32_t request_id;
110*5d5fbe79SDavid van Moolenbroek   /* error status */
111*5d5fbe79SDavid van Moolenbroek   s32_t error_status;
112*5d5fbe79SDavid van Moolenbroek   /* error index */
113*5d5fbe79SDavid van Moolenbroek   s32_t error_index;
114*5d5fbe79SDavid van Moolenbroek   /* non-repeaters (getBulkRequest (SNMPv2c)) */
115*5d5fbe79SDavid van Moolenbroek   s32_t non_repeaters;
116*5d5fbe79SDavid van Moolenbroek   /* max-repetitions (getBulkRequest (SNMPv2c)) */
117*5d5fbe79SDavid van Moolenbroek   s32_t max_repetitions;
118*5d5fbe79SDavid van Moolenbroek 
119*5d5fbe79SDavid van Moolenbroek   /* Usually response-pdu (2). When snmpv3 errors are detected report-pdu(8) */
120*5d5fbe79SDavid van Moolenbroek   u8_t request_out_type;
121*5d5fbe79SDavid van Moolenbroek 
122*5d5fbe79SDavid van Moolenbroek #if LWIP_SNMP_V3
123*5d5fbe79SDavid van Moolenbroek   s32_t msg_id;
124*5d5fbe79SDavid van Moolenbroek   s32_t msg_max_size;
125*5d5fbe79SDavid van Moolenbroek   u8_t  msg_flags;
126*5d5fbe79SDavid van Moolenbroek   s32_t msg_security_model;
127*5d5fbe79SDavid van Moolenbroek   u8_t  msg_authoritative_engine_id[SNMP_V3_MAX_ENGINE_ID_LENGTH];
128*5d5fbe79SDavid van Moolenbroek   u8_t  msg_authoritative_engine_id_len;
129*5d5fbe79SDavid van Moolenbroek   s32_t msg_authoritative_engine_boots;
130*5d5fbe79SDavid van Moolenbroek   s32_t msg_authoritative_engine_time;
131*5d5fbe79SDavid van Moolenbroek   u8_t  msg_user_name[SNMP_V3_MAX_USER_LENGTH];
132*5d5fbe79SDavid van Moolenbroek   u8_t  msg_user_name_len;
133*5d5fbe79SDavid van Moolenbroek   u8_t  msg_authentication_parameters[SNMP_V3_MAX_AUTH_PARAM_LENGTH];
134*5d5fbe79SDavid van Moolenbroek   u8_t  msg_authentication_parameters_len;
135*5d5fbe79SDavid van Moolenbroek   u8_t  msg_privacy_parameters[SNMP_V3_MAX_PRIV_PARAM_LENGTH];
136*5d5fbe79SDavid van Moolenbroek   u8_t  msg_privacy_parameters_len;
137*5d5fbe79SDavid van Moolenbroek   u8_t  context_engine_id[SNMP_V3_MAX_ENGINE_ID_LENGTH];
138*5d5fbe79SDavid van Moolenbroek   u8_t  context_engine_id_len;
139*5d5fbe79SDavid van Moolenbroek   u8_t  context_name[SNMP_V3_MAX_ENGINE_ID_LENGTH];
140*5d5fbe79SDavid van Moolenbroek   u8_t  context_name_len;
141*5d5fbe79SDavid van Moolenbroek #endif
142*5d5fbe79SDavid van Moolenbroek 
143*5d5fbe79SDavid van Moolenbroek   struct pbuf *inbound_pbuf;
144*5d5fbe79SDavid van Moolenbroek   struct snmp_varbind_enumerator inbound_varbind_enumerator;
145*5d5fbe79SDavid van Moolenbroek   u16_t inbound_varbind_offset;
146*5d5fbe79SDavid van Moolenbroek   u16_t inbound_varbind_len;
147*5d5fbe79SDavid van Moolenbroek   u16_t inbound_padding_len;
148*5d5fbe79SDavid van Moolenbroek 
149*5d5fbe79SDavid van Moolenbroek   struct pbuf *outbound_pbuf;
150*5d5fbe79SDavid van Moolenbroek   struct snmp_pbuf_stream outbound_pbuf_stream;
151*5d5fbe79SDavid van Moolenbroek   u16_t outbound_pdu_offset;
152*5d5fbe79SDavid van Moolenbroek   u16_t outbound_error_status_offset;
153*5d5fbe79SDavid van Moolenbroek   u16_t outbound_error_index_offset;
154*5d5fbe79SDavid van Moolenbroek   u16_t outbound_varbind_offset;
155*5d5fbe79SDavid van Moolenbroek #if LWIP_SNMP_V3
156*5d5fbe79SDavid van Moolenbroek   u16_t outbound_msg_global_data_offset;
157*5d5fbe79SDavid van Moolenbroek   u16_t outbound_msg_global_data_end;
158*5d5fbe79SDavid van Moolenbroek   u16_t outbound_msg_security_parameters_str_offset;
159*5d5fbe79SDavid van Moolenbroek   u16_t outbound_msg_security_parameters_seq_offset;
160*5d5fbe79SDavid van Moolenbroek   u16_t outbound_msg_security_parameters_end;
161*5d5fbe79SDavid van Moolenbroek   u16_t outbound_msg_authentication_parameters_offset;
162*5d5fbe79SDavid van Moolenbroek   u16_t outbound_scoped_pdu_seq_offset;
163*5d5fbe79SDavid van Moolenbroek   u16_t outbound_scoped_pdu_string_offset;
164*5d5fbe79SDavid van Moolenbroek #endif
165*5d5fbe79SDavid van Moolenbroek 
166*5d5fbe79SDavid van Moolenbroek   u8_t value_buffer[SNMP_MAX_VALUE_SIZE];
167*5d5fbe79SDavid van Moolenbroek };
168*5d5fbe79SDavid van Moolenbroek 
169*5d5fbe79SDavid van Moolenbroek /** A helper struct keeping length information about varbinds */
170*5d5fbe79SDavid van Moolenbroek struct snmp_varbind_len
171*5d5fbe79SDavid van Moolenbroek {
172*5d5fbe79SDavid van Moolenbroek   u8_t  vb_len_len;
173*5d5fbe79SDavid van Moolenbroek   u16_t vb_value_len;
174*5d5fbe79SDavid van Moolenbroek   u8_t  oid_len_len;
175*5d5fbe79SDavid van Moolenbroek   u16_t oid_value_len;
176*5d5fbe79SDavid van Moolenbroek   u8_t  value_len_len;
177*5d5fbe79SDavid van Moolenbroek   u16_t value_value_len;
178*5d5fbe79SDavid van Moolenbroek };
179*5d5fbe79SDavid van Moolenbroek 
180*5d5fbe79SDavid van Moolenbroek /** Agent community string */
181*5d5fbe79SDavid van Moolenbroek extern const char *snmp_community;
182*5d5fbe79SDavid van Moolenbroek /** Agent community string for write access */
183*5d5fbe79SDavid van Moolenbroek extern const char *snmp_community_write;
184*5d5fbe79SDavid van Moolenbroek /** handle for sending traps */
185*5d5fbe79SDavid van Moolenbroek extern void* snmp_traps_handle;
186*5d5fbe79SDavid van Moolenbroek 
187*5d5fbe79SDavid van Moolenbroek void snmp_receive(void *handle, struct pbuf *p, const ip_addr_t *source_ip, u16_t port);
188*5d5fbe79SDavid van Moolenbroek err_t snmp_sendto(void *handle, struct pbuf *p, const ip_addr_t *dst, u16_t port);
189*5d5fbe79SDavid van Moolenbroek u8_t snmp_get_local_ip_for_dst(void* handle, const ip_addr_t *dst, ip_addr_t *result);
190*5d5fbe79SDavid van Moolenbroek err_t snmp_varbind_length(struct snmp_varbind *varbind, struct snmp_varbind_len *len);
191*5d5fbe79SDavid van Moolenbroek err_t snmp_append_outbound_varbind(struct snmp_pbuf_stream *pbuf_stream, struct snmp_varbind* varbind);
192*5d5fbe79SDavid van Moolenbroek 
193*5d5fbe79SDavid van Moolenbroek #ifdef __cplusplus
194*5d5fbe79SDavid van Moolenbroek }
195*5d5fbe79SDavid van Moolenbroek #endif
196*5d5fbe79SDavid van Moolenbroek 
197*5d5fbe79SDavid van Moolenbroek #endif /* LWIP_SNMP */
198*5d5fbe79SDavid van Moolenbroek 
199*5d5fbe79SDavid van Moolenbroek #endif /* LWIP_HDR_APPS_SNMP_MSG_H */
200