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
@@ -8,124 +8,124 @@ require 'rex/socket'
8
8
  ###
9
9
  module Rex::Socket::Ip
10
10
 
11
- include Rex::Socket
12
-
13
- ##
14
- #
15
- # Factory
16
- #
17
- ##
18
-
19
- #
20
- # Creates the client using the supplied hash.
21
- #
22
- def self.create(hash = {})
23
- hash['Proto'] = 'ip'
24
- self.create_param(Rex::Socket::Parameters.from_hash(hash))
25
- end
26
-
27
- #
28
- # Wrapper around the base socket class' creation method that automatically
29
- # sets the parameter's protocol to IP.
30
- #
31
- def self.create_param(param)
32
- param.proto = 'ip'
33
- Rex::Socket.create_param(param)
34
- end
35
-
36
- ##
37
- #
38
- # IP connected state methods
39
- #
40
- ##
41
-
42
- #
43
- # Write the supplied datagram to the connected IP socket.
44
- #
45
- def write(gram)
46
- raise RuntimeError, "IP sockets must use sendto(), not write()"
47
- end
48
-
49
- alias put write
50
-
51
- #
52
- # Read a datagram from the IP socket.
53
- #
54
- def read(length = 65535)
55
- raise RuntimeError, "IP sockets must use recvfrom(), not read()"
56
- end
57
-
58
- ##
59
- #
60
- # IP non-connected state methods
61
- #
62
- ##
63
-
64
- #
65
- # Sends a datagram to the supplied host:port with optional flags.
66
- #
67
- def sendto(gram, peerhost, flags = 0)
68
- dest = ::Socket.pack_sockaddr_in(0, peerhost)
69
-
70
- # Some BSDs require byteswap for len and offset
71
- if(
72
- Rex::Compat.is_freebsd or
73
- Rex::Compat.is_netbsd or
74
- Rex::Compat.is_bsdi or
75
- Rex::Compat.is_macosx
76
- )
77
- gram=gram.dup
78
- gram[2,2]=gram[2,2].unpack("n").pack("s")
79
- gram[6,2]=gram[6,2].unpack("n").pack("s")
80
- end
81
-
82
- begin
83
- send(gram, flags, dest)
84
- rescue ::Errno::EHOSTUNREACH,::Errno::ENETDOWN,::Errno::ENETUNREACH,::Errno::ENETRESET,::Errno::EHOSTDOWN,::Errno::EACCES,::Errno::EINVAL,::Errno::EADDRNOTAVAIL
85
- return nil
86
- end
87
-
88
- end
89
-
90
- #
91
- # Receives a datagram and returns the data and host of the requestor
92
- # as [ data, host ].
93
- #
94
- def recvfrom(length = 65535, timeout=def_read_timeout)
95
- begin
96
- if ((rv = ::IO.select([ fd ], nil, nil, timeout)) and
97
- (rv[0]) and (rv[0][0] == fd)
98
- )
99
- data, saddr = super(length)
100
- af, host = Rex::Socket.from_sockaddr(saddr)
101
-
102
- return [ data, host ]
103
- else
104
- return [ '', nil ]
105
- end
106
- rescue Exception
107
- return [ '', nil ]
108
- end
109
- end
110
-
111
- #
112
- # Calls recvfrom and only returns the data
113
- #
114
- def get(timeout=nil)
115
- data, saddr = recvfrom(65535, timeout)
116
- return data
117
- end
118
-
119
- #
120
- # The default number of seconds to wait for a read operation to timeout.
121
- #
122
- def def_read_timeout
123
- 10
124
- end
125
-
126
- def type?
127
- return 'ip'
128
- end
11
+ include Rex::Socket
12
+
13
+ ##
14
+ #
15
+ # Factory
16
+ #
17
+ ##
18
+
19
+ #
20
+ # Creates the client using the supplied hash.
21
+ #
22
+ def self.create(hash = {})
23
+ hash['Proto'] = 'ip'
24
+ self.create_param(Rex::Socket::Parameters.from_hash(hash))
25
+ end
26
+
27
+ #
28
+ # Wrapper around the base socket class' creation method that automatically
29
+ # sets the parameter's protocol to IP.
30
+ #
31
+ def self.create_param(param)
32
+ param.proto = 'ip'
33
+ Rex::Socket.create_param(param)
34
+ end
35
+
36
+ ##
37
+ #
38
+ # IP connected state methods
39
+ #
40
+ ##
41
+
42
+ #
43
+ # Write the supplied datagram to the connected IP socket.
44
+ #
45
+ def write(gram)
46
+ raise RuntimeError, "IP sockets must use sendto(), not write()"
47
+ end
48
+
49
+ alias put write
50
+
51
+ #
52
+ # Read a datagram from the IP socket.
53
+ #
54
+ def read(length = 65535)
55
+ raise RuntimeError, "IP sockets must use recvfrom(), not read()"
56
+ end
57
+
58
+ ##
59
+ #
60
+ # IP non-connected state methods
61
+ #
62
+ ##
63
+
64
+ #
65
+ # Sends a datagram to the supplied host:port with optional flags.
66
+ #
67
+ def sendto(gram, peerhost, flags = 0)
68
+ dest = ::Socket.pack_sockaddr_in(0, peerhost)
69
+
70
+ # Some BSDs require byteswap for len and offset
71
+ if(
72
+ Rex::Compat.is_freebsd or
73
+ Rex::Compat.is_netbsd or
74
+ Rex::Compat.is_bsdi or
75
+ Rex::Compat.is_macosx
76
+ )
77
+ gram=gram.dup
78
+ gram[2,2]=gram[2,2].unpack("n").pack("s")
79
+ gram[6,2]=gram[6,2].unpack("n").pack("s")
80
+ end
81
+
82
+ begin
83
+ send(gram, flags, dest)
84
+ rescue ::Errno::EHOSTUNREACH,::Errno::ENETDOWN,::Errno::ENETUNREACH,::Errno::ENETRESET,::Errno::EHOSTDOWN,::Errno::EACCES,::Errno::EINVAL,::Errno::EADDRNOTAVAIL
85
+ return nil
86
+ end
87
+
88
+ end
89
+
90
+ #
91
+ # Receives a datagram and returns the data and host of the requestor
92
+ # as [ data, host ].
93
+ #
94
+ def recvfrom(length = 65535, timeout=def_read_timeout)
95
+ begin
96
+ if ((rv = ::IO.select([ fd ], nil, nil, timeout)) and
97
+ (rv[0]) and (rv[0][0] == fd)
98
+ )
99
+ data, saddr = super(length)
100
+ af, host = Rex::Socket.from_sockaddr(saddr)
101
+
102
+ return [ data, host ]
103
+ else
104
+ return [ '', nil ]
105
+ end
106
+ rescue Exception
107
+ return [ '', nil ]
108
+ end
109
+ end
110
+
111
+ #
112
+ # Calls recvfrom and only returns the data
113
+ #
114
+ def get(timeout=nil)
115
+ data, saddr = recvfrom(65535, timeout)
116
+ return data
117
+ end
118
+
119
+ #
120
+ # The default number of seconds to wait for a read operation to timeout.
121
+ #
122
+ def def_read_timeout
123
+ 10
124
+ end
125
+
126
+ def type?
127
+ return 'ip'
128
+ end
129
129
 
130
130
  end
131
131
 
@@ -6,357 +6,358 @@ require 'rex/socket'
6
6
  # This class represents the set of parameters that are used to create
7
7
  # a socket, whether it be a server or client socket.
8
8
  #
9
+ # @example
10
+ # nsock = Rex::Socket::Tcp.create(
11
+ # 'PeerHost' => opts['RHOST'] || rhost,
12
+ # 'PeerPort' => (opts['RPORT'] || rport).to_i,
13
+ # 'LocalHost' => opts['CHOST'] || chost || "0.0.0.0",
14
+ # 'LocalPort' => (opts['CPORT'] || cport || 0).to_i,
15
+ # 'SSL' => dossl,
16
+ # 'SSLVersion'=> opts['SSLVersion'] || ssl_version,
17
+ # 'Proxies' => proxies,
18
+ # 'Timeout' => (opts['ConnectTimeout'] || connect_timeout || 10).to_i,
19
+ # 'Context' =>
20
+ # {
21
+ # 'Msf' => framework,
22
+ # 'MsfExploit' => self,
23
+ # })
24
+ #
9
25
  ###
10
26
  class Rex::Socket::Parameters
11
27
 
12
- ##
13
- #
14
- # Factory
15
- #
16
- ##
17
-
18
- #
19
- # Creates an instance of the Parameters class using the supplied hash.
20
- #
21
- def self.from_hash(hash)
22
- return self.new(hash)
23
- end
24
-
25
- ##
26
- #
27
- # Constructor
28
- #
29
- ##
30
-
31
- #
32
- # Initializes the attributes from the supplied hash. The following hash
33
- # keys can be specified.
34
- #
35
- # PeerHost / PeerAddr
36
- #
37
- # The remote host to connect to.
38
- #
39
- # PeerPort
40
- #
41
- # The remote port to connect to.
42
- #
43
- # LocalHost / LocalAddr
44
- #
45
- # The local host to communicate from, if any.
46
- #
47
- # LocalPort
48
- #
49
- # The local port to communicate from, if any.
50
- #
51
- # Bare
52
- #
53
- # Create a bare socket.
54
- #
55
- # Server
56
- #
57
- # Whether or not this should be a server.
58
- #
59
- # SSL
60
- #
61
- # Whether or not SSL should be used.
62
- #
63
- # SSLVersion
64
- #
65
- # Specify SSL2, SSL3, or TLS1 (SSL3 is default)
66
- #
67
- # SSLCert
68
- #
69
- # A file containing an SSL certificate (for server sockets)
70
- #
71
- # Proxies
72
- #
73
- # List of proxies to use.
74
- #
75
- # Proto
76
- #
77
- # The underlying protocol to use.
78
- #
79
- # IPv6
80
- #
81
- # Force the use of IPv6.
82
- #
83
- # Comm
84
- #
85
- # The underlying Comm class to use to create the socket for this parameter
86
- # set.
87
- #
88
- # Context
89
- #
90
- # A context hash that can allow users of this parameter class instance to
91
- # determine who is responsible for requesting that a socket be created.
92
- #
93
- # Retries
94
- #
95
- # The number of times a connection should be retried.
96
- #
97
- # Timeout
98
- #
99
- # The number of seconds before a connection should time out
100
- #
101
-
102
- def initialize(hash)
103
- if (hash['PeerHost'])
104
- self.peerhost = hash['PeerHost']
105
- elsif (hash['PeerAddr'])
106
- self.peerhost = hash['PeerAddr']
107
- else
108
- self.peerhost = nil
109
- end
110
-
111
- if (hash['LocalHost'])
112
- self.localhost = hash['LocalHost']
113
- elsif (hash['LocalAddr'])
114
- self.localhost = hash['LocalAddr']
115
- else
116
- self.localhost = '0.0.0.0'
117
- end
118
-
119
- if (hash['PeerPort'])
120
- self.peerport = hash['PeerPort'].to_i
121
- else
122
- self.peerport = 0
123
- end
124
-
125
- if (hash['LocalPort'])
126
- self.localport = hash['LocalPort'].to_i
127
- else
128
- self.localport = 0
129
- end
130
-
131
- if (hash['Bare'])
132
- self.bare = hash['Bare']
133
- else
134
- self.bare = false
135
- end
136
-
137
- if (hash['SSL'] and hash['SSL'].to_s =~ /^(t|y|1)/i)
138
- self.ssl = true
139
- else
140
- self.ssl = false
141
- end
142
-
143
- if (hash['SSLVersion'] and hash['SSLVersion'].to_s =~ /^(SSL2|SSL3|TLS1)$/i)
144
- self.ssl_version = hash['SSLVersion']
145
- end
146
-
147
- if (hash['SSLCert'] and ::File.file?(hash['SSLCert']))
148
- begin
149
- self.ssl_cert = ::File.read(hash['SSLCert'])
150
- rescue ::Exception => e
151
- elog("Failed to read cert: #{e.class}: #{e}", LogSource)
152
- end
153
- end
154
-
155
- if hash['Proxies']
156
- self.proxies = hash['Proxies'].split('-').map{|a| a.strip}.map{|a| a.split(':').map{|b| b.strip}}
157
- end
158
-
159
- # The protocol this socket will be using
160
- if (hash['Proto'])
161
- self.proto = hash['Proto'].downcase
162
- else
163
- self.proto = 'tcp'
164
- end
165
-
166
- # Whether or not the socket should be a server
167
- self.server = hash['Server'] || false
168
-
169
- # The communication subsystem to use to create the socket
170
- self.comm = hash['Comm']
171
-
172
- # The context that was passed in, if any.
173
- self.context = hash['Context'] || {}
174
-
175
- # If no comm was supplied, try to use the comm that is best fit to
176
- # handle the provided host based on the current routing table.
177
- if( self.server )
178
- if (self.comm == nil and self.localhost)
179
- self.comm = Rex::Socket::SwitchBoard.best_comm(self.localhost)
180
- end
181
- else
182
- if (self.comm == nil and self.peerhost)
183
- self.comm = Rex::Socket::SwitchBoard.best_comm(self.peerhost)
184
- end
185
- end
186
-
187
- # If we still haven't found a comm, we default to the local comm.
188
- self.comm = Rex::Socket::Comm::Local if (self.comm == nil)
189
-
190
- # If we are a UDP server, turn off the server flag as it was only set when
191
- # creating the UDP socket in order to avail of the switch board above.
192
- if( self.server and self.proto == 'udp' )
193
- self.server = false
194
- end
195
-
196
- # The number of connection retries to make (client only)
197
- if hash['Retries']
198
- self.retries = hash['Retries'].to_i
199
- else
200
- self.retries = 0
201
- end
202
-
203
- # The number of seconds before a connect attempt times out (client only)
204
- if hash['Timeout']
205
- self.timeout = hash['Timeout'].to_i
206
- else
207
- self.timeout = 5
208
- end
209
-
210
- # Whether to force IPv6 addressing
211
- self.v6 = hash['IPv6'] || false
212
- end
213
-
214
- ##
215
- #
216
- # Conditionals
217
- #
218
- ##
219
-
220
- #
221
- # Returns true if this represents parameters for a server.
222
- #
223
- def server?
224
- return (server == true)
225
- end
226
-
227
- #
228
- # Returns true if this represents parameters for a client.
229
- #
230
- def client?
231
- return (server == false)
232
- end
233
-
234
- #
235
- # Returns true if the protocol for the parameters is TCP.
236
- #
237
- def tcp?
238
- return (proto == 'tcp')
239
- end
240
-
241
- #
242
- # Returns true if the protocol for the parameters is UDP.
243
- #
244
- def udp?
245
- return (proto == 'udp')
246
- end
247
-
248
- #
249
- # Returns true if the protocol for the parameters is IP.
250
- #
251
- def ip?
252
- return (proto == 'ip')
253
- end
254
-
255
- #
256
- # Returns true if the socket is a bare socket that does not inherit from
257
- # any extended Rex classes.
258
- #
259
- def bare?
260
- return (bare == true)
261
- end
262
-
263
- #
264
- # Returns true if SSL has been requested.
265
- #
266
- def ssl?
267
- return ssl
268
- end
269
-
270
- #
271
- # Returns true if IPv6 has been enabled
272
- #
273
- def v6?
274
- return v6
275
- end
276
-
277
-
278
- ##
279
- #
280
- # Attributes
281
- #
282
- ##
283
-
284
- #
285
- # The remote host information, equivalent to the PeerHost parameter hash
286
- # key.
287
- #
288
- attr_accessor :peerhost
289
- #
290
- # The remote port. Equivalent to the PeerPort parameter hash key.
291
- #
292
- attr_accessor :peerport
293
- #
294
- # The local host. Equivalent to the LocalHost parameter hash key.
295
- #
296
- attr_accessor :localhost
297
- #
298
- # The local port. Equivalent to the LocalPort parameter hash key.
299
- #
300
- attr_accessor :localport
301
- #
302
- # The protocol to to use, such as TCP. Equivalent to the Proto parameter
303
- # hash key.
304
- #
305
- attr_accessor :proto
306
- #
307
- # Whether or not this is a server. Equivalent to the Server parameter hash
308
- # key.
309
- #
310
- attr_accessor :server
311
- #
312
- # The Comm class that should be used to create the underlying socket.
313
- #
314
- attr_accessor :comm
315
- #
316
- # The context hash that was passed in to the structure.
317
- #
318
- attr_accessor :context
319
- #
320
- # The number of attempts that should be made.
321
- #
322
- attr_accessor :retries
323
- #
324
- # The number of seconds before a connection attempt should time out.
325
- #
326
- attr_accessor :timeout
327
- #
328
- # Whether or not this is a bare (non-extended) socket instance that should
329
- # be created.
330
- #
331
- attr_accessor :bare
332
- #
333
- # Whether or not SSL should be used to wrap the connection.
334
- #
335
- attr_accessor :ssl
336
- #
337
- # What version of SSL to use (SSL2, SSL3, TLS1)
338
- #
339
- attr_accessor :ssl_version
340
- #
341
- # The SSL certificate, in pem format, stored as a string. See +SslTcpServer#make_ssl+
342
- #
343
- attr_accessor :ssl_cert
344
- #
345
- # Whether we should use IPv6
346
- #
347
- attr_accessor :v6
348
-
349
-
350
- attr_accessor :proxies
351
-
352
-
353
- ##
354
- #
355
- # Synonyms
356
- #
357
- ##
358
-
359
- alias peeraddr peerhost
360
- alias localaddr localhost
361
-
28
+ ##
29
+ #
30
+ # Factory
31
+ #
32
+ ##
33
+
34
+ #
35
+ # Creates an instance of the Parameters class using the supplied hash.
36
+ #
37
+ def self.from_hash(hash)
38
+ return self.new(hash)
39
+ end
40
+
41
+ ##
42
+ #
43
+ # Constructor
44
+ #
45
+ ##
46
+
47
+ #
48
+ # Initializes the attributes from the supplied hash. The following hash
49
+ # keys can be specified.
50
+ #
51
+ # @option hash [String] 'PeerHost' The remote host to connect to
52
+ # @option hash [String] 'PeerAddr' (alias for 'PeerHost')
53
+ # @option hash [Fixnum] 'PeerPort' The remote port to connect to
54
+ # @option hash [String] 'LocalHost' The local host to communicate from, if any
55
+ # @option hash [String] 'LocalPort' The local port to communicate from, if any
56
+ # @option hash [Bool] 'Bool' Create a bare socket
57
+ # @option hash [Bool] 'Server' Whether or not this should be a server
58
+ # @option hash [Bool] 'SSL' Whether or not SSL should be used
59
+ # @option hash [String] 'SSLVersion' Specify SSL2, SSL3, or TLS1 (SSL3 is
60
+ # default)
61
+ # @option hash [String] 'SSLCert' A file containing an SSL certificate (for
62
+ # server sockets)
63
+ # @option hash [String] 'SSLCipher' see {#ssl_cipher}
64
+ # @option hash [Bool] 'SSLCompression' enable SSL-level compression where available
65
+ # @option hash [String] 'SSLVerifyMode' SSL certificate verification
66
+ # mechanism. One of 'NONE' (default), 'CLIENT_ONCE', 'FAIL_IF_NO_PEER_CERT ', 'PEER'
67
+ # @option hash [String] 'Proxies' List of proxies to use.
68
+ # @option hash [String] 'Proto' The underlying protocol to use.
69
+ # @option hash [String] 'IPv6' Force the use of IPv6.
70
+ # @option hash [String] 'Comm' The underlying {Comm} object to use to create
71
+ # the socket for this parameter set.
72
+ # @option hash [Hash] 'Context' A context hash that can allow users of
73
+ # this parameter class instance to determine who is responsible for
74
+ # requesting that a socket be created.
75
+ # @option hash [String] 'Retries' The number of times a connection should be
76
+ # retried.
77
+ # @option hash [Fixnum] 'Timeout' The number of seconds before a connection
78
+ # should time out
79
+ def initialize(hash)
80
+ if (hash['PeerHost'])
81
+ self.peerhost = hash['PeerHost']
82
+ elsif (hash['PeerAddr'])
83
+ self.peerhost = hash['PeerAddr']
84
+ else
85
+ self.peerhost = nil
86
+ end
87
+
88
+ if (hash['LocalHost'])
89
+ self.localhost = hash['LocalHost']
90
+ elsif (hash['LocalAddr'])
91
+ self.localhost = hash['LocalAddr']
92
+ else
93
+ self.localhost = '0.0.0.0'
94
+ end
95
+
96
+ if (hash['PeerPort'])
97
+ self.peerport = hash['PeerPort'].to_i
98
+ else
99
+ self.peerport = 0
100
+ end
101
+
102
+ if (hash['LocalPort'])
103
+ self.localport = hash['LocalPort'].to_i
104
+ else
105
+ self.localport = 0
106
+ end
107
+
108
+ if (hash['Bare'])
109
+ self.bare = hash['Bare']
110
+ else
111
+ self.bare = false
112
+ end
113
+
114
+ if (hash['SSL'] and hash['SSL'].to_s =~ /^(t|y|1)/i)
115
+ self.ssl = true
116
+ else
117
+ self.ssl = false
118
+ end
119
+
120
+ supported_ssl_versions = ['SSL2', 'SSL23', 'TLS1', 'SSL3', :SSLv2, :SSLv3, :SSLv23, :TLSv1]
121
+ if (hash['SSLVersion'] and supported_ssl_versions.include? hash['SSLVersion'])
122
+ self.ssl_version = hash['SSLVersion']
123
+ end
124
+
125
+ supported_ssl_verifiers = %W{CLIENT_ONCE FAIL_IF_NO_PEER_CERT NONE PEER}
126
+ if (hash['SSLVerifyMode'] and supported_ssl_verifiers.include? hash['SSLVerifyMode'])
127
+ self.ssl_verify_mode = hash['SSLVerifyMode']
128
+ end
129
+
130
+ if hash['SSLCompression']
131
+ self.ssl_compression = hash['SSLCompression']
132
+ end
133
+
134
+ if (hash['SSLCipher'])
135
+ self.ssl_cipher = hash['SSLCipher']
136
+ end
137
+
138
+ if (hash['SSLCert'] and ::File.file?(hash['SSLCert']))
139
+ begin
140
+ self.ssl_cert = ::File.read(hash['SSLCert'])
141
+ rescue ::Exception => e
142
+ elog("Failed to read cert: #{e.class}: #{e}", LogSource)
143
+ end
144
+ end
145
+
146
+ if hash['Proxies']
147
+ self.proxies = hash['Proxies'].split('-').map{|a| a.strip}.map{|a| a.split(':').map{|b| b.strip}}
148
+ end
149
+
150
+ # The protocol this socket will be using
151
+ if (hash['Proto'])
152
+ self.proto = hash['Proto'].downcase
153
+ else
154
+ self.proto = 'tcp'
155
+ end
156
+
157
+ # Whether or not the socket should be a server
158
+ self.server = hash['Server'] || false
159
+
160
+ # The communication subsystem to use to create the socket
161
+ self.comm = hash['Comm']
162
+
163
+ # The context that was passed in, if any.
164
+ self.context = hash['Context'] || {}
165
+
166
+ # If no comm was supplied, try to use the comm that is best fit to
167
+ # handle the provided host based on the current routing table.
168
+ if( self.server )
169
+ if (self.comm == nil and self.localhost)
170
+ self.comm = Rex::Socket::SwitchBoard.best_comm(self.localhost)
171
+ end
172
+ else
173
+ if (self.comm == nil and self.peerhost)
174
+ self.comm = Rex::Socket::SwitchBoard.best_comm(self.peerhost)
175
+ end
176
+ end
177
+
178
+ # If we still haven't found a comm, we default to the local comm.
179
+ self.comm = Rex::Socket::Comm::Local if (self.comm == nil)
180
+
181
+ # If we are a UDP server, turn off the server flag as it was only set when
182
+ # creating the UDP socket in order to avail of the switch board above.
183
+ if( self.server and self.proto == 'udp' )
184
+ self.server = false
185
+ end
186
+
187
+ # The number of connection retries to make (client only)
188
+ if hash['Retries']
189
+ self.retries = hash['Retries'].to_i
190
+ else
191
+ self.retries = 0
192
+ end
193
+
194
+ # The number of seconds before a connect attempt times out (client only)
195
+ if hash['Timeout']
196
+ self.timeout = hash['Timeout'].to_i
197
+ else
198
+ self.timeout = 5
199
+ end
200
+
201
+ # Whether to force IPv6 addressing
202
+ self.v6 = hash['IPv6'] || false
203
+ end
204
+
205
+ ##
206
+ #
207
+ # Conditionals
208
+ #
209
+ ##
210
+
211
+ #
212
+ # Returns true if this represents parameters for a server.
213
+ #
214
+ def server?
215
+ return (server == true)
216
+ end
217
+
218
+ #
219
+ # Returns true if this represents parameters for a client.
220
+ #
221
+ def client?
222
+ return (server == false)
223
+ end
224
+
225
+ #
226
+ # Returns true if the protocol for the parameters is TCP.
227
+ #
228
+ def tcp?
229
+ return (proto == 'tcp')
230
+ end
231
+
232
+ #
233
+ # Returns true if the protocol for the parameters is UDP.
234
+ #
235
+ def udp?
236
+ return (proto == 'udp')
237
+ end
238
+
239
+ #
240
+ # Returns true if the protocol for the parameters is IP.
241
+ #
242
+ def ip?
243
+ return (proto == 'ip')
244
+ end
245
+
246
+ #
247
+ # Returns true if the socket is a bare socket that does not inherit from
248
+ # any extended Rex classes.
249
+ #
250
+ def bare?
251
+ return (bare == true)
252
+ end
253
+
254
+ #
255
+ # Returns true if SSL has been requested.
256
+ #
257
+ def ssl?
258
+ return ssl
259
+ end
260
+
261
+ #
262
+ # Returns true if IPv6 has been enabled
263
+ #
264
+ def v6?
265
+ return v6
266
+ end
267
+
268
+
269
+ ##
270
+ #
271
+ # Attributes
272
+ #
273
+ ##
274
+
275
+ # The remote host information, equivalent to the PeerHost parameter hash
276
+ # key.
277
+ # @return [String]
278
+ attr_accessor :peerhost
279
+
280
+ # The remote port. Equivalent to the PeerPort parameter hash key.
281
+ # @return [Fixnum]
282
+ attr_accessor :peerport
283
+
284
+ # The local host. Equivalent to the LocalHost parameter hash key.
285
+ # @return [String]
286
+ attr_accessor :localhost
287
+
288
+ # The local port. Equivalent to the LocalPort parameter hash key.
289
+ # @return [Fixnum]
290
+ attr_accessor :localport
291
+
292
+ # The protocol to to use, such as TCP. Equivalent to the Proto parameter
293
+ # hash key.
294
+ # @return [String]
295
+ attr_accessor :proto
296
+
297
+ # Whether or not this is a server. Equivalent to the Server parameter
298
+ # hash key.
299
+ # @return [Bool]
300
+ attr_accessor :server
301
+
302
+ # The {Comm} instance that should be used to create the underlying socket.
303
+ # @return [Comm]
304
+ attr_accessor :comm
305
+
306
+ # The context hash that was passed in to the structure. (default: {})
307
+ # @return [Hash]
308
+ attr_accessor :context
309
+
310
+ # The number of attempts that should be made.
311
+ # @return [Fixnum]
312
+ attr_accessor :retries
313
+
314
+ # The number of seconds before a connection attempt should time out.
315
+ # @return [Fixnum]
316
+ attr_accessor :timeout
317
+
318
+ # Whether or not this is a bare (non-extended) socket instance that should
319
+ # be created.
320
+ # @return [Bool]
321
+ attr_accessor :bare
322
+
323
+ # Whether or not SSL should be used to wrap the connection.
324
+ # @return [Bool]
325
+ attr_accessor :ssl
326
+
327
+ # What version of SSL to use (SSL2, SSL3, SSL23, TLS1)
328
+ # @return [String,Symbol]
329
+ attr_accessor :ssl_version
330
+
331
+ # What specific SSL Cipher(s) to use, may be a string containing the cipher
332
+ # name or an array of strings containing cipher names e.g.
333
+ # ["DHE-RSA-AES256-SHA", "DHE-DSS-AES256-SHA"]
334
+ # @return [String,Array]
335
+ attr_accessor :ssl_cipher
336
+
337
+ # The SSL certificate, in pem format, stored as a string. See
338
+ # {Rex::Socket::SslTcpServer#makessl}
339
+ # @return [String]
340
+ attr_accessor :ssl_cert
341
+
342
+ # Enables SSL/TLS-level compression
343
+ # @return [Bool]
344
+ attr_accessor :ssl_compression
345
+
346
+ #
347
+ # The SSL context verification mechanism
348
+ #
349
+ attr_accessor :ssl_verify_mode
350
+
351
+ #
352
+ # Whether we should use IPv6
353
+ # @return [Bool]
354
+ attr_accessor :v6
355
+
356
+
357
+ # List of proxies to use
358
+ # @return [String]
359
+ attr_accessor :proxies
360
+
361
+ alias peeraddr peerhost
362
+ alias localaddr localhost
362
363
  end