mirror of https://github.com/AxioDL/nod.git
46 lines
782 B
C
46 lines
782 B
C
|
#ifndef __SHA1_H__
|
||
|
#define __SHA1_H__
|
||
|
|
||
|
#include <stdint.h>
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
#define SHA1_HASH_LENGTH 20
|
||
|
#define SHA1_BLOCK_LENGTH 64
|
||
|
|
||
|
typedef struct sha1nfo {
|
||
|
uint32_t buffer[SHA1_BLOCK_LENGTH/4];
|
||
|
uint32_t state[SHA1_HASH_LENGTH/4];
|
||
|
uint32_t byteCount;
|
||
|
uint8_t bufferOffset;
|
||
|
uint8_t keyBuffer[SHA1_BLOCK_LENGTH];
|
||
|
uint8_t innerHash[SHA1_HASH_LENGTH];
|
||
|
} sha1nfo;
|
||
|
|
||
|
/**
|
||
|
*/
|
||
|
void sha1_init(sha1nfo *s);
|
||
|
/**
|
||
|
*/
|
||
|
void sha1_writebyte(sha1nfo *s, uint8_t data);
|
||
|
/**
|
||
|
*/
|
||
|
void sha1_write(sha1nfo *s, const char *data, size_t len);
|
||
|
/**
|
||
|
*/
|
||
|
uint8_t* sha1_result(sha1nfo *s);
|
||
|
/**
|
||
|
*/
|
||
|
void sha1_initHmac(sha1nfo *s, const uint8_t* key, int keyLength);
|
||
|
/**
|
||
|
*/
|
||
|
uint8_t* sha1_resultHmac(sha1nfo *s);
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
#endif // __SHA1_H__
|