-
Notifications
You must be signed in to change notification settings - Fork 24
/
Copy pathSample.Crypt.h
94 lines (67 loc) · 4.74 KB
/
Sample.Crypt.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
#pragma once
#include "Sample.h"
DEF_SAMPLE(Crypt)
{
std::tstring text = ts("this is an example");
std::vector<vu::byte> data;
/* 0x41, 0x42, 0x43, 0x44, 0x45 */
data.clear();
data.push_back(0x41); data.push_back(0x42); data.push_back(0x43);
data.push_back(0x44); data.push_back(0x45);
std::tstring file_path = ts("C:\\Windows\\explorer.exe");
std::tcout << ts("Crypt - MD5") << std::endl;
std::tcout << vu::crypt_md5_buffer(data) << std::endl;
std::tcout << vu::crypt_md5_text(text) << std::endl;
std::tcout << vu::crypt_md5_file(file_path) << std::endl;
std::tcout << ts("Crypt - SHA") << std::endl;
std::tcout << ts("sha1-160 -> ") << vu::crypt_sha_text(text, vu::sha_version::_1, vu::crypt_bits::_160) << std::endl;
std::tcout << ts("sha2-224 -> ") << vu::crypt_sha_text(text, vu::sha_version::_2, vu::crypt_bits::_224) << std::endl;
std::tcout << ts("sha2-256 -> ") << vu::crypt_sha_text(text, vu::sha_version::_2, vu::crypt_bits::_256) << std::endl;
std::tcout << ts("sha2-384 -> ") << vu::crypt_sha_text(text, vu::sha_version::_2, vu::crypt_bits::_384) << std::endl;
std::tcout << ts("sha2-512 -> ") << vu::crypt_sha_text(text, vu::sha_version::_2, vu::crypt_bits::_512) << std::endl;
std::tcout << ts("sha2-224-file -> ") << vu::crypt_sha_file(file_path, vu::sha_version::_2, vu::crypt_bits::_224) << std::endl;
std::tcout << ts("sha2-256-file -> ") << vu::crypt_sha_file(file_path, vu::sha_version::_2, vu::crypt_bits::_256) << std::endl;
std::tcout << ts("sha2-384-file -> ") << vu::crypt_sha_file(file_path, vu::sha_version::_2, vu::crypt_bits::_384) << std::endl;
std::tcout << ts("sha2-512-file -> ") << vu::crypt_sha_file(file_path, vu::sha_version::_2, vu::crypt_bits::_512) << std::endl;
std::tcout << ts("sha3-224 -> ") << vu::crypt_sha_text(text, vu::sha_version::_3, vu::crypt_bits::_224) << std::endl;
std::tcout << ts("sha3-256 -> ") << vu::crypt_sha_text(text, vu::sha_version::_3, vu::crypt_bits::_256) << std::endl;
std::tcout << ts("sha3-384 -> ") << vu::crypt_sha_text(text, vu::sha_version::_3, vu::crypt_bits::_384) << std::endl;
std::tcout << ts("sha3-512 -> ") << vu::crypt_sha_text(text, vu::sha_version::_3, vu::crypt_bits::_512) << std::endl;
std::tcout << ts("sha3-224-file -> ") << vu::crypt_sha_file(file_path, vu::sha_version::_3, vu::crypt_bits::_224) << std::endl;
std::tcout << ts("sha3-256-file -> ") << vu::crypt_sha_file(file_path, vu::sha_version::_3, vu::crypt_bits::_256) << std::endl;
std::tcout << ts("sha3-384-file -> ") << vu::crypt_sha_file(file_path, vu::sha_version::_3, vu::crypt_bits::_384) << std::endl;
std::tcout << ts("sha3-512-file -> ") << vu::crypt_sha_file(file_path, vu::sha_version::_3, vu::crypt_bits::_512) << std::endl;
std::tcout << ts("Crypt - B64") << std::endl;
text.clear();
vu::crypt_b64encode(data, text);
std::tcout << text << std::endl;
data.clear();
vu::crypt_b64decode(text, data);
std::cout << data.data() << std::endl;
data.clear();
vu::read_file_binary(file_path, data);
vu::crypt_b64encode(data, text);
data.clear();
vu::crypt_b64decode(text, data);
vu::write_file_binary(ts("Test-B64Decoded.exe"), data);
std::tcout << ts("Crypt - CRC") << std::endl;
std::tcout << ts("crc-32-file -> ") << std::hex << vu::crypt_crc_file(file_path, vu::crypt_bits::_32) << std::endl;
std::tcout << ts("crc-64-file -> ") << std::hex << vu::crypt_crc_file(file_path, vu::crypt_bits::_64) << std::endl;
/* 0x41, 0x42, 0x43, 0x44, 0x45 */
data.clear();
data.push_back(0x41); data.push_back(0x42); data.push_back(0x43);
data.push_back(0x44); data.push_back(0x45);
std::tcout << ts("crc-8 -> ") << std::hex << vu::crypt_crc_buffer(data, vu::crypt_bits::_8) << std::endl;
std::tcout << ts("crc-16 -> ") << std::hex << vu::crypt_crc_buffer(data, vu::crypt_bits::_16) << std::endl;
std::tcout << ts("crc-32 -> ") << std::hex << vu::crypt_crc_buffer(data, vu::crypt_bits::_32) << std::endl;
std::tcout << ts("crc-64 -> ") << std::hex << vu::crypt_crc_buffer(data, vu::crypt_bits::_64) << std::endl;
#define crc_rohc 8, 0x07, 0xFF, true, true, 0x00, 0xD0
std::tcout << ts("crc8 rohc -> ") << std::hex << vu::crypt_crc_buffer(data, crc_rohc) << std::endl;
#define crc_x_25 16, 0x1021, 0xFFFF, true, true, 0xffff, 0x906E
std::tcout << ts("crc8 x-25 -> ") << std::hex << vu::crypt_crc_buffer(data, crc_x_25) << std::endl;
#define crc_bzip 32, 0x04C11DB7, 0xFFFFFFFF, false, false, 0xFFFFFFFF, 0xFC891918
std::tcout << ts("crc32 bzip -> ") << std::hex << vu::crypt_crc_buffer(data, crc_bzip) << std::endl;
#define crc_we 64, 0x42f0e1eba9ea3693, 0xffffffffffffffff, false, false, 0xffffffffffffffff, 0x62ec59e3f1a4f00a
std::tcout << ts("crc64 we -> ") << std::hex << vu::crypt_crc_buffer(data, crc_we) << std::endl;
return vu::VU_OK;
}