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
@@ -0,0 +1,508 @@
1
+
2
+ module Rex
3
+
4
+ module Poly
5
+
6
+ #
7
+ # A subclass to represent a Rex poly machine on the x86 architecture.
8
+ #
9
+ class MachineX86 < Rex::Poly::Machine
10
+
11
+ def initialize( badchars='', consume_base_pointer=nil, consume_stack_pointer=true )
12
+ super( badchars, Metasm::Ia32.new )
13
+
14
+ @reg_available << Rex::Arch::X86::EAX
15
+ @reg_available << Rex::Arch::X86::EBX
16
+ @reg_available << Rex::Arch::X86::ECX
17
+ @reg_available << Rex::Arch::X86::EDX
18
+ @reg_available << Rex::Arch::X86::ESI
19
+ @reg_available << Rex::Arch::X86::EDI
20
+ @reg_available << Rex::Arch::X86::EBP
21
+ @reg_available << Rex::Arch::X86::ESP
22
+
23
+ # By default we consume the EBP register if badchars contains \x00. This helps speed
24
+ # things up greatly as many instructions opperating on EBP introduce a NULL byte. For
25
+ # example, a MOV instruction with EAX as the source operand is as follows:
26
+ # 8B08 mov ecx, [eax]
27
+ # but the same instruction with EBP as the source operand is as follows:
28
+ # 8B4D00 mov ecx, [ebp] ; This is assembled as 'mov ecx, [ebp+0]'
29
+ # we can see that EBP is encoded differently with an offset included. We can still
30
+ # try to generate a solution with EBP included and \x00 in the badchars list but
31
+ # it can take considerably longer.
32
+ if( ( consume_base_pointer.nil? and not Rex::Text.badchar_index( "\x00", @badchars ).nil? ) or consume_base_pointer == true )
33
+ create_variable( 'base_pointer', 'ebp' )
34
+ end
35
+
36
+ # By default we consume the ESP register to avoid munging the stack.
37
+ if( consume_stack_pointer )
38
+ create_variable( 'stack_pointer', 'esp' )
39
+ end
40
+
41
+ # discover all the safe FPU instruction we can use.
42
+ @safe_fpu_instructions = ::Array.new
43
+ Rex::Arch::X86.fpu_instructions.each do | fpu |
44
+ if( is_valid?( fpu ) )
45
+ @safe_fpu_instructions << fpu
46
+ end
47
+ end
48
+ end
49
+
50
+ #
51
+ # The general purpose registers are 32bit
52
+ #
53
+ def native_size
54
+ Rex::Poly::Machine::DWORD
55
+ end
56
+
57
+ #
58
+ # Overload this method to intercept the 'set' primitive with the 'location' keyword
59
+ # and create the block with the '_set_variable_location'. We do this to keep a
60
+ # consistent style.
61
+ #
62
+ def create_block_primitive( block_name, primitive_name, *args )
63
+ if( primitive_name == 'set' and args.length == 2 and args[1] == 'location' )
64
+ _create_block_primitive( block_name, '_set_variable_location', args[0] )
65
+ else
66
+ super
67
+ end
68
+ end
69
+
70
+ #
71
+ # XXX: If we have a loop primitive, it is a decent speed bump to force the associated variable
72
+ # of the first loop primitive to be assigned as ECX (for the x86 LOOP instruction), this is not
73
+ # neccasary but can speed generation up significantly.
74
+ #
75
+ #def generate
76
+ # @blocks.each_value do | block |
77
+ # if( block.first.primitive == 'loop' )
78
+ # @variables.delete( block.first.args.first )
79
+ # create_variable( block.first.args.first, 'ecx' )
80
+ # break
81
+ # end
82
+ # end
83
+ # # ...go go go
84
+ # super
85
+ #end
86
+
87
+ protected
88
+
89
+ #
90
+ # Resolve a register number into a suitable register name.
91
+ #
92
+ def _register_value( regnum, size=nil )
93
+ value = nil
94
+ # we default to a native 32 bits if no size is specified.
95
+ if( size.nil? )
96
+ size = native_size()
97
+ end
98
+
99
+ if( size == Rex::Poly::Machine::DWORD )
100
+ value = Rex::Arch::X86::REG_NAMES32[ regnum ]
101
+ elsif( size == Rex::Poly::Machine::WORD )
102
+ value = Rex::Arch::X86::REG_NAMES16[ regnum ]
103
+ elsif( size == Rex::Poly::Machine::BYTE )
104
+ # (will return nil for ESI,EDI,EBP,ESP)
105
+ value = Rex::Arch::X86::REG_NAMES8L[ regnum ]
106
+ else
107
+ raise RuntimeError, "Register number '#{regnum}' (size #{size.to_i}) is unavailable."
108
+ end
109
+ return value
110
+ end
111
+
112
+ #
113
+ # Create the x86 primitives.
114
+ #
115
+ def _create_primitives
116
+
117
+ #
118
+ # Create the '_set_variable_location' primitive. The first param it the variable to place the current
119
+ # blocks location value in.
120
+ #
121
+ _create_primitive( '_set_variable_location',
122
+ ::Proc.new do | block, machine, variable |
123
+ if( @safe_fpu_instructions.empty? )
124
+ raise UnallowedPermutation
125
+ end
126
+ [
127
+ "dw #{ "0x%04X" % [ @safe_fpu_instructions[ rand(@safe_fpu_instructions.length) ].unpack( 'v' ).first ] }",
128
+ "mov #{machine.variable_value( 'temp' )}, esp",
129
+ "fnstenv [ #{machine.variable_value( 'temp' )} - 12 ]",
130
+ "pop #{machine.variable_value( variable )}"
131
+ ]
132
+ end,
133
+ ::Proc.new do | block, machine, variable |
134
+ if( @safe_fpu_instructions.empty? )
135
+ raise UnallowedPermutation
136
+ end
137
+ [
138
+ "dw #{ "0x%04X" % [ @safe_fpu_instructions[ rand(@safe_fpu_instructions.length) ].unpack( 'v' ).first ] }",
139
+ "mov #{machine.variable_value( 'temp' )}, esp",
140
+ "fnstenv [ #{machine.variable_value( 'temp' )} - 12 ]",
141
+ "pop #{machine.variable_value( variable )}"
142
+ ]
143
+ end,
144
+ ::Proc.new do | block, machine, variable |
145
+ if( @safe_fpu_instructions.empty? )
146
+ raise UnallowedPermutation
147
+ end
148
+ [
149
+ "dw #{ "0x%04X" % [ @safe_fpu_instructions[ rand(@safe_fpu_instructions.length) ].unpack( 'v' ).first ] }",
150
+ "push esp",
151
+ "pop #{machine.variable_value( 'temp' )}",
152
+ "fnstenv [ #{machine.variable_value( 'temp' )} - 12 ]",
153
+ "pop #{machine.variable_value( variable )}"
154
+ ]
155
+ end,
156
+ ::Proc.new do | block, machine, variable |
157
+ if( @safe_fpu_instructions.empty? )
158
+ raise UnallowedPermutation
159
+ end
160
+ [
161
+ "dw #{ "0x%04X" % [ @safe_fpu_instructions[ rand(@safe_fpu_instructions.length) ].unpack( 'v' ).first ] }",
162
+ "fnstenv [ esp - 12 ]",
163
+ "pop #{machine.variable_value( variable )}"
164
+ ]
165
+ end,
166
+ ::Proc.new do | block, machine, variable |
167
+ [
168
+ "call $+5",
169
+ "pop #{machine.variable_value( variable )}",
170
+ "push #{machine.block_offset( block ) + 5}",
171
+ "pop #{machine.variable_value( 'temp' )}",
172
+ "sub #{machine.variable_value( variable )}, #{machine.variable_value( 'temp' )}"
173
+ ]
174
+ end,
175
+ ::Proc.new do | block, machine, variable |
176
+ [
177
+ "db 0xE8, 0xFF, 0xFF, 0xFF, 0xFF, 0xC0",
178
+ "pop #{machine.variable_value( variable )}",
179
+ "push #{machine.block_offset( block ) + 5}",
180
+ "pop #{machine.variable_value( 'temp' )}",
181
+ "sub #{machine.variable_value( variable )}, #{machine.variable_value( 'temp' )}"
182
+ ]
183
+ end
184
+ )
185
+
186
+ #
187
+ # Create the 'loop' primitive. The first param it the counter variable which holds the number of
188
+ # times to perform the loop. The second param it the destination block to loop to.
189
+ #
190
+ _create_primitive( 'loop',
191
+ ::Proc.new do | block, machine, counter, destination |
192
+ if( machine.variable_value( counter ) != Rex::Arch::X86::REG_NAMES32[ Rex::Arch::X86::ECX ] )
193
+ # we raise and UndefinedPermutation exception to indicate that untill a valid register (ECX) is
194
+ # chosen we simply can't render this. This lets the machine know we can still try to use this
195
+ # permutation and at a later stage the requirements (counter==ecx) may be satisfied.
196
+ raise UndefinedPermutation
197
+ end
198
+ offset = -( machine.block_offset( machine.block_next( block ) ) - machine.block_offset( destination ) )
199
+ Rex::Arch::X86.loop( offset )
200
+ end,
201
+ ::Proc.new do | block, machine, counter, destination |
202
+ offset = -( machine.block_offset( machine.block_next( block ) ) - machine.block_offset( destination ) )
203
+ [
204
+ "dec #{machine.variable_value( counter )}",
205
+ "test #{machine.variable_value( counter )}, #{machine.variable_value( counter )}",
206
+ # JNZ destination
207
+ "db 0x0F, 0x85 dd #{ "0x%08X" % [ offset & 0xFFFFFFFF ] }"
208
+ ]
209
+ end
210
+ )
211
+
212
+ #
213
+ # Create the 'xor' primitive. The first param it the variable to xor with the second param value which
214
+ # can be either a variable, literal or block offset.
215
+ #
216
+ _create_primitive( 'xor',
217
+ ::Proc.new do | block, machine, variable, value |
218
+ [
219
+ "xor #{machine.variable_value( variable )}, #{machine.resolve_value( value )}"
220
+ ]
221
+ end,
222
+ ::Proc.new do | block, machine, variable, value |
223
+ # a ^ b == (a | b) & ~(a & b)
224
+ [
225
+ "mov #{machine.variable_value( 'temp' )}, #{machine.variable_value( variable )}",
226
+ "or #{machine.variable_value( 'temp' )}, #{machine.resolve_value( value )}",
227
+ "and #{machine.variable_value( variable )}, #{machine.resolve_value( value )}",
228
+ "not #{machine.variable_value( variable )}",
229
+ "and #{machine.variable_value( variable )}, #{machine.variable_value( 'temp' )}"
230
+ ]
231
+ end
232
+ )
233
+
234
+ #
235
+ # Create the 'goto' primitive. The first param is a destination block to jump to.
236
+ #
237
+ _create_primitive( 'goto',
238
+ ::Proc.new do | block, machine, destination |
239
+ offset = -( machine.block_offset( machine.block_next( block ) ) - machine.block_offset( destination ) )
240
+ if( ( offset > 0 and offset > 127 ) or ( offset < 0 and offset < -127 ) )
241
+ raise UnallowedPermutation
242
+ end
243
+ [
244
+ # short relative jump
245
+ "db 0xEB db #{ "0x%02X" % [ offset & 0xFF ] }"
246
+ ]
247
+ end,
248
+ ::Proc.new do | block, machine, destination |
249
+ offset = -( machine.block_offset( machine.block_next( block ) ) - machine.block_offset( destination ) )
250
+ [
251
+ # near relative jump
252
+ "db 0xE9 dd #{ "0x%08X" % [ offset & 0xFFFFFFFF ] }"
253
+ ]
254
+ end
255
+ )
256
+
257
+ #
258
+ # Create the 'add' primitive. The first param it the variable which will be added to the second
259
+ # param, which may either be a literal number value, a variables assigned register or a block
260
+ # name, in which case the block offset will be used.
261
+ #
262
+ _create_primitive( 'add',
263
+ ::Proc.new do | block, machine, variable, value |
264
+ if( machine.variable_exist?( value ) )
265
+ raise UnallowedPermutation
266
+ end
267
+ [
268
+ "lea #{machine.variable_value( variable )}, [ #{machine.variable_value( variable )} + #{machine.resolve_value( value )} ]"
269
+ ]
270
+ end,
271
+ ::Proc.new do | block, machine, variable, value |
272
+ [
273
+ "push #{machine.resolve_value( value )}",
274
+ "add #{machine.variable_value( variable )}, [esp]",
275
+ "pop #{machine.variable_value( 'temp' )}"
276
+ ]
277
+ end,
278
+ ::Proc.new do | block, machine, variable, value |
279
+ [
280
+ "add #{machine.variable_value( variable )}, #{machine.resolve_value( value )}"
281
+ ]
282
+ end,
283
+ ::Proc.new do | block, machine, variable, value |
284
+ if( machine.variable_exist?( value ) )
285
+ raise UnallowedPermutation
286
+ end
287
+ [
288
+ "sub #{machine.variable_value( variable )}, #{ "0x%08X" % [ ~(machine.resolve_value( value ) - 1) & 0xFFFFFFFF ] }"
289
+ ]
290
+ end
291
+ # ::Proc.new do | block, machine, variable, value |
292
+ # if( machine.variable_exist?( value ) )
293
+ # raise UnallowedPermutation
294
+ # end
295
+ # [
296
+ # "push #{ "0x%08X" % [ ~(machine.resolve_value( value ) - 1) & 0xFFFFFFFF ] }",
297
+ # "pop #{machine.variable_value( 'temp' )}",
298
+ # "not #{machine.variable_value( 'temp' )}",
299
+ # "add #{machine.variable_value( variable )}, #{machine.variable_value( 'temp' )}"
300
+ # ]
301
+ # end,
302
+ # ::Proc.new do | block, machine, variable, value |
303
+ # if( machine.variable_exist?( value ) )
304
+ # raise UnallowedPermutation
305
+ # end
306
+ # [
307
+ # "xor #{machine.variable_value( 'temp' )}, #{machine.variable_value( 'temp' )}",
308
+ # "mov #{machine.variable_value( 'temp', 16 )}, #{ "0x%04X" % [ ~(machine.resolve_value( value ) - 1) & 0xFFFF ] }",
309
+ # "not #{machine.variable_value( 'temp', 16 )}",
310
+ # "add #{machine.variable_value( variable )}, #{machine.variable_value( 'temp' )}"
311
+ # ]
312
+ # end,
313
+ )
314
+
315
+ #
316
+ # Create the 'set' primitive. The first param it the variable which will be set. the second
317
+ # param is the value to set the variable to (a variable, block or literal).
318
+ #
319
+ _create_primitive( 'set',
320
+ ::Proc.new do | block, machine, variable, value |
321
+ if( machine.variable_exist?( value ) )
322
+ raise UnallowedPermutation
323
+ end
324
+ [
325
+ "push #{ "0x%08X" % [ ~machine.resolve_value( value ) & 0xFFFFFFFF ] }",
326
+ "pop #{machine.variable_value( variable )}",
327
+ "not #{machine.variable_value( variable )}"
328
+ ]
329
+ end,
330
+ ::Proc.new do | block, machine, variable, value |
331
+ if( machine.variable_exist?( value ) )
332
+ raise UnallowedPermutation
333
+ end
334
+ if( machine.resolve_value( value, WORD ) > 0xFFFF )
335
+ raise UndefinedPermutation
336
+ end
337
+ [
338
+ "xor #{machine.variable_value( variable )}, #{machine.variable_value( variable )}",
339
+ "mov #{machine.variable_value( variable, WORD )}, #{ "0x%04X" % [ ~machine.resolve_value( value, WORD ) & 0xFFFF ] }",
340
+ "not #{machine.variable_value( variable, WORD )}"
341
+ ]
342
+ end,
343
+ ::Proc.new do | block, machine, variable, value |
344
+ [
345
+ "push #{machine.resolve_value( value )}",
346
+ "pop #{machine.variable_value( variable )}"
347
+ ]
348
+ end,
349
+ ::Proc.new do | block, machine, variable, value |
350
+ [
351
+ "mov #{machine.variable_value( variable )}, #{machine.resolve_value( value )}"
352
+ ]
353
+ end,
354
+ ::Proc.new do | block, machine, variable, value |
355
+ if( machine.variable_exist?( value ) )
356
+ raise UnallowedPermutation
357
+ end
358
+ if( machine.resolve_value( value, WORD ) > 0xFFFF )
359
+ raise UndefinedPermutation
360
+ end
361
+ [
362
+ "xor #{machine.variable_value( variable )}, #{machine.variable_value( variable )}",
363
+ "mov #{machine.variable_value( variable, WORD )}, #{ "0x%04X" % [ machine.resolve_value( value, WORD ) & 0xFFFF ] }"
364
+ ]
365
+ end,
366
+ ::Proc.new do | block, machine, variable, value |
367
+ if( machine.variable_exist?( value ) )
368
+ raise UnallowedPermutation
369
+ end
370
+ dword = machine.make_safe_dword( machine.resolve_value( value ) )
371
+ [
372
+ "mov #{machine.variable_value( variable )}, #{ "0x%08X" % [ dword ] }",
373
+ "sub #{machine.variable_value( variable )}, #{ "0x%08X" % [ dword - machine.resolve_value( value ) ] }"
374
+ ]
375
+ end,
376
+ ::Proc.new do | block, machine, variable, value |
377
+ if( machine.variable_exist?( value ) )
378
+ raise UnallowedPermutation
379
+ end
380
+ dword = machine.make_safe_dword( machine.resolve_value( value ) )
381
+ [
382
+ "mov #{machine.variable_value( variable )}, #{ "0x%08X" % [ dword - machine.resolve_value( value ) ] }",
383
+ "add #{machine.variable_value( variable )}, #{ "0x%08X" % [ ~dword & 0xFFFFFFFF ] }",
384
+ "not #{machine.variable_value( variable )}"
385
+ ]
386
+ end
387
+ )
388
+
389
+ #
390
+ # Create the 'load' primitive. The first param it the variable which will be set. The second
391
+ # param is the value (either a variable or literal) to load from. the third param is the size
392
+ # of the load operation, either DWORD, WORD or BYTE.
393
+ #
394
+ _create_primitive( 'load',
395
+ ::Proc.new do | block, machine, variable, value, size |
396
+ result = nil
397
+ if( size == Rex::Poly::Machine::DWORD )
398
+ result = [ "mov #{machine.variable_value( variable )}, [#{machine.resolve_value( value )}]" ]
399
+ elsif( size == Rex::Poly::Machine::WORD )
400
+ result = [ "movzx #{machine.variable_value( variable )}, word [#{machine.resolve_value( value )}]" ]
401
+ elsif( size == Rex::Poly::Machine::BYTE )
402
+ result = [ "movzx #{machine.variable_value( variable )}, byte [#{machine.resolve_value( value )}]" ]
403
+ else
404
+ raise InvalidPermutation
405
+ end
406
+ result
407
+ end,
408
+ ::Proc.new do | block, machine, variable, value, size |
409
+ result = nil
410
+ if( size == Rex::Poly::Machine::DWORD )
411
+ # we raise and UnallowedPermutation here as this permutation should only satisfy requests for
412
+ # sizes of WORD or BYTE, any DWORD requests will be satisfied by the above permutation (otherwise
413
+ # we would just be duplicating a 'mov dest, [src]' sequence which is the same as above.
414
+ raise UnallowedPermutation
415
+ elsif( size == Rex::Poly::Machine::WORD )
416
+ result = [
417
+ "mov #{machine.variable_value( variable )}, [#{machine.resolve_value( value )}]",
418
+ "shl #{machine.variable_value( variable )}, 16",
419
+ "shr #{machine.variable_value( variable )}, 16"
420
+ ]
421
+ elsif( size == Rex::Poly::Machine::BYTE )
422
+ result = [
423
+ "mov #{machine.variable_value( variable )}, [#{machine.resolve_value( value )}]",
424
+ "shl #{machine.variable_value( variable )}, 24",
425
+ "shr #{machine.variable_value( variable )}, 24"
426
+ ]
427
+ else
428
+ raise InvalidPermutation
429
+ end
430
+ result
431
+ end,
432
+ ::Proc.new do | block, machine, variable, value, size |
433
+ result = nil
434
+ if( size == Rex::Poly::Machine::DWORD )
435
+ result = [
436
+ "push [#{machine.resolve_value( value )}]",
437
+ "pop #{machine.variable_value( variable )}"
438
+ ]
439
+ elsif( size == Rex::Poly::Machine::WORD )
440
+ result = [
441
+ "push [#{machine.resolve_value( value )}]",
442
+ "pop #{machine.variable_value( variable )}",
443
+ "shl #{machine.variable_value( variable )}, 16",
444
+ "shr #{machine.variable_value( variable )}, 16"
445
+ ]
446
+ elsif( size == Rex::Poly::Machine::BYTE )
447
+ result = [
448
+ "push [#{machine.resolve_value( value )}]",
449
+ "pop #{machine.variable_value( variable )}",
450
+ "shl #{machine.variable_value( variable )}, 24",
451
+ "shr #{machine.variable_value( variable )}, 24"
452
+ ]
453
+ else
454
+ raise InvalidPermutation
455
+ end
456
+ result
457
+ end
458
+ )
459
+
460
+ #
461
+ # Create the 'store' primitive.
462
+ #
463
+ _create_primitive( 'store',
464
+ ::Proc.new do | block, machine, variable, value, size |
465
+ result = nil
466
+ if( size == Rex::Poly::Machine::DWORD )
467
+ result = [ "mov [#{machine.variable_value( variable )}], #{machine.resolve_value( value )}" ]
468
+ elsif( size == Rex::Poly::Machine::WORD )
469
+ result = [ "mov word [#{machine.variable_value( variable )}], #{machine.resolve_value( value, WORD )}" ]
470
+ elsif( size == Rex::Poly::Machine::BYTE )
471
+ if( machine.resolve_value( value, BYTE ).nil? )
472
+ # so long as we cant resolve the variable to an 8bit register value (AL,BL,CL,DL) we must raise
473
+ # an UndefinedPermutation exception (this will happen when the variable has been assigned to ESI,
474
+ # EDI, EBP or ESP which dont have a low byte representation)
475
+ raise UndefinedPermutation
476
+ end
477
+ result = [ "mov byte [#{machine.variable_value( variable )}], #{machine.resolve_value( value, BYTE )}" ]
478
+ else
479
+ raise InvalidPermutation
480
+ end
481
+ result
482
+ end,
483
+ ::Proc.new do | block, machine, variable, value, size |
484
+ result = nil
485
+ if( size == Rex::Poly::Machine::DWORD )
486
+ result = [
487
+ "push #{machine.resolve_value( value )}",
488
+ "pop [#{machine.variable_value( variable )}]"
489
+ ]
490
+ elsif( size == Rex::Poly::Machine::WORD )
491
+ result = [
492
+ "push #{machine.resolve_value( value, WORD )}",
493
+ "pop word [#{machine.variable_value( variable )}]"
494
+ ]
495
+ else
496
+ # we can never do this permutation for BYTE size (or any other size)
497
+ raise UnallowedPermutation
498
+ end
499
+ result
500
+ end
501
+ )
502
+ end
503
+
504
+ end
505
+
506
+ end
507
+
508
+ end