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
@@ -14,391 +14,397 @@ DefaultProtocol = '1.1'
14
14
  ###
15
15
  class Packet
16
16
 
17
- #
18
- # Parser processing codes
19
- #
20
- module ParseCode
21
- Completed = 1
22
- Partial = 2
23
- Error = 3
24
- end
25
-
26
- #
27
- # Parser states
28
- #
29
- module ParseState
30
- ProcessingHeader = 1
31
- ProcessingBody = 2
32
- Completed = 3
33
- end
34
-
35
- require 'rex/proto/http/header'
36
-
37
- #
38
- # Initializes an instance of an HTTP packet.
39
- #
40
- def initialize()
41
- self.headers = Header.new
42
- self.auto_cl = true
43
-
44
- reset
45
- end
46
-
47
- #
48
- # Return the associated header value, if any.
49
- #
50
- def [](key)
51
- if (self.headers.include?(key))
52
- return self.headers[key]
53
- end
54
-
55
- self.headers.each_pair do |k,v|
56
- if (k.downcase == key.downcase)
57
- return v
58
- end
59
- end
60
-
61
- return nil
62
- end
63
-
64
- #
65
- # Set the associated header value.
66
- #
67
- def []=(key, value)
68
- self.headers[key] = value
69
- end
70
-
71
- #
72
- # Parses the supplied buffer. Returns one of the two parser processing
73
- # codes (Completed, Partial, or Error).
74
- #
75
- def parse(buf)
76
-
77
- # Append the incoming buffer to the buffer queue.
78
- self.bufq += buf.to_s
79
-
80
- begin
81
-
82
- # Process the header
83
- if(self.state == ParseState::ProcessingHeader)
84
- parse_header
85
- end
86
-
87
- # Continue on to the body if the header was processed
88
- if(self.state == ParseState::ProcessingBody)
89
- # Chunked encoding sets the parsing state on its own
90
- if (self.body_bytes_left == 0 and not self.transfer_chunked)
91
- self.state = ParseState::Completed
92
- else
93
- parse_body
94
- end
95
- end
96
- rescue
97
- # XXX: BUG: This rescue might be a problem because it will swallow TimeoutError
98
- self.error = $!
99
- return ParseCode::Error
100
- end
101
-
102
- # Return completed or partial to the parsing status to the caller
103
- (self.state == ParseState::Completed) ? ParseCode::Completed : ParseCode::Partial
104
- end
105
-
106
- #
107
- # Reset the parsing state and buffers.
108
- #
109
- def reset
110
- self.state = ParseState::ProcessingHeader
111
- self.transfer_chunked = false
112
- self.inside_chunk = false
113
- self.headers.reset
114
- self.bufq = ''
115
- self.body = ''
116
- end
117
-
118
- #
119
- # Reset the parsing state but leave the buffers.
120
- #
121
- def reset_except_queue
122
- self.state = ParseState::ProcessingHeader
123
- self.transfer_chunked = false
124
- self.inside_chunk = false
125
- self.headers.reset
126
- self.body = ''
127
- end
128
-
129
- #
130
- # Returns whether or not parsing has completed.
131
- #
132
- def completed?
133
-
134
- return true if self.state == ParseState::Completed
135
-
136
- # If the parser state is processing the body and there are an
137
- # undetermined number of bytes left to read, we just need to say that
138
- # things are completed as it's hard to tell whether or not they really
139
- # are.
140
- if (self.state == ParseState::ProcessingBody and self.body_bytes_left < 0)
141
- return true
142
- end
143
-
144
- false
145
- end
146
-
147
- #
148
- # Build a 'Transfer-Encoding: chunked' payload with random chunk sizes
149
- #
150
- def chunk(str, min_size = 1, max_size = 1000)
151
- chunked = ''
152
-
153
- # min chunk size is 1 byte
154
- if (min_size < 1); min_size = 1; end
155
-
156
- # don't be dumb
157
- if (max_size < min_size); max_size = min_size; end
158
-
159
- while (str.size > 0)
160
- chunk = str.slice!(0, rand(max_size - min_size) + min_size)
161
- chunked += sprintf("%x", chunk.size) + "\r\n" + chunk + "\r\n"
162
- end
163
- chunked += "0\r\n\r\n"
164
- end
165
-
166
- #
167
- # Converts the packet to a string.
168
- #
169
- def to_s
170
- content = self.body.to_s.dup
171
-
172
- # Update the content length field in the header with the body length.
173
- if (content)
174
- if !self.compress.nil?
175
- case self.compress
176
- when 'gzip'
177
- self.headers['Content-Encoding'] = 'gzip'
178
- content = Rex::Text.gzip(content)
179
- when 'deflate'
180
- self.headers['Content-Encoding'] = 'deflate'
181
- content = Rex::Text.zlib_deflate(content)
182
- when 'none'
183
- # this one is fine...
184
- # when 'compress'
185
- else
186
- raise RuntimeError, 'Invalid Content-Encoding'
187
- end
188
- end
189
-
190
- if (self.auto_cl == true && self.transfer_chunked == true)
191
- raise RuntimeError, "'Content-Length' and 'Transfer-Encoding: chunked' are incompatible"
192
- elsif self.auto_cl == true
193
- self.headers['Content-Length'] = content.length
194
- elsif self.transfer_chunked == true
195
- if self.proto != '1.1'
196
- raise RuntimeError, 'Chunked encoding is only available via 1.1'
197
- end
198
- self.headers['Transfer-Encoding'] = 'chunked'
199
- content = self.chunk(content, self.chunk_min_size, self.chunk_max_size)
200
- end
201
- end
202
-
203
- str = self.headers.to_s(cmd_string)
204
- str += content || ''
205
- end
206
-
207
- #
208
- # Converts the packet from a string.
209
- #
210
- def from_s(str)
211
- reset
212
- parse(str)
213
- end
214
-
215
- #
216
- # Returns the command string, such as:
217
- #
218
- # HTTP/1.0 200 OK for a response
219
- #
220
- # or
221
- #
222
- # GET /foo HTTP/1.0 for a request
223
- #
224
- def cmd_string
225
- self.headers.cmd_string
226
- end
227
-
228
- attr_accessor :headers
229
- attr_accessor :error
230
- attr_accessor :state
231
- attr_accessor :bufq
232
- attr_accessor :body
233
- attr_accessor :auto_cl
234
- attr_accessor :max_data
235
- attr_accessor :transfer_chunked
236
- attr_accessor :compress
237
- attr_reader :incomplete
238
-
239
- attr_accessor :chunk_min_size
240
- attr_accessor :chunk_max_size
17
+ #
18
+ # Parser processing codes
19
+ #
20
+ module ParseCode
21
+ Completed = 1
22
+ Partial = 2
23
+ Error = 3
24
+ end
25
+
26
+ #
27
+ # Parser states
28
+ #
29
+ module ParseState
30
+ ProcessingHeader = 1
31
+ ProcessingBody = 2
32
+ Completed = 3
33
+ end
34
+
35
+ require 'rex/proto/http/header'
36
+
37
+ #
38
+ # Initializes an instance of an HTTP packet.
39
+ #
40
+ def initialize()
41
+ self.headers = Header.new
42
+ self.auto_cl = true
43
+
44
+ reset
45
+ end
46
+
47
+ #
48
+ # Return the associated header value, if any.
49
+ #
50
+ def [](key)
51
+ if (self.headers.include?(key))
52
+ return self.headers[key]
53
+ end
54
+
55
+ self.headers.each_pair do |k,v|
56
+ if (k.downcase == key.downcase)
57
+ return v
58
+ end
59
+ end
60
+
61
+ return nil
62
+ end
63
+
64
+ #
65
+ # Set the associated header value.
66
+ #
67
+ def []=(key, value)
68
+ self.headers[key] = value
69
+ end
70
+
71
+ #
72
+ # Parses the supplied buffer. Returns one of the two parser processing
73
+ # codes (Completed, Partial, or Error).
74
+ #
75
+ def parse(buf)
76
+
77
+ # Append the incoming buffer to the buffer queue.
78
+ self.bufq += buf.to_s
79
+
80
+ begin
81
+
82
+ # Process the header
83
+ if(self.state == ParseState::ProcessingHeader)
84
+ parse_header
85
+ end
86
+
87
+ # Continue on to the body if the header was processed
88
+ if(self.state == ParseState::ProcessingBody)
89
+ # Chunked encoding sets the parsing state on its own
90
+ if (self.body_bytes_left == 0 and not self.transfer_chunked)
91
+ self.state = ParseState::Completed
92
+ else
93
+ parse_body
94
+ end
95
+ end
96
+ rescue
97
+ # XXX: BUG: This rescue might be a problem because it will swallow TimeoutError
98
+ self.error = $!
99
+ return ParseCode::Error
100
+ end
101
+
102
+ # Return completed or partial to the parsing status to the caller
103
+ (self.state == ParseState::Completed) ? ParseCode::Completed : ParseCode::Partial
104
+ end
105
+
106
+ #
107
+ # Reset the parsing state and buffers.
108
+ #
109
+ def reset
110
+ self.state = ParseState::ProcessingHeader
111
+ self.transfer_chunked = false
112
+ self.inside_chunk = false
113
+ self.headers.reset
114
+ self.bufq = ''
115
+ self.body = ''
116
+ end
117
+
118
+ #
119
+ # Reset the parsing state but leave the buffers.
120
+ #
121
+ def reset_except_queue
122
+ self.state = ParseState::ProcessingHeader
123
+ self.transfer_chunked = false
124
+ self.inside_chunk = false
125
+ self.headers.reset
126
+ self.body = ''
127
+ end
128
+
129
+ #
130
+ # Returns whether or not parsing has completed.
131
+ #
132
+ def completed?
133
+
134
+ return true if self.state == ParseState::Completed
135
+
136
+ # If the parser state is processing the body and there are an
137
+ # undetermined number of bytes left to read, we just need to say that
138
+ # things are completed as it's hard to tell whether or not they really
139
+ # are.
140
+ if (self.state == ParseState::ProcessingBody and self.body_bytes_left < 0)
141
+ return true
142
+ end
143
+
144
+ false
145
+ end
146
+
147
+ #
148
+ # Build a 'Transfer-Encoding: chunked' payload with random chunk sizes
149
+ #
150
+ def chunk(str, min_size = 1, max_size = 1000)
151
+ chunked = ''
152
+
153
+ # min chunk size is 1 byte
154
+ if (min_size < 1); min_size = 1; end
155
+
156
+ # don't be dumb
157
+ if (max_size < min_size); max_size = min_size; end
158
+
159
+ while (str.size > 0)
160
+ chunk = str.slice!(0, rand(max_size - min_size) + min_size)
161
+ chunked += sprintf("%x", chunk.size) + "\r\n" + chunk + "\r\n"
162
+ end
163
+ chunked += "0\r\n\r\n"
164
+ end
165
+
166
+ #
167
+ # Converts the packet to a string.
168
+ #
169
+ def to_s
170
+ content = self.body.to_s.dup
171
+
172
+ # Update the content length field in the header with the body length.
173
+ if (content)
174
+ if !self.compress.nil?
175
+ case self.compress
176
+ when 'gzip'
177
+ self.headers['Content-Encoding'] = 'gzip'
178
+ content = Rex::Text.gzip(content)
179
+ when 'deflate'
180
+ self.headers['Content-Encoding'] = 'deflate'
181
+ content = Rex::Text.zlib_deflate(content)
182
+ when 'none'
183
+ # this one is fine...
184
+ # when 'compress'
185
+ else
186
+ raise RuntimeError, 'Invalid Content-Encoding'
187
+ end
188
+ end
189
+
190
+ if (self.auto_cl == true && self.transfer_chunked == true)
191
+ raise RuntimeError, "'Content-Length' and 'Transfer-Encoding: chunked' are incompatible"
192
+ elsif self.auto_cl == true
193
+ self.headers['Content-Length'] = content.length
194
+ elsif self.transfer_chunked == true
195
+ if self.proto != '1.1'
196
+ raise RuntimeError, 'Chunked encoding is only available via 1.1'
197
+ end
198
+ self.headers['Transfer-Encoding'] = 'chunked'
199
+ content = self.chunk(content, self.chunk_min_size, self.chunk_max_size)
200
+ end
201
+ end
202
+
203
+ str = self.headers.to_s(cmd_string)
204
+ str += content || ''
205
+ end
206
+
207
+ #
208
+ # Converts the packet from a string.
209
+ #
210
+ def from_s(str)
211
+ reset
212
+ parse(str)
213
+ end
214
+
215
+ #
216
+ # Returns the command string, such as:
217
+ #
218
+ # HTTP/1.0 200 OK for a response
219
+ #
220
+ # or
221
+ #
222
+ # GET /foo HTTP/1.0 for a request
223
+ #
224
+ def cmd_string
225
+ self.headers.cmd_string
226
+ end
227
+
228
+ attr_accessor :headers
229
+ attr_accessor :error
230
+ attr_accessor :state
231
+ attr_accessor :bufq
232
+ attr_accessor :body
233
+ attr_accessor :auto_cl
234
+ attr_accessor :max_data
235
+ attr_accessor :transfer_chunked
236
+ attr_accessor :compress
237
+ attr_reader :incomplete
238
+
239
+ attr_accessor :chunk_min_size
240
+ attr_accessor :chunk_max_size
241
241
 
242
242
  protected
243
243
 
244
- attr_writer :incomplete
245
- attr_accessor :body_bytes_left
246
- attr_accessor :inside_chunk
247
- attr_accessor :keepalive
248
-
249
- ##
250
- #
251
- # Overridable methods
252
- #
253
- ##
254
-
255
- #
256
- # Allows derived classes to split apart the command string.
257
- #
258
- def update_cmd_parts(str)
259
- end
260
-
261
- ##
262
- #
263
- # Parsing
264
- #
265
- ##
266
-
267
- def parse_header
268
-
269
- head,data = self.bufq.split(/\r?\n\r?\n/, 2)
270
-
271
- return if not data
272
-
273
- self.headers.from_s(head)
274
- self.bufq = data || ""
275
-
276
- # Set the content-length to -1 as a placeholder (read until EOF)
277
- self.body_bytes_left = -1
278
-
279
- # Extract the content length if it was specified
280
- if (self.headers['Content-Length'])
281
- self.body_bytes_left = self.headers['Content-Length'].to_i
282
- end
283
-
284
- # Look for a chunked transfer header
285
- if (self.headers['Transfer-Encoding'].to_s.downcase == 'chunked')
286
- self.transfer_chunked = true
287
- self.auto_cl = false
288
- end
289
-
290
- # Determine how to handle data when there is no length header
291
- if (self.body_bytes_left == -1)
292
- if (not self.transfer_chunked)
293
- if (self.headers['Connection'].to_s.downcase.include?('keep-alive'))
294
- # If we are using keep-alive, but have no content-length and
295
- # no chunked transfer header, pretend this is the entire
296
- # buffer and call it done
297
- self.body_bytes_left = self.bufq.length
298
- elsif (not self.headers['Content-Length'] and self.class == Rex::Proto::Http::Request)
299
- # RFC 2616 says: "The presence of a message-body in a request
300
- # is signaled by the inclusion of a Content-Length or
301
- # Transfer-Encoding header field in the request's
302
- # message-headers."
303
- #
304
- # So if we haven't seen either a Content-Length or a
305
- # Transfer-Encoding header, there shouldn't be a message body.
306
- self.body_bytes_left = 0
307
- #else
308
- # Otherwise we need to keep reading until EOF
309
- end
310
- end
311
- end
312
-
313
- # Throw an error if we didnt parse the header properly
314
- if !self.headers.cmd_string
315
- raise RuntimeError, "Invalid command string", caller
316
- end
317
-
318
- # Move the state into body processing
319
- self.state = ParseState::ProcessingBody
320
-
321
- # Allow derived classes to update the parts of the command string
322
- self.update_cmd_parts(self.headers.cmd_string)
323
- end
324
-
325
- #
326
- # Parses the body portion of the request.
327
- #
328
- def parse_body
329
- # Just return if the buffer is empty
330
- if (self.bufq.length == 0)
331
- return
332
- end
333
-
334
- # Handle chunked transfer-encoding responses
335
- if (self.transfer_chunked and self.inside_chunk != 1 and self.bufq.length)
336
-
337
- # Remove any leading newlines or spaces
338
- self.bufq.lstrip!
339
-
340
- # If we didn't get a newline, then this might not be the full
341
- # length, go back and get more.
342
- # e.g.
343
- # first packet: "200"
344
- # second packet: "0\r\n\r\n<html>..."
345
- if not bufq.index("\n")
346
- return
347
- end
348
-
349
- # Extract the actual hexadecimal length value
350
- clen = self.bufq.slice!(/^[a-fA-F0-9]+\r?\n/)
351
-
352
- clen.rstrip! if (clen)
353
-
354
- # if we happen to fall upon the end of the buffer for the next chunk len and have no data left, go get some more...
355
- if clen.nil? and self.bufq.length == 0
356
- return
357
- end
358
-
359
- # Invalid chunk length, exit out early
360
- if clen.nil?
361
- self.state = ParseState::Completed
362
- return
363
- end
364
-
365
- self.body_bytes_left = clen.to_i(16)
366
-
367
- if (self.body_bytes_left == 0)
368
- self.bufq.sub!(/^\r?\n/s,'')
369
- self.state = ParseState::Completed
370
- return
371
- end
372
-
373
- self.inside_chunk = 1
374
- end
375
-
376
- # If there are bytes remaining, slice as many as we can and append them
377
- # to our body state.
378
- if (self.body_bytes_left > 0)
379
- part = self.bufq.slice!(0, self.body_bytes_left)
380
- self.body += part
381
- self.body_bytes_left -= part.length
382
- # Otherwise, just read it all.
383
- else
384
- self.body += self.bufq
385
- self.bufq = ''
386
- end
387
-
388
- # Finish this chunk and move on to the next one
389
- if (self.transfer_chunked and self.body_bytes_left == 0)
390
- self.inside_chunk = 0
391
- self.parse_body
392
- return
393
- end
394
-
395
- # If there are no more bytes left, then parsing has completed and we're
396
- # ready to go.
397
- if (not self.transfer_chunked and self.body_bytes_left == 0)
398
- self.state = ParseState::Completed
399
- return
400
- end
401
- end
244
+ attr_writer :incomplete
245
+ attr_accessor :body_bytes_left
246
+ attr_accessor :inside_chunk
247
+ attr_accessor :keepalive
248
+
249
+ ##
250
+ #
251
+ # Overridable methods
252
+ #
253
+ ##
254
+
255
+ #
256
+ # Allows derived classes to split apart the command string.
257
+ #
258
+ def update_cmd_parts(str)
259
+ end
260
+
261
+ ##
262
+ #
263
+ # Parsing
264
+ #
265
+ ##
266
+
267
+ def parse_header
268
+
269
+ head,data = self.bufq.split(/\r?\n\r?\n/, 2)
270
+
271
+ return if not data
272
+
273
+ self.headers.from_s(head)
274
+ self.bufq = data || ""
275
+
276
+ # Set the content-length to -1 as a placeholder (read until EOF)
277
+ self.body_bytes_left = -1
278
+
279
+ # Extract the content length if it was specified
280
+ if (self.headers['Content-Length'])
281
+ self.body_bytes_left = self.headers['Content-Length'].to_i
282
+ end
283
+
284
+ # Look for a chunked transfer header
285
+ if (self.headers['Transfer-Encoding'].to_s.downcase == 'chunked')
286
+ self.transfer_chunked = true
287
+ self.auto_cl = false
288
+ end
289
+
290
+ # Determine how to handle data when there is no length header
291
+ if (self.body_bytes_left == -1)
292
+ if (not self.transfer_chunked)
293
+ if (self.headers['Connection'].to_s.downcase.include?('keep-alive'))
294
+ # If we are using keep-alive, but have no content-length and
295
+ # no chunked transfer header, pretend this is the entire
296
+ # buffer and call it done
297
+ self.body_bytes_left = self.bufq.length
298
+ elsif (not self.headers['Content-Length'] and self.class == Rex::Proto::Http::Request)
299
+ # RFC 2616 says: "The presence of a message-body in a request
300
+ # is signaled by the inclusion of a Content-Length or
301
+ # Transfer-Encoding header field in the request's
302
+ # message-headers."
303
+ #
304
+ # So if we haven't seen either a Content-Length or a
305
+ # Transfer-Encoding header, there shouldn't be a message body.
306
+ self.body_bytes_left = 0
307
+ #else
308
+ # Otherwise we need to keep reading until EOF
309
+ end
310
+ end
311
+ end
312
+
313
+ # Throw an error if we didnt parse the header properly
314
+ if !self.headers.cmd_string
315
+ raise RuntimeError, "Invalid command string", caller
316
+ end
317
+
318
+ # Move the state into body processing
319
+ self.state = ParseState::ProcessingBody
320
+
321
+ # Allow derived classes to update the parts of the command string
322
+ self.update_cmd_parts(self.headers.cmd_string)
323
+ end
324
+
325
+ #
326
+ # Parses the body portion of the request.
327
+ #
328
+ def parse_body
329
+ # Just return if the buffer is empty
330
+ if (self.bufq.length == 0)
331
+ return
332
+ end
333
+
334
+ # Handle chunked transfer-encoding responses
335
+ if (self.transfer_chunked and self.inside_chunk != 1 and self.bufq.length)
336
+
337
+ # Remove any leading newlines or spaces
338
+ self.bufq.lstrip!
339
+
340
+ # If we didn't get a newline, then this might not be the full
341
+ # length, go back and get more.
342
+ # e.g.
343
+ # first packet: "200"
344
+ # second packet: "0\r\n\r\n<html>..."
345
+ if not bufq.index("\n")
346
+ return
347
+ end
348
+
349
+ # Extract the actual hexadecimal length value
350
+ clen = self.bufq.slice!(/^[a-fA-F0-9]+\r?\n/)
351
+
352
+ clen.rstrip! if (clen)
353
+
354
+ # if we happen to fall upon the end of the buffer for the next chunk len and have no data left, go get some more...
355
+ if clen.nil? and self.bufq.length == 0
356
+ return
357
+ end
358
+
359
+ # Invalid chunk length, exit out early
360
+ if clen.nil?
361
+ self.state = ParseState::Completed
362
+ return
363
+ end
364
+
365
+ self.body_bytes_left = clen.to_i(16)
366
+
367
+ if (self.body_bytes_left == 0)
368
+ self.bufq.sub!(/^\r?\n/s,'')
369
+ self.state = ParseState::Completed
370
+ self.check_100
371
+ return
372
+ end
373
+
374
+ self.inside_chunk = 1
375
+ end
376
+
377
+ # If there are bytes remaining, slice as many as we can and append them
378
+ # to our body state.
379
+ if (self.body_bytes_left > 0)
380
+ part = self.bufq.slice!(0, self.body_bytes_left)
381
+ self.body += part
382
+ self.body_bytes_left -= part.length
383
+ # Otherwise, just read it all.
384
+ else
385
+ self.body += self.bufq
386
+ self.bufq = ''
387
+ end
388
+
389
+ # Finish this chunk and move on to the next one
390
+ if (self.transfer_chunked and self.body_bytes_left == 0)
391
+ self.inside_chunk = 0
392
+ self.parse_body
393
+ return
394
+ end
395
+
396
+ # If there are no more bytes left, then parsing has completed and we're
397
+ # ready to go.
398
+ if (not self.transfer_chunked and self.body_bytes_left == 0)
399
+ self.state = ParseState::Completed
400
+ self.check_100
401
+ return
402
+ end
403
+ end
404
+
405
+ # Override this as needed
406
+ def check_100
407
+ end
402
408
 
403
409
  end
404
410