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