gambas-source-code/main/lib/hash/main.c
Benoît Minisini 0b7c342e8e Add Md5(), Sha1(), Sha256() and Sha512() functions.
[CONFIGURATION]
* NEW: Update 'README' and 'README.md' files.

[COMPILER]
* NEW: Add Md5(), Sha1(), Sha256() and Sha512() functions.

[INTERPRETER]
* NEW: Add Md5(), Sha1(), Sha256() and Sha512() functions.

[GB.HASH]
* NEW: This is a new component that implements the Md5(), Sha1(), Sha256() and Sha512() functions.
  The code comes from BusyBox.
2022-09-13 02:48:11 +02:00

143 lines
2.8 KiB
C

/***************************************************************************
main.c
(c) Benoît Minisini <benoit.minisini@gambas-basic.org>
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2, or (at your option)
any later version.
This program 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 General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
MA 02110-1301, USA.
***************************************************************************/
#define __MAIN_C
#include <stdio.h>
#include <stdlib.h>
#include <stdarg.h>
#include <string.h>
#include <ctype.h>
#include "gb_common.h"
#include "hash.h"
#include "main.h"
const GB_INTERFACE *GB_PTR EXPORT;
static union {
//sha3_ctx_t sha3;
sha512_ctx_t sha512;
sha256_ctx_t sha256;
sha1_ctx_t sha1;
md5_ctx_t md5;
} _context;
static int _algo = -1;
static void (*_update)(void*, const void*, size_t);
static unsigned (*_final)(void*, void*);
static int _hash_len;
static bool hash_begin(int algo)
{
switch(algo)
{
case HASH_MD5:
md5_begin(&_context.md5);
_update = (void*)md5_hash;
_final = (void*)md5_end;
_hash_len = 16;
break;
case HASH_SHA1:
sha1_begin(&_context.sha1);
_update = (void*)sha1_hash;
_final = (void*)sha1_end;
_hash_len = 20;
break;
case HASH_SHA256:
sha256_begin(&_context.sha256);
_update = (void*)sha256_hash;
_final = (void*)sha256_end;
_hash_len = 32;
break;
case HASH_SHA512:
sha512_begin(&_context.sha512);
_update = (void*)sha512_hash;
_final = (void*)sha512_end;
_hash_len = 64;
break;
default:
return TRUE;
}
_algo = algo;
return FALSE;
}
static void hash_process(const void *data, size_t len)
{
if (_algo < 0)
return;
(*_update)(&_context, data, len);
}
static char *hash_end(void)
{
static const char hex_digit[16] = "0123456789ABCDEF";
char *result = NULL;
unsigned char hash[64];
char hex[2];
int size;
int i;
if (_algo < 0)
return NULL;
size = (*_final)(&_context, (void *)&hash[0]);
for (i = 0; i < size; i++)
{
hex[0] = hex_digit[hash[i] >> 4];
hex[1] = hex_digit[hash[i] & 15];
result = GB.AddString(result, hex, 2);
}
GB.FreeStringLater(result);
return result;
}
void *GB_HASH_1[] EXPORT = {
(void *)1,
hash_begin,
hash_process,
hash_end,
NULL
};
int EXPORT GB_INIT(void)
{
return 0;
}
void EXPORT GB_EXIT()
{
}