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
95
96
|
# File 'lib/cobreak/decrypt.rb', line 4
def show(mode, dato)
decrypt = OpenStruct.new
decrypt.mode = mode
decrypt.wordlist = File.join(Gem.path[1], "gems", "cobreak-#{CoBreak.version}", 'lib', 'cobreak', 'show', "#{decrypt.mode}.db")
dbs = Sequel.sqlite
dbs = Sequel.sqlite
dbs.create_table? :hashes do
String :original
String :hash
end
case decrypt.mode
when ('md4')
decrypt.crypt = OpenSSL::Digest::MD4.new
when ('md5')
decrypt.crypt = OpenSSL::Digest::MD5.new
when ('sha1')
decrypt.crypt = OpenSSL::Digest::SHA1.new
when ('sha224')
decrypt.crypt = OpenSSL::Digest::SHA224.new
when ('sha256')
decrypt.crypt = OpenSSL::Digest::SHA256.new
when ('sha384')
decrypt.crypt = OpenSSL::Digest::SHA384.new
when ('sha512')
decrypt.crypt = OpenSSL::Digest::SHA512.new
when ('ripemd160')
decrypt.crypt = OpenSSL::Digest::RIPEMD160.new
end
File.foreach(decrypt.wordlist) {|line|
line.chomp!
if(decrypt.mode.downcase=='md4')
dbs[:hashes] << {original:line, hash:CoBreak::OpenSSL::MD4.hexdigest(line)}
elsif(decrypt.mode.downcase=='md5')
dbs[:hashes] << {original:line, hash:CoBreak::OpenSSL::MD5.hexdigest(line)}
elsif(decrypt.mode.downcase=='half-md5')
dbs[:hashes] << {original:line, hash:CoBreak::OpenSSL::HALF_MD5.hexdigest(line)}
elsif(decrypt.mode.downcase=='sha1')
dbs[:hashes] << {original:line, hash:CoBreak::OpenSSL::SHA1.hexdigest(line)}
elsif(decrypt.mode.downcase=='sha2-224')
dbs[:hashes] << {original:line, hash:CoBreak::OpenSSL::SHA2_224.hexdigest(line)}
elsif(decrypt.mode.downcase=='sha2-256')
dbs[:hashes] << {original:line, hash:CoBreak::OpenSSL::SHA2_256.hexdigest(line)}
elsif(decrypt.mode.downcase=='sha2-384')
dbs[:hashes] << {original:line, hash:CoBreak::OpenSSL::SHA2_384.hexdigest(line)}
elsif(decrypt.mode.downcase=='sha2-512')
dbs[:hashes] << {original:line, hash:CoBreak::OpenSSL::SHA2_512.hexdigest(line)}
elsif(decrypt.mode.downcase=='sha3-224')
dbs[:hashes] << {original:line, hash:CoBreak::OpenSSL::SHA3_224.hexdigest(line)}
elsif(decrypt.mode.downcase=='sha3-256')
dbs[:hashes] << {original:line, hash:CoBreak::OpenSSL::SHA3_256.hexdigest(line)}
elsif(decrypt.mode.downcase=='sha3-384')
dbs[:hashes] << {original:line, hash:CoBreak::OpenSSL::SHA3_384.hexdigest(line)}
elsif(decrypt.mode.downcase=='sha3-512')
dbs[:hashes] << {original:line, hash:CoBreak::OpenSSL::SHA3_512.hexdigest(line)}
elsif(decrypt.mode.downcase=='ripemd-160')
dbs[:hashes] << {original:line, hash:CoBreak::OpenSSL::RIPEMD_160.hexdigest(line)}
elsif(decrypt.mode.downcase=='tiger-160')
dbs[:hashes] << {original:line, hash:CoBreak::GCrypt::TIGER_160.hexdigest(line)}
elsif(decrypt.mode.downcase=='double-sha1')
dbs[:hashes] << {original:line, hash:CoBreak::GCrypt::DOUBLE_SHA1.hexdigest(line)}
elsif(decrypt.mode.downcase=='blake2s-128')
dbs[:hashes] << {original:line, hash:CoBreak::GCrypt::BLAKE2S_128.hexdigest(line)}
elsif(decrypt.mode.downcase=='blake2s-160')
dbs[:hashes] << {original:line, hash:CoBreak::GCrypt::BLAKE2S_160.hexdigest(line)}
elsif(decrypt.mode.downcase=='blake2s-224')
dbs[:hashes] << {original:line, hash:CoBreak::GCrypt::BLAKE2S_224.hexdigest(line)}
elsif(decrypt.mode.downcase=='blake2s-256')
dbs[:hashes] << {original:line, hash:CoBreak::GCrypt::BLAKE2S_256.hexdigest(line)}
elsif(decrypt.mode.downcase=='blake2b-160')
dbs[:hashes] << {original:line, hash:CoBreak::GCrypt::BLAKE2B_160.hexdigest(line)}
elsif(decrypt.mode.downcase=='blake2b-256')
dbs[:hashes] << {original:line, hash:CoBreak::GCrypt::BLAKE2B_256.hexdigest(line)}
elsif(decrypt.mode.downcase=='blake2b-384')
dbs[:hashes] << {original:line, hash:CoBreak::GCrypt::BLAKE2B_384.hexdigest(line)}
elsif(decrypt.mode.downcase=='blake2b-512')
dbs[:hashes] << {original:line, hash:CoBreak::GCrypt::BLAKE2B_512.hexdigest(line)}
elsif(decrypt.mode.downcase=='whirlpool')
dbs[:hashes] << {original:line, hash:CoBreak::GCrypt::WHIRLPOOL.hexdigest(line)}
elsif(decrypt.mode.downcase=='gost-streebog-256')
dbs[:hashes] << {original:line, hash:CoBreak::GCrypt::GOST_STREEBOG_256.hexdigest(line)}
elsif(decrypt.mode.downcase=='gost-streebog-512')
dbs[:hashes] << {original:line, hash:CoBreak::GCrypt::GOST_STREEBOG_512.hexdigest(line)}
end
}
decrypt.pass = dbs[:hashes].filter(hash:dato).map(:original)
unless (decrypt.pass.empty?)
puts "\e[1;32m[\e[1;37m+\e[1;32m]\e[1;37m Type Hash: #{decrypt.mode}"
puts "\e[1;32m[\e[1;37m+\e[1;32m]\e[1;37m Hash Found: #{decrypt.pass.join(',')}\e[0m"
else
puts "\e[1;31m[\e[1;37m+\e[1;31m]\e[1;37m Hash Not Found in Database...\e[0m"
end
end
|