librex 0.0.19 → 0.0.20

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (435) hide show
  1. data/Rakefile +0 -1
  2. metadata +1 -434
  3. data/lib/rex/LICENSE +0 -29
  4. data/lib/rex/arch.rb +0 -103
  5. data/lib/rex/arch/sparc.rb +0 -75
  6. data/lib/rex/arch/sparc.rb.ut.rb +0 -18
  7. data/lib/rex/arch/x86.rb +0 -513
  8. data/lib/rex/arch/x86.rb.ut.rb +0 -93
  9. data/lib/rex/assembly/nasm.rb +0 -104
  10. data/lib/rex/assembly/nasm.rb.ut.rb +0 -22
  11. data/lib/rex/codepage.map +0 -104
  12. data/lib/rex/compat.rb +0 -311
  13. data/lib/rex/constants.rb +0 -113
  14. data/lib/rex/elfparsey.rb +0 -11
  15. data/lib/rex/elfparsey/elf.rb +0 -123
  16. data/lib/rex/elfparsey/elfbase.rb +0 -258
  17. data/lib/rex/elfparsey/exceptions.rb +0 -27
  18. data/lib/rex/elfscan.rb +0 -12
  19. data/lib/rex/elfscan/scanner.rb +0 -207
  20. data/lib/rex/elfscan/search.rb +0 -46
  21. data/lib/rex/encoder/alpha2.rb +0 -31
  22. data/lib/rex/encoder/alpha2/alpha_mixed.rb +0 -68
  23. data/lib/rex/encoder/alpha2/alpha_upper.rb +0 -79
  24. data/lib/rex/encoder/alpha2/generic.rb +0 -114
  25. data/lib/rex/encoder/alpha2/unicode_mixed.rb +0 -117
  26. data/lib/rex/encoder/alpha2/unicode_upper.rb +0 -129
  27. data/lib/rex/encoder/ndr.rb +0 -89
  28. data/lib/rex/encoder/ndr.rb.ut.rb +0 -44
  29. data/lib/rex/encoder/nonalpha.rb +0 -61
  30. data/lib/rex/encoder/nonupper.rb +0 -64
  31. data/lib/rex/encoder/xdr.rb +0 -106
  32. data/lib/rex/encoder/xdr.rb.ut.rb +0 -29
  33. data/lib/rex/encoder/xor.rb +0 -69
  34. data/lib/rex/encoder/xor/dword.rb +0 -13
  35. data/lib/rex/encoder/xor/dword_additive.rb +0 -13
  36. data/lib/rex/encoders/xor_dword.rb +0 -35
  37. data/lib/rex/encoders/xor_dword_additive.rb +0 -53
  38. data/lib/rex/encoders/xor_dword_additive.rb.ut.rb +0 -12
  39. data/lib/rex/encoding/xor.rb +0 -20
  40. data/lib/rex/encoding/xor.rb.ts.rb +0 -14
  41. data/lib/rex/encoding/xor/byte.rb +0 -15
  42. data/lib/rex/encoding/xor/byte.rb.ut.rb +0 -21
  43. data/lib/rex/encoding/xor/dword.rb +0 -21
  44. data/lib/rex/encoding/xor/dword.rb.ut.rb +0 -15
  45. data/lib/rex/encoding/xor/dword_additive.rb +0 -92
  46. data/lib/rex/encoding/xor/dword_additive.rb.ut.rb +0 -15
  47. data/lib/rex/encoding/xor/exceptions.rb +0 -17
  48. data/lib/rex/encoding/xor/generic.rb +0 -146
  49. data/lib/rex/encoding/xor/generic.rb.ut.rb +0 -120
  50. data/lib/rex/encoding/xor/qword.rb +0 -15
  51. data/lib/rex/encoding/xor/word.rb +0 -21
  52. data/lib/rex/encoding/xor/word.rb.ut.rb +0 -13
  53. data/lib/rex/exceptions.rb +0 -275
  54. data/lib/rex/exceptions.rb.ut.rb +0 -44
  55. data/lib/rex/exploitation/cmdstager.rb +0 -9
  56. data/lib/rex/exploitation/cmdstager/base.rb +0 -175
  57. data/lib/rex/exploitation/cmdstager/debug_asm.rb +0 -142
  58. data/lib/rex/exploitation/cmdstager/debug_write.rb +0 -136
  59. data/lib/rex/exploitation/cmdstager/tftp.rb +0 -63
  60. data/lib/rex/exploitation/cmdstager/vbs.rb +0 -128
  61. data/lib/rex/exploitation/egghunter.rb +0 -277
  62. data/lib/rex/exploitation/egghunter.rb.ut.rb +0 -25
  63. data/lib/rex/exploitation/encryptjs.rb +0 -77
  64. data/lib/rex/exploitation/heaplib.js.b64 +0 -331
  65. data/lib/rex/exploitation/heaplib.rb +0 -94
  66. data/lib/rex/exploitation/javascriptosdetect.rb +0 -897
  67. data/lib/rex/exploitation/obfuscatejs.rb +0 -335
  68. data/lib/rex/exploitation/omelet.rb +0 -320
  69. data/lib/rex/exploitation/omelet.rb.ut.rb +0 -13
  70. data/lib/rex/exploitation/opcodedb.rb +0 -818
  71. data/lib/rex/exploitation/opcodedb.rb.ut.rb +0 -279
  72. data/lib/rex/exploitation/seh.rb +0 -92
  73. data/lib/rex/exploitation/seh.rb.ut.rb +0 -19
  74. data/lib/rex/file.rb +0 -112
  75. data/lib/rex/file.rb.ut.rb +0 -16
  76. data/lib/rex/image_source.rb +0 -12
  77. data/lib/rex/image_source/disk.rb +0 -60
  78. data/lib/rex/image_source/image_source.rb +0 -46
  79. data/lib/rex/image_source/memory.rb +0 -37
  80. data/lib/rex/io/bidirectional_pipe.rb +0 -157
  81. data/lib/rex/io/datagram_abstraction.rb +0 -35
  82. data/lib/rex/io/ring_buffer.rb +0 -364
  83. data/lib/rex/io/stream.rb +0 -319
  84. data/lib/rex/io/stream_abstraction.rb +0 -197
  85. data/lib/rex/io/stream_server.rb +0 -211
  86. data/lib/rex/job_container.rb +0 -187
  87. data/lib/rex/logging.rb +0 -4
  88. data/lib/rex/logging/log_dispatcher.rb +0 -179
  89. data/lib/rex/logging/log_sink.rb +0 -42
  90. data/lib/rex/logging/sinks/flatfile.rb +0 -55
  91. data/lib/rex/logging/sinks/stderr.rb +0 -43
  92. data/lib/rex/machparsey.rb +0 -9
  93. data/lib/rex/machparsey/exceptions.rb +0 -34
  94. data/lib/rex/machparsey/mach.rb +0 -209
  95. data/lib/rex/machparsey/machbase.rb +0 -408
  96. data/lib/rex/machscan.rb +0 -9
  97. data/lib/rex/machscan/scanner.rb +0 -217
  98. data/lib/rex/mime.rb +0 -9
  99. data/lib/rex/mime/header.rb +0 -77
  100. data/lib/rex/mime/message.rb +0 -144
  101. data/lib/rex/mime/part.rb +0 -20
  102. data/lib/rex/nop/opty2.rb +0 -108
  103. data/lib/rex/nop/opty2.rb.ut.rb +0 -23
  104. data/lib/rex/nop/opty2_tables.rb +0 -300
  105. data/lib/rex/ole.rb +0 -205
  106. data/lib/rex/ole/clsid.rb +0 -47
  107. data/lib/rex/ole/difat.rb +0 -141
  108. data/lib/rex/ole/directory.rb +0 -231
  109. data/lib/rex/ole/direntry.rb +0 -240
  110. data/lib/rex/ole/docs/dependencies.txt +0 -8
  111. data/lib/rex/ole/docs/references.txt +0 -1
  112. data/lib/rex/ole/fat.rb +0 -99
  113. data/lib/rex/ole/header.rb +0 -204
  114. data/lib/rex/ole/minifat.rb +0 -77
  115. data/lib/rex/ole/propset.rb +0 -144
  116. data/lib/rex/ole/samples/create_ole.rb +0 -27
  117. data/lib/rex/ole/samples/dir.rb +0 -35
  118. data/lib/rex/ole/samples/dump_stream.rb +0 -34
  119. data/lib/rex/ole/samples/ole_info.rb +0 -23
  120. data/lib/rex/ole/storage.rb +0 -395
  121. data/lib/rex/ole/stream.rb +0 -53
  122. data/lib/rex/ole/substorage.rb +0 -49
  123. data/lib/rex/ole/util.rb +0 -157
  124. data/lib/rex/parser/arguments.rb +0 -97
  125. data/lib/rex/parser/arguments.rb.ut.rb +0 -67
  126. data/lib/rex/parser/ini.rb +0 -185
  127. data/lib/rex/parser/ini.rb.ut.rb +0 -29
  128. data/lib/rex/parser/ip360_aspl_xml.rb +0 -102
  129. data/lib/rex/parser/ip360_xml.rb +0 -97
  130. data/lib/rex/parser/nessus_xml.rb +0 -118
  131. data/lib/rex/parser/netsparker_xml.rb +0 -94
  132. data/lib/rex/parser/nexpose_xml.rb +0 -136
  133. data/lib/rex/parser/nmap_xml.rb +0 -137
  134. data/lib/rex/parser/retina_xml.rb +0 -109
  135. data/lib/rex/payloads.rb +0 -1
  136. data/lib/rex/payloads/win32.rb +0 -2
  137. data/lib/rex/payloads/win32/common.rb +0 -26
  138. data/lib/rex/payloads/win32/kernel.rb +0 -53
  139. data/lib/rex/payloads/win32/kernel/common.rb +0 -54
  140. data/lib/rex/payloads/win32/kernel/migration.rb +0 -12
  141. data/lib/rex/payloads/win32/kernel/recovery.rb +0 -50
  142. data/lib/rex/payloads/win32/kernel/stager.rb +0 -194
  143. data/lib/rex/peparsey.rb +0 -12
  144. data/lib/rex/peparsey/exceptions.rb +0 -32
  145. data/lib/rex/peparsey/pe.rb +0 -212
  146. data/lib/rex/peparsey/pe_memdump.rb +0 -63
  147. data/lib/rex/peparsey/pebase.rb +0 -1680
  148. data/lib/rex/peparsey/section.rb +0 -136
  149. data/lib/rex/pescan.rb +0 -13
  150. data/lib/rex/pescan/analyze.rb +0 -309
  151. data/lib/rex/pescan/scanner.rb +0 -206
  152. data/lib/rex/pescan/search.rb +0 -56
  153. data/lib/rex/platforms.rb +0 -1
  154. data/lib/rex/platforms/windows.rb +0 -51
  155. data/lib/rex/poly.rb +0 -132
  156. data/lib/rex/poly/block.rb +0 -477
  157. data/lib/rex/poly/register.rb +0 -100
  158. data/lib/rex/poly/register/x86.rb +0 -40
  159. data/lib/rex/post.rb +0 -8
  160. data/lib/rex/post/dir.rb +0 -51
  161. data/lib/rex/post/file.rb +0 -172
  162. data/lib/rex/post/file_stat.rb +0 -220
  163. data/lib/rex/post/gen.pl +0 -13
  164. data/lib/rex/post/io.rb +0 -182
  165. data/lib/rex/post/meterpreter.rb +0 -4
  166. data/lib/rex/post/meterpreter/channel.rb +0 -445
  167. data/lib/rex/post/meterpreter/channel_container.rb +0 -54
  168. data/lib/rex/post/meterpreter/channels/pool.rb +0 -160
  169. data/lib/rex/post/meterpreter/channels/pools/file.rb +0 -62
  170. data/lib/rex/post/meterpreter/channels/pools/stream_pool.rb +0 -103
  171. data/lib/rex/post/meterpreter/channels/stream.rb +0 -87
  172. data/lib/rex/post/meterpreter/client.rb +0 -364
  173. data/lib/rex/post/meterpreter/client_core.rb +0 -274
  174. data/lib/rex/post/meterpreter/dependencies.rb +0 -3
  175. data/lib/rex/post/meterpreter/extension.rb +0 -32
  176. data/lib/rex/post/meterpreter/extensions/espia/espia.rb +0 -58
  177. data/lib/rex/post/meterpreter/extensions/espia/tlv.rb +0 -16
  178. data/lib/rex/post/meterpreter/extensions/incognito/incognito.rb +0 -94
  179. data/lib/rex/post/meterpreter/extensions/incognito/tlv.rb +0 -21
  180. data/lib/rex/post/meterpreter/extensions/networkpug/networkpug.rb +0 -57
  181. data/lib/rex/post/meterpreter/extensions/networkpug/tlv.rb +0 -15
  182. data/lib/rex/post/meterpreter/extensions/priv/fs.rb +0 -118
  183. data/lib/rex/post/meterpreter/extensions/priv/passwd.rb +0 -61
  184. data/lib/rex/post/meterpreter/extensions/priv/priv.rb +0 -111
  185. data/lib/rex/post/meterpreter/extensions/priv/tlv.rb +0 -28
  186. data/lib/rex/post/meterpreter/extensions/sniffer/sniffer.rb +0 -101
  187. data/lib/rex/post/meterpreter/extensions/sniffer/tlv.rb +0 -26
  188. data/lib/rex/post/meterpreter/extensions/stdapi/constants.rb +0 -333
  189. data/lib/rex/post/meterpreter/extensions/stdapi/fs/dir.rb +0 -282
  190. data/lib/rex/post/meterpreter/extensions/stdapi/fs/file.rb +0 -266
  191. data/lib/rex/post/meterpreter/extensions/stdapi/fs/file_stat.rb +0 -103
  192. data/lib/rex/post/meterpreter/extensions/stdapi/fs/io.rb +0 -48
  193. data/lib/rex/post/meterpreter/extensions/stdapi/net/config.rb +0 -144
  194. data/lib/rex/post/meterpreter/extensions/stdapi/net/interface.rb +0 -73
  195. data/lib/rex/post/meterpreter/extensions/stdapi/net/route.rb +0 -56
  196. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket.rb +0 -137
  197. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/tcp_client_channel.rb +0 -180
  198. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/tcp_server_channel.rb +0 -167
  199. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/udp_channel.rb +0 -208
  200. data/lib/rex/post/meterpreter/extensions/stdapi/railgun.rb.ts.rb +0 -6
  201. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/api_constants.rb +0 -38106
  202. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/api_constants.rb.ut.rb +0 -31
  203. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/buffer_item.rb +0 -47
  204. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/buffer_item.rb.ut.rb +0 -36
  205. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_advapi32.rb +0 -1818
  206. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_iphlpapi.rb +0 -96
  207. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_kernel32.rb +0 -3848
  208. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_netapi32.rb +0 -26
  209. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_ntdll.rb +0 -153
  210. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_shell32.rb +0 -21
  211. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_user32.rb +0 -3169
  212. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_ws2_32.rb +0 -599
  213. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll.rb +0 -318
  214. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_function.rb +0 -100
  215. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_function.rb.ut.rb +0 -42
  216. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_helper.rb +0 -148
  217. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_helper.rb.ut.rb +0 -127
  218. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/multicall.rb +0 -309
  219. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/railgun.rb +0 -204
  220. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/tlv.rb +0 -51
  221. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/util.rb +0 -630
  222. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/win_const_manager.rb +0 -75
  223. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/win_const_manager.rb.ut.rb +0 -103
  224. data/lib/rex/post/meterpreter/extensions/stdapi/stdapi.rb +0 -149
  225. data/lib/rex/post/meterpreter/extensions/stdapi/sys/config.rb +0 -97
  226. data/lib/rex/post/meterpreter/extensions/stdapi/sys/event_log.rb +0 -192
  227. data/lib/rex/post/meterpreter/extensions/stdapi/sys/event_log_subsystem/event_record.rb +0 -41
  228. data/lib/rex/post/meterpreter/extensions/stdapi/sys/power.rb +0 -61
  229. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process.rb +0 -370
  230. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/image.rb +0 -129
  231. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/io.rb +0 -55
  232. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/memory.rb +0 -336
  233. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/thread.rb +0 -141
  234. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry.rb +0 -279
  235. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry_subsystem/registry_key.rb +0 -193
  236. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry_subsystem/registry_value.rb +0 -102
  237. data/lib/rex/post/meterpreter/extensions/stdapi/sys/thread.rb +0 -180
  238. data/lib/rex/post/meterpreter/extensions/stdapi/tlv.rb +0 -211
  239. data/lib/rex/post/meterpreter/extensions/stdapi/ui.rb +0 -227
  240. data/lib/rex/post/meterpreter/extensions/stdapi/webcam/webcam.rb +0 -63
  241. data/lib/rex/post/meterpreter/inbound_packet_handler.rb +0 -30
  242. data/lib/rex/post/meterpreter/object_aliases.rb +0 -83
  243. data/lib/rex/post/meterpreter/packet.rb +0 -688
  244. data/lib/rex/post/meterpreter/packet_dispatcher.rb +0 -431
  245. data/lib/rex/post/meterpreter/packet_parser.rb +0 -94
  246. data/lib/rex/post/meterpreter/packet_response_waiter.rb +0 -83
  247. data/lib/rex/post/meterpreter/ui/console.rb +0 -137
  248. data/lib/rex/post/meterpreter/ui/console/command_dispatcher.rb +0 -62
  249. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/core.rb +0 -730
  250. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/espia.rb +0 -108
  251. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/incognito.rb +0 -241
  252. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/networkpug.rb +0 -231
  253. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv.rb +0 -61
  254. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/elevate.rb +0 -98
  255. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/passwd.rb +0 -51
  256. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/timestomp.rb +0 -132
  257. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/sniffer.rb +0 -187
  258. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi.rb +0 -65
  259. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/fs.rb +0 -442
  260. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/net.rb +0 -298
  261. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/sys.rb +0 -486
  262. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/ui.rb +0 -315
  263. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/webcam.rb +0 -157
  264. data/lib/rex/post/meterpreter/ui/console/interactive_channel.rb +0 -95
  265. data/lib/rex/post/permission.rb +0 -26
  266. data/lib/rex/post/process.rb +0 -57
  267. data/lib/rex/post/thread.rb +0 -57
  268. data/lib/rex/post/ui.rb +0 -52
  269. data/lib/rex/proto.rb +0 -13
  270. data/lib/rex/proto.rb.ts.rb +0 -8
  271. data/lib/rex/proto/dcerpc.rb +0 -6
  272. data/lib/rex/proto/dcerpc.rb.ts.rb +0 -9
  273. data/lib/rex/proto/dcerpc/client.rb +0 -361
  274. data/lib/rex/proto/dcerpc/client.rb.ut.rb +0 -491
  275. data/lib/rex/proto/dcerpc/exceptions.rb +0 -150
  276. data/lib/rex/proto/dcerpc/handle.rb +0 -47
  277. data/lib/rex/proto/dcerpc/handle.rb.ut.rb +0 -85
  278. data/lib/rex/proto/dcerpc/ndr.rb +0 -72
  279. data/lib/rex/proto/dcerpc/ndr.rb.ut.rb +0 -41
  280. data/lib/rex/proto/dcerpc/packet.rb +0 -253
  281. data/lib/rex/proto/dcerpc/packet.rb.ut.rb +0 -56
  282. data/lib/rex/proto/dcerpc/response.rb +0 -187
  283. data/lib/rex/proto/dcerpc/response.rb.ut.rb +0 -15
  284. data/lib/rex/proto/dcerpc/uuid.rb +0 -84
  285. data/lib/rex/proto/dcerpc/uuid.rb.ut.rb +0 -46
  286. data/lib/rex/proto/dhcp.rb +0 -7
  287. data/lib/rex/proto/dhcp/constants.rb +0 -33
  288. data/lib/rex/proto/dhcp/server.rb +0 -292
  289. data/lib/rex/proto/drda.rb +0 -5
  290. data/lib/rex/proto/drda.rb.ts.rb +0 -17
  291. data/lib/rex/proto/drda/constants.rb +0 -49
  292. data/lib/rex/proto/drda/constants.rb.ut.rb +0 -23
  293. data/lib/rex/proto/drda/packet.rb +0 -252
  294. data/lib/rex/proto/drda/packet.rb.ut.rb +0 -109
  295. data/lib/rex/proto/drda/utils.rb +0 -123
  296. data/lib/rex/proto/drda/utils.rb.ut.rb +0 -84
  297. data/lib/rex/proto/http.rb +0 -5
  298. data/lib/rex/proto/http.rb.ts.rb +0 -12
  299. data/lib/rex/proto/http/client.rb +0 -821
  300. data/lib/rex/proto/http/client.rb.ut.rb +0 -95
  301. data/lib/rex/proto/http/handler.rb +0 -46
  302. data/lib/rex/proto/http/handler/erb.rb +0 -128
  303. data/lib/rex/proto/http/handler/erb.rb.ut.rb +0 -21
  304. data/lib/rex/proto/http/handler/erb.rb.ut.rb.rhtml +0 -1
  305. data/lib/rex/proto/http/handler/proc.rb +0 -60
  306. data/lib/rex/proto/http/handler/proc.rb.ut.rb +0 -24
  307. data/lib/rex/proto/http/header.rb +0 -161
  308. data/lib/rex/proto/http/header.rb.ut.rb +0 -46
  309. data/lib/rex/proto/http/packet.rb +0 -407
  310. data/lib/rex/proto/http/packet.rb.ut.rb +0 -165
  311. data/lib/rex/proto/http/request.rb +0 -356
  312. data/lib/rex/proto/http/request.rb.ut.rb +0 -214
  313. data/lib/rex/proto/http/response.rb +0 -90
  314. data/lib/rex/proto/http/response.rb.ut.rb +0 -149
  315. data/lib/rex/proto/http/server.rb +0 -369
  316. data/lib/rex/proto/http/server.rb.ut.rb +0 -79
  317. data/lib/rex/proto/ntlm.rb +0 -7
  318. data/lib/rex/proto/ntlm.rb.ut.rb +0 -177
  319. data/lib/rex/proto/ntlm/base.rb +0 -326
  320. data/lib/rex/proto/ntlm/constants.rb +0 -74
  321. data/lib/rex/proto/ntlm/crypt.rb +0 -415
  322. data/lib/rex/proto/ntlm/exceptions.rb +0 -16
  323. data/lib/rex/proto/ntlm/message.rb +0 -536
  324. data/lib/rex/proto/ntlm/utils.rb +0 -764
  325. data/lib/rex/proto/proxy/socks4a.rb +0 -440
  326. data/lib/rex/proto/rfb.rb +0 -19
  327. data/lib/rex/proto/rfb.rb.ut.rb +0 -37
  328. data/lib/rex/proto/rfb/cipher.rb +0 -84
  329. data/lib/rex/proto/rfb/client.rb +0 -207
  330. data/lib/rex/proto/rfb/constants.rb +0 -52
  331. data/lib/rex/proto/smb.rb +0 -7
  332. data/lib/rex/proto/smb.rb.ts.rb +0 -8
  333. data/lib/rex/proto/smb/client.rb +0 -1952
  334. data/lib/rex/proto/smb/client.rb.ut.rb +0 -223
  335. data/lib/rex/proto/smb/constants.rb +0 -1047
  336. data/lib/rex/proto/smb/constants.rb.ut.rb +0 -18
  337. data/lib/rex/proto/smb/crypt.rb +0 -36
  338. data/lib/rex/proto/smb/evasions.rb +0 -66
  339. data/lib/rex/proto/smb/exceptions.rb +0 -858
  340. data/lib/rex/proto/smb/simpleclient.rb +0 -306
  341. data/lib/rex/proto/smb/simpleclient.rb.ut.rb +0 -128
  342. data/lib/rex/proto/smb/utils.rb +0 -103
  343. data/lib/rex/proto/smb/utils.rb.ut.rb +0 -20
  344. data/lib/rex/proto/sunrpc.rb +0 -1
  345. data/lib/rex/proto/sunrpc/client.rb +0 -195
  346. data/lib/rex/proto/tftp.rb +0 -12
  347. data/lib/rex/proto/tftp/constants.rb +0 -39
  348. data/lib/rex/proto/tftp/server.rb +0 -497
  349. data/lib/rex/proto/tftp/server.rb.ut.rb +0 -28
  350. data/lib/rex/script.rb +0 -42
  351. data/lib/rex/script/base.rb +0 -59
  352. data/lib/rex/script/meterpreter.rb +0 -15
  353. data/lib/rex/script/shell.rb +0 -9
  354. data/lib/rex/service.rb +0 -48
  355. data/lib/rex/service_manager.rb +0 -141
  356. data/lib/rex/service_manager.rb.ut.rb +0 -32
  357. data/lib/rex/services/local_relay.rb +0 -423
  358. data/lib/rex/socket.rb +0 -684
  359. data/lib/rex/socket.rb.ut.rb +0 -107
  360. data/lib/rex/socket/comm.rb +0 -119
  361. data/lib/rex/socket/comm/local.rb +0 -412
  362. data/lib/rex/socket/comm/local.rb.ut.rb +0 -75
  363. data/lib/rex/socket/ip.rb +0 -130
  364. data/lib/rex/socket/parameters.rb +0 -345
  365. data/lib/rex/socket/parameters.rb.ut.rb +0 -51
  366. data/lib/rex/socket/range_walker.rb +0 -346
  367. data/lib/rex/socket/range_walker.rb.ut.rb +0 -55
  368. data/lib/rex/socket/ssl_tcp.rb +0 -184
  369. data/lib/rex/socket/ssl_tcp.rb.ut.rb +0 -39
  370. data/lib/rex/socket/ssl_tcp_server.rb +0 -122
  371. data/lib/rex/socket/ssl_tcp_server.rb.ut.rb +0 -61
  372. data/lib/rex/socket/subnet_walker.rb +0 -75
  373. data/lib/rex/socket/subnet_walker.rb.ut.rb +0 -28
  374. data/lib/rex/socket/switch_board.rb +0 -278
  375. data/lib/rex/socket/switch_board.rb.ut.rb +0 -52
  376. data/lib/rex/socket/tcp.rb +0 -76
  377. data/lib/rex/socket/tcp.rb.ut.rb +0 -64
  378. data/lib/rex/socket/tcp_server.rb +0 -66
  379. data/lib/rex/socket/tcp_server.rb.ut.rb +0 -44
  380. data/lib/rex/socket/udp.rb +0 -164
  381. data/lib/rex/socket/udp.rb.ut.rb +0 -44
  382. data/lib/rex/struct2.rb +0 -5
  383. data/lib/rex/struct2/c_struct.rb +0 -181
  384. data/lib/rex/struct2/c_struct_template.rb +0 -39
  385. data/lib/rex/struct2/constant.rb +0 -26
  386. data/lib/rex/struct2/element.rb +0 -44
  387. data/lib/rex/struct2/generic.rb +0 -73
  388. data/lib/rex/struct2/restraint.rb +0 -54
  389. data/lib/rex/struct2/s_string.rb +0 -72
  390. data/lib/rex/struct2/s_struct.rb +0 -111
  391. data/lib/rex/sync.rb +0 -6
  392. data/lib/rex/sync/event.rb +0 -94
  393. data/lib/rex/sync/read_write_lock.rb +0 -176
  394. data/lib/rex/sync/ref.rb +0 -57
  395. data/lib/rex/sync/thread_safe.rb +0 -82
  396. data/lib/rex/test.rb +0 -35
  397. data/lib/rex/text.rb +0 -1163
  398. data/lib/rex/text.rb.ut.rb +0 -190
  399. data/lib/rex/thread_factory.rb +0 -42
  400. data/lib/rex/time.rb +0 -65
  401. data/lib/rex/transformer.rb +0 -115
  402. data/lib/rex/transformer.rb.ut.rb +0 -38
  403. data/lib/rex/ui.rb +0 -21
  404. data/lib/rex/ui/interactive.rb +0 -298
  405. data/lib/rex/ui/output.rb +0 -78
  406. data/lib/rex/ui/output/none.rb +0 -18
  407. data/lib/rex/ui/progress_tracker.rb +0 -96
  408. data/lib/rex/ui/subscriber.rb +0 -149
  409. data/lib/rex/ui/text/color.rb +0 -97
  410. data/lib/rex/ui/text/color.rb.ut.rb +0 -18
  411. data/lib/rex/ui/text/dispatcher_shell.rb +0 -467
  412. data/lib/rex/ui/text/input.rb +0 -117
  413. data/lib/rex/ui/text/input/buffer.rb +0 -75
  414. data/lib/rex/ui/text/input/readline.rb +0 -129
  415. data/lib/rex/ui/text/input/socket.rb +0 -95
  416. data/lib/rex/ui/text/input/stdio.rb +0 -45
  417. data/lib/rex/ui/text/irb_shell.rb +0 -57
  418. data/lib/rex/ui/text/output.rb +0 -80
  419. data/lib/rex/ui/text/output/buffer.rb +0 -61
  420. data/lib/rex/ui/text/output/file.rb +0 -43
  421. data/lib/rex/ui/text/output/socket.rb +0 -43
  422. data/lib/rex/ui/text/output/stdio.rb +0 -40
  423. data/lib/rex/ui/text/progress_tracker.rb +0 -56
  424. data/lib/rex/ui/text/progress_tracker.rb.ut.rb +0 -34
  425. data/lib/rex/ui/text/shell.rb +0 -328
  426. data/lib/rex/ui/text/table.rb +0 -279
  427. data/lib/rex/ui/text/table.rb.ut.rb +0 -55
  428. data/lib/rex/zip.rb +0 -93
  429. data/lib/rex/zip/archive.rb +0 -184
  430. data/lib/rex/zip/blocks.rb +0 -182
  431. data/lib/rex/zip/entry.rb +0 -104
  432. data/lib/rex/zip/samples/comment.rb +0 -32
  433. data/lib/rex/zip/samples/mkwar.rb +0 -138
  434. data/lib/rex/zip/samples/mkzip.rb +0 -19
  435. data/lib/rex/zip/samples/recursive.rb +0 -58
@@ -1,44 +0,0 @@
1
- #!/usr/bin/env ruby
2
-
3
- $:.unshift(File.join(File.dirname(__FILE__), '..', '..'))
4
-
5
- require 'rex/test'
6
- require 'rex/exceptions'
7
- require 'rex/encoder/ndr'
8
-
9
- class Rex::Encoder::NDR::UnitTest < Test::Unit::TestCase
10
-
11
- Klass = Rex::Encoder::NDR
12
-
13
- def test_align
14
- assert_equal(0, Klass.align('').length, 'align 0')
15
- assert_equal(3, Klass.align('f').length, 'align 1')
16
- assert_equal(2, Klass.align('fo').length, 'align 2')
17
- assert_equal(1, Klass.align('foo').length, 'align 3')
18
- assert_equal(0, Klass.align('fooo').length, 'align 4')
19
- assert_equal(3, Klass.align('foooo').length, 'align 5')
20
- end
21
-
22
- def test_numbers
23
- assert_equal("\x0a\x00\x00\x00", Klass.long(10), 'long')
24
- assert_equal("\x0a\x00", Klass.short(10), 'short')
25
- assert_equal("\x0a", Klass.byte(10), 'byte')
26
- end
27
-
28
- def test_conformant_array
29
- assert_equal("\x05\x00\x00\x00aaaaa", Klass.UniConformantArray('aaaaa').slice(0,9), 'UniConformantArray')
30
- assert_equal(12, Klass.UniConformantArray('aaaaa').length, 'UniConformantArray length')
31
- end
32
-
33
- def test_string
34
- assert_equal("\x06\x00\x00\x00" + "\x00\x00\x00\x00" + "\x06\x00\x00\x00" "aaaaa\x00", Klass.string('aaaaa').slice(0,4+4+4+6), 'string')
35
- assert_equal(20, Klass.string('aaaaa').length, 'string length')
36
-
37
- assert_equal("\x06\x00\x00\x00" + "\x00\x00\x00\x00" + "\x06\x00\x00\x00" "a\x00a\x00a\x00a\x00a\x00\x00\x00", Klass.wstring('aaaaa').slice(0,4+4+4+12), 'wstring')
38
- assert_equal(24, Klass.wstring('aaaaa').length, 'wstring length')
39
-
40
- assert_equal("\x02\x00\x00\x00" + "\x00\x00\x00\x00" + "\x02\x00\x00\x00" "aa\x00\x00", Klass.wstring_prebuilt('aa' + "\x00\x00"), 'wstring_prebuilt')
41
- assert_equal(16, Klass.wstring_prebuilt('aa' + "\x00\x00").length, 'wstring_prebuilt length')
42
- end
43
-
44
- end
@@ -1,61 +0,0 @@
1
- #!/usr/bin/env ruby
2
-
3
- require 'rex/text'
4
-
5
- module Rex
6
- module Encoder
7
-
8
- class NonAlpha
9
-
10
- def NonAlpha.gen_decoder()
11
- decoder =
12
- "\x66\xB9\xFF\xFF" +
13
- "\xEB\x19" + # Jmp to table
14
- "\x5E" + # pop esi
15
- "\x8B\xFE" + # mov edi, esi - Get table addr
16
- "\x83\xC7" + "A" + # add edi, tablelen - Get shellcode addr
17
- "\x8B\xD7" + # mov edx, edi - Hold end of table ptr
18
- "\x3B\xF2" + # cmp esi, edx
19
- "\x7D\x0B" + # jle to end
20
- "\xB0\x7B" + # mov eax, 0x7B - Set up eax with magic
21
- "\xF2\xAE" + # repne scasb - Find magic!
22
- "\xFF\xCF" + # dec edi - scasb purs us one ahead
23
- "\xAC" + # lodsb
24
- "\x28\x07" + # subb [edi], al
25
- "\xEB\xF1" + # jmp BACK!
26
- "\xEB" + "B" + # jmp [shellcode]
27
- "\xE8\xE2\xFF\xFF\xFF"
28
- end
29
-
30
- def NonAlpha.encode_byte(block, table, tablelen)
31
- if (tablelen > 255) or (block == 0x7B)
32
- raise RuntimeError, "BadChar"
33
- end
34
-
35
- if (block >= 0x41 and block <= 0x5A) or (block >= 0x61 and block <= 0x7A)
36
- # gen offset, return magic
37
- offset = 0x7b - block;
38
- table += offset.chr
39
- tablelen = tablelen + 1
40
- block = 0x7B
41
- end
42
-
43
- return [block.chr, table, tablelen]
44
- end
45
-
46
- def NonAlpha.encode(buf)
47
- table = ""
48
- tablelen = 0
49
- nonascii = ""
50
- encoded = gen_decoder()
51
- buf.each_byte { |block|
52
- newchar, table, tablelen = encode_byte(block.unpack('C')[0], table, tablelen)
53
- nonascii += newchar
54
- }
55
- encoded.gsub!(/A/, tablelen)
56
- encoded.gsub!(/B/, tablelen+5)
57
- encoded += table
58
- encoded += nonascii
59
- end
60
-
61
- end end end
@@ -1,64 +0,0 @@
1
- #!/usr/bin/env ruby
2
-
3
- require 'rex/text'
4
-
5
- module Rex
6
- module Encoder
7
-
8
- class NonUpper
9
-
10
-
11
- def NonUpper.gen_decoder()
12
- decoder =
13
- "\x66\xB9\xFF\xFF" +
14
- "\xEB\x19" + # Jmp to table
15
- "\x5E" + # pop esi
16
- "\x8B\xFE" + # mov edi, esi - Get table addr
17
- "\x83\xC7" + "A" + # add edi, tablelen - Get shellcode addr
18
- "\x8B\xD7" + # mov edx, edi - Hold end of table ptr
19
- "\x3B\xF2" + # cmp esi, edx
20
- "\x7D\x0B" + # jle to end
21
- "\xB0\x7B" + # mov eax, 0x7B - Set up eax with magic
22
- "\xF2\xAE" + # repne scasb - Find magic!
23
- "\xFF\xCF" + # dec edi - scasb purs us one ahead
24
- "\xAC" + # lodsb
25
- "\x28\x07" + # subb [edi], al
26
- "\xEB\xF1" + # jmp BACK!
27
- "\xEB" + "B" + # jmp [shellcode]
28
- "\xE8\xE2\xFF\xFF\xFF"
29
- end
30
-
31
- def NonUpper.encode_byte(badchars, block, table, tablelen)
32
- if (tablelen > 255) or (block == 0x40)
33
- raise RuntimeError, "BadChar"
34
- end
35
-
36
- if (block >= 0x41 and block <= 0x40) or (badchars =~ block)
37
- # gen offset, return magic
38
- offset = 0x40 - block;
39
- table += offset.chr
40
- tablelen = tablelen + 1
41
- block = 0x40
42
- end
43
-
44
- return [block.chr, table, tablelen]
45
- end
46
-
47
- def NonUpper.encode(buf)
48
- table = ""
49
- tablelen = 0
50
- nonascii = ""
51
- encoded = gen_decoder()
52
- buf.each_byte {
53
- |block|
54
-
55
- newchar, table, tablelen = encode_byte(block.unpack('C')[0], table, tablelen)
56
- nonascii += newchar
57
- }
58
- encoded.gsub!(/A/, tablelen)
59
- encoded.gsub!(/B/, tablelen+5)
60
- encoded += table
61
- encoded += nonascii
62
- end
63
-
64
- end end end
@@ -1,106 +0,0 @@
1
- module Rex
2
- module Encoder
3
-
4
- ###
5
- #
6
- # This class implements basic XDR encoding.
7
- #
8
- ###
9
- module XDR
10
- MAX_ARG = 0xffffffff
11
-
12
- # Also: unsigned int, bool, enum
13
- def XDR.encode_int(int)
14
- return [int].pack('N')
15
- end
16
-
17
- def XDR.decode_int!(data)
18
- return data.slice!(0..3).unpack('N')[0] if data
19
- data = 0
20
- end
21
-
22
- def XDR.encode_lchar(char)
23
- char |= 0xffffff00 if char & 0x80 != 0
24
- return encode_int(char)
25
- end
26
-
27
- def XDR.decode_lchar!(data)
28
- return (decode_int!(data) & 0xff).chr
29
- end
30
-
31
- # Also: Variable length opaque
32
- def XDR.encode_string(str, max=MAX_ARG)
33
- raise ArgumentError, 'XDR: String too long' if str.length > max
34
- len = str.length
35
- str << "\x00" * ((4 - (len & 3)) & 3)
36
- return encode_int(len) + str
37
- end
38
-
39
- def XDR.decode_string!(data)
40
- real_len = decode_int!(data)
41
- return "" if real_len == 0
42
- align_len = (real_len + 3) & ~3
43
- return data.slice!(0..align_len-1).slice(0..real_len-1)
44
- end
45
-
46
- def XDR.encode_varray(arr, max=MAX_ARG, &block)
47
- raise ArgumentError, 'XDR: Too many array elements' if arr.length > max
48
- return encode_int(arr.length) + arr.collect(&block).join(nil)
49
- end
50
-
51
- def XDR.decode_varray!(data)
52
- buf = []
53
- 1.upto(decode_int!(data)) { buf.push(yield(data)) }
54
- return buf
55
- end
56
-
57
- # encode(0, [0, 1], "foo", ["bar", 4]) does:
58
- # encode_int(0) +
59
- # encode_varray([0, 1]) { |i| XDR.encode_int(i) } +
60
- # encode_string("foo") +
61
- # encode_string("bar", 4)
62
- def XDR.encode(*data)
63
- data.collect do |var|
64
- if var.kind_of?(String)
65
- encode_string(var)
66
- elsif var.kind_of?(Integer)
67
- encode_int(var)
68
- elsif var.kind_of?(Array) && var[0].kind_of?(String)
69
- raise ArgumentError, 'XDR: Incorrect string array arguments' if var.length != 2
70
- encode_string(var[0], var[1])
71
- elsif var.kind_of?(Array) && var[0].kind_of?(Integer)
72
- encode_varray(var) { |i| XDR.encode_int(i) }
73
- # 0 means an empty array index in the case of Integer and an empty string in
74
- # the case of String so we get the best of both worlds
75
- elsif var.kind_of?(Array) && var[0].nil?
76
- encode_int(0)
77
- else
78
- type = var.class
79
- type = var[0].class if var.kind_of?(Array)
80
- raise TypeError, "XDR: encode does not support #{type}"
81
- end
82
- end.join(nil)
83
- end
84
-
85
- # decode(buf, Integer, String, [Integer], [String]) does:
86
- # [decode_int!(buf), decode_string!(buf),
87
- # decode_varray!(buf) { |i| XDR.decode_int!(i) },
88
- # decode_varray!(buf) { |s| XDR.decode_string(s) }]
89
- def XDR.decode!(buf, *data)
90
- return *data.collect do |var|
91
- if data.length == 0
92
- elsif var.kind_of?(Array) && var[0] == String
93
- decode_varray!(buf) { |s| XDR.decode_string!(s) }
94
- elsif var.kind_of?(Array) && var[0] == Integer
95
- decode_varray!(buf) { |i| XDR.decode_int!(i) }
96
- elsif var == String
97
- decode_string!(buf)
98
- elsif var == Integer
99
- decode_int!(buf)
100
- end
101
- end
102
- end
103
- end
104
-
105
- end
106
- end
@@ -1,29 +0,0 @@
1
- #!/usr/bin/env ruby
2
-
3
- $:.unshift(File.join(File.dirname(__FILE__), '..', '..'))
4
-
5
- require 'test/unit'
6
- require 'rex/exceptions'
7
- require 'rex/encoder/xdr'
8
-
9
- class Rex::Encoder::XDR::UnitTest < Test::Unit::TestCase
10
-
11
- def test_encode
12
- assert_equal("\000\000\004\322", Rex::Encoder::XDR.encode_int(1234), 'encode_int')
13
- assert_equal("\377\377\377\322", Rex::Encoder::XDR.encode_lchar(1234), 'encode_lchar')
14
- assert_equal("\000\000\000\003abc\000", Rex::Encoder::XDR.encode_string('abc'), 'encode_string')
15
- assert_equal("\000\000\000\003abc\000", Rex::Encoder::XDR.encode_string('abc', 4), 'encode_string with maxlen')
16
- assert_raises(Rex::ArgumentError) {
17
- Rex::Encoder::XDR.encode_string('abc', 2)
18
- }
19
- assert_equal("\000\000\000\003\000\000\000\001\000\000\000\002\000\000\000\003", Rex::Encoder::XDR.encode_varray([1,2,3]) {|i| Rex::Encoder::XDR.encode_int(i) }, 'encode_varray')
20
- assert_equal("\000\000\000\000\000\000\000\002\000\000\000\000\000\000\000\001\000\000\000\003foo\000\000\000\000\003bar\000", Rex::Encoder::XDR.encode(0, [0, 1], "foo", ["bar", 4]), 'encode')
21
- end
22
-
23
- def test_decode
24
- assert_equal(1234, Rex::Encoder::XDR.decode_int!("\000\000\004\322"), 'decode_int!')
25
- assert_equal('abc', Rex::Encoder::XDR.decode_string!("\000\000\000\003abc\000"), 'decode_string')
26
- assert_equal([1,2,3], Rex::Encoder::XDR.decode_varray!("\000\000\000\003\000\000\000\001\000\000\000\002\000\000\000\003") { |i| Rex::Encoder::XDR.decode_int!(i) } , 'decode_varray!')
27
- assert_equal(1234, Rex::Encoder::XDR.decode_lchar!("\377\377\377\322"), 'decode_lchar!')
28
- end
29
- end
@@ -1,69 +0,0 @@
1
- #!/usr/bin/env ruby
2
-
3
- module Rex
4
- module Encoder
5
-
6
- ###
7
- #
8
- # This class performs basic XOR encoding.
9
- #
10
- ###
11
- class Xor
12
-
13
- attr_accessor :raw, :encoded, :badchars, :opts, :key, :fkey # :nodoc:
14
-
15
- #
16
- # wrap that in a wanna be static class
17
- #
18
- def self.encode(*args)
19
- self.new.encode(*args)
20
- end
21
-
22
- #
23
- # Return the class associated with this encoder.
24
- #
25
- def encoder()
26
- self.class::EncoderKlass
27
- end
28
-
29
- #
30
- # This method encodes the supplied data, taking into account the badchar
31
- # list, and returns the encoded buffer.
32
- #
33
- def encode(data, badchars = '', opts = { })
34
- self.raw = data
35
- self.badchars = badchars
36
- self.opts = opts
37
-
38
- # apply any transforms to the plaintext data
39
- data = _unencoded_transform(data)
40
-
41
- self.encoded, self.key, self.fkey = encoder().find_key_and_encode(data, badchars)
42
-
43
- # apply any transforms to the encoded data
44
- self.encoded = _encoded_transform(encoded)
45
-
46
- return _prepend() + encoded + _append()
47
- end
48
-
49
- protected
50
- def _unencoded_transform(data) # :nodoc:
51
- data
52
- end
53
-
54
- def _encoded_transform(data) # :nodoc:
55
- data
56
- end
57
-
58
- def _prepend() # :nodoc:
59
- ""
60
- end
61
-
62
- def _append() # :nodoc:
63
- ""
64
- end
65
-
66
- end
67
-
68
- end end
69
-
@@ -1,13 +0,0 @@
1
- #!/usr/bin/env ruby
2
-
3
- require 'rex/encoder/xor'
4
- require 'rex/encoding/xor/dword'
5
-
6
- ###
7
- #
8
- # This class wraps the Dword XOR encoder.
9
- #
10
- ###
11
- class Rex::Encoder::Xor::Dword < Rex::Encoder::Xor
12
- EncoderKlass = Rex::Encoding::Xor::Dword
13
- end
@@ -1,13 +0,0 @@
1
- #!/usr/bin/env ruby
2
-
3
- require 'rex/encoder/xor'
4
- require 'rex/encoding/xor/dword_additive'
5
-
6
- ###
7
- #
8
- # This class wraps the Dword XOR Additive feedback encoder.
9
- #
10
- ###
11
- class Rex::Encoder::Xor::DwordAdditive < Rex::Encoder::Xor
12
- EncoderKlass = Rex::Encoding::Xor::DwordAdditive
13
- end
@@ -1,35 +0,0 @@
1
- #!/usr/bin/env ruby
2
-
3
- require 'rex/arch/x86'
4
- require 'rex/encoder/xor/dword'
5
-
6
- module Rex
7
- module Encoders
8
-
9
- ###
10
- #
11
- # Spoon's smaller variable-length encoder (updated to use call $+4 by vlad902)
12
- #
13
- ###
14
- class XorDword < Rex::Encoder::Xor::Dword
15
- module Backend
16
- def _prepend
17
- # set the counter to the rounded up number of dwords to decode
18
- Rex::Arch::X86.set(
19
- Rex::Arch::X86::ECX,
20
- (encoded.length - 1 >> 2) + 1,
21
- badchars
22
- ) +
23
- "\xe8\xff\xff\xff" + # call $+4
24
- "\xff\xc0" + # inc eax
25
- "\x5e" + # pop esi
26
- "\x81\x76\x0e" + key + # xor_xor: xor [esi + 0x0e], $xorkey
27
- "\x83\xee\xfc" + # sub esi, -4
28
- "\xe2\xf4" # loop xor_xor
29
- end
30
- end
31
-
32
- include Backend
33
- end
34
-
35
- end end
@@ -1,53 +0,0 @@
1
- #!/usr/bin/env ruby
2
-
3
- require 'rex/encoder/xor/dword_additive'
4
-
5
- ##
6
- #
7
- # Jmp/Call Dword Additive Feedback Encoder
8
- # Author: skape
9
- # Arch: x86
10
- #
11
- ##
12
- module Rex
13
- module Encoders
14
-
15
- class XorDwordAdditive < Rex::Encoder::Xor::DwordAdditive
16
- module Backend
17
-
18
- def _unencoded_transform(data)
19
- # check for any dword aligned zeros that would falsely terminate the decoder
20
- idx = 0
21
- while true
22
- idx = data.index("\x00\x00\x00\x00", idx)
23
- break if !idx
24
- if idx & 3 == 0
25
- raise RuntimeError, "Unencoded data cannot have a dword aligned 0 dword!", caller()
26
- end
27
- idx += 1
28
- end
29
-
30
- # pad to a dword boundary and append null dword for termination
31
- data = data + ("\x00" * ((4 - data.length & 3) & 3)) + "\x00\x00\x00\x00"
32
- end
33
-
34
- def _prepend
35
- "\xfc" + # cld
36
- "\xbb" + key + # mov ebx, key
37
- "\xeb\x0c" + # jmp short 0x14
38
- "\x5e" + # pop esi
39
- "\x56" + # push esi
40
- "\x31\x1e" + # xor [esi], ebx
41
- "\xad" + # lodsd
42
- "\x01\xc3" + # add ebx, eax
43
- "\x85\xc0" + # test eax, eax
44
- "\x75\xf7" + # jnz 0xa
45
- "\xc3" + # ret
46
- "\xe8\xef\xff\xff\xff" # call 0x8
47
- end
48
- end
49
-
50
- include Backend
51
- end
52
-
53
- end end