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,129 +0,0 @@
1
- #!/usr/bin/env ruby
2
-
3
- require 'rex/post/meterpreter/client'
4
- require 'rex/post/meterpreter/extensions/stdapi/constants'
5
-
6
- module Rex
7
- module Post
8
- module Meterpreter
9
- module Extensions
10
- module Stdapi
11
- module Sys
12
- module ProcessSubsystem
13
-
14
- ###
15
- #
16
- # Interacts with loading, unloading, enumerating, and querying
17
- # image files in the context of a given process.
18
- #
19
- ###
20
- class Image
21
-
22
- ##
23
- #
24
- # Constructor
25
- #
26
- ##
27
-
28
- #
29
- # Initializes the image instance.
30
- #
31
- def initialize(process)
32
- self.process = process
33
- end
34
-
35
- #
36
- # Returns the image base address associated with the supplied image name.
37
- #
38
- def [](key)
39
- each_image { |i|
40
- if (i['name'].downcase == key.downcase)
41
- return i['base']
42
- end
43
- }
44
-
45
- return nil
46
- end
47
-
48
- #
49
- # Loads an image file into the context of the process.
50
- #
51
- def load(image_path)
52
- request = Packet.create_request('stdapi_sys_process_image_load')
53
-
54
- request.add_tlv(TLV_TYPE_HANDLE, process.handle)
55
- request.add_tlv(TLV_TYPE_IMAGE_FILE_PATH, image_path)
56
-
57
- response = process.client.send_request(request)
58
-
59
- return response.get_tlv_value(TLV_TYPE_IMAGE_BASE)
60
- end
61
-
62
- #
63
- # Returns the address of the procedure that is found in the supplied
64
- # library.
65
- #
66
- def get_procedure_address(image_file, procedure)
67
- request = Packet.create_request('stdapi_sys_process_image_get_proc_address')
68
-
69
- request.add_tlv(TLV_TYPE_HANDLE, process.handle)
70
- request.add_tlv(TLV_TYPE_IMAGE_FILE, image_file)
71
- request.add_tlv(TLV_TYPE_PROCEDURE_NAME, procedure)
72
-
73
- response = process.client.send_request(request)
74
-
75
- return response.get_tlv_value(TLV_TYPE_PROCEDURE_ADDRESS)
76
- end
77
-
78
- #
79
- # Unloads an image file that is loaded into the address space of the
80
- # process by its base address.
81
- #
82
- def unload(base)
83
- request = Packet.create_request('stdapi_sys_process_image_unload')
84
-
85
- request.add_tlv(TLV_TYPE_HANDLE, process.handle)
86
- request.add_tlv(TLV_TYPE_IMAGE_BASE, base)
87
-
88
- response = process.client.send_request(request)
89
-
90
- return true
91
- end
92
-
93
- #
94
- # Enumerates through each image in the process.
95
- #
96
- def each_image(&block)
97
- get_images.each(&block)
98
- end
99
-
100
- #
101
- # Returns an array of images in the process with hash objects that
102
- # have keys for 'name', 'path', and 'base'.
103
- #
104
- def get_images
105
- request = Packet.create_request('stdapi_sys_process_image_get_images')
106
- images = []
107
-
108
- request.add_tlv(TLV_TYPE_HANDLE, process.handle)
109
-
110
- response = process.client.send_request(request)
111
-
112
- response.each(TLV_TYPE_IMAGE_GROUP) { |i|
113
- images <<
114
- {
115
- 'name' => i.get_tlv_value(TLV_TYPE_IMAGE_NAME),
116
- 'base' => i.get_tlv_value(TLV_TYPE_IMAGE_BASE),
117
- 'path' => i.get_tlv_value(TLV_TYPE_IMAGE_FILE_PATH)
118
- }
119
- }
120
-
121
- return images
122
- end
123
-
124
- protected
125
- attr_accessor :process # :nodoc:
126
-
127
- end
128
-
129
- end; end; end; end; end; end; end
@@ -1,55 +0,0 @@
1
- #!/usr/bin/env ruby
2
-
3
- require 'rex/post/meterpreter/client'
4
- require 'rex/post/meterpreter/extensions/stdapi/constants'
5
-
6
- module Rex
7
- module Post
8
- module Meterpreter
9
- module Extensions
10
- module Stdapi
11
- module Sys
12
- module ProcessSubsystem
13
-
14
- ###
15
- #
16
- # This class provides an input/output interface to an executed
17
- # process' standard input and output.
18
- #
19
- ###
20
- class IO
21
-
22
- ##
23
- #
24
- # Constructor
25
- #
26
- ##
27
-
28
- #
29
- # Initializes the IO instance.
30
- #
31
- def initialize(process)
32
- self.process = process
33
- end
34
-
35
- #
36
- # Writes the supplied buffer to the standard input handle of the
37
- # executed process.
38
- #
39
- def write(buf)
40
- return process.channel.write(buf)
41
- end
42
-
43
- #
44
- # Reads data from the standard output handle of the executed process.
45
- #
46
- def read(length = nil)
47
- return process.channel.read(length)
48
- end
49
-
50
- protected
51
- attr_accessor :process # :nodoc:
52
-
53
- end
54
-
55
- end; end; end; end; end; end; end
@@ -1,336 +0,0 @@
1
- #!/usr/bin/env ruby
2
-
3
- require 'rex/post/meterpreter/client'
4
- require 'rex/post/meterpreter/extensions/stdapi/constants'
5
-
6
- module Rex
7
- module Post
8
- module Meterpreter
9
- module Extensions
10
- module Stdapi
11
- module Sys
12
- module ProcessSubsystem
13
-
14
- ###
15
- #
16
- # Provides an interface to allocate, free, read, write, query,
17
- # protect, lock, and unlock memory in the context of a given
18
- # process.
19
- #
20
- ###
21
- class Memory
22
-
23
- # Page protection translation hash
24
- @@page_protection_map =
25
- {
26
- PROT_NONE => PAGE_NOACCESS,
27
- PROT_EXEC => PAGE_EXECUTE,
28
- PROT_EXEC | PROT_READ => PAGE_EXECUTE_READ,
29
- PROT_EXEC | PROT_READ |
30
- PROT_WRITE => PAGE_EXECUTE_READWRITE,
31
- PROT_EXEC | PROT_READ |
32
- PROT_WRITE | PROT_COW => PAGE_EXECUTE_WRITECOPY,
33
- PROT_READ => PAGE_READONLY,
34
- PROT_READ | PROT_WRITE => PAGE_READWRITE,
35
- PROT_READ | PROT_WRITE |
36
- PROT_COW => PAGE_WRITECOPY,
37
- PROT_WRITE => PAGE_READWRITE
38
- }
39
-
40
- ##
41
- #
42
- # Constructor
43
- #
44
- ##
45
-
46
- #
47
- # Initializes a memory modification instance with the supplied process
48
- # instance.
49
- #
50
- def initialize(process)
51
- self.process = process
52
- end
53
-
54
- #
55
- # Allocate storage of the supplied length and returns the
56
- # address at which the memory was allocated.
57
- #
58
- def allocate(length, protection = nil, base = nil)
59
- allocation_type = MEM_COMMIT
60
-
61
- # If no protection was supplied, default to the most flexible
62
- if (protection == nil)
63
- protection = PAGE_EXECUTE_READWRITE
64
- else
65
- protection = gen_prot_to_specific(protection)
66
- end
67
-
68
- # If the preferred base is non-nil, set the reserve flag
69
- if (base != nil)
70
- allocation_type |= MEM_RESERVE
71
- end
72
-
73
- return _allocate(base, length, allocation_type, protection)
74
- end
75
-
76
- #
77
- # Low-level memory allocation.
78
- #
79
- def _allocate(base, length, allocation_type, protection)
80
- request = Packet.create_request('stdapi_sys_process_memory_allocate')
81
-
82
- # Populate the request
83
- if (base != nil)
84
- request.add_tlv(TLV_TYPE_BASE_ADDRESS, base)
85
- end
86
-
87
- request.add_tlv(TLV_TYPE_HANDLE, process.handle)
88
- request.add_tlv(TLV_TYPE_LENGTH, length)
89
- request.add_tlv(TLV_TYPE_ALLOCATION_TYPE, allocation_type)
90
- request.add_tlv(TLV_TYPE_PROTECTION, protection)
91
-
92
- # Transmit the request
93
- response = process.client.send_request(request);
94
-
95
- return response.get_tlv_value(TLV_TYPE_BASE_ADDRESS)
96
- end
97
-
98
- #
99
- # Deallocate a region of memory in the context of a process.
100
- #
101
- def free(base, length = 0)
102
- return _free(base, length)
103
- end
104
-
105
- #
106
- # Low-level memory deallocation.
107
- #
108
- def _free(base, length)
109
- request = Packet.create_request('stdapi_sys_process_memory_free')
110
-
111
- request.add_tlv(TLV_TYPE_HANDLE, process.handle)
112
- request.add_tlv(TLV_TYPE_BASE_ADDRESS, base)
113
- request.add_tlv(TLV_TYPE_LENGTH, length)
114
-
115
- response = process.client.send_request(request)
116
-
117
- return true
118
- end
119
-
120
- #
121
- # Read memory from the context of a process and return the buffer.
122
- #
123
- def read(base, length)
124
- request = Packet.create_request('stdapi_sys_process_memory_read')
125
-
126
- request.add_tlv(TLV_TYPE_HANDLE, process.handle)
127
- request.add_tlv(TLV_TYPE_BASE_ADDRESS, base)
128
- request.add_tlv(TLV_TYPE_LENGTH, length)
129
-
130
- response = process.client.send_request(request)
131
-
132
- return response.get_tlv_value(TLV_TYPE_PROCESS_MEMORY)
133
- end
134
-
135
- #
136
- # Write memory to the context of a process and return the number of bytes
137
- # actually written.
138
- #
139
- def write(base, data)
140
- request = Packet.create_request('stdapi_sys_process_memory_write')
141
-
142
- request.add_tlv(TLV_TYPE_HANDLE, process.handle)
143
- request.add_tlv(TLV_TYPE_BASE_ADDRESS, base)
144
- request.add_tlv(TLV_TYPE_PROCESS_MEMORY, data)
145
-
146
- response = process.client.send_request(request)
147
-
148
- return response.get_tlv_value(TLV_TYPE_LENGTH)
149
- end
150
-
151
- #
152
- # Queries an address for information about its state.
153
- #
154
- def query(base)
155
- request = Packet.create_request('stdapi_sys_process_memory_query')
156
-
157
- request.add_tlv(TLV_TYPE_HANDLE, process.handle)
158
- request.add_tlv(TLV_TYPE_BASE_ADDRESS, base)
159
-
160
- response = process.client.send_request(request)
161
-
162
- # Build out the hash from the response information
163
- info = {}
164
-
165
- info['BaseAddress'] = response.get_tlv_value(TLV_TYPE_BASE_ADDRESS)
166
- info['AllocationBase'] = response.get_tlv_value(TLV_TYPE_ALLOC_BASE_ADDRESS)
167
- info['AllocationProtect'] = specific_prot_to_gen(response.get_tlv_value(TLV_TYPE_ALLOC_PROTECTION))
168
- info['RegionSize'] = response.get_tlv_value(TLV_TYPE_LENGTH)
169
-
170
- # Translate the memory state
171
- state = response.get_tlv_value(TLV_TYPE_MEMORY_STATE)
172
-
173
- if (state == MEM_FREE)
174
- info['Available'] = true
175
- elsif (state == MEM_COMMIT)
176
- info['Available'] = false
177
- elsif (state == MEM_RESERVE)
178
- info['Reserved'] = true
179
- end
180
-
181
- # Translate the region protections
182
- info['Protect'] = specific_prot_to_gen(response.get_tlv_value(TLV_TYPE_PROTECTION))
183
-
184
- # Translate the memory type
185
- type = response.get_tlv_value(TLV_TYPE_MEMORY_TYPE)
186
-
187
- if (type == MEM_IMAGE)
188
- info['ImageMapping'] = true
189
- elsif (type == MEM_MAPPED)
190
- info['MemoryMapping'] = true
191
- elsif (type == MEM_PRIVATE)
192
- info['PrivateMapping'] = true
193
- end
194
-
195
- return info
196
- end
197
-
198
- #
199
- # Change the protection masks on the region supplied in base.
200
- #
201
- def protect(base, length = nil, protection = nil)
202
- request = Packet.create_request('stdapi_sys_process_memory_protect')
203
-
204
- if (length == nil)
205
- length = 4096
206
- end
207
-
208
- # If no protection was supplied, default to the most flexible
209
- if (protection == nil)
210
- protection = PAGE_EXECUTE_READWRITE
211
- else
212
- protection = gen_prot_to_specific(protection)
213
- end
214
-
215
- request.add_tlv(TLV_TYPE_HANDLE, process.handle)
216
- request.add_tlv(TLV_TYPE_BASE_ADDRESS, base)
217
- request.add_tlv(TLV_TYPE_LENGTH, length)
218
- request.add_tlv(TLV_TYPE_PROTECTION, protection)
219
-
220
- # Send the request
221
- response = process.client.send_request(request)
222
-
223
- # Return the old protection to the caller
224
- return specific_prot_to_gen(response.get_tlv_value(TLV_TYPE_PROTECTION))
225
- end
226
-
227
- #
228
- # Lock a region of memory into physical memory so that it can't be
229
- # swapped to disk. This can only be done in the context of the
230
- # process that is running the meterpreter server. The instance's
231
- # handle is ignored.
232
- #
233
- def lock(base, length)
234
- request = Packet.create_request('stdapi_sys_process_memory_lock')
235
-
236
- request.add_tlv(TLV_TYPE_BASE_ADDRESS, base)
237
- request.add_tlv(TLV_TYPE_LENGTH, length)
238
-
239
- response = process.client.send_request(request)
240
-
241
- return true
242
- end
243
-
244
- #
245
- # Unloock a region of memory into physical memory so that it can be
246
- # swapped to disk. This can only be done in the context of the
247
- # process that is running the meterpreter server. The instance's
248
- # handle is ignored.
249
- #
250
- def unlock(base, length)
251
- request = Packet.create_request('stdapi_sys_process_memory_unlock')
252
-
253
- request.add_tlv(TLV_TYPE_BASE_ADDRESS, base)
254
- request.add_tlv(TLV_TYPE_LENGTH, length)
255
-
256
- response = process.client.send_request(request)
257
-
258
- return true
259
- end
260
-
261
-
262
- ##
263
- #
264
- # Conditionals
265
- #
266
- ##
267
-
268
- #
269
- # Check to see if an address is readable.
270
- #
271
- def readable?(base)
272
- info = nil
273
-
274
- begin
275
- info = query(base)
276
- rescue
277
- end
278
-
279
- if ((info != nil) &&
280
- (info['Available'] == false) &&
281
- (info['Protect'] & PROT_READ == PROT_READ))
282
- return true
283
- end
284
-
285
- return false
286
- end
287
-
288
- #
289
- # Check to see if an address is writable.
290
- #
291
- def writable?(base)
292
- info = nil
293
-
294
- begin
295
- info = query(base)
296
- rescue
297
- end
298
-
299
- if ((info != nil) &&
300
- (info['Available'] == false) &&
301
- (info['Protect'] & PROT_WRITE == PROT_WRITE))
302
- return true
303
- end
304
-
305
- return false
306
- end
307
-
308
- protected
309
-
310
- #
311
- # Translates general protection flags to specific protection flags.
312
- #
313
- def gen_prot_to_specific(prot)
314
- if (prot == nil)
315
- return PAGE_READ
316
- end
317
-
318
- return @@page_protection_map[prot]
319
- end
320
-
321
- #
322
- # Translates specific protection flags to general protection flags.
323
- #
324
- def specific_prot_to_gen(prot)
325
-
326
- if (prot == nil)
327
- return PAGE_READONLY
328
- end
329
-
330
- return @@page_protection_map.invert[prot]
331
- end
332
-
333
- attr_accessor :process # :nodoc:
334
- end
335
-
336
- end; end; end; end; end; end; end