1*5d5fbe79SDavid van Moolenbroek /** 2*5d5fbe79SDavid van Moolenbroek * @file 3*5d5fbe79SDavid van Moolenbroek * Additional SNMPv3 functionality RFC3414 and RFC3826 (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) 2016 Elias Oenal. 8*5d5fbe79SDavid van Moolenbroek * All rights reserved. 9*5d5fbe79SDavid van Moolenbroek * 10*5d5fbe79SDavid van Moolenbroek * Redistribution and use in source and binary forms, with or without modification, 11*5d5fbe79SDavid van Moolenbroek * are permitted provided that the following conditions are met: 12*5d5fbe79SDavid van Moolenbroek * 13*5d5fbe79SDavid van Moolenbroek * 1. Redistributions of source code must retain the above copyright notice, 14*5d5fbe79SDavid van Moolenbroek * this list of conditions and the following disclaimer. 15*5d5fbe79SDavid van Moolenbroek * 2. Redistributions in binary form must reproduce the above copyright notice, 16*5d5fbe79SDavid van Moolenbroek * this list of conditions and the following disclaimer in the documentation 17*5d5fbe79SDavid van Moolenbroek * and/or other materials provided with the distribution. 18*5d5fbe79SDavid van Moolenbroek * 3. The name of the author may not be used to endorse or promote products 19*5d5fbe79SDavid van Moolenbroek * derived from this software without specific prior written permission. 20*5d5fbe79SDavid van Moolenbroek * 21*5d5fbe79SDavid van Moolenbroek * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED 22*5d5fbe79SDavid van Moolenbroek * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF 23*5d5fbe79SDavid van Moolenbroek * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT 24*5d5fbe79SDavid van Moolenbroek * SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 25*5d5fbe79SDavid van Moolenbroek * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT 26*5d5fbe79SDavid van Moolenbroek * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 27*5d5fbe79SDavid van Moolenbroek * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 28*5d5fbe79SDavid van Moolenbroek * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING 29*5d5fbe79SDavid van Moolenbroek * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY 30*5d5fbe79SDavid van Moolenbroek * OF SUCH DAMAGE. 31*5d5fbe79SDavid van Moolenbroek * 32*5d5fbe79SDavid van Moolenbroek * Author: Elias Oenal <lwip@eliasoenal.com> 33*5d5fbe79SDavid van Moolenbroek */ 34*5d5fbe79SDavid van Moolenbroek 35*5d5fbe79SDavid van Moolenbroek #ifndef LWIP_HDR_APPS_SNMP_V3_PRIV_H 36*5d5fbe79SDavid van Moolenbroek #define LWIP_HDR_APPS_SNMP_V3_PRIV_H 37*5d5fbe79SDavid van Moolenbroek 38*5d5fbe79SDavid van Moolenbroek #include "lwip/apps/snmp_opts.h" 39*5d5fbe79SDavid van Moolenbroek 40*5d5fbe79SDavid van Moolenbroek #if LWIP_SNMP && LWIP_SNMP_V3 41*5d5fbe79SDavid van Moolenbroek 42*5d5fbe79SDavid van Moolenbroek #include "lwip/apps/snmpv3.h" 43*5d5fbe79SDavid van Moolenbroek #include "snmp_pbuf_stream.h" 44*5d5fbe79SDavid van Moolenbroek 45*5d5fbe79SDavid van Moolenbroek /* According to RFC 3411 */ 46*5d5fbe79SDavid van Moolenbroek #define SNMP_V3_MAX_ENGINE_ID_LENGTH 32 47*5d5fbe79SDavid van Moolenbroek #define SNMP_V3_MAX_USER_LENGTH 32 48*5d5fbe79SDavid van Moolenbroek 49*5d5fbe79SDavid van Moolenbroek #define SNMP_V3_MAX_AUTH_PARAM_LENGTH 12 50*5d5fbe79SDavid van Moolenbroek #define SNMP_V3_MAX_PRIV_PARAM_LENGTH 8 51*5d5fbe79SDavid van Moolenbroek 52*5d5fbe79SDavid van Moolenbroek #define SNMP_V3_MD5_LEN 16 53*5d5fbe79SDavid van Moolenbroek #define SNMP_V3_SHA_LEN 20 54*5d5fbe79SDavid van Moolenbroek 55*5d5fbe79SDavid van Moolenbroek typedef enum 56*5d5fbe79SDavid van Moolenbroek { 57*5d5fbe79SDavid van Moolenbroek SNMP_V3_PRIV_MODE_DECRYPT = 0, 58*5d5fbe79SDavid van Moolenbroek SNMP_V3_PRIV_MODE_ENCRYPT = 1 59*5d5fbe79SDavid van Moolenbroek } snmpv3_priv_mode_t; 60*5d5fbe79SDavid van Moolenbroek 61*5d5fbe79SDavid van Moolenbroek s32_t snmpv3_get_engine_boots_internal(void); 62*5d5fbe79SDavid van Moolenbroek err_t snmpv3_auth(struct snmp_pbuf_stream* stream, u16_t length, const u8_t* key, snmpv3_auth_algo_t algo, u8_t* hmac_out); 63*5d5fbe79SDavid van Moolenbroek err_t snmpv3_crypt(struct snmp_pbuf_stream* stream, u16_t length, const u8_t* key, 64*5d5fbe79SDavid van Moolenbroek const u8_t* priv_param, const u32_t engine_boots, const u32_t engine_time, snmpv3_priv_algo_t algo, snmpv3_priv_mode_t mode); 65*5d5fbe79SDavid van Moolenbroek err_t snmpv3_build_priv_param(u8_t* priv_param); 66*5d5fbe79SDavid van Moolenbroek void snmpv3_enginetime_timer(void *arg); 67*5d5fbe79SDavid van Moolenbroek 68*5d5fbe79SDavid van Moolenbroek #endif 69*5d5fbe79SDavid van Moolenbroek 70*5d5fbe79SDavid van Moolenbroek #endif /* LWIP_HDR_APPS_SNMP_V3_PRIV_H */ 71