/*  $Id: md5.h 4567 2001-02-24 08:10:16Z rra $
**
**  RSA Data Security, Inc. MD5 Message-Digest Algorithm
**
**  LANDON CURT NOLL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
**  INCLUDING ALL IMPLIED WARRANTIES OF MER- CHANTABILITY AND FITNESS.  IN
**  NO EVENT SHALL LANDON CURT NOLL BE LIABLE FOR ANY SPECIAL, INDIRECT OR
**  CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF
**  USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
**  OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
**  PERFORMANCE OF THIS SOFTWARE.
**
**  Copyright (C) 1990, RSA Data Security, Inc. All rights reserved.
**
**  License to copy and use this software is granted provided that it is
**  identified as the "RSA Data Security, Inc. MD5 Message-Digest
**  Algorithm" in all material mentioning or referencing this software or
**  this function.
**
**  License is also granted to make and use derivative works provided that
**  such works are identified as "derived from the RSA Data Security,
**  Inc. MD5 Message-Digest Algorithm" in all material mentioning or
**  referencing the derived work.
**
**  RSA Data Security, Inc. makes no representations concerning either the
**  merchantability of this software or the suitability of this software for
**  any particular purpose.  It is provided "as is" without express or
**  implied warranty of any kind.
**
**  These notices must be retained in any copies of any part of this
**  documentation and/or software.
*/

#ifndef INN_MD5_H
#define INN_MD5_H 1

#include <inn/defines.h>

/* Make sure we have uint32_t. */
#include <sys/types.h>
#if INN_HAVE_INTTYPES_H
# include <inttypes.h>
#endif

/* SCO OpenServer gets int32_t from here. */
#if INN_HAVE_SYS_BITYPES_H
# include <sys/bitypes.h>
#endif

/* Bytes to process at once, defined by the algorithm. */ 
#define MD5_CHUNKSIZE   (1 << 6)
#define MD5_CHUNKWORDS  (MD5_CHUNKSIZE / sizeof(uint32_t))

/* Length of the digest, defined by the algorithm. */
#define MD5_DIGESTSIZE  16
#define MD5_DIGESTWORDS (MD5_DIGESTSIZE / sizeof(uint32_t))

BEGIN_DECLS

/* Data structure for MD5 message-digest computation. */
struct md5_context {
    uint32_t count[2];                          /* A 64-bit byte count. */
    uint32_t buf[MD5_DIGESTWORDS];              /* Scratch buffer. */
    union {
        unsigned char byte[MD5_CHUNKSIZE];      /* Byte chunk buffer. */
        uint32_t word[MD5_CHUNKWORDS];          /* Word chunk buffer. */
    } in;
    unsigned int datalen;                       /* Length of data in in. */
    unsigned char digest[MD5_DIGESTSIZE];       /* Final digest. */
};

extern void md5_hash(const unsigned char *, size_t, unsigned char *);
extern void md5_init(struct md5_context *);
extern void md5_update(struct md5_context *, const unsigned char *, size_t);
extern void md5_final(struct md5_context *);

END_DECLS

#endif /* !INN_MD5_H */