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,197 +0,0 @@
1
- #!/usr/bin/env ruby
2
-
3
- require 'socket'
4
- require 'fcntl'
5
-
6
- module Rex
7
- module IO
8
-
9
- ###
10
- #
11
- # This class provides an abstraction to a stream based
12
- # connection through the use of a streaming socketpair.
13
- #
14
- ###
15
- module StreamAbstraction
16
-
17
- ###
18
- #
19
- # Extension information for required Stream interface.
20
- #
21
- ###
22
- module Ext
23
-
24
- #
25
- # Initializes peer information.
26
- #
27
- def initinfo(peer,local)
28
- @peer = peer
29
- @local = local
30
- end
31
-
32
- #
33
- # Symbolic peer information.
34
- #
35
- def peerinfo
36
- (@peer || "Remote Pipe")
37
- end
38
-
39
- #
40
- # Symbolic local information.
41
- #
42
- def localinfo
43
- (@local || "Local Pipe")
44
- end
45
- end
46
-
47
- #
48
- # This method creates a streaming socket pair and initializes it.
49
- #
50
- def initialize_abstraction
51
- self.lsock, self.rsock = Rex::Socket.tcp_socket_pair()
52
- self.lsock.extend(Rex::IO::Stream)
53
- self.lsock.extend(Ext)
54
- self.rsock.extend(Rex::IO::Stream)
55
-
56
- self.monitor_rsock
57
- end
58
-
59
- #
60
- # This method cleans up the abstraction layer.
61
- #
62
- def cleanup_abstraction
63
- self.lsock.close if (self.lsock)
64
- self.rsock.close if (self.rsock)
65
-
66
- self.lsock = nil
67
- self.rsock = nil
68
- end
69
-
70
- #
71
- # Writes to the local side.
72
- #
73
- def syswrite(buffer)
74
- lsock.syswrite(buffer)
75
- end
76
-
77
- #
78
- # Reads from the local side.
79
- #
80
- def sysread(length)
81
- lsock.sysread(length)
82
- end
83
-
84
- #
85
- # Shuts down the local side of the stream abstraction.
86
- #
87
- def shutdown(how)
88
- lsock.shutdown(how)
89
- end
90
-
91
- #
92
- # Closes both sides of the stream abstraction.
93
- #
94
- def close
95
- cleanup_abstraction
96
- end
97
-
98
- #
99
- # Symbolic peer information.
100
- #
101
- def peerinfo
102
- "Remote-side of Pipe"
103
- end
104
-
105
- #
106
- # Symbolic local information.
107
- #
108
- def localinfo
109
- "Local-side of Pipe"
110
- end
111
-
112
- #
113
- # The left side of the stream.
114
- #
115
- attr_reader :lsock
116
- #
117
- # The right side of the stream.
118
- #
119
- attr_reader :rsock
120
-
121
- protected
122
-
123
- def monitor_rsock
124
- self.monitor_thread = Rex::ThreadFactory.spawn("StreamMonitorRemote", false) {
125
- loop do
126
- closed = false
127
- buf = nil
128
-
129
- if not self.rsock
130
- wlog("monitor_rsock: the remote socket is nil, exiting loop")
131
- break
132
- end
133
-
134
- begin
135
- s = Rex::ThreadSafe.select( [ self.rsock ], nil, nil, 0.2 )
136
- if( s == nil || s[0] == nil )
137
- next
138
- end
139
- rescue Exception => e
140
- wlog("monitor_rsock: exception during select: #{e.class} #{e}")
141
- closed = true
142
- end
143
-
144
- if( closed == false )
145
- begin
146
- buf = self.rsock.sysread( 32768 )
147
- if buf == nil
148
- closed = true
149
- wlog("monitor_rsock: closed remote socket due to nil read")
150
- end
151
-
152
- rescue ::Exception
153
- closed = true
154
- wlog("monitor_rsock: exception during read: #{e.class} #{e}")
155
- end
156
- end
157
-
158
- if( closed == false )
159
- total_sent = 0
160
- total_length = buf.length
161
- while( total_sent < total_length )
162
- begin
163
- data = buf[0, buf.length]
164
- sent = self.write( data )
165
- # sf: Only remove the data off the queue is syswrite was successfull.
166
- # This way we naturally perform a resend if a failure occured.
167
- # Catches an edge case with meterpreter TCP channels where remote send
168
- # failes gracefully and a resend is required.
169
- if( sent > 0 )
170
- total_sent += sent
171
- buf[0, sent] = ""
172
- end
173
- rescue ::IOError => e
174
- closed = true
175
- wlog("monitor_rsock: exception during write: #{e.class} #{e}")
176
- break
177
- end
178
- end
179
- end
180
-
181
- if( closed )
182
- self.close_write if self.respond_to?('close_write')
183
- break
184
- end
185
- end
186
- }
187
- end
188
-
189
- protected
190
- attr_accessor :monitor_thread
191
- attr_writer :lsock
192
- attr_writer :rsock
193
-
194
- end
195
-
196
- end; end
197
-
@@ -1,211 +0,0 @@
1
- module Rex
2
- module IO
3
-
4
- ###
5
- #
6
- # This mixin provides the framework and interface for implementing a streaming
7
- # server that can listen for and accept stream client connections. Stream
8
- # servers extend this class and are required to implement the following
9
- # methods:
10
- #
11
- # accept
12
- # fd
13
- #
14
- ###
15
- module StreamServer
16
-
17
- ##
18
- #
19
- # Abstract methods
20
- #
21
- ##
22
-
23
- ##
24
- #
25
- # Default server monitoring and client management implementation follows
26
- # below.
27
- #
28
- ##
29
-
30
- #
31
- # This callback is notified when a client connects.
32
- #
33
- def on_client_connect(client)
34
- if (on_client_connect_proc)
35
- on_client_connect_proc.call(client)
36
- end
37
- end
38
-
39
- #
40
- # This callback is notified when a client connection has data that needs to
41
- # be processed.
42
- #
43
- def on_client_data(client)
44
- if (on_client_data_proc)
45
- on_client_data_proc.call(client)
46
- end
47
- end
48
-
49
- #
50
- # This callback is notified when a client connection has closed.
51
- #
52
- def on_client_close(client)
53
- if (on_client_close_proc)
54
- on_client_close_proc.call(client)
55
- end
56
- end
57
-
58
- #
59
- # Start monitoring the listener socket for connections and keep track of
60
- # all client connections.
61
- #
62
- def start
63
- self.clients = []
64
-
65
- self.listener_thread = Rex::ThreadFactory.spawn("StreamServerListener", false) {
66
- monitor_listener
67
- }
68
- self.clients_thread = Rex::ThreadFactory.spawn("StreamServerClientMonitor", false) {
69
- monitor_clients
70
- }
71
- end
72
-
73
- #
74
- # Terminates the listener monitoring threads and closes all active clients.
75
- #
76
- def stop
77
- self.listener_thread.kill
78
- self.clients_thread.kill
79
-
80
- self.clients.each { |cli|
81
- close_client(cli)
82
- }
83
- end
84
-
85
- #
86
- # This method closes a client connection and cleans up the resources
87
- # associated with it.
88
- #
89
- def close_client(client)
90
- if (client)
91
- clients.delete(client)
92
-
93
- begin
94
- client.close
95
- rescue IOError
96
- end
97
- end
98
- end
99
-
100
- #
101
- # This method waits on the server listener thread
102
- #
103
- def wait
104
- self.listener_thread.join if self.listener_thread
105
- end
106
-
107
- ##
108
- #
109
- # Callback procedures.
110
- #
111
- ##
112
-
113
- #
114
- # This callback procedure can be set and will be called when new clients
115
- # connect.
116
- #
117
- attr_accessor :on_client_connect_proc
118
- #
119
- # This callback procedure can be set and will be called when clients
120
- # have data to be processed.
121
- #
122
- attr_accessor :on_client_data_proc
123
- #
124
- # This callback procedure can be set and will be called when a client
125
- # disconnects from the server.
126
- #
127
- attr_accessor :on_client_close_proc
128
-
129
- attr_accessor :clients # :nodoc:
130
- attr_accessor :listener_thread, :clients_thread # :nodoc:
131
-
132
- protected
133
-
134
- #
135
- # This method monitors the listener socket for new connections and calls
136
- # the +on_client_connect+ callback routine.
137
- #
138
- def monitor_listener
139
-
140
- while true
141
- begin
142
- cli = accept
143
- if not cli
144
- elog("The accept() returned nil in stream server listener monitor: #{fd.inspect}")
145
- ::IO.select(nil, nil, nil, 0.10)
146
- next
147
- end
148
-
149
- # Append to the list of clients
150
- self.clients << cli
151
-
152
- # Initialize the connection processing
153
- on_client_connect(cli)
154
-
155
- # Skip exceptions caused by accept() [ SSL ]
156
- rescue ::EOFError, ::Errno::ECONNRESET, ::Errno::ENOTCONN, ::Errno::ECONNABORTED
157
- rescue ::Interrupt
158
- raise $!
159
- rescue ::Exception
160
- elog("Error in stream server server monitor: #{$!}")
161
- rlog(ExceptionCallStack)
162
- break
163
- end
164
- end
165
- end
166
-
167
- #
168
- # This method monitors client connections for data and calls the
169
- # +on_client_data+ routine when new data arrives.
170
- #
171
- def monitor_clients
172
- begin
173
- if (clients.length == 0)
174
- Rex::ThreadSafe::sleep(0.25)
175
- next
176
- end
177
-
178
- sd = Rex::ThreadSafe.select(clients)
179
-
180
- sd[0].each { |cfd|
181
- begin
182
- on_client_data(cfd)
183
- rescue ::EOFError, ::Errno::ECONNRESET, ::Errno::ENOTCONN, ::Errno::ECONNABORTED
184
- on_client_close(cfd)
185
- close_client(cfd)
186
- rescue ::Interrupt
187
- raise $!
188
- rescue ::Exception
189
- close_client(cfd)
190
- elog("Error in stream server client monitor: #{$!}")
191
- rlog(ExceptionCallStack)
192
-
193
- end
194
- }
195
-
196
- rescue ::Rex::StreamClosedError => e
197
- # Remove the closed stream from the list
198
- clients.delete(e.stream)
199
- rescue ::Interrupt
200
- raise $!
201
- rescue ::Exception
202
- elog("Error in stream server client monitor: #{$!}")
203
- rlog(ExceptionCallStack)
204
- end while true
205
- end
206
-
207
- end
208
-
209
- end
210
- end
211
-
@@ -1,187 +0,0 @@
1
- module Rex
2
-
3
- ###
4
- #
5
- # This class is the concrete representation of an abstract job.
6
- #
7
- ###
8
- class Job
9
-
10
- #
11
- # Creates an individual job instance and initializes it with the supplied
12
- # parameters.
13
- #
14
- def initialize(container, jid, name, ctx, run_proc, clean_proc)
15
- self.container = container
16
- self.jid = jid
17
- self.name = name
18
- self.run_proc = run_proc
19
- self.clean_proc = clean_proc
20
- self.ctx = ctx
21
- self.start_time = nil
22
- end
23
-
24
- #
25
- # Runs the job in the context of its own thread if the async flag is false.
26
- # Otherwise, the job is run inline.
27
- #
28
- def start(async = false)
29
- self.start_time = Time.now
30
- if (async)
31
- self.job_thread = Rex::ThreadFactory.spawn("JobID(#{jid})-#{name}", false) {
32
- # Deschedule our thread momentarily
33
- ::IO.select(nil, nil, nil, 0.01)
34
-
35
- begin
36
- run_proc.call(ctx)
37
- ensure
38
- clean_proc.call(ctx)
39
- container.remove_job(self)
40
- end
41
- }
42
- else
43
- begin
44
- run_proc.call(ctx)
45
- rescue ::Exception
46
- container.stop_job(jid)
47
- raise $!
48
- end
49
- end
50
- end
51
-
52
- #
53
- # Stops the job if it's currently running and calls its cleanup procedure
54
- #
55
- def stop
56
- if (self.job_thread)
57
- self.job_thread.kill
58
- self.job_thread = nil
59
- end
60
-
61
- clean_proc.call(ctx) if (clean_proc)
62
- end
63
-
64
- #
65
- # The name of the job.
66
- #
67
- attr_reader :name
68
-
69
- #
70
- # The job identifier as assigned by the job container.
71
- #
72
- attr_reader :jid
73
-
74
- #
75
- # The time at which this job was started.
76
- #
77
- attr_reader :start_time
78
-
79
- #
80
- # Some job context.
81
- #
82
- attr_reader :ctx
83
-
84
- protected
85
-
86
- attr_writer :name #:nodoc:
87
- attr_writer :jid #:nodoc:
88
- attr_accessor :job_thread #:nodoc:
89
- attr_accessor :container #:nodoc:
90
- attr_accessor :run_proc #:nodoc:
91
- attr_accessor :clean_proc #:nodoc:
92
- attr_writer :ctx #:nodoc:
93
- attr_writer :start_time #:nodoc:
94
-
95
- end
96
-
97
- ###
98
- #
99
- # This class contains zero or more abstract jobs that can be enumerated and
100
- # stopped in a generic fashion. This is used to provide a mechanism for
101
- # keeping track of arbitrary contexts that may or may not require a dedicated
102
- # thread.
103
- #
104
- ###
105
- class JobContainer < Hash
106
-
107
- def initialize
108
- self.job_id_pool = 0
109
- end
110
-
111
- #
112
- # Adds an already running task as a symbolic job to the container.
113
- #
114
- def add_job(name, ctx, run_proc, clean_proc)
115
- real_name = name
116
- count = 0
117
- jid = job_id_pool
118
-
119
- self.job_id_pool += 1
120
-
121
- # If we were not supplied with a job name, pick one from the hat
122
- if (real_name == nil)
123
- real_name = '#' + jid.to_s
124
- end
125
-
126
- # Find a unique job name
127
- while (j = self[real_name])
128
- real_name = name + " #{count}"
129
- count += 1
130
- end
131
-
132
- j = Job.new(self, jid, real_name, ctx, run_proc, clean_proc)
133
-
134
- self[jid.to_s] = j
135
- end
136
-
137
- #
138
- # Starts a job using the supplied name and run/clean procedures.
139
- #
140
- def start_job(name, ctx, run_proc, clean_proc = nil)
141
- j = add_job(name, ctx, run_proc, clean_proc)
142
- j.start
143
-
144
- j.jid
145
- end
146
-
147
- #
148
- # Starts a background job that doesn't call the cleanup routine or run
149
- # the run_proc in its own thread. Rather, the run_proc is called
150
- # immediately and the clean_proc is never called until the job is removed
151
- # from the job container.
152
- #
153
- def start_bg_job(name, ctx, run_proc, clean_proc = nil, async = true)
154
- j = add_job(name, ctx, run_proc, clean_proc)
155
- j.start(async)
156
-
157
- j.jid
158
- end
159
-
160
- #
161
- # Stops the job with the supplied name and forces it to cleanup. Stopping
162
- # the job also leads to its removal.
163
- #
164
- def stop_job(jid)
165
- if (j = self[jid.to_s])
166
- j.stop
167
-
168
- remove_job(j)
169
- end
170
- end
171
-
172
- #
173
- # Removes a job that was previously running. This is typically called when
174
- # a job completes its task.
175
- #
176
- def remove_job(inst)
177
- self.delete(inst.jid.to_s)
178
- end
179
-
180
- protected
181
-
182
- attr_accessor :job_id_pool # :nodoc:
183
-
184
- end
185
-
186
- end
187
-