/* radare - LGPL - Copyright 2009-2015 - pancake, nibble */ typedef void (*HashHandler)(const ut8 *block, int len); static void handle_md4 (const ut8 *block, int len); static void handle_md5 (const ut8 *block, int len); static void handle_sha1 (const ut8 *block, int len); static void handle_sha256 (const ut8 *block, int len); static void handle_sha512 (const ut8 *block, int len); static void handle_adler32 (const ut8 *block, int len); static void handle_crc32 (const ut8 *block, int len); static void handle_crc16 (const ut8 *block, int len); static void handle_xor (const ut8 *block, int len); static void handle_entropy (const ut8 *block, int len); static void handle_hamdist (const ut8 *block, int len); static void handle_parity (const ut8 *block, int len); static void handle_pcprint (const ut8 *input, int len); typedef struct { const char *name; HashHandler handler; } RHashHashHandlers; static RHashHashHandlers hash_handlers[] = { {"md4", handle_md4}, {"md5", handle_md5}, {"sha1", handle_sha1}, {"sha256", handle_sha256}, {"sha512", handle_sha512}, {"adler32", handle_adler32}, {"crc32", handle_crc32}, {"crc16", handle_crc16}, {"xor", handle_xor}, {"entropy", handle_entropy}, {"parity", handle_parity}, {"hamdist", handle_hamdist}, {"pcprint", handle_pcprint}, {NULL, NULL}, }; static void handle_md4 (const ut8 *block, int len) { int i = 0; RHash *ctx = r_hash_new (true, R_HASH_MD4); const ut8 *c = r_hash_do_md4 (ctx, block, len); for (i=0; ilang, ptr); if (p && p->name) lang = p->name; } if (*lang==' ') { RLangPlugin *p = r_lang_get_by_extension (core->lang, input+2); if (p && p->name) lang = p->name; } else if (input[1]=='?' || input[1]=='*' || input[1]=='\0') { r_lang_list (core->lang); return true; } p = strchr (input, ' '); if (p) *p=0; // TODO: set argv here if (r_lang_use (core->lang, lang)) { r_lang_setup (core->lang); if (p) { r_lang_run_file (core->lang, p+1); } else { if (r_config_get_i (core->config, "scr.interactive")) { r_lang_prompt (core->lang); } else eprintf ("Error: scr.interactive required to run the rlang prompt\n"); } } else { if (!p || *p==' ') eprintf ("Invalid hashbang. See '#!' for help.\n"); } return true; } static int cmd_hash(void *data, const char *input) { char algo[32]; RCore *core = (RCore *)data; ut32 osize = 0, len = core->blocksize; const char *ptr; int pos = 0, handled_cmd = false; switch (*input) { case '\t': case ' ': return 0; case '#': if (!input[1]) { algolist (1); return true; } case '!': return cmd_hash_bang (core, input); } ptr = strchr (input, ' '); sscanf (input, "%31s", algo); if (ptr && *(ptr+1) && r_num_is_valid_input (core->num, ptr+1)) { int nlen = r_num_math (core->num, ptr+1); if (nlen>0) len = nlen; osize = core->blocksize; if (nlen>core->blocksize) { r_core_block_size (core, nlen); if (nlen != core->blocksize) { eprintf ("Invalid block size\n"); r_core_block_size (core, osize); return true; } } } else if (!ptr || !*(ptr+1)) osize = len; /* TODO: Simplify this spaguetti monster */ while (osize > 0 && hash_handlers[pos].name != NULL) { if (!r_str_ccmp (input, hash_handlers[pos].name, ' ')) { hash_handlers[pos].handler (core->block, len); handled_cmd = true; break; } pos++; } if (!osize) { eprintf ("Error: provided size must be size > 0\n"); } if (*input == '?') { const char *helpmsg[] = { "Usage: #algo @ addr", "", "", " #"," comment","note the space after the sharp sign", " ##","","List hash/checksum algorithms.", " #sha256", " 10K @ 33","calculate sha256 of 10K at 33", NULL }; const char *helpmsg2[] = { "Hashes:","","", NULL }; const char *helpmsg3[] = { "Usage #!interpreter [] [