mirror of
https://github.com/radareorg/radare2.git
synced 2025-01-01 02:33:50 +00:00
97 lines
2.3 KiB
C
97 lines
2.3 KiB
C
/* radare - LGPL - Copyright 2009-2017 pancake */
|
|
|
|
#include <r_hash.h>
|
|
#include "sha1.h"
|
|
#include "sha2.h"
|
|
|
|
R_API void mdfour(ut8 *out, const ut8 *in, int n);
|
|
|
|
#define CHKFLAG(x) if (!flags || flags & x)
|
|
|
|
R_API RHash *r_hash_new(bool rst, int flags) {
|
|
RHash *ctx = R_NEW0 (RHash);
|
|
if (ctx) {
|
|
r_hash_do_begin (ctx, flags);
|
|
ctx->rst = rst;
|
|
}
|
|
return ctx;
|
|
}
|
|
|
|
R_API void r_hash_do_begin(RHash *ctx, int flags) {
|
|
CHKFLAG (R_HASH_MD5) r_hash_do_md5 (ctx, NULL, -1);
|
|
CHKFLAG (R_HASH_SHA1) SHA1_Init (&ctx->sha1);
|
|
CHKFLAG (R_HASH_SHA256) SHA256_Init (&ctx->sha256);
|
|
CHKFLAG (R_HASH_SHA384) SHA384_Init (&ctx->sha384);
|
|
CHKFLAG (R_HASH_SHA512) SHA512_Init (&ctx->sha512);
|
|
ctx->rst = false;
|
|
}
|
|
|
|
R_API void r_hash_do_end(RHash *ctx, int flags) {
|
|
CHKFLAG (R_HASH_MD5) r_hash_do_md5 (ctx, NULL, -2);
|
|
CHKFLAG (R_HASH_SHA1) SHA1_Final (ctx->digest, &ctx->sha1);
|
|
CHKFLAG (R_HASH_SHA256) SHA256_Final (ctx->digest, &ctx->sha256);
|
|
CHKFLAG (R_HASH_SHA384) SHA384_Final (ctx->digest, &ctx->sha384);
|
|
CHKFLAG (R_HASH_SHA512) SHA512_Final (ctx->digest, &ctx->sha512);
|
|
ctx->rst = true;
|
|
}
|
|
|
|
R_API void r_hash_free(RHash *ctx) {
|
|
free (ctx);
|
|
}
|
|
|
|
R_API ut8 *r_hash_do_sha1(RHash *ctx, const ut8 *input, int len) {
|
|
if (len < 0) {
|
|
return NULL;
|
|
}
|
|
if (ctx->rst) {
|
|
SHA1_Init (&ctx->sha1);
|
|
}
|
|
SHA1_Update (&ctx->sha1, input, len);
|
|
if (ctx->rst || len == 0) {
|
|
SHA1_Final (ctx->digest, &ctx->sha1);
|
|
}
|
|
return ctx->digest;
|
|
}
|
|
|
|
R_API ut8 *r_hash_do_sha256(RHash *ctx, const ut8 *input, int len) {
|
|
if (len < 0) {
|
|
return NULL;
|
|
}
|
|
if (ctx->rst) {
|
|
SHA256_Init (&ctx->sha256);
|
|
}
|
|
SHA256_Update (&ctx->sha256, input, len);
|
|
if (ctx->rst || len == 0) {
|
|
SHA256_Final (ctx->digest, &ctx->sha256);
|
|
}
|
|
return ctx->digest;
|
|
}
|
|
|
|
R_API ut8 *r_hash_do_sha384(RHash *ctx, const ut8 *input, int len) {
|
|
if (len < 0) {
|
|
return NULL;
|
|
}
|
|
if (ctx->rst) {
|
|
SHA384_Init (&ctx->sha384);
|
|
}
|
|
SHA384_Update (&ctx->sha384, input, len);
|
|
if (ctx->rst || len == 0) {
|
|
SHA384_Final (ctx->digest, &ctx->sha384);
|
|
}
|
|
return ctx->digest;
|
|
}
|
|
|
|
R_API ut8 *r_hash_do_sha512(RHash *ctx, const ut8 *input, int len) {
|
|
if (len < 0) {
|
|
return NULL;
|
|
}
|
|
if (ctx->rst) {
|
|
SHA512_Init (&ctx->sha512);
|
|
}
|
|
SHA512_Update (&ctx->sha512, input, len);
|
|
if (ctx->rst || len == 0) {
|
|
SHA512_Final (ctx->digest, &ctx->sha512);
|
|
}
|
|
return ctx->digest;
|
|
}
|