Class: Rex::Encoding::Xor::DwordAdditive
- Inherits:
-
Generic
- Object
- Generic
- Rex::Encoding::Xor::DwordAdditive
show all
- Defined in:
- lib/rex/encoding/xor/dword_additive.rb
Class Method Summary
collapse
Methods inherited from Generic
_check, _check_encode, _check_key, _find_bad_keys, encode, find_key, find_key_and_encode
Class Method Details
permalink
._encode_mutate_key(buf, key, pos, len) ⇒ Object
hook in the key mutation routine of encode for the additive feedback
[View source]
34
35
36
37
38
39
40
41
42
43
44
45
|
# File 'lib/rex/encoding/xor/dword_additive.rb', line 34
def DwordAdditive._encode_mutate_key(buf, key, pos, len)
if (pos + 1) % len == 0
key = pack_key(
unpack_key(key) + unpack_key(buf[pos - (len - 1), len]) &
(1 << (len << 3)) - 1
)
end
return key
end
|
permalink
._find_good_key(data, badkeys, badchars) ⇒ Object
I realize this algorithm is broken. We invalidate some keys in _find_bad_keys that could actually be perfectly fine. However, it seems to work ok for now, and this is all just a lame adhoc method. Maybe someday we can revisit this and make it a bit less ghetto…
[View source]
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
|
# File 'lib/rex/encoding/xor/dword_additive.rb', line 54
def DwordAdditive._find_good_key(data, badkeys, badchars)
ksize = keysize
kstart = ""
ksize.times { kstart << rand(256) }
key = kstart.dup
loop do
pos = _check(data, key, badchars)
break if !pos
strip = pos % ksize
key[strip] = key[strip] + 1 & 0xff
if key[strip] == kstart[strip]
raise KeySearchError, "Key space exhausted on strip #{strip}!", caller
end
end
return key
end
|
permalink
.pack_key(key) ⇒ Object
[View source]
26
27
28
|
# File 'lib/rex/encoding/xor/dword_additive.rb', line 26
def DwordAdditive.pack_key(key)
return [ key ].pack(_packspec)
end
|
permalink
.unpack_key(key) ⇒ Object
[View source]
29
30
31
|
# File 'lib/rex/encoding/xor/dword_additive.rb', line 29
def DwordAdditive.unpack_key(key)
return key.unpack(_packspec)[0]
end
|