1*8fb009dcSAndroid Build Coastguard Worker /* Copyright (C) 1995-1998 Eric Young ([email protected]) 2*8fb009dcSAndroid Build Coastguard Worker * All rights reserved. 3*8fb009dcSAndroid Build Coastguard Worker * 4*8fb009dcSAndroid Build Coastguard Worker * This package is an SSL implementation written 5*8fb009dcSAndroid Build Coastguard Worker * by Eric Young ([email protected]). 6*8fb009dcSAndroid Build Coastguard Worker * The implementation was written so as to conform with Netscapes SSL. 7*8fb009dcSAndroid Build Coastguard Worker * 8*8fb009dcSAndroid Build Coastguard Worker * This library is free for commercial and non-commercial use as long as 9*8fb009dcSAndroid Build Coastguard Worker * the following conditions are aheared to. The following conditions 10*8fb009dcSAndroid Build Coastguard Worker * apply to all code found in this distribution, be it the RC4, RSA, 11*8fb009dcSAndroid Build Coastguard Worker * lhash, DES, etc., code; not just the SSL code. The SSL documentation 12*8fb009dcSAndroid Build Coastguard Worker * included with this distribution is covered by the same copyright terms 13*8fb009dcSAndroid Build Coastguard Worker * except that the holder is Tim Hudson ([email protected]). 14*8fb009dcSAndroid Build Coastguard Worker * 15*8fb009dcSAndroid Build Coastguard Worker * Copyright remains Eric Young's, and as such any Copyright notices in 16*8fb009dcSAndroid Build Coastguard Worker * the code are not to be removed. 17*8fb009dcSAndroid Build Coastguard Worker * If this package is used in a product, Eric Young should be given attribution 18*8fb009dcSAndroid Build Coastguard Worker * as the author of the parts of the library used. 19*8fb009dcSAndroid Build Coastguard Worker * This can be in the form of a textual message at program startup or 20*8fb009dcSAndroid Build Coastguard Worker * in documentation (online or textual) provided with the package. 21*8fb009dcSAndroid Build Coastguard Worker * 22*8fb009dcSAndroid Build Coastguard Worker * Redistribution and use in source and binary forms, with or without 23*8fb009dcSAndroid Build Coastguard Worker * modification, are permitted provided that the following conditions 24*8fb009dcSAndroid Build Coastguard Worker * are met: 25*8fb009dcSAndroid Build Coastguard Worker * 1. Redistributions of source code must retain the copyright 26*8fb009dcSAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer. 27*8fb009dcSAndroid Build Coastguard Worker * 2. Redistributions in binary form must reproduce the above copyright 28*8fb009dcSAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer in the 29*8fb009dcSAndroid Build Coastguard Worker * documentation and/or other materials provided with the distribution. 30*8fb009dcSAndroid Build Coastguard Worker * 3. All advertising materials mentioning features or use of this software 31*8fb009dcSAndroid Build Coastguard Worker * must display the following acknowledgement: 32*8fb009dcSAndroid Build Coastguard Worker * "This product includes cryptographic software written by 33*8fb009dcSAndroid Build Coastguard Worker * Eric Young ([email protected])" 34*8fb009dcSAndroid Build Coastguard Worker * The word 'cryptographic' can be left out if the rouines from the library 35*8fb009dcSAndroid Build Coastguard Worker * being used are not cryptographic related :-). 36*8fb009dcSAndroid Build Coastguard Worker * 4. If you include any Windows specific code (or a derivative thereof) from 37*8fb009dcSAndroid Build Coastguard Worker * the apps directory (application code) you must include an acknowledgement: 38*8fb009dcSAndroid Build Coastguard Worker * "This product includes software written by Tim Hudson ([email protected])" 39*8fb009dcSAndroid Build Coastguard Worker * 40*8fb009dcSAndroid Build Coastguard Worker * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND 41*8fb009dcSAndroid Build Coastguard Worker * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 42*8fb009dcSAndroid Build Coastguard Worker * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 43*8fb009dcSAndroid Build Coastguard Worker * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 44*8fb009dcSAndroid Build Coastguard Worker * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 45*8fb009dcSAndroid Build Coastguard Worker * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 46*8fb009dcSAndroid Build Coastguard Worker * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 47*8fb009dcSAndroid Build Coastguard Worker * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 48*8fb009dcSAndroid Build Coastguard Worker * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 49*8fb009dcSAndroid Build Coastguard Worker * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 50*8fb009dcSAndroid Build Coastguard Worker * SUCH DAMAGE. 51*8fb009dcSAndroid Build Coastguard Worker * 52*8fb009dcSAndroid Build Coastguard Worker * The licence and distribution terms for any publically available version or 53*8fb009dcSAndroid Build Coastguard Worker * derivative of this code cannot be changed. i.e. this code cannot simply be 54*8fb009dcSAndroid Build Coastguard Worker * copied and put under another distribution licence 55*8fb009dcSAndroid Build Coastguard Worker * [including the GNU Public Licence.] */ 56*8fb009dcSAndroid Build Coastguard Worker 57*8fb009dcSAndroid Build Coastguard Worker #ifndef OPENSSL_HEADER_HMAC_H 58*8fb009dcSAndroid Build Coastguard Worker #define OPENSSL_HEADER_HMAC_H 59*8fb009dcSAndroid Build Coastguard Worker 60*8fb009dcSAndroid Build Coastguard Worker #include <openssl/base.h> 61*8fb009dcSAndroid Build Coastguard Worker 62*8fb009dcSAndroid Build Coastguard Worker #include <openssl/digest.h> 63*8fb009dcSAndroid Build Coastguard Worker 64*8fb009dcSAndroid Build Coastguard Worker #if defined(__cplusplus) 65*8fb009dcSAndroid Build Coastguard Worker extern "C" { 66*8fb009dcSAndroid Build Coastguard Worker #endif 67*8fb009dcSAndroid Build Coastguard Worker 68*8fb009dcSAndroid Build Coastguard Worker 69*8fb009dcSAndroid Build Coastguard Worker // HMAC contains functions for constructing PRFs from Merkle–Damgård hash 70*8fb009dcSAndroid Build Coastguard Worker // functions using HMAC. 71*8fb009dcSAndroid Build Coastguard Worker 72*8fb009dcSAndroid Build Coastguard Worker 73*8fb009dcSAndroid Build Coastguard Worker // One-shot operation. 74*8fb009dcSAndroid Build Coastguard Worker 75*8fb009dcSAndroid Build Coastguard Worker // HMAC calculates the HMAC of |data_len| bytes of |data|, using the given key 76*8fb009dcSAndroid Build Coastguard Worker // and hash function, and writes the result to |out|. On entry, |out| must 77*8fb009dcSAndroid Build Coastguard Worker // contain at least |EVP_MD_size| bytes of space. The actual length of the 78*8fb009dcSAndroid Build Coastguard Worker // result is written to |*out_len|. An output size of |EVP_MAX_MD_SIZE| will 79*8fb009dcSAndroid Build Coastguard Worker // always be large enough. It returns |out| or NULL on error. 80*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT uint8_t *HMAC(const EVP_MD *evp_md, const void *key, 81*8fb009dcSAndroid Build Coastguard Worker size_t key_len, const uint8_t *data, 82*8fb009dcSAndroid Build Coastguard Worker size_t data_len, uint8_t *out, 83*8fb009dcSAndroid Build Coastguard Worker unsigned int *out_len); 84*8fb009dcSAndroid Build Coastguard Worker 85*8fb009dcSAndroid Build Coastguard Worker 86*8fb009dcSAndroid Build Coastguard Worker // Incremental operation. 87*8fb009dcSAndroid Build Coastguard Worker 88*8fb009dcSAndroid Build Coastguard Worker // HMAC_CTX_init initialises |ctx| for use in an HMAC operation. It's assumed 89*8fb009dcSAndroid Build Coastguard Worker // that HMAC_CTX objects will be allocated on the stack thus no allocation 90*8fb009dcSAndroid Build Coastguard Worker // function is provided. 91*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT void HMAC_CTX_init(HMAC_CTX *ctx); 92*8fb009dcSAndroid Build Coastguard Worker 93*8fb009dcSAndroid Build Coastguard Worker // HMAC_CTX_new allocates and initialises a new |HMAC_CTX| and returns it, or 94*8fb009dcSAndroid Build Coastguard Worker // NULL on allocation failure. The caller must use |HMAC_CTX_free| to release 95*8fb009dcSAndroid Build Coastguard Worker // the resulting object. 96*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT HMAC_CTX *HMAC_CTX_new(void); 97*8fb009dcSAndroid Build Coastguard Worker 98*8fb009dcSAndroid Build Coastguard Worker // HMAC_CTX_cleanup frees data owned by |ctx|. It does not free |ctx| itself. 99*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT void HMAC_CTX_cleanup(HMAC_CTX *ctx); 100*8fb009dcSAndroid Build Coastguard Worker 101*8fb009dcSAndroid Build Coastguard Worker // HMAC_CTX_cleanse zeros the digest state from |ctx| and then performs the 102*8fb009dcSAndroid Build Coastguard Worker // actions of |HMAC_CTX_cleanup|. 103*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT void HMAC_CTX_cleanse(HMAC_CTX *ctx); 104*8fb009dcSAndroid Build Coastguard Worker 105*8fb009dcSAndroid Build Coastguard Worker // HMAC_CTX_free calls |HMAC_CTX_cleanup| and then frees |ctx| itself. 106*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT void HMAC_CTX_free(HMAC_CTX *ctx); 107*8fb009dcSAndroid Build Coastguard Worker 108*8fb009dcSAndroid Build Coastguard Worker // HMAC_Init_ex sets up an initialised |HMAC_CTX| to use |md| as the hash 109*8fb009dcSAndroid Build Coastguard Worker // function and |key| as the key. For a non-initial call, |md| may be NULL, in 110*8fb009dcSAndroid Build Coastguard Worker // which case the previous hash function will be used. If the hash function has 111*8fb009dcSAndroid Build Coastguard Worker // not changed and |key| is NULL, |ctx| reuses the previous key. It returns one 112*8fb009dcSAndroid Build Coastguard Worker // on success or zero on allocation failure. 113*8fb009dcSAndroid Build Coastguard Worker // 114*8fb009dcSAndroid Build Coastguard Worker // WARNING: NULL and empty keys are ambiguous on non-initial calls. Passing NULL 115*8fb009dcSAndroid Build Coastguard Worker // |key| but repeating the previous |md| reuses the previous key rather than the 116*8fb009dcSAndroid Build Coastguard Worker // empty key. 117*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT int HMAC_Init_ex(HMAC_CTX *ctx, const void *key, size_t key_len, 118*8fb009dcSAndroid Build Coastguard Worker const EVP_MD *md, ENGINE *impl); 119*8fb009dcSAndroid Build Coastguard Worker 120*8fb009dcSAndroid Build Coastguard Worker // HMAC_Update hashes |data_len| bytes from |data| into the current HMAC 121*8fb009dcSAndroid Build Coastguard Worker // operation in |ctx|. It returns one. 122*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT int HMAC_Update(HMAC_CTX *ctx, const uint8_t *data, 123*8fb009dcSAndroid Build Coastguard Worker size_t data_len); 124*8fb009dcSAndroid Build Coastguard Worker 125*8fb009dcSAndroid Build Coastguard Worker // HMAC_Final completes the HMAC operation in |ctx| and writes the result to 126*8fb009dcSAndroid Build Coastguard Worker // |out| and the sets |*out_len| to the length of the result. On entry, |out| 127*8fb009dcSAndroid Build Coastguard Worker // must contain at least |HMAC_size| bytes of space. An output size of 128*8fb009dcSAndroid Build Coastguard Worker // |EVP_MAX_MD_SIZE| will always be large enough. It returns one on success or 129*8fb009dcSAndroid Build Coastguard Worker // zero on allocation failure. 130*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT int HMAC_Final(HMAC_CTX *ctx, uint8_t *out, 131*8fb009dcSAndroid Build Coastguard Worker unsigned int *out_len); 132*8fb009dcSAndroid Build Coastguard Worker 133*8fb009dcSAndroid Build Coastguard Worker 134*8fb009dcSAndroid Build Coastguard Worker // Utility functions. 135*8fb009dcSAndroid Build Coastguard Worker 136*8fb009dcSAndroid Build Coastguard Worker // HMAC_size returns the size, in bytes, of the HMAC that will be produced by 137*8fb009dcSAndroid Build Coastguard Worker // |ctx|. On entry, |ctx| must have been setup with |HMAC_Init_ex|. 138*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT size_t HMAC_size(const HMAC_CTX *ctx); 139*8fb009dcSAndroid Build Coastguard Worker 140*8fb009dcSAndroid Build Coastguard Worker // HMAC_CTX_get_md returns |ctx|'s hash function. 141*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT const EVP_MD *HMAC_CTX_get_md(const HMAC_CTX *ctx); 142*8fb009dcSAndroid Build Coastguard Worker 143*8fb009dcSAndroid Build Coastguard Worker // HMAC_CTX_copy_ex sets |dest| equal to |src|. On entry, |dest| must have been 144*8fb009dcSAndroid Build Coastguard Worker // initialised by calling |HMAC_CTX_init|. It returns one on success and zero 145*8fb009dcSAndroid Build Coastguard Worker // on error. 146*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT int HMAC_CTX_copy_ex(HMAC_CTX *dest, const HMAC_CTX *src); 147*8fb009dcSAndroid Build Coastguard Worker 148*8fb009dcSAndroid Build Coastguard Worker // HMAC_CTX_reset calls |HMAC_CTX_cleanup| followed by |HMAC_CTX_init|. 149*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT void HMAC_CTX_reset(HMAC_CTX *ctx); 150*8fb009dcSAndroid Build Coastguard Worker 151*8fb009dcSAndroid Build Coastguard Worker 152*8fb009dcSAndroid Build Coastguard Worker // Deprecated functions. 153*8fb009dcSAndroid Build Coastguard Worker 154*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT int HMAC_Init(HMAC_CTX *ctx, const void *key, int key_len, 155*8fb009dcSAndroid Build Coastguard Worker const EVP_MD *md); 156*8fb009dcSAndroid Build Coastguard Worker 157*8fb009dcSAndroid Build Coastguard Worker // HMAC_CTX_copy calls |HMAC_CTX_init| on |dest| and then sets it equal to 158*8fb009dcSAndroid Build Coastguard Worker // |src|. On entry, |dest| must /not/ be initialised for an operation with 159*8fb009dcSAndroid Build Coastguard Worker // |HMAC_Init_ex|. It returns one on success and zero on error. 160*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT int HMAC_CTX_copy(HMAC_CTX *dest, const HMAC_CTX *src); 161*8fb009dcSAndroid Build Coastguard Worker 162*8fb009dcSAndroid Build Coastguard Worker 163*8fb009dcSAndroid Build Coastguard Worker // Private functions 164*8fb009dcSAndroid Build Coastguard Worker 165*8fb009dcSAndroid Build Coastguard Worker struct hmac_ctx_st { 166*8fb009dcSAndroid Build Coastguard Worker const EVP_MD *md; 167*8fb009dcSAndroid Build Coastguard Worker EVP_MD_CTX md_ctx; 168*8fb009dcSAndroid Build Coastguard Worker EVP_MD_CTX i_ctx; 169*8fb009dcSAndroid Build Coastguard Worker EVP_MD_CTX o_ctx; 170*8fb009dcSAndroid Build Coastguard Worker } /* HMAC_CTX */; 171*8fb009dcSAndroid Build Coastguard Worker 172*8fb009dcSAndroid Build Coastguard Worker 173*8fb009dcSAndroid Build Coastguard Worker #if defined(__cplusplus) 174*8fb009dcSAndroid Build Coastguard Worker } // extern C 175*8fb009dcSAndroid Build Coastguard Worker 176*8fb009dcSAndroid Build Coastguard Worker #if !defined(BORINGSSL_NO_CXX) 177*8fb009dcSAndroid Build Coastguard Worker extern "C++" { 178*8fb009dcSAndroid Build Coastguard Worker 179*8fb009dcSAndroid Build Coastguard Worker BSSL_NAMESPACE_BEGIN 180*8fb009dcSAndroid Build Coastguard Worker 181*8fb009dcSAndroid Build Coastguard Worker BORINGSSL_MAKE_DELETER(HMAC_CTX, HMAC_CTX_free) 182*8fb009dcSAndroid Build Coastguard Worker 183*8fb009dcSAndroid Build Coastguard Worker using ScopedHMAC_CTX = 184*8fb009dcSAndroid Build Coastguard Worker internal::StackAllocated<HMAC_CTX, void, HMAC_CTX_init, HMAC_CTX_cleanup>; 185*8fb009dcSAndroid Build Coastguard Worker 186*8fb009dcSAndroid Build Coastguard Worker BSSL_NAMESPACE_END 187*8fb009dcSAndroid Build Coastguard Worker 188*8fb009dcSAndroid Build Coastguard Worker } // extern C++ 189*8fb009dcSAndroid Build Coastguard Worker #endif 190*8fb009dcSAndroid Build Coastguard Worker 191*8fb009dcSAndroid Build Coastguard Worker #endif 192*8fb009dcSAndroid Build Coastguard Worker 193*8fb009dcSAndroid Build Coastguard Worker #endif // OPENSSL_HEADER_HMAC_H 194