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,282 +0,0 @@
1
- #!/usr/bin/env ruby
2
-
3
- require 'rex/post/dir'
4
- require 'rex/post/meterpreter/extensions/stdapi/stdapi'
5
-
6
- module Rex
7
- module Post
8
- module Meterpreter
9
- module Extensions
10
- module Stdapi
11
- module Fs
12
-
13
- ###
14
- #
15
- # This class implements directory operations against the remote endpoint. It
16
- # implements the Rex::Post::Dir interface.
17
- #
18
- ###
19
- class Dir < Rex::Post::Dir
20
-
21
- class << self
22
- attr_accessor :client
23
- end
24
-
25
- ##
26
- #
27
- # Constructor
28
- #
29
- ##
30
-
31
- #
32
- # Initializes the directory instance.
33
- #
34
- def initialize(path)
35
- self.path = path
36
- self.client = self.class.client
37
- end
38
-
39
- ##
40
- #
41
- # Enumeration
42
- #
43
- ##
44
-
45
- #
46
- # Enumerates all of the contents of the directory.
47
- #
48
- def each(&block)
49
- client.fs.dir.foreach(self.path, &block)
50
- end
51
-
52
- #
53
- # Enumerates all of the files/folders in a given directory.
54
- #
55
- def Dir.entries(name = getwd)
56
- request = Packet.create_request('stdapi_fs_ls')
57
- files = []
58
-
59
- request.add_tlv(TLV_TYPE_DIRECTORY_PATH, name)
60
-
61
- response = client.send_request(request)
62
-
63
- response.each(TLV_TYPE_FILE_NAME) { |file_name|
64
- files << file_name.value
65
- }
66
-
67
- return files
68
- end
69
-
70
- #
71
- # Enumerates files with a bit more information than the default entries.
72
- #
73
- def Dir.entries_with_info(name = getwd)
74
- request = Packet.create_request('stdapi_fs_ls')
75
- files = []
76
-
77
- request.add_tlv(TLV_TYPE_DIRECTORY_PATH, name)
78
-
79
- response = client.send_request(request)
80
-
81
- fname = response.get_tlvs(TLV_TYPE_FILE_NAME)
82
- fpath = response.get_tlvs(TLV_TYPE_FILE_PATH)
83
- sbuf = response.get_tlvs(TLV_TYPE_STAT_BUF)
84
-
85
- if (!fname or !sbuf)
86
- return []
87
- end
88
-
89
- fname.each_with_index { |file_name, idx|
90
- st = nil
91
-
92
- if (sbuf[idx])
93
- st = ::Rex::Post::FileStat.new
94
- st.update(sbuf[idx].value)
95
- end
96
-
97
- files <<
98
- {
99
- 'FileName' => file_name.value,
100
- 'FilePath' => fpath[idx].value,
101
- 'StatBuf' => st,
102
- }
103
- }
104
-
105
- return files
106
- end
107
-
108
- ##
109
- #
110
- # General directory operations
111
- #
112
- ##
113
-
114
- #
115
- # Changes the working directory of the remote process.
116
- #
117
- def Dir.chdir(path)
118
- request = Packet.create_request('stdapi_fs_chdir')
119
-
120
- request.add_tlv(TLV_TYPE_DIRECTORY_PATH, path)
121
-
122
- response = client.send_request(request)
123
-
124
- return 0
125
- end
126
-
127
- #
128
- # Creates a directory.
129
- #
130
- def Dir.mkdir(path)
131
- request = Packet.create_request('stdapi_fs_mkdir')
132
-
133
- request.add_tlv(TLV_TYPE_DIRECTORY_PATH, path)
134
-
135
- response = client.send_request(request)
136
-
137
- return 0
138
- end
139
-
140
- #
141
- # Returns the current working directory of the remote process.
142
- #
143
- def Dir.pwd
144
- request = Packet.create_request('stdapi_fs_getwd')
145
-
146
- response = client.send_request(request)
147
-
148
- return response.get_tlv(TLV_TYPE_DIRECTORY_PATH).value
149
- end
150
-
151
- #
152
- # Synonym for pwd.
153
- #
154
- def Dir.getwd
155
- pwd
156
- end
157
-
158
- #
159
- # Removes the supplied directory if it's empty.
160
- #
161
- def Dir.delete(path)
162
- request = Packet.create_request('stdapi_fs_delete_dir')
163
-
164
- request.add_tlv(TLV_TYPE_DIRECTORY_PATH, path)
165
-
166
- response = client.send_request(request)
167
-
168
- return 0
169
- end
170
-
171
- #
172
- # Synonyms for delete.
173
- #
174
- def Dir.rmdir(path)
175
- delete(path)
176
- end
177
-
178
- #
179
- # Synonyms for delete.
180
- #
181
- def Dir.unlink(path)
182
- delete(path)
183
- end
184
-
185
- ##
186
- #
187
- # Directory mirroring
188
- #
189
- ##
190
-
191
- #
192
- # Downloads the contents of a remote directory a
193
- # local directory, optionally in a recursive fashion.
194
- #
195
- def Dir.download(dst, src, recursive = false, force = true, &stat)
196
- self.entries(src).each { |src_sub|
197
- dst_item = dst + ::File::SEPARATOR + src_sub
198
- src_item = src + File::SEPARATOR + src_sub
199
-
200
- if (src_sub == '.' or src_sub == '..')
201
- next
202
- end
203
-
204
- src_stat = client.fs.filestat.new(src_item)
205
-
206
- if (src_stat.file?)
207
- stat.call('downloading', src_item, dst_item) if (stat)
208
- begin
209
- client.fs.file.download(dst_item, src_item)
210
- stat.call('downloaded', src_item, dst_item) if (stat)
211
- rescue ::Rex::Post::Meterpreter::RequestError => e
212
- if force
213
- stat.call('failed', src_item, dst_item) if (stat)
214
- else
215
- raise e
216
- end
217
- end
218
-
219
- elsif (src_stat.directory?)
220
- if (recursive == false)
221
- next
222
- end
223
-
224
- begin
225
- ::Dir.mkdir(dst_item)
226
- rescue
227
- end
228
-
229
- stat.call('mirroring', src_item, dst_item) if (stat)
230
- download(dst_item, src_item, recursive, force, &stat)
231
- stat.call('mirrored', src_item, dst_item) if (stat)
232
- end
233
- }
234
- end
235
-
236
- #
237
- # Uploads the contents of a local directory to a remote
238
- # directory, optionally in a recursive fashion.
239
- #
240
- def Dir.upload(dst, src, recursive = false, &stat)
241
- ::Dir.entries(src).each { |src_sub|
242
- dst_item = dst + File::SEPARATOR + src_sub
243
- src_item = src + ::File::SEPARATOR + src_sub
244
-
245
- if (src_sub == '.' or src_sub == '..')
246
- next
247
- end
248
-
249
- src_stat = ::File.stat(src_item)
250
-
251
- if (src_stat.file?)
252
- stat.call('uploading', src_item, dst_item) if (stat)
253
- client.fs.file.upload(dst_item, src_item)
254
- stat.call('uploaded', src_item, dst_item) if (stat)
255
- elsif (src_stat.directory?)
256
- if (recursive == false)
257
- next
258
- end
259
-
260
- begin
261
- self.mkdir(dst_item)
262
- rescue
263
- end
264
-
265
- stat.call('mirroring', src_item, dst_item) if (stat)
266
- upload(dst_item, src_item, recursive, &stat)
267
- stat.call('mirrored', src_item, dst_item) if (stat)
268
- end
269
- }
270
- end
271
-
272
- #
273
- # The path of the directory that was opened.
274
- #
275
- attr_reader :path
276
- protected
277
- attr_accessor :client # :nodoc:
278
- attr_writer :path # :nodoc:
279
-
280
- end
281
-
282
- end; end; end; end; end; end
@@ -1,266 +0,0 @@
1
- #!/usr/bin/env ruby
2
-
3
- require 'rex/post/file'
4
- require 'rex/post/meterpreter/channel'
5
- require 'rex/post/meterpreter/channels/pools/file'
6
- require 'rex/post/meterpreter/extensions/stdapi/stdapi'
7
- require 'rex/post/meterpreter/extensions/stdapi/fs/io'
8
- require 'rex/post/meterpreter/extensions/stdapi/fs/file_stat'
9
- require 'fileutils'
10
-
11
- module Rex
12
- module Post
13
- module Meterpreter
14
- module Extensions
15
- module Stdapi
16
- module Fs
17
-
18
- ###
19
- #
20
- # This class implements the Rex::Post::File interface and wraps interaction
21
- # with files on the remote machine.
22
- #
23
- ###
24
- class File < Rex::Post::Meterpreter::Extensions::Stdapi::Fs::IO
25
-
26
- SEPARATOR = "\\"
27
- Separator = "\\"
28
-
29
- include Rex::Post::File
30
-
31
- class << self
32
- attr_accessor :client
33
- end
34
-
35
- #
36
- # Search for files.
37
- #
38
- def File.search( root=nil, glob="*.*", recurse=true, timeout=-1 )
39
-
40
- files = ::Array.new
41
-
42
- request = Packet.create_request( 'stdapi_fs_search' )
43
-
44
- root = root.chomp( '\\' ) if root
45
-
46
- request.add_tlv( TLV_TYPE_SEARCH_ROOT, root )
47
- request.add_tlv( TLV_TYPE_SEARCH_GLOB, glob )
48
- request.add_tlv( TLV_TYPE_SEARCH_RECURSE, recurse )
49
-
50
- # we set the response timeout to -1 to wait indefinatly as a
51
- # search could take an indeterminate ammount of time to complete.
52
- response = client.send_request( request, timeout )
53
- if( response.result == 0 )
54
- response.each( TLV_TYPE_SEARCH_RESULTS ) do | results |
55
- files << {
56
- 'path' => results.get_tlv_value( TLV_TYPE_FILE_PATH ).chomp( '\\' ),
57
- 'name' => results.get_tlv_value( TLV_TYPE_FILE_NAME ),
58
- 'size' => results.get_tlv_value( TLV_TYPE_FILE_SIZE )
59
- }
60
- end
61
- end
62
-
63
- return files
64
- end
65
-
66
- #
67
- # Returns the base name of the supplied file path to the caller.
68
- #
69
- def File.basename(*a)
70
- path = a[0]
71
- sep = "\\" + File::SEPARATOR
72
-
73
- # I suck at regex.
74
- path =~ /(.*)#{sep}(.*)$/
75
-
76
- Rex::FileUtils.clean_path($2 || path)
77
- end
78
-
79
- #
80
- # Expands a file path, substituting all environment variables, such as
81
- # %TEMP%.
82
- #
83
- def File.expand_path(path)
84
- request = Packet.create_request('stdapi_fs_file_expand_path')
85
-
86
- request.add_tlv(TLV_TYPE_FILE_PATH, path)
87
-
88
- response = client.send_request(request)
89
-
90
- return response.get_tlv_value(TLV_TYPE_FILE_PATH)
91
- end
92
-
93
- #
94
- # Performs a stat on a file and returns a FileStat instance.
95
- #
96
- def File.stat(name)
97
- return client.fs.filestat.new(name)
98
- end
99
-
100
- #
101
- # Performs a delete on the specified file.
102
- #
103
- def File.rm(name)
104
- request = Packet.create_request('stdapi_fs_delete_file')
105
-
106
- request.add_tlv(TLV_TYPE_FILE_PATH,name)
107
-
108
- response = client.send_request(request)
109
-
110
- return response
111
- end
112
-
113
- #
114
- # Performs a delete on the specified file.
115
- #
116
- def File.unlink(name)
117
- return File.rm(name)
118
- end
119
-
120
- #
121
- # Upload one or more files to the remote computer the remote
122
- # directory supplied in destination.
123
- #
124
- def File.upload(destination, *src_files, &stat)
125
- src_files.each { |src|
126
- dest = destination
127
-
128
- stat.call('uploading', src, dest) if (stat)
129
- if (File.basename(destination) != ::File.basename(src))
130
- dest += File::SEPARATOR + ::File.basename(src)
131
- end
132
-
133
- upload_file(dest, src)
134
- stat.call('uploaded', src, dest) if (stat)
135
- }
136
- end
137
-
138
- #
139
- # Upload a single file.
140
- #
141
- def File.upload_file(dest_file, src_file)
142
- # Open the file on the remote side for writing and read
143
- # all of the contents of the local file
144
- dest_fd = client.fs.file.new(dest_file, "wb")
145
- src_buf = ''
146
-
147
- ::File.open(src_file, 'rb') { |f|
148
- src_buf = f.read(f.stat.size)
149
- }
150
-
151
- begin
152
- dest_fd.write(src_buf)
153
- ensure
154
- dest_fd.close
155
- end
156
- end
157
-
158
- #
159
- # Download one or more files from the remote computer to the local
160
- # directory supplied in destination.
161
- #
162
- def File.download(destination, *src_files, &stat)
163
- src_files.each { |src|
164
- dest = destination
165
-
166
- stat.call('downloading', src, dest) if (stat)
167
-
168
- if (::File.basename(destination) != File.basename(src))
169
- dest += ::File::SEPARATOR + File.basename(src)
170
- end
171
-
172
- download_file(dest, src)
173
-
174
- stat.call('downloaded', src, dest) if (stat)
175
- }
176
- end
177
-
178
- #
179
- # Download a single file.
180
- #
181
- def File.download_file(dest_file, src_file)
182
- src_fd = client.fs.file.new(src_file, "rb")
183
- ::FileUtils.mkdir_p(::File.dirname(dest_file))
184
- dst_fd = ::File.new(dest_file, "wb")
185
-
186
- # Keep transferring until EOF is reached...
187
- begin
188
- while ((data = src_fd.read) != nil)
189
- dst_fd.write(data)
190
- end
191
- rescue EOFError
192
- ensure
193
- src_fd.close
194
- dst_fd.close
195
- end
196
- end
197
-
198
- ##
199
- #
200
- # Constructor
201
- #
202
- ##
203
-
204
- #
205
- # Initializes and opens the specified file with the specified permissions.
206
- #
207
- def initialize(name, mode = "r", perms = 0)
208
- self.client = self.class.client
209
- self.filed = _open(name, mode, perms)
210
- end
211
-
212
- ##
213
- #
214
- # IO implementators
215
- #
216
- ##
217
-
218
- #
219
- # Returns whether or not the file has reach EOF.
220
- #
221
- def eof
222
- return self.filed.eof
223
- end
224
-
225
- #
226
- # Returns the current position of the file pointer.
227
- #
228
- def pos
229
- return self.filed.tell
230
- end
231
-
232
- #
233
- # Synonym for sysseek.
234
- #
235
- def seek(offset, whence = SEEK_SET)
236
- return self.sysseek(offset, whence)
237
- end
238
-
239
- #
240
- # Seeks to the supplied offset based on the supplied relativity.
241
- #
242
- def sysseek(offset, whence = SEEK_SET)
243
- return self.filed.seek(offset, whence)
244
- end
245
-
246
- protected
247
-
248
- ##
249
- #
250
- # Internal methods
251
- #
252
- ##
253
-
254
- #
255
- # Creates a File channel using the supplied information.
256
- #
257
- def _open(name, mode = "r", perms = 0)
258
- return Rex::Post::Meterpreter::Channels::Pools::File.open(
259
- self.client, name, mode, perms)
260
- end
261
-
262
- attr_accessor :client # :nodoc:
263
-
264
- end
265
-
266
- end; end; end; end; end; end