| /** | 
 |  * \file sha1.h | 
 |  * based from http://xyssl.org/code/source/sha1/ | 
 |  *  FIPS-180-1 compliant SHA-1 implementation | 
 |  * | 
 |  *  Copyright (C) 2003-2006  Christophe Devine | 
 |  * | 
 |  *  This library is free software; you can redistribute it and/or | 
 |  *  modify it under the terms of the GNU Lesser General Public | 
 |  *  License, version 2.1 as published by the Free Software Foundation. | 
 |  * | 
 |  *  This library is distributed in the hope that it will be useful, | 
 |  *  but WITHOUT ANY WARRANTY; without even the implied warranty of | 
 |  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | 
 |  *  Lesser General Public License for more details. | 
 |  * | 
 |  *  You should have received a copy of the GNU Lesser General Public | 
 |  *  License along with this library; if not, write to the Free Software | 
 |  *  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, | 
 |  *  MA	02110-1301  USA | 
 |  */ | 
 | /* | 
 |  *  The SHA-1 standard was published by NIST in 1993. | 
 |  * | 
 |  *  http://www.itl.nist.gov/fipspubs/fip180-1.htm | 
 |  */ | 
 | #ifndef _SHA1_H | 
 | #define _SHA1_H | 
 |  | 
 | #ifdef __cplusplus | 
 | extern "C" { | 
 | #endif | 
 |  | 
 | #define SHA1_SUM_POS	-0x20 | 
 | #define SHA1_SUM_LEN	20 | 
 |  | 
 | /** | 
 |  * \brief	   SHA-1 context structure | 
 |  */ | 
 | typedef struct | 
 | { | 
 |     unsigned long total[2];	/*!< number of bytes processed	*/ | 
 |     unsigned long state[5];	/*!< intermediate digest state	*/ | 
 |     unsigned char buffer[64];	/*!< data block being processed */ | 
 | } | 
 | sha1_context; | 
 |  | 
 | /** | 
 |  * \brief	   SHA-1 context setup | 
 |  * | 
 |  * \param ctx	   SHA-1 context to be initialized | 
 |  */ | 
 | void sha1_starts( sha1_context *ctx ); | 
 |  | 
 | /** | 
 |  * \brief	   SHA-1 process buffer | 
 |  * | 
 |  * \param ctx	   SHA-1 context | 
 |  * \param input    buffer holding the  data | 
 |  * \param ilen	   length of the input data | 
 |  */ | 
 | void sha1_update( sha1_context *ctx, unsigned char *input, int ilen ); | 
 |  | 
 | /** | 
 |  * \brief	   SHA-1 final digest | 
 |  * | 
 |  * \param ctx	   SHA-1 context | 
 |  * \param output   SHA-1 checksum result | 
 |  */ | 
 | void sha1_finish( sha1_context *ctx, unsigned char output[20] ); | 
 |  | 
 | /** | 
 |  * \brief	   Output = SHA-1( input buffer ) | 
 |  * | 
 |  * \param input    buffer holding the  data | 
 |  * \param ilen	   length of the input data | 
 |  * \param output   SHA-1 checksum result | 
 |  */ | 
 | void sha1_csum( unsigned char *input, int ilen, | 
 | 		unsigned char output[20] ); | 
 |  | 
 | /** | 
 |  * \brief	   Output = SHA-1( input buffer ), with watchdog triggering | 
 |  * | 
 |  * \param input    buffer holding the  data | 
 |  * \param ilen	   length of the input data | 
 |  * \param output   SHA-1 checksum result | 
 |  * \param chunk_sz watchdog triggering period (in bytes of input processed) | 
 |  */ | 
 | void sha1_csum_wd (unsigned char *input, int ilen, | 
 | 		unsigned char output[20], unsigned int chunk_sz); | 
 |  | 
 | /** | 
 |  * \brief	   Output = SHA-1( file contents ) | 
 |  * | 
 |  * \param path	   input file name | 
 |  * \param output   SHA-1 checksum result | 
 |  * \return	   0 if successful, or 1 if fopen failed | 
 |  */ | 
 | int sha1_file( char *path, unsigned char output[20] ); | 
 |  | 
 | /** | 
 |  * \brief	   Output = HMAC-SHA-1( input buffer, hmac key ) | 
 |  * | 
 |  * \param key	   HMAC secret key | 
 |  * \param keylen   length of the HMAC key | 
 |  * \param input    buffer holding the  data | 
 |  * \param ilen	   length of the input data | 
 |  * \param output   HMAC-SHA-1 result | 
 |  */ | 
 | void sha1_hmac( unsigned char *key, int keylen, | 
 | 		unsigned char *input, int ilen, | 
 | 		unsigned char output[20] ); | 
 |  | 
 | /** | 
 |  * \brief	   Checkup routine | 
 |  * | 
 |  * \return	   0 if successful, or 1 if the test failed | 
 |  */ | 
 | int sha1_self_test( void ); | 
 |  | 
 | #ifdef __cplusplus | 
 | } | 
 | #endif | 
 |  | 
 | #endif /* sha1.h */ |