2018-06-20 02:45:36 -04:00
|
|
|
#ifndef MD5_h
|
|
|
|
#define MD5_h
|
|
|
|
|
2022-02-13 20:20:21 -05:00
|
|
|
#include "Platform.h"
|
2018-06-20 02:45:36 -04:00
|
|
|
|
|
|
|
/*
|
|
|
|
* This is an OpenSSL-compatible implementation of the RSA Data Security,
|
|
|
|
* Inc. MD5 Message-Digest Algorithm (RFC 1321).
|
|
|
|
*
|
|
|
|
* Written by Solar Designer <solar at openwall.com> in 2001, and placed
|
|
|
|
* in the public domain. There's absolutely no warranty.
|
|
|
|
*
|
|
|
|
* This differs from Colin Plumb's older public domain implementation in
|
|
|
|
* that no 32-bit integer data type is required, there's no compile-time
|
|
|
|
* endianness configuration, and the function prototypes match OpenSSL's.
|
|
|
|
* The primary goals are portability and ease of use.
|
|
|
|
*
|
|
|
|
* This implementation is meant to be fast, but not as fast as possible.
|
|
|
|
* Some known optimizations are not included to reduce source code size
|
|
|
|
* and avoid compile-time configuration.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Updated by Scott MacVicar for arduino
|
|
|
|
* <scott@macvicar.net>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
typedef unsigned long MD5_u32plus;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
MD5_u32plus lo, hi;
|
|
|
|
MD5_u32plus a, b, c, d;
|
|
|
|
unsigned char buffer[64];
|
|
|
|
MD5_u32plus block[16];
|
|
|
|
} MD5_CTX;
|
|
|
|
|
|
|
|
class MD5
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
MD5();
|
|
|
|
static unsigned char* make_hash(char *arg);
|
|
|
|
static unsigned char* make_hash(char *arg,size_t size);
|
|
|
|
static char* make_digest(const unsigned char *digest, int len);
|
|
|
|
static const void *body(void *ctxBuf, const void *data, size_t size);
|
|
|
|
static void MD5Init(void *ctxBuf);
|
|
|
|
static void MD5Final(unsigned char *result, void *ctxBuf);
|
|
|
|
static void MD5Update(void *ctxBuf, const void *data, size_t size);
|
|
|
|
};
|
|
|
|
|
2022-02-13 16:36:24 -05:00
|
|
|
#endif
|