/* radare - LGPL - Copyright 2009-2021 - pancake, nibble */ #include typedef void (*HashHandler)(const ut8 *block, int len); typedef struct { const char *name; HashHandler handler; } RHashHashHandlers; static inline void hexprint(const ut8 *data, int len) { int i = 0; for (i = 0; i < len; i++) { r_cons_printf ("%02x", data[i]); } r_cons_newline (); } static void handle_md4 (const ut8 *block, int len) { RHash *ctx = r_hash_new (true, R_HASH_MD4); const ut8 *c = r_hash_do_md4 (ctx, block, len); hexprint (c, R_HASH_SIZE_MD4); r_hash_free (ctx); } static void handle_md5 (const ut8 *block, int len) { RHash *ctx = r_hash_new (true, R_HASH_MD5); const ut8 *c = r_hash_do_md5 (ctx, block, len); hexprint (c, R_HASH_SIZE_MD5); r_hash_free (ctx); } static void handle_sha1 (const ut8 *block, int len) { RHash *ctx = r_hash_new (true, R_HASH_SHA1); const ut8 *c = r_hash_do_sha1 (ctx, block, len); hexprint (c, R_HASH_SIZE_SHA1); r_hash_free (ctx); } static void handle_sha256 (const ut8 *block, int len) { RHash *ctx = r_hash_new (true, R_HASH_SHA256); const ut8 *c = r_hash_do_sha256 (ctx, block, len); hexprint (c, R_HASH_SIZE_SHA256); r_hash_free (ctx); } static void handle_sha512 (const ut8 *block, int len) { RHash *ctx = r_hash_new (true, R_HASH_SHA512); const ut8 *c = r_hash_do_sha512 (ctx, block, len); hexprint (c, R_HASH_SIZE_SHA512); r_hash_free (ctx); } static void handle_adler32 (const ut8 *block, int len) { ut32 hn = r_hash_adler32 (block, len); hexprint ((ut8 *)&hn, sizeof (ut32)); } static void handle_xor (const ut8 *block, int len) { r_cons_printf ("%02x\n", r_hash_xor (block, len)); } static void handle_xorpair(const ut8 *block, int len) { r_cons_printf ("%04x\n", r_hash_xorpair (block, len)); } static void handle_entropy(const ut8 *block, int len) { r_cons_printf ("%f\n", r_hash_entropy (block, len)); } static void handle_parity (const ut8 *block, int len) { r_cons_printf ("%d\n", r_hash_parity (block, len)?1:0); } static void handle_hamdist (const ut8 *block, int len) { r_cons_printf ("%02x\n", r_hash_hamdist (block, len)); } static void handle_pcprint (const ut8 *block, int len) { r_cons_printf ("%d\n", r_hash_pcprint (block, len)); //r_cons_printf ("%02x\n", r_hash_pcprint (block, len)); } static void handle_mod255 (const ut8 *block, int len) { r_cons_printf ("%d\n", r_hash_mod255 (block, len)); //r_cons_printf ("%02x\n", r_hash_pcprint (block, len)); } static void handle_xxhash(const ut8 *block, int len) { r_cons_printf ("%" PFMT32x "\n", r_hash_xxhash (block, len)); } static void handle_luhn(const ut8 *block, int len) { r_cons_printf ("%" PFMT64u "\n", r_hash_luhn (block, len)); } static void handle_ssdeep(const ut8 *block, int len) { char *res = r_hash_ssdeep (block, len); r_cons_printf ("%s\n", res); free (res); } static void handle_crc8_smbus(const ut8 *block, int len) { r_cons_printf ("%02" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_8_SMBUS)); } #if R_HAVE_CRC8_EXTRA static void handle_crc8_cdma2000 (const ut8 *block, int len) { r_cons_printf ("%02" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC8_CDMA2000)); } static void handle_crc8_darc (const ut8 *block, int len) { r_cons_printf ("%02" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC8_DARC)); } static void handle_crc8_dvb_s2 (const ut8 *block, int len) { r_cons_printf ("%02" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC8_DVB_S2)); } static void handle_crc8_ebu (const ut8 *block, int len) { r_cons_printf ("%02" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC8_EBU)); } static void handle_crc8_icode (const ut8 *block, int len) { r_cons_printf ("%02" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC8_ICODE)); } static void handle_crc8_itu (const ut8 *block, int len) { r_cons_printf ("%02" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC8_ITU)); } static void handle_crc8_maxim (const ut8 *block, int len) { r_cons_printf ("%02" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC8_MAXIM)); } static void handle_crc8_rohc (const ut8 *block, int len) { r_cons_printf ("%02" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC8_ROHC)); } static void handle_crc8_wcdma (const ut8 *block, int len) { r_cons_printf ("%02" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC8_WCDMA)); } #endif /* #if R_HAVE_CRC8_EXTRA */ #if R_HAVE_CRC15_EXTRA static void handle_crc15_can (const ut8 *block, int len) { r_cons_printf ("%04" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_15_CAN)); } #endif /* #if R_HAVE_CRC15_EXTRA */ static void handle_crc16 (const ut8 *block, int len) { r_cons_printf ("%04" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_16)); } static void handle_crc16_hdlc (const ut8 *block, int len) { r_cons_printf ("%04" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_16_HDLC)); } static void handle_crc16_usb (const ut8 *block, int len) { r_cons_printf ("%04" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_16_USB)); } static void handle_crc16_citt (const ut8 *block, int len) { r_cons_printf ("%04" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_16_CITT)); } #if R_HAVE_CRC16_EXTRA static void handle_crc16_aug_ccitt (const ut8 *block, int len) { r_cons_printf ("%04" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC16_AUG_CCITT)); } static void handle_crc16_buypass (const ut8 *block, int len) { r_cons_printf ("%04" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC16_BUYPASS)); } static void handle_crc16_cdma2000 (const ut8 *block, int len) { r_cons_printf ("%04" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC16_CDMA2000)); } static void handle_crc16_dds110 (const ut8 *block, int len) { r_cons_printf ("%04" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC16_DDS110)); } static void handle_crc16_dect_r (const ut8 *block, int len) { r_cons_printf ("%04" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC16_DECT_R)); } static void handle_crc16_dect_x (const ut8 *block, int len) { r_cons_printf ("%04" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC16_DECT_X)); } static void handle_crc16_dnp (const ut8 *block, int len) { r_cons_printf ("%04" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC16_DNP)); } static void handle_crc16_en13757 (const ut8 *block, int len) { r_cons_printf ("%04" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC16_EN13757)); } static void handle_crc16_genibus (const ut8 *block, int len) { r_cons_printf ("%04" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC16_GENIBUS)); } static void handle_crc16_maxim (const ut8 *block, int len) { r_cons_printf ("%04" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC16_MAXIM)); } static void handle_crc16_mcrf4xx (const ut8 *block, int len) { r_cons_printf ("%04" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC16_MCRF4XX)); } static void handle_crc16_riello (const ut8 *block, int len) { r_cons_printf ("%04" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC16_RIELLO)); } static void handle_crc16_t10dif (const ut8 *block, int len) { r_cons_printf ("%04" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC16_T10_DIF)); } static void handle_crc16_teledisk (const ut8 *block, int len) { r_cons_printf ("%04" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC16_TELEDISK)); } static void handle_crc16_tms37157 (const ut8 *block, int len) { r_cons_printf ("%04" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC16_TMS37157)); } static void handle_crca (const ut8 *block, int len) { r_cons_printf ("%04" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRCA)); } static void handle_crc16_kermit (const ut8 *block, int len) { r_cons_printf ("%04" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC16_KERMIT)); } static void handle_crc16_modbus (const ut8 *block, int len) { r_cons_printf ("%04" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC16_MODBUS)); } static void handle_crc16_x25 (const ut8 *block, int len) { r_cons_printf ("%04" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC16_X25)); } static void handle_crc16_xmodem (const ut8 *block, int len) { r_cons_printf ("%04" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC16_XMODEM)); } #endif /* #if R_HAVE_CRC16_EXTRA */ #if R_HAVE_CRC24 static void handle_crc24 (const ut8 *block, int len) { r_cons_printf ("%06" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_24)); } #endif /* #if R_HAVE_CRC24 */ static void handle_crc32 (const ut8 *block, int len) { r_cons_printf ("%08" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_32)); } static void handle_crc32c (const ut8 *block, int len) { r_cons_printf ("%08" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_32C)); } static void handle_crc32_ecma_267 (const ut8 *block, int len) { r_cons_printf ("%08" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_32_ECMA_267)); } #if R_HAVE_CRC32_EXTRA static void handle_crc32_bzip2 (const ut8 *block, int len) { r_cons_printf ("%08" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC32_BZIP2)); } static void handle_crc32d (const ut8 *block, int len) { r_cons_printf ("%08" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC32D)); } static void handle_crc32_mpeg2 (const ut8 *block, int len) { r_cons_printf ("%08" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC32_MPEG2)); } static void handle_crc32_posix (const ut8 *block, int len) { r_cons_printf ("%08" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC32_POSIX)); } static void handle_crc32q (const ut8 *block, int len) { r_cons_printf ("%08" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC32Q)); } static void handle_crc32_jamcrc (const ut8 *block, int len) { r_cons_printf ("%08" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC32_JAMCRC)); } static void handle_crc32_xfer (const ut8 *block, int len) { r_cons_printf ("%08" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC32_XFER)); } #endif /* #ifR_HAVE_CRC32_EXTRA */ #if R_HAVE_CRC64 static void handle_crc64 (const ut8 * block, int len) { r_cons_printf ("%016" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC64)); } #endif /* #if R_HAVE_CRC64 */ #if R_HAVE_CRC64_EXTRA static void handle_crc64_ecma182 (const ut8 * block, int len) { r_cons_printf ("%016" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC64_ECMA182)); } static void handle_crc64_we (const ut8 * block, int len) { r_cons_printf ("%016" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC64_WE)); } static void handle_crc64_xz (const ut8 * block, int len) { r_cons_printf ("%016" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC64_XZ)); } static void handle_crc64_iso(const ut8 * block, int len) { r_cons_printf ("%016" PFMTCRCx "\n", r_hash_crc_preset (block, len, CRC_PRESET_CRC64_ISO)); } #endif /* #if R_HAVE_CRC64_EXTRA */ static void handle_fletcher8(const ut8 *block, int len) { r_cons_printf ("%x\n", r_hash_fletcher8 (block, len)); } static void handle_fletcher16(const ut8 *block, int len) { r_cons_printf ("%02x\n", r_hash_fletcher16 (block, len)); } static void handle_fletcher32(const ut8 *block, int len) { r_cons_printf ("%" PFMT32x "\n", r_hash_fletcher32 (block, len)); } static void handle_fletcher64(const ut8 *block, int len) { r_cons_printf ("%" PFMT64x "\n", r_hash_fletcher64 (block, len)); } static int cmd_hash_bang(RCore *core, const char *input) { if (r_sandbox_enable (0)) { eprintf ("hashbang disabled in sandbox mode\n"); return false; } if (r_str_endswith (input, "?")) { char *ex = strchr (input, '!'); if (ex) { char *foo = r_str_ndup (ex + 1, strlen (ex) - 2); RLangPlugin *lp = r_lang_get_by_name (core->lang, foo); if (lp) { if (lp->example) { r_cons_println (lp->example); } else { eprintf ("This language plugin doesnt provide any example.\n"); } } else { eprintf ("Unknown rlang plugin '%s'.\n", foo); } free (foo); } return false; } int ac; char **av = r_str_argv (input + 1, &ac); if (ac > 0) { RLangPlugin *p = r_lang_get_by_name (core->lang, av[0]); if (p) { // I see no point in using r_lang_use here, as we already haz a ptr to the pluging in our handz // Maybe add r_lang_use_plugin in r_lang api? core->lang->cur = p; if (ac > 1) { if (!strcmp (av[1], "-e")) { char *run_str = strstr (input + 2, "-e") + 2; r_lang_run_string (core->lang, run_str); } else { if (r_lang_set_argv (core->lang, ac - 1, &av[1])) { r_lang_run_file (core->lang, av[1]); } else { char *run_str = strstr (input + 2, av[1]); r_lang_run_file (core->lang, run_str); } } } else { if (r_cons_is_interactive ()) { r_lang_prompt (core->lang); } else { eprintf ("Error: scr.interactive required to run the rlang prompt\n"); } } } else if (av[0][0] == '?' || av[0][0] == '*') { r_lang_list (core->lang); } } else { r_lang_list (core->lang); } r_str_argv_free (av); return true; } static int cmd_hash(void *data, const char *input) { RCore *core = (RCore *)data; if (*input == '!') { return cmd_hash_bang (core, input); } if (*input == '?') { const char *helpmsg3[] = { "Usage #!interpreter [] [