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,4 +1,3 @@
1
- #!/usr/bin/env ruby
2
1
  # -*- coding: binary -*-
3
2
 
4
3
  require 'rex/post/file_stat'
@@ -19,85 +18,85 @@ module Fs
19
18
  ###
20
19
  class FileStat < Rex::Post::FileStat
21
20
 
22
- class << self
23
- attr_accessor :client
24
- end
25
-
26
- @@struct_stat = [
27
- 'st_dev', 4, # 0
28
- 'st_ino', 2, # 4
29
- 'st_mode', 2, # 6
30
- 'st_nlink', 2, # 8
31
- 'st_uid', 2, # 10
32
- 'st_gid', 2, # 12
33
- 'pad1', 2, # 14
34
- 'st_rdev', 4, # 16
35
- 'st_size', 4, # 20
36
- 'st_atime', 8, # 24
37
- 'st_mtime', 8, # 32
38
- 'st_ctime', 8, # 40
39
- ]
40
-
41
- ##
42
- #
43
- # Constructor
44
- #
45
- ##
46
-
47
- #
48
- # Returns an instance of a FileStat object.
49
- #
50
- def initialize(file)
51
- self.stathash = stat(file) if (file)
52
- end
53
-
54
- #
55
- # Swaps in a new stat hash.
56
- #
57
- def update(stat_buf)
58
- elem = @@struct_stat
59
- hash = {}
60
- offset = 0
61
- index = 0
62
-
63
- while (index < elem.length)
64
- size = elem[index + 1]
65
-
66
- value = stat_buf[offset, size].unpack(size == 2 ? 'v' : 'V')[0]
67
- offset += size
68
-
69
- hash[elem[index]] = value
70
-
71
- index += 2
72
- end
73
-
74
- return (self.stathash = hash)
75
- end
21
+ class << self
22
+ attr_accessor :client
23
+ end
24
+
25
+ @@struct_stat = [
26
+ 'st_dev', 4, # 0
27
+ 'st_ino', 2, # 4
28
+ 'st_mode', 2, # 6
29
+ 'st_nlink', 2, # 8
30
+ 'st_uid', 2, # 10
31
+ 'st_gid', 2, # 12
32
+ 'pad1', 2, # 14
33
+ 'st_rdev', 4, # 16
34
+ 'st_size', 4, # 20
35
+ 'st_atime', 8, # 24
36
+ 'st_mtime', 8, # 32
37
+ 'st_ctime', 8, # 40
38
+ ]
39
+
40
+ ##
41
+ #
42
+ # Constructor
43
+ #
44
+ ##
45
+
46
+ #
47
+ # Returns an instance of a FileStat object.
48
+ #
49
+ def initialize(file)
50
+ self.stathash = stat(file) if (file)
51
+ end
52
+
53
+ #
54
+ # Swaps in a new stat hash.
55
+ #
56
+ def update(stat_buf)
57
+ elem = @@struct_stat
58
+ hash = {}
59
+ offset = 0
60
+ index = 0
61
+
62
+ while (index < elem.length)
63
+ size = elem[index + 1]
64
+
65
+ value = stat_buf[offset, size].unpack(size == 2 ? 'v' : 'V')[0]
66
+ offset += size
67
+
68
+ hash[elem[index]] = value
69
+
70
+ index += 2
71
+ end
72
+
73
+ return (self.stathash = hash)
74
+ end
76
75
 
77
76
  protected
78
77
 
79
- ##
80
- #
81
- # Initializer
82
- #
83
- ##
78
+ ##
79
+ #
80
+ # Initializer
81
+ #
82
+ ##
84
83
 
85
- #
86
- # Gets information about the supplied file and returns a populated
87
- # hash to the requestor.
88
- #
89
- def stat(file)
90
- request = Packet.create_request('stdapi_fs_stat')
84
+ #
85
+ # Gets information about the supplied file and returns a populated
86
+ # hash to the requestor.
87
+ #
88
+ def stat(file)
89
+ request = Packet.create_request('stdapi_fs_stat')
91
90
 
92
- request.add_tlv(TLV_TYPE_FILE_PATH, self.class.client.unicode_filter_decode( file ))
91
+ request.add_tlv(TLV_TYPE_FILE_PATH, self.class.client.unicode_filter_decode( file ))
93
92
 
94
- response = self.class.client.send_request(request)
95
- stat_buf = response.get_tlv(TLV_TYPE_STAT_BUF).value
93
+ response = self.class.client.send_request(request)
94
+ stat_buf = response.get_tlv(TLV_TYPE_STAT_BUF).value
96
95
 
97
- # Next, we go through the returned stat_buf and fix up the values
98
- # and insert them into a hash
99
- return update(stat_buf)
100
- end
96
+ # Next, we go through the returned stat_buf and fix up the values
97
+ # and insert them into a hash
98
+ return update(stat_buf)
99
+ end
101
100
 
102
101
  end
103
102
 
@@ -1,4 +1,3 @@
1
- #!/usr/bin/env ruby
2
1
  # -*- coding: binary -*-
3
2
 
4
3
  require 'rex/post/io'
@@ -19,30 +18,30 @@ module Fs
19
18
  ##
20
19
  class IO < Rex::Post::IO
21
20
 
22
- #
23
- # Read the specified number of bytes from the channel.
24
- #
25
- def sysread(length = nil)
26
- self.filed.read(length)
27
- end
28
-
29
- alias read sysread
30
-
31
- #
32
- # Writes the supplied buffer to the channel.
33
- #
34
- def syswrite(buf)
35
- self.filed.write(buf)
36
- end
37
-
38
- alias write syswrite
39
-
40
- #
41
- # Closes the channel.
42
- #
43
- def close
44
- self.filed.close
45
- end
21
+ #
22
+ # Read the specified number of bytes from the channel.
23
+ #
24
+ def sysread(length = nil)
25
+ self.filed.read(length)
26
+ end
27
+
28
+ alias read sysread
29
+
30
+ #
31
+ # Writes the supplied buffer to the channel.
32
+ #
33
+ def syswrite(buf)
34
+ self.filed.write(buf)
35
+ end
36
+
37
+ alias write syswrite
38
+
39
+ #
40
+ # Closes the channel.
41
+ #
42
+ def close
43
+ self.filed.close
44
+ end
46
45
 
47
46
  end
48
47
 
@@ -0,0 +1,59 @@
1
+ # -*- coding: binary -*-
2
+
3
+ require 'ipaddr'
4
+
5
+ module Rex
6
+ module Post
7
+ module Meterpreter
8
+ module Extensions
9
+ module Stdapi
10
+ module Net
11
+
12
+ ###
13
+ #
14
+ # This class represents an arp entry
15
+ # on the remote machine.
16
+ #
17
+ ###
18
+ class Arp
19
+
20
+ ##
21
+ #
22
+ # Constructor
23
+ #
24
+ ##
25
+
26
+ #
27
+ # Returns an arp entry and initializes it to the supplied
28
+ # parameters.
29
+ #
30
+ def initialize(opts={})
31
+ self.ip_addr = IPAddr.new_ntoh(opts[:ip_addr]).to_s
32
+ self.mac_addr = mac_to_string(opts[:mac_addr])
33
+ self.interface = opts[:interface]
34
+ end
35
+
36
+ def mac_to_string(mac_addr)
37
+ macocts = []
38
+ mac_addr.each_byte { |o| macocts << o }
39
+ macocts += [0] * (6 - macocts.size) if macocts.size < 6
40
+ return sprintf("%02x:%02x:%02x:%02x:%02x:%02x",
41
+ macocts[0], macocts[1], macocts[2],
42
+ macocts[3], macocts[4], macocts[5])
43
+ end
44
+
45
+ #
46
+ # The ip address corresponding to the arp address.
47
+ #
48
+ attr_accessor :ip_addr
49
+ #
50
+ # The physical (MAC) address of the ARP entry
51
+ #
52
+ attr_accessor :mac_addr
53
+ #
54
+ # The name of the interface.
55
+ #
56
+ attr_accessor :interface
57
+ end
58
+
59
+ end; end; end; end; end; end
@@ -1,8 +1,9 @@
1
- #!/usr/bin/env ruby
2
1
  # -*- coding: binary -*-
3
2
 
4
3
  require 'rex/post/meterpreter/extensions/stdapi/tlv'
4
+ require 'rex/post/meterpreter/extensions/stdapi/net/arp'
5
5
  require 'rex/post/meterpreter/extensions/stdapi/net/route'
6
+ require 'rex/post/meterpreter/extensions/stdapi/net/netstat'
6
7
  require 'rex/post/meterpreter/extensions/stdapi/net/interface'
7
8
 
8
9
  module Rex
@@ -21,157 +22,234 @@ module Net
21
22
  ###
22
23
  class Config
23
24
 
24
- ##
25
- #
26
- # Constructor
27
- #
28
- ##
29
-
30
- #
31
- # Initializes a Config instance that is used to get information about the
32
- # network configuration of the remote machine.
33
- #
34
- def initialize(client)
35
- self.client = client
36
- end
37
-
38
- ##
39
- #
40
- # Interfaces
41
- #
42
- ##
43
-
44
- #
45
- # Enumerates each interface.
46
- #
47
- def each_interface(&block)
48
- get_interfaces().each(&block)
49
- end
50
-
51
- #
52
- # Returns an array of network interfaces with each element.
53
- #
54
- # being an Interface
55
- def get_interfaces
56
- request = Packet.create_request('stdapi_net_config_get_interfaces')
57
- ifaces = []
58
-
59
- response = client.send_request(request)
60
-
61
- response.each(TLV_TYPE_NETWORK_INTERFACE) { |iface|
62
- addrs = []
63
- netmasks = []
64
- scopes = []
65
- while (a = iface.get_tlv_value(TLV_TYPE_IP, addrs.length))
66
- # Netmasks aren't tightly associated with addresses, they're
67
- # just thrown all together in the interface TLV ordered to
68
- # match up. This could be done better by creating another
69
- # GroupTlv type for addresses containing an address, a netmask,
70
- # and possibly a scope.
71
- n = iface.get_tlv_value(TLV_TYPE_NETMASK, addrs.length)
72
- if (n.nil?)
73
- # Some systems can't report a netmask, only a network
74
- # prefix, so figure out the netmask from that.
75
- n = iface.get_tlv_value(TLV_TYPE_IP_PREFIX, addrs.length)
76
- if n
77
- n = Rex::Socket.bit2netmask(n, !!(a.length == 16))
78
- end
79
- else
80
- n = Rex::Socket.addr_ntoa(n)
81
- end
82
- s = iface.get_tlv_value(TLV_TYPE_IP6_SCOPE, addrs.length)
83
- scopes[addrs.length] = s if s
84
- netmasks[addrs.length] = n if n
85
- addrs << Rex::Socket.addr_ntoa(a)
86
- end
87
- ifaces << Interface.new(
88
- :index => iface.get_tlv_value(TLV_TYPE_INTERFACE_INDEX),
89
- :mac_addr => iface.get_tlv_value(TLV_TYPE_MAC_ADDRESS),
90
- :mac_name => iface.get_tlv_value(TLV_TYPE_MAC_NAME),
91
- :mtu => iface.get_tlv_value(TLV_TYPE_INTERFACE_MTU),
92
- :flags => iface.get_tlv_value(TLV_TYPE_INTERFACE_FLAGS),
93
- :addrs => addrs,
94
- :netmasks => netmasks,
95
- :scopes => scopes
96
- )
97
- }
98
-
99
- return ifaces
100
- end
101
-
102
- alias interfaces get_interfaces
103
-
104
- ##
105
- #
106
- # Routing
107
- #
108
- ##
109
-
110
- #
111
- # Enumerates each route.
112
- #
113
- def each_route(&block)
114
- get_routes().each(&block)
115
- end
116
-
117
- #
118
- # Returns an array of routes with each element being a Route.
119
- #
120
- def get_routes
121
- request = Packet.create_request('stdapi_net_config_get_routes')
122
- routes = []
123
-
124
- response = client.send_request(request)
125
-
126
- # Build out the array of routes
127
- # Note: This will include both IPv4 and IPv6 routes
128
- response.each(TLV_TYPE_NETWORK_ROUTE) { |route|
129
- routes << Route.new(
130
- route.get_tlv_value(TLV_TYPE_SUBNET),
131
- route.get_tlv_value(TLV_TYPE_NETMASK),
132
- route.get_tlv_value(TLV_TYPE_GATEWAY),
133
- route.get_tlv_value(TLV_TYPE_STRING),
134
- route.get_tlv_value(TLV_TYPE_ROUTE_METRIC))
135
- }
136
-
137
- return routes
138
- end
139
-
140
- alias routes get_routes
141
-
142
- #
143
- # Adds a route to the target machine.
144
- #
145
- def add_route(subnet, netmask, gateway)
146
- request = Packet.create_request('stdapi_net_config_add_route')
147
-
148
- request.add_tlv(TLV_TYPE_SUBNET_STRING, subnet)
149
- request.add_tlv(TLV_TYPE_NETMASK_STRING, netmask)
150
- request.add_tlv(TLV_TYPE_GATEWAY_STRING, gateway)
151
-
152
- response = client.send_request(request)
153
-
154
- return true
155
- end
156
-
157
- #
158
- # Removes a route from the target machine.
159
- #
160
- def remove_route(subnet, netmask, gateway)
161
- request = Packet.create_request('stdapi_net_config_remove_route')
162
-
163
- request.add_tlv(TLV_TYPE_SUBNET_STRING, subnet)
164
- request.add_tlv(TLV_TYPE_NETMASK_STRING, netmask)
165
- request.add_tlv(TLV_TYPE_GATEWAY_STRING, gateway)
166
-
167
- response = client.send_request(request)
168
-
169
- return true
170
- end
25
+ ##
26
+ #
27
+ # Constructor
28
+ #
29
+ ##
30
+
31
+ #
32
+ # Initializes a Config instance that is used to get information about the
33
+ # network configuration of the remote machine.
34
+ #
35
+ def initialize(client)
36
+ self.client = client
37
+ end
38
+
39
+ ##
40
+ #
41
+ # Interfaces
42
+ #
43
+ ##
44
+
45
+ #
46
+ # Enumerates each interface.
47
+ #
48
+ def each_interface(&block)
49
+ get_interfaces().each(&block)
50
+ end
51
+
52
+ # Returns an array of network interfaces with each element.
53
+ #
54
+ # @return [Array<Interface>]
55
+ def get_interfaces
56
+ request = Packet.create_request('stdapi_net_config_get_interfaces')
57
+ ifaces = []
58
+
59
+ response = client.send_request(request)
60
+
61
+ response.each(TLV_TYPE_NETWORK_INTERFACE) { |iface|
62
+ addrs = []
63
+ netmasks = []
64
+ scopes = []
65
+ while (a = iface.get_tlv_value(TLV_TYPE_IP, addrs.length))
66
+ # Netmasks aren't tightly associated with addresses, they're
67
+ # just thrown all together in the interface TLV ordered to
68
+ # match up. This could be done better by creating another
69
+ # GroupTlv type for addresses containing an address, a netmask,
70
+ # and possibly a scope.
71
+ n = iface.get_tlv_value(TLV_TYPE_NETMASK, addrs.length)
72
+ if (n.nil?)
73
+ # Some systems can't report a netmask, only a network
74
+ # prefix, so figure out the netmask from that.
75
+ n = iface.get_tlv_value(TLV_TYPE_IP_PREFIX, addrs.length)
76
+ if n
77
+ n = Rex::Socket.bit2netmask(n, !!(a.length == 16))
78
+ end
79
+ else
80
+ n = Rex::Socket.addr_ntoa(n)
81
+ end
82
+ s = iface.get_tlv_value(TLV_TYPE_IP6_SCOPE, addrs.length)
83
+ scopes[addrs.length] = s if s
84
+ netmasks[addrs.length] = n if n
85
+ addrs << Rex::Socket.addr_ntoa(a)
86
+ end
87
+ ifaces << Interface.new(
88
+ :index => iface.get_tlv_value(TLV_TYPE_INTERFACE_INDEX),
89
+ :mac_addr => iface.get_tlv_value(TLV_TYPE_MAC_ADDRESS),
90
+ :mac_name => iface.get_tlv_value(TLV_TYPE_MAC_NAME),
91
+ :mtu => iface.get_tlv_value(TLV_TYPE_INTERFACE_MTU),
92
+ :flags => iface.get_tlv_value(TLV_TYPE_INTERFACE_FLAGS),
93
+ :addrs => addrs,
94
+ :netmasks => netmasks,
95
+ :scopes => scopes
96
+ )
97
+ }
98
+
99
+ return ifaces
100
+ end
101
+
102
+ alias interfaces get_interfaces
103
+
104
+ ##
105
+ #
106
+ # Network connections
107
+ #
108
+ ##
109
+
110
+ #
111
+ # Returns an array of network connection entries with each element being a Netstat.
112
+ #
113
+
114
+ def get_netstat
115
+ request = Packet.create_request('stdapi_net_config_get_netstat')
116
+ netstat = []
117
+
118
+ response = client.send_request(request)
119
+
120
+ # Build out the array of netstat
121
+ response.each(TLV_TYPE_NETSTAT_ENTRY) { |connection|
122
+ netstat << Netstat.new(
123
+ :local_addr => connection.get_tlv_value(TLV_TYPE_LOCAL_HOST_RAW),
124
+ :remote_addr => connection.get_tlv_value(TLV_TYPE_PEER_HOST_RAW),
125
+ :local_port => connection.get_tlv_value(TLV_TYPE_LOCAL_PORT),
126
+ :remote_port => connection.get_tlv_value(TLV_TYPE_PEER_PORT),
127
+ :protocol => connection.get_tlv_value(TLV_TYPE_MAC_NAME), # tcp/tcp6/udp/udp6
128
+ :state => connection.get_tlv_value(TLV_TYPE_SUBNET_STRING),
129
+ :uid => connection.get_tlv_value(TLV_TYPE_PID),
130
+ :inode => connection.get_tlv_value(TLV_TYPE_ROUTE_METRIC),
131
+ :pid_name => connection.get_tlv_value(TLV_TYPE_PROCESS_NAME)
132
+ )
133
+ }
134
+
135
+ return netstat
136
+ end
137
+
138
+ alias netstat get_netstat
139
+
140
+ ##
141
+ #
142
+ # Routing
143
+ #
144
+ ##
145
+
146
+ #
147
+ # Returns an array of arp entries with each element being an Arp.
148
+ #
149
+
150
+ def get_arp_table
151
+ request = Packet.create_request('stdapi_net_config_get_arp_table')
152
+ arps = []
153
+
154
+ response = client.send_request(request)
155
+
156
+ # Build out the array of arp
157
+ response.each(TLV_TYPE_ARP_ENTRY) { |arp|
158
+ arps << Arp.new(
159
+ :ip_addr => arp.get_tlv_value(TLV_TYPE_IP),
160
+ :mac_addr => arp.get_tlv_value(TLV_TYPE_MAC_ADDRESS),
161
+ :interface => arp.get_tlv_value(TLV_TYPE_MAC_NAME)
162
+ )
163
+ }
164
+
165
+ return arps
166
+ end
167
+
168
+ alias arp_table get_arp_table
169
+
170
+ #
171
+ # Enumerates each route.
172
+ #
173
+ def each_route(&block)
174
+ get_routes().each(&block)
175
+ end
176
+
177
+ #
178
+ # Returns an array of routes with each element being a Route.
179
+ #
180
+ def get_routes
181
+ request = Packet.create_request('stdapi_net_config_get_routes')
182
+ routes = []
183
+
184
+ response = client.send_request(request)
185
+
186
+ # Build out the array of routes
187
+ # Note: This will include both IPv4 and IPv6 routes
188
+ response.each(TLV_TYPE_NETWORK_ROUTE) { |route|
189
+ routes << Route.new(
190
+ route.get_tlv_value(TLV_TYPE_SUBNET),
191
+ route.get_tlv_value(TLV_TYPE_NETMASK),
192
+ route.get_tlv_value(TLV_TYPE_GATEWAY),
193
+ route.get_tlv_value(TLV_TYPE_STRING),
194
+ route.get_tlv_value(TLV_TYPE_ROUTE_METRIC))
195
+ }
196
+
197
+ return routes
198
+ end
199
+
200
+ alias routes get_routes
201
+
202
+ #
203
+ # Adds a route to the target machine.
204
+ #
205
+ def add_route(subnet, netmask, gateway)
206
+ request = Packet.create_request('stdapi_net_config_add_route')
207
+
208
+ request.add_tlv(TLV_TYPE_SUBNET_STRING, subnet)
209
+ request.add_tlv(TLV_TYPE_NETMASK_STRING, netmask)
210
+ request.add_tlv(TLV_TYPE_GATEWAY_STRING, gateway)
211
+
212
+ response = client.send_request(request)
213
+
214
+ return true
215
+ end
216
+
217
+ #
218
+ # Removes a route from the target machine.
219
+ #
220
+ def remove_route(subnet, netmask, gateway)
221
+ request = Packet.create_request('stdapi_net_config_remove_route')
222
+
223
+ request.add_tlv(TLV_TYPE_SUBNET_STRING, subnet)
224
+ request.add_tlv(TLV_TYPE_NETMASK_STRING, netmask)
225
+ request.add_tlv(TLV_TYPE_GATEWAY_STRING, gateway)
226
+
227
+ response = client.send_request(request)
228
+
229
+ return true
230
+ end
231
+
232
+ #
233
+ # Get's the current proxy configuration
234
+ #
235
+ def get_proxy_config()
236
+ request = Packet.create_request('stdapi_net_config_get_proxy')
237
+
238
+ response = client.send_request(request)
239
+
240
+ proxy_config = {
241
+ :autodetect => response.get_tlv_value(TLV_TYPE_PROXY_CFG_AUTODETECT),
242
+ :autoconfigurl => response.get_tlv_value(TLV_TYPE_PROXY_CFG_AUTOCONFIGURL),
243
+ :proxy => response.get_tlv_value(TLV_TYPE_PROXY_CFG_PROXY),
244
+ :proxybypass => response.get_tlv_value(TLV_TYPE_PROXY_CFG_PROXYBYPASS)
245
+ }
246
+
247
+ return proxy_config
248
+ end
171
249
 
172
250
  protected
173
251
 
174
- attr_accessor :client # :nodoc:
252
+ attr_accessor :client # :nodoc:
175
253
 
176
254
  end
177
255