librex 0.0.13 → 0.0.15

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 (435) hide show
  1. data/README.markdown +1 -1
  2. data/Rakefile +1 -0
  3. metadata +3 -435
  4. data/lib/rex/LICENSE +0 -29
  5. data/lib/rex/arch.rb +0 -103
  6. data/lib/rex/arch/sparc.rb +0 -75
  7. data/lib/rex/arch/sparc.rb.ut.rb +0 -18
  8. data/lib/rex/arch/x86.rb +0 -513
  9. data/lib/rex/arch/x86.rb.ut.rb +0 -93
  10. data/lib/rex/assembly/nasm.rb +0 -104
  11. data/lib/rex/assembly/nasm.rb.ut.rb +0 -22
  12. data/lib/rex/codepage.map +0 -104
  13. data/lib/rex/compat.rb +0 -311
  14. data/lib/rex/constants.rb +0 -113
  15. data/lib/rex/elfparsey.rb +0 -11
  16. data/lib/rex/elfparsey/elf.rb +0 -123
  17. data/lib/rex/elfparsey/elfbase.rb +0 -258
  18. data/lib/rex/elfparsey/exceptions.rb +0 -27
  19. data/lib/rex/elfscan.rb +0 -12
  20. data/lib/rex/elfscan/scanner.rb +0 -207
  21. data/lib/rex/elfscan/search.rb +0 -46
  22. data/lib/rex/encoder/alpha2.rb +0 -31
  23. data/lib/rex/encoder/alpha2/alpha_mixed.rb +0 -68
  24. data/lib/rex/encoder/alpha2/alpha_upper.rb +0 -79
  25. data/lib/rex/encoder/alpha2/generic.rb +0 -114
  26. data/lib/rex/encoder/alpha2/unicode_mixed.rb +0 -117
  27. data/lib/rex/encoder/alpha2/unicode_upper.rb +0 -129
  28. data/lib/rex/encoder/ndr.rb +0 -89
  29. data/lib/rex/encoder/ndr.rb.ut.rb +0 -44
  30. data/lib/rex/encoder/nonalpha.rb +0 -61
  31. data/lib/rex/encoder/nonupper.rb +0 -64
  32. data/lib/rex/encoder/xdr.rb +0 -106
  33. data/lib/rex/encoder/xdr.rb.ut.rb +0 -29
  34. data/lib/rex/encoder/xor.rb +0 -69
  35. data/lib/rex/encoder/xor/dword.rb +0 -13
  36. data/lib/rex/encoder/xor/dword_additive.rb +0 -13
  37. data/lib/rex/encoders/xor_dword.rb +0 -35
  38. data/lib/rex/encoders/xor_dword_additive.rb +0 -53
  39. data/lib/rex/encoders/xor_dword_additive.rb.ut.rb +0 -12
  40. data/lib/rex/encoding/xor.rb +0 -20
  41. data/lib/rex/encoding/xor.rb.ts.rb +0 -14
  42. data/lib/rex/encoding/xor/byte.rb +0 -15
  43. data/lib/rex/encoding/xor/byte.rb.ut.rb +0 -21
  44. data/lib/rex/encoding/xor/dword.rb +0 -21
  45. data/lib/rex/encoding/xor/dword.rb.ut.rb +0 -15
  46. data/lib/rex/encoding/xor/dword_additive.rb +0 -92
  47. data/lib/rex/encoding/xor/dword_additive.rb.ut.rb +0 -15
  48. data/lib/rex/encoding/xor/exceptions.rb +0 -17
  49. data/lib/rex/encoding/xor/generic.rb +0 -146
  50. data/lib/rex/encoding/xor/generic.rb.ut.rb +0 -120
  51. data/lib/rex/encoding/xor/qword.rb +0 -15
  52. data/lib/rex/encoding/xor/word.rb +0 -21
  53. data/lib/rex/encoding/xor/word.rb.ut.rb +0 -13
  54. data/lib/rex/exceptions.rb +0 -275
  55. data/lib/rex/exceptions.rb.ut.rb +0 -44
  56. data/lib/rex/exploitation/cmdstager.rb +0 -9
  57. data/lib/rex/exploitation/cmdstager/base.rb +0 -175
  58. data/lib/rex/exploitation/cmdstager/debug_asm.rb +0 -142
  59. data/lib/rex/exploitation/cmdstager/debug_write.rb +0 -136
  60. data/lib/rex/exploitation/cmdstager/tftp.rb +0 -63
  61. data/lib/rex/exploitation/cmdstager/vbs.rb +0 -128
  62. data/lib/rex/exploitation/egghunter.rb +0 -277
  63. data/lib/rex/exploitation/egghunter.rb.ut.rb +0 -25
  64. data/lib/rex/exploitation/encryptjs.rb +0 -77
  65. data/lib/rex/exploitation/heaplib.js.b64 +0 -331
  66. data/lib/rex/exploitation/heaplib.rb +0 -94
  67. data/lib/rex/exploitation/javascriptosdetect.rb +0 -897
  68. data/lib/rex/exploitation/obfuscatejs.rb +0 -335
  69. data/lib/rex/exploitation/omelet.rb +0 -320
  70. data/lib/rex/exploitation/omelet.rb.ut.rb +0 -13
  71. data/lib/rex/exploitation/opcodedb.rb +0 -818
  72. data/lib/rex/exploitation/opcodedb.rb.ut.rb +0 -279
  73. data/lib/rex/exploitation/seh.rb +0 -92
  74. data/lib/rex/exploitation/seh.rb.ut.rb +0 -19
  75. data/lib/rex/file.rb +0 -112
  76. data/lib/rex/file.rb.ut.rb +0 -16
  77. data/lib/rex/image_source.rb +0 -12
  78. data/lib/rex/image_source/disk.rb +0 -60
  79. data/lib/rex/image_source/image_source.rb +0 -46
  80. data/lib/rex/image_source/memory.rb +0 -37
  81. data/lib/rex/io/bidirectional_pipe.rb +0 -157
  82. data/lib/rex/io/datagram_abstraction.rb +0 -35
  83. data/lib/rex/io/stream.rb +0 -319
  84. data/lib/rex/io/stream_abstraction.rb +0 -197
  85. data/lib/rex/io/stream_server.rb +0 -211
  86. data/lib/rex/job_container.rb +0 -187
  87. data/lib/rex/logging.rb +0 -4
  88. data/lib/rex/logging/log_dispatcher.rb +0 -179
  89. data/lib/rex/logging/log_sink.rb +0 -42
  90. data/lib/rex/logging/sinks/flatfile.rb +0 -55
  91. data/lib/rex/logging/sinks/stderr.rb +0 -43
  92. data/lib/rex/machparsey.rb +0 -9
  93. data/lib/rex/machparsey/exceptions.rb +0 -34
  94. data/lib/rex/machparsey/mach.rb +0 -209
  95. data/lib/rex/machparsey/machbase.rb +0 -408
  96. data/lib/rex/machscan.rb +0 -9
  97. data/lib/rex/machscan/scanner.rb +0 -217
  98. data/lib/rex/mime.rb +0 -9
  99. data/lib/rex/mime/header.rb +0 -77
  100. data/lib/rex/mime/message.rb +0 -144
  101. data/lib/rex/mime/part.rb +0 -20
  102. data/lib/rex/nop/opty2.rb +0 -108
  103. data/lib/rex/nop/opty2.rb.ut.rb +0 -23
  104. data/lib/rex/nop/opty2_tables.rb +0 -300
  105. data/lib/rex/ole.rb +0 -205
  106. data/lib/rex/ole/clsid.rb +0 -47
  107. data/lib/rex/ole/difat.rb +0 -141
  108. data/lib/rex/ole/directory.rb +0 -231
  109. data/lib/rex/ole/direntry.rb +0 -240
  110. data/lib/rex/ole/docs/dependencies.txt +0 -8
  111. data/lib/rex/ole/docs/references.txt +0 -1
  112. data/lib/rex/ole/fat.rb +0 -99
  113. data/lib/rex/ole/header.rb +0 -204
  114. data/lib/rex/ole/minifat.rb +0 -77
  115. data/lib/rex/ole/propset.rb +0 -144
  116. data/lib/rex/ole/samples/create_ole.rb +0 -27
  117. data/lib/rex/ole/samples/dir.rb +0 -35
  118. data/lib/rex/ole/samples/dump_stream.rb +0 -34
  119. data/lib/rex/ole/samples/ole_info.rb +0 -23
  120. data/lib/rex/ole/storage.rb +0 -395
  121. data/lib/rex/ole/stream.rb +0 -53
  122. data/lib/rex/ole/substorage.rb +0 -49
  123. data/lib/rex/ole/util.rb +0 -157
  124. data/lib/rex/parser/arguments.rb +0 -97
  125. data/lib/rex/parser/arguments.rb.ut.rb +0 -67
  126. data/lib/rex/parser/ini.rb +0 -185
  127. data/lib/rex/parser/ini.rb.ut.rb +0 -29
  128. data/lib/rex/parser/ip360_aspl_xml.rb +0 -102
  129. data/lib/rex/parser/ip360_xml.rb +0 -93
  130. data/lib/rex/parser/nessus_xml.rb +0 -118
  131. data/lib/rex/parser/netsparker_xml.rb +0 -94
  132. data/lib/rex/parser/nexpose_xml.rb +0 -131
  133. data/lib/rex/parser/nmap_xml.rb +0 -121
  134. data/lib/rex/parser/retina_xml.rb +0 -109
  135. data/lib/rex/payloads.rb +0 -1
  136. data/lib/rex/payloads/win32.rb +0 -2
  137. data/lib/rex/payloads/win32/common.rb +0 -26
  138. data/lib/rex/payloads/win32/kernel.rb +0 -53
  139. data/lib/rex/payloads/win32/kernel/common.rb +0 -54
  140. data/lib/rex/payloads/win32/kernel/migration.rb +0 -12
  141. data/lib/rex/payloads/win32/kernel/recovery.rb +0 -50
  142. data/lib/rex/payloads/win32/kernel/stager.rb +0 -194
  143. data/lib/rex/peparsey.rb +0 -12
  144. data/lib/rex/peparsey/exceptions.rb +0 -32
  145. data/lib/rex/peparsey/pe.rb +0 -212
  146. data/lib/rex/peparsey/pe_memdump.rb +0 -63
  147. data/lib/rex/peparsey/pebase.rb +0 -1680
  148. data/lib/rex/peparsey/section.rb +0 -136
  149. data/lib/rex/pescan.rb +0 -13
  150. data/lib/rex/pescan/analyze.rb +0 -309
  151. data/lib/rex/pescan/scanner.rb +0 -206
  152. data/lib/rex/pescan/search.rb +0 -56
  153. data/lib/rex/platforms.rb +0 -1
  154. data/lib/rex/platforms/windows.rb +0 -51
  155. data/lib/rex/poly.rb +0 -132
  156. data/lib/rex/poly/block.rb +0 -477
  157. data/lib/rex/poly/register.rb +0 -100
  158. data/lib/rex/poly/register/x86.rb +0 -40
  159. data/lib/rex/post.rb +0 -8
  160. data/lib/rex/post/dir.rb +0 -51
  161. data/lib/rex/post/file.rb +0 -172
  162. data/lib/rex/post/file_stat.rb +0 -220
  163. data/lib/rex/post/gen.pl +0 -13
  164. data/lib/rex/post/io.rb +0 -182
  165. data/lib/rex/post/meterpreter.rb +0 -4
  166. data/lib/rex/post/meterpreter/channel.rb +0 -445
  167. data/lib/rex/post/meterpreter/channel_container.rb +0 -54
  168. data/lib/rex/post/meterpreter/channels/pool.rb +0 -160
  169. data/lib/rex/post/meterpreter/channels/pools/file.rb +0 -62
  170. data/lib/rex/post/meterpreter/channels/pools/stream_pool.rb +0 -103
  171. data/lib/rex/post/meterpreter/channels/stream.rb +0 -87
  172. data/lib/rex/post/meterpreter/client.rb +0 -364
  173. data/lib/rex/post/meterpreter/client_core.rb +0 -274
  174. data/lib/rex/post/meterpreter/dependencies.rb +0 -3
  175. data/lib/rex/post/meterpreter/extension.rb +0 -32
  176. data/lib/rex/post/meterpreter/extensions/espia/espia.rb +0 -58
  177. data/lib/rex/post/meterpreter/extensions/espia/tlv.rb +0 -16
  178. data/lib/rex/post/meterpreter/extensions/incognito/incognito.rb +0 -94
  179. data/lib/rex/post/meterpreter/extensions/incognito/tlv.rb +0 -21
  180. data/lib/rex/post/meterpreter/extensions/networkpug/networkpug.rb +0 -57
  181. data/lib/rex/post/meterpreter/extensions/networkpug/tlv.rb +0 -15
  182. data/lib/rex/post/meterpreter/extensions/priv/fs.rb +0 -118
  183. data/lib/rex/post/meterpreter/extensions/priv/passwd.rb +0 -61
  184. data/lib/rex/post/meterpreter/extensions/priv/priv.rb +0 -111
  185. data/lib/rex/post/meterpreter/extensions/priv/tlv.rb +0 -28
  186. data/lib/rex/post/meterpreter/extensions/sniffer/sniffer.rb +0 -101
  187. data/lib/rex/post/meterpreter/extensions/sniffer/tlv.rb +0 -26
  188. data/lib/rex/post/meterpreter/extensions/stdapi/constants.rb +0 -333
  189. data/lib/rex/post/meterpreter/extensions/stdapi/fs/dir.rb +0 -282
  190. data/lib/rex/post/meterpreter/extensions/stdapi/fs/file.rb +0 -266
  191. data/lib/rex/post/meterpreter/extensions/stdapi/fs/file_stat.rb +0 -103
  192. data/lib/rex/post/meterpreter/extensions/stdapi/fs/io.rb +0 -48
  193. data/lib/rex/post/meterpreter/extensions/stdapi/net/config.rb +0 -144
  194. data/lib/rex/post/meterpreter/extensions/stdapi/net/interface.rb +0 -73
  195. data/lib/rex/post/meterpreter/extensions/stdapi/net/route.rb +0 -56
  196. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket.rb +0 -137
  197. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/tcp_client_channel.rb +0 -180
  198. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/tcp_server_channel.rb +0 -167
  199. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/udp_channel.rb +0 -208
  200. data/lib/rex/post/meterpreter/extensions/stdapi/railgun.rb.ts.rb +0 -6
  201. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/api_constants.rb +0 -38106
  202. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/api_constants.rb.ut.rb +0 -31
  203. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/buffer_item.rb +0 -47
  204. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/buffer_item.rb.ut.rb +0 -36
  205. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_advapi32.rb +0 -1818
  206. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_iphlpapi.rb +0 -96
  207. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_kernel32.rb +0 -3848
  208. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_netapi32.rb +0 -26
  209. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_ntdll.rb +0 -153
  210. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_shell32.rb +0 -21
  211. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_user32.rb +0 -3169
  212. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_ws2_32.rb +0 -599
  213. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll.rb +0 -318
  214. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_function.rb +0 -100
  215. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_function.rb.ut.rb +0 -42
  216. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_helper.rb +0 -148
  217. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_helper.rb.ut.rb +0 -127
  218. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/multicall.rb +0 -309
  219. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/railgun.rb +0 -204
  220. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/tlv.rb +0 -51
  221. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/util.rb +0 -630
  222. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/win_const_manager.rb +0 -75
  223. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/win_const_manager.rb.ut.rb +0 -103
  224. data/lib/rex/post/meterpreter/extensions/stdapi/stdapi.rb +0 -149
  225. data/lib/rex/post/meterpreter/extensions/stdapi/sys/config.rb +0 -97
  226. data/lib/rex/post/meterpreter/extensions/stdapi/sys/event_log.rb +0 -192
  227. data/lib/rex/post/meterpreter/extensions/stdapi/sys/event_log_subsystem/event_record.rb +0 -41
  228. data/lib/rex/post/meterpreter/extensions/stdapi/sys/power.rb +0 -61
  229. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process.rb +0 -370
  230. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/image.rb +0 -129
  231. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/io.rb +0 -55
  232. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/memory.rb +0 -336
  233. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/thread.rb +0 -141
  234. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry.rb +0 -279
  235. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry_subsystem/registry_key.rb +0 -193
  236. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry_subsystem/registry_value.rb +0 -102
  237. data/lib/rex/post/meterpreter/extensions/stdapi/sys/thread.rb +0 -180
  238. data/lib/rex/post/meterpreter/extensions/stdapi/tlv.rb +0 -211
  239. data/lib/rex/post/meterpreter/extensions/stdapi/ui.rb +0 -227
  240. data/lib/rex/post/meterpreter/extensions/stdapi/webcam/webcam.rb +0 -63
  241. data/lib/rex/post/meterpreter/inbound_packet_handler.rb +0 -30
  242. data/lib/rex/post/meterpreter/object_aliases.rb +0 -83
  243. data/lib/rex/post/meterpreter/packet.rb +0 -688
  244. data/lib/rex/post/meterpreter/packet_dispatcher.rb +0 -431
  245. data/lib/rex/post/meterpreter/packet_parser.rb +0 -94
  246. data/lib/rex/post/meterpreter/packet_response_waiter.rb +0 -83
  247. data/lib/rex/post/meterpreter/ui/console.rb +0 -137
  248. data/lib/rex/post/meterpreter/ui/console/command_dispatcher.rb +0 -62
  249. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/core.rb +0 -730
  250. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/espia.rb +0 -108
  251. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/incognito.rb +0 -241
  252. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/networkpug.rb +0 -231
  253. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv.rb +0 -61
  254. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/elevate.rb +0 -98
  255. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/passwd.rb +0 -51
  256. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/timestomp.rb +0 -132
  257. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/sniffer.rb +0 -187
  258. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi.rb +0 -65
  259. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/fs.rb +0 -442
  260. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/net.rb +0 -298
  261. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/sys.rb +0 -486
  262. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/ui.rb +0 -315
  263. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/webcam.rb +0 -157
  264. data/lib/rex/post/meterpreter/ui/console/interactive_channel.rb +0 -95
  265. data/lib/rex/post/permission.rb +0 -26
  266. data/lib/rex/post/process.rb +0 -57
  267. data/lib/rex/post/thread.rb +0 -57
  268. data/lib/rex/post/ui.rb +0 -52
  269. data/lib/rex/proto.rb +0 -13
  270. data/lib/rex/proto.rb.ts.rb +0 -8
  271. data/lib/rex/proto/dcerpc.rb +0 -6
  272. data/lib/rex/proto/dcerpc.rb.ts.rb +0 -9
  273. data/lib/rex/proto/dcerpc/client.rb +0 -361
  274. data/lib/rex/proto/dcerpc/client.rb.ut.rb +0 -491
  275. data/lib/rex/proto/dcerpc/exceptions.rb +0 -150
  276. data/lib/rex/proto/dcerpc/handle.rb +0 -47
  277. data/lib/rex/proto/dcerpc/handle.rb.ut.rb +0 -85
  278. data/lib/rex/proto/dcerpc/ndr.rb +0 -72
  279. data/lib/rex/proto/dcerpc/ndr.rb.ut.rb +0 -41
  280. data/lib/rex/proto/dcerpc/packet.rb +0 -253
  281. data/lib/rex/proto/dcerpc/packet.rb.ut.rb +0 -56
  282. data/lib/rex/proto/dcerpc/response.rb +0 -187
  283. data/lib/rex/proto/dcerpc/response.rb.ut.rb +0 -15
  284. data/lib/rex/proto/dcerpc/uuid.rb +0 -84
  285. data/lib/rex/proto/dcerpc/uuid.rb.ut.rb +0 -46
  286. data/lib/rex/proto/dhcp.rb +0 -7
  287. data/lib/rex/proto/dhcp/constants.rb +0 -33
  288. data/lib/rex/proto/dhcp/server.rb +0 -292
  289. data/lib/rex/proto/drda.rb +0 -5
  290. data/lib/rex/proto/drda.rb.ts.rb +0 -17
  291. data/lib/rex/proto/drda/constants.rb +0 -49
  292. data/lib/rex/proto/drda/constants.rb.ut.rb +0 -23
  293. data/lib/rex/proto/drda/packet.rb +0 -252
  294. data/lib/rex/proto/drda/packet.rb.ut.rb +0 -109
  295. data/lib/rex/proto/drda/utils.rb +0 -123
  296. data/lib/rex/proto/drda/utils.rb.ut.rb +0 -84
  297. data/lib/rex/proto/http.rb +0 -5
  298. data/lib/rex/proto/http.rb.ts.rb +0 -12
  299. data/lib/rex/proto/http/client.rb +0 -821
  300. data/lib/rex/proto/http/client.rb.ut.rb +0 -95
  301. data/lib/rex/proto/http/handler.rb +0 -46
  302. data/lib/rex/proto/http/handler/erb.rb +0 -128
  303. data/lib/rex/proto/http/handler/erb.rb.ut.rb +0 -21
  304. data/lib/rex/proto/http/handler/erb.rb.ut.rb.rhtml +0 -1
  305. data/lib/rex/proto/http/handler/proc.rb +0 -60
  306. data/lib/rex/proto/http/handler/proc.rb.ut.rb +0 -24
  307. data/lib/rex/proto/http/header.rb +0 -161
  308. data/lib/rex/proto/http/header.rb.ut.rb +0 -46
  309. data/lib/rex/proto/http/packet.rb +0 -407
  310. data/lib/rex/proto/http/packet.rb.ut.rb +0 -165
  311. data/lib/rex/proto/http/request.rb +0 -356
  312. data/lib/rex/proto/http/request.rb.ut.rb +0 -214
  313. data/lib/rex/proto/http/response.rb +0 -90
  314. data/lib/rex/proto/http/response.rb.ut.rb +0 -149
  315. data/lib/rex/proto/http/server.rb +0 -369
  316. data/lib/rex/proto/http/server.rb.ut.rb +0 -79
  317. data/lib/rex/proto/ntlm.rb +0 -7
  318. data/lib/rex/proto/ntlm.rb.ut.rb +0 -177
  319. data/lib/rex/proto/ntlm/base.rb +0 -326
  320. data/lib/rex/proto/ntlm/constants.rb +0 -74
  321. data/lib/rex/proto/ntlm/crypt.rb +0 -415
  322. data/lib/rex/proto/ntlm/exceptions.rb +0 -9
  323. data/lib/rex/proto/ntlm/message.rb +0 -533
  324. data/lib/rex/proto/ntlm/utils.rb +0 -763
  325. data/lib/rex/proto/proxy/socks4a.rb +0 -440
  326. data/lib/rex/proto/rfb.rb +0 -19
  327. data/lib/rex/proto/rfb.rb.ut.rb +0 -37
  328. data/lib/rex/proto/rfb/cipher.rb +0 -84
  329. data/lib/rex/proto/rfb/client.rb +0 -207
  330. data/lib/rex/proto/rfb/constants.rb +0 -52
  331. data/lib/rex/proto/smb.rb +0 -7
  332. data/lib/rex/proto/smb.rb.ts.rb +0 -8
  333. data/lib/rex/proto/smb/client.rb +0 -1952
  334. data/lib/rex/proto/smb/client.rb.ut.rb +0 -223
  335. data/lib/rex/proto/smb/constants.rb +0 -1047
  336. data/lib/rex/proto/smb/constants.rb.ut.rb +0 -18
  337. data/lib/rex/proto/smb/crypt.rb +0 -36
  338. data/lib/rex/proto/smb/evasions.rb +0 -66
  339. data/lib/rex/proto/smb/exceptions.rb +0 -858
  340. data/lib/rex/proto/smb/simpleclient.rb +0 -306
  341. data/lib/rex/proto/smb/simpleclient.rb.ut.rb +0 -128
  342. data/lib/rex/proto/smb/utils.rb +0 -103
  343. data/lib/rex/proto/smb/utils.rb.ut.rb +0 -20
  344. data/lib/rex/proto/sunrpc.rb +0 -1
  345. data/lib/rex/proto/sunrpc/client.rb +0 -195
  346. data/lib/rex/proto/tftp.rb +0 -12
  347. data/lib/rex/proto/tftp/constants.rb +0 -39
  348. data/lib/rex/proto/tftp/server.rb +0 -497
  349. data/lib/rex/proto/tftp/server.rb.ut.rb +0 -28
  350. data/lib/rex/script.rb +0 -42
  351. data/lib/rex/script/base.rb +0 -59
  352. data/lib/rex/script/meterpreter.rb +0 -15
  353. data/lib/rex/script/shell.rb +0 -9
  354. data/lib/rex/service.rb +0 -48
  355. data/lib/rex/service_manager.rb +0 -141
  356. data/lib/rex/service_manager.rb.ut.rb +0 -32
  357. data/lib/rex/services/local_relay.rb +0 -423
  358. data/lib/rex/socket.rb +0 -684
  359. data/lib/rex/socket.rb.ut.rb +0 -107
  360. data/lib/rex/socket/comm.rb +0 -119
  361. data/lib/rex/socket/comm/local.rb +0 -412
  362. data/lib/rex/socket/comm/local.rb.ut.rb +0 -75
  363. data/lib/rex/socket/ip.rb +0 -130
  364. data/lib/rex/socket/parameters.rb +0 -345
  365. data/lib/rex/socket/parameters.rb.ut.rb +0 -51
  366. data/lib/rex/socket/range_walker.rb +0 -346
  367. data/lib/rex/socket/range_walker.rb.ut.rb +0 -55
  368. data/lib/rex/socket/ssl_tcp.rb +0 -184
  369. data/lib/rex/socket/ssl_tcp.rb.ut.rb +0 -39
  370. data/lib/rex/socket/ssl_tcp_server.rb +0 -122
  371. data/lib/rex/socket/ssl_tcp_server.rb.ut.rb +0 -61
  372. data/lib/rex/socket/subnet_walker.rb +0 -75
  373. data/lib/rex/socket/subnet_walker.rb.ut.rb +0 -28
  374. data/lib/rex/socket/switch_board.rb +0 -278
  375. data/lib/rex/socket/switch_board.rb.ut.rb +0 -52
  376. data/lib/rex/socket/tcp.rb +0 -76
  377. data/lib/rex/socket/tcp.rb.ut.rb +0 -64
  378. data/lib/rex/socket/tcp_server.rb +0 -67
  379. data/lib/rex/socket/tcp_server.rb.ut.rb +0 -44
  380. data/lib/rex/socket/udp.rb +0 -164
  381. data/lib/rex/socket/udp.rb.ut.rb +0 -44
  382. data/lib/rex/struct2.rb +0 -5
  383. data/lib/rex/struct2/c_struct.rb +0 -181
  384. data/lib/rex/struct2/c_struct_template.rb +0 -39
  385. data/lib/rex/struct2/constant.rb +0 -26
  386. data/lib/rex/struct2/element.rb +0 -44
  387. data/lib/rex/struct2/generic.rb +0 -73
  388. data/lib/rex/struct2/restraint.rb +0 -54
  389. data/lib/rex/struct2/s_string.rb +0 -72
  390. data/lib/rex/struct2/s_struct.rb +0 -111
  391. data/lib/rex/sync.rb +0 -6
  392. data/lib/rex/sync/event.rb +0 -94
  393. data/lib/rex/sync/read_write_lock.rb +0 -176
  394. data/lib/rex/sync/ref.rb +0 -57
  395. data/lib/rex/sync/thread_safe.rb +0 -82
  396. data/lib/rex/test.rb +0 -35
  397. data/lib/rex/text.rb +0 -1149
  398. data/lib/rex/text.rb.ut.rb +0 -190
  399. data/lib/rex/thread_factory.rb +0 -42
  400. data/lib/rex/time.rb +0 -65
  401. data/lib/rex/transformer.rb +0 -115
  402. data/lib/rex/transformer.rb.ut.rb +0 -38
  403. data/lib/rex/ui.rb +0 -21
  404. data/lib/rex/ui/interactive.rb +0 -254
  405. data/lib/rex/ui/output.rb +0 -78
  406. data/lib/rex/ui/output/none.rb +0 -18
  407. data/lib/rex/ui/progress_tracker.rb +0 -96
  408. data/lib/rex/ui/subscriber.rb +0 -149
  409. data/lib/rex/ui/text/color.rb +0 -97
  410. data/lib/rex/ui/text/color.rb.ut.rb +0 -18
  411. data/lib/rex/ui/text/dispatcher_shell.rb +0 -467
  412. data/lib/rex/ui/text/input.rb +0 -117
  413. data/lib/rex/ui/text/input/buffer.rb +0 -75
  414. data/lib/rex/ui/text/input/readline.rb +0 -129
  415. data/lib/rex/ui/text/input/socket.rb +0 -95
  416. data/lib/rex/ui/text/input/stdio.rb +0 -45
  417. data/lib/rex/ui/text/irb_shell.rb +0 -57
  418. data/lib/rex/ui/text/output.rb +0 -80
  419. data/lib/rex/ui/text/output/buffer.rb +0 -61
  420. data/lib/rex/ui/text/output/file.rb +0 -43
  421. data/lib/rex/ui/text/output/socket.rb +0 -43
  422. data/lib/rex/ui/text/output/stdio.rb +0 -40
  423. data/lib/rex/ui/text/progress_tracker.rb +0 -56
  424. data/lib/rex/ui/text/progress_tracker.rb.ut.rb +0 -34
  425. data/lib/rex/ui/text/shell.rb +0 -328
  426. data/lib/rex/ui/text/table.rb +0 -279
  427. data/lib/rex/ui/text/table.rb.ut.rb +0 -55
  428. data/lib/rex/zip.rb +0 -93
  429. data/lib/rex/zip/archive.rb +0 -184
  430. data/lib/rex/zip/blocks.rb +0 -182
  431. data/lib/rex/zip/entry.rb +0 -104
  432. data/lib/rex/zip/samples/comment.rb +0 -32
  433. data/lib/rex/zip/samples/mkwar.rb +0 -138
  434. data/lib/rex/zip/samples/mkzip.rb +0 -19
  435. data/lib/rex/zip/samples/recursive.rb +0 -58
@@ -1,408 +0,0 @@
1
- #!/usr/bin/env ruby
2
-
3
- require 'rex/struct2'
4
-
5
- module Rex
6
- module MachParsey
7
-
8
- require 'rex/machparsey/exceptions'
9
- require 'rex/struct2'
10
-
11
- class GenericStruct
12
- attr_accessor :struct
13
- def initialize(_struct)
14
- self.struct = _struct
15
- end
16
-
17
- # Access a value
18
- def v
19
- struct.v
20
- end
21
-
22
- # Access a value by array
23
- def [](*args)
24
- struct[*args]
25
- end
26
-
27
- # Obtain an array of all fields
28
- def keys
29
- struct.keys
30
- end
31
-
32
- def method_missing(meth, *args)
33
- v[meth.to_s] || (raise NoMethodError.new, meth)
34
- end
35
- end
36
-
37
- class GenericHeader < GenericStruct
38
- end
39
-
40
- BITS_32 = 0
41
- BITS_64 = 1
42
- ENDIAN_LSB = 0
43
- ENDIAN_MSB = 1
44
-
45
- class MachBase
46
-
47
- MH_MAGIC = 0xfeedface
48
- MH_MAGIC_64 = 0xfeedfacf
49
- MH_CIGAM = 0xcefaedfe
50
- MH_CIGAM_64 = 0xcffaedfe
51
- MACH_HEADER_SIZE = 28
52
- MACH_HEADER_SIZE_64 = 32
53
-
54
-
55
- MACH_HEADER_LSB = Rex::Struct2::CStructTemplate.new(
56
- ['uint32v', 'magic', 0],
57
- ['uint32v', 'cputype', 0],
58
- ['uint32v', 'cpusubtype',0],
59
- ['uint32v', 'filetype', 0],
60
- ['uint32v', 'ncmds', 0],
61
- ['uint32v', 'sizeofcmds',0],
62
- ['uint32v', 'flags', 0]
63
- )
64
-
65
- MACH_HEADER_MSB = Rex::Struct2::CStructTemplate.new(
66
- ['uint32n', 'magic', 0],
67
- ['uint32n', 'cputype', 0],
68
- ['uint32n', 'cpusubtype',0],
69
- ['uint32n', 'filetype', 0],
70
- ['uint32n', 'ncmds', 0],
71
- ['uint32n', 'sizeofcmds',0],
72
- ['uint32n', 'flags', 0]
73
- )
74
-
75
-
76
- MACH_HEADER_64_LSB = Rex::Struct2::CStructTemplate.new(
77
- ['uint32v', 'magic', 0],
78
- ['uint32v', 'cputype', 0],
79
- ['uint32v', 'cpusubtype',0],
80
- ['uint32v', 'filetype', 0],
81
- ['uint32v', 'ncmds', 0],
82
- ['uint32v', 'sizeofcmds',0],
83
- ['uint32v', 'flags', 0],
84
- ['uint32v', 'reserved', 0]
85
- )
86
-
87
- MACH_HEADER_64_MSB = Rex::Struct2::CStructTemplate.new(
88
- ['uint32n', 'magic', 0],
89
- ['uint32n', 'cputype', 0],
90
- ['uint32n', 'cpusubtype',0],
91
- ['uint32n', 'filetype', 0],
92
- ['uint32n', 'ncmds', 0],
93
- ['uint32n', 'sizeofcmds',0],
94
- ['uint32n', 'flags', 0],
95
- ['uint32n', 'reserved', 0]
96
- )
97
-
98
- #cpu types for Mach-O binaries
99
- CPU_TYPE_I386 = 0x7
100
- CPU_TYPE_X86_64 = 0x01000007
101
- CPU_TYPE_ARM = 0xC
102
- CPU_TYPE_POWERPC = 0x12
103
- CPU_TYPE_POWERPC64 = 0x01000012
104
-
105
- CPU_SUBTYPE_LITTLE_ENDIAN = 0
106
- CPU_SUBTYPE_BIG_ENDIAN = 1
107
-
108
- LC_SEGMENT = 0x1 #/* segment of this file to be mapped */
109
- LC_SYMTAB = 0x2 #/* link-edit stab symbol table info */
110
- LC_SYMSEG = 0x3 #/* link-edit gdb symbol table info (obsolete) */
111
- LC_THREAD = 0x4 #/* thread */
112
- LC_UNIXTHREAD = 0x5 #/* unix thread (includes a stack) */
113
- LC_LOADFVMLIB = 0x6 #/* load a specified fixed VM shared library */
114
- LC_IDFVMLIB = 0x7 #/* fixed VM shared library identification */
115
- LC_IDENT = 0x8 #/* object identification info (obsolete) */
116
- LC_FVMFILE = 0x9 #/* fixed VM file inclusion (internal use) */
117
- LC_PREPAGE = 0xa #/* prepage command (internal use) */
118
- LC_DYSYMTAB = 0xb #/* dynamic link-edit symbol table info */
119
- LC_LOAD_DYLIB = 0xc #/* load a dynamicly linked shared library */
120
- LC_ID_DYLIB = 0xd #/* dynamicly linked shared lib identification */
121
- LC_LOAD_DYLINKER = 0xe #/* load a dynamic linker */
122
- LC_ID_DYLINKER = 0xf #/* dynamic linker identification */
123
- LC_PREBOUND_DYLIB = 0x10 #/* modules prebound for a dynamicly */
124
- LC_SEGMENT_64 = 0x19 #/* segment of this file to be mapped */
125
-
126
-
127
-
128
-
129
- class MachHeader < GenericHeader
130
- attr_accessor :bits, :endian
131
-
132
- def initialize(rawdata)
133
- mach_header = MACH_HEADER_LSB.make_struct
134
- if !mach_header.from_s(rawdata)
135
- raise MachHeaderError, "Could't access Mach-O Magic", caller
136
- end
137
-
138
- if mach_header.v['magic'] == MH_MAGIC
139
- endian = ENDIAN_LSB
140
- bits = BITS_32
141
- mach_header = MACH_HEADER_LSB.make_struct
142
- elsif mach_header.v['magic'] == MH_CIGAM
143
- bits = BITS_32
144
- endian = ENDIAN_MSB
145
- mach_header = MACH_HEADER_MSB.make_struct
146
- elsif mach_header.v['magic'] == MH_MAGIC_64
147
- endian = ENDIAN_LSB
148
- bits = BITS_64
149
- mach_header = MACH_HEADER_LSB.make_struct
150
- elsif mach_header.v['magic'] == MH_CIGAM_64
151
- endian = ENDIAN_MSB
152
- bits = BITS_64
153
- mach_header = MACH_HEADER_MSB.make_struct
154
- else
155
- raise MachHeaderError, "Couldn't find Mach Magic", caller
156
- end
157
-
158
- if !mach_header.from_s(rawdata)
159
- raise MachHeaderError, "Could't process Mach-O Header", caller
160
- end
161
-
162
- self.struct = mach_header
163
- self.endian = endian
164
- self.bits = bits
165
- end
166
- end
167
-
168
- LOAD_COMMAND_SIZE = 8
169
-
170
- LOAD_COMMAND_LSB = Rex::Struct2::CStructTemplate.new(
171
- ['uint32v','cmd',0],
172
- ['uint32v','cmdsize',0]
173
- )
174
-
175
- LOAD_COMMAND_MSB = Rex::Struct2::CStructTemplate.new(
176
- ['uint32n','cmd',0],
177
- ['uint32n','cmdsize',0]
178
- )
179
-
180
- class LoadCommand < GenericHeader
181
- def initialize(rawdata, endian)
182
-
183
- if endian == ENDIAN_MSB
184
- load_command = LOAD_COMMAND_MSB.make_struct
185
- else
186
- load_command = LOAD_COMMAND_LSB.make_struct
187
- end
188
-
189
- if !load_command.from_s(rawdata)
190
- raise MachParseError, "Couldn't parse load command"
191
- end
192
-
193
- self.struct = load_command
194
-
195
- end
196
- end
197
-
198
- SEGMENT_COMMAND_SIZE = 56
199
-
200
- SEGMENT_COMMAND_LSB = Rex::Struct2::CStructTemplate.new(
201
- ['uint32v', 'cmd', 0],
202
- ['uint32v', 'cmdsize', 0],
203
- ['string', 'segname', 16, ''],
204
- ['uint32v', 'vmaddr', 0],
205
- ['uint32v', 'vmsize', 0],
206
- ['uint32v', 'fileoff', 0],
207
- ['uint32v', 'filesize', 0],
208
- ['uint32v', 'maxprot', 0],
209
- ['uint32v', 'initprot', 0],
210
- ['uint32v', 'nsects', 0],
211
- ['uint32v', 'flags', 0]
212
- )
213
-
214
- SEGMENT_COMMAND_MSB = Rex::Struct2::CStructTemplate.new(
215
- ['uint32n', 'cmd', 0],
216
- ['uint32n', 'cmdsize', 0],
217
- ['string', 'segname', 16, ''],
218
- ['uint32n', 'vmaddr', 0],
219
- ['uint32n', 'vmsize', 0],
220
- ['uint32n', 'fileoff', 0],
221
- ['uint32n', 'filesize', 0],
222
- ['uint32n', 'maxprot', 0],
223
- ['uint32n', 'initprot', 0],
224
- ['uint32n', 'nsects', 0],
225
- ['uint32n', 'flags', 0]
226
- )
227
-
228
- SEGMENT_COMMAND_SIZE_64 = 72
229
-
230
- SEGMENT_COMMAND_64_LSB = Rex::Struct2::CStructTemplate.new(
231
- ['uint32v', 'cmd', 0],
232
- ['uint32v', 'cmdsize', 0],
233
- ['string', 'segname', 16, ''],
234
- ['uint64v', 'vmaddr', 0],
235
- ['uint64v', 'vmsize', 0],
236
- ['uint64v', 'fileoff', 0],
237
- ['uint64v', 'filesize', 0],
238
- ['uint32v', 'maxprot', 0],
239
- ['uint32v', 'initprot', 0],
240
- ['uint32v', 'nsects', 0],
241
- ['uint32v', 'flags', 0]
242
- )
243
-
244
- SEGMENT_COMMAND_64_MSB = Rex::Struct2::CStructTemplate.new(
245
- ['uint32n', 'cmd', 0],
246
- ['uint32n', 'cmdsize', 0],
247
- ['string', 'segname', 16, ''],
248
- ['uint64n', 'vmaddr', 0],
249
- ['uint64n', 'vmsize', 0],
250
- ['uint64n', 'fileoff', 0],
251
- ['uint64n', 'filesize', 0],
252
- ['uint32n', 'maxprot', 0],
253
- ['uint32n', 'initprot', 0],
254
- ['uint32n', 'nsects', 0],
255
- ['uint32n', 'flags', 0]
256
- )
257
-
258
- class Segment < GenericHeader
259
- attr_accessor :_bits, :_endian
260
-
261
- def initialize(rawdata, bits, endian)
262
- self._bits = bits
263
-
264
- if bits == BITS_64
265
- if endian == ENDIAN_MSB
266
- segment_command = SEGMENT_COMMAND_64_MSB.make_struct
267
- else
268
- segment_command = SEGMENT_COMMAND_64_LSB.make_struct
269
- end
270
- else
271
- if endian == ENDIAN_MSB
272
- segment_command = SEGMENT_COMMAND_MSB.make_struct
273
- else
274
- segment_command = SEGMENT_COMMAND_LSB.make_struct
275
- end
276
- end
277
- if !segment_command.from_s(rawdata)
278
- raise MachParseError, "Couldn't parse segment command"
279
- end
280
-
281
- self.struct = segment_command
282
- end
283
-
284
- def Segname
285
- v['segname']
286
- end
287
-
288
- def Vmaddr
289
- v['vmaddr']
290
- end
291
-
292
- def Vmsize
293
- v['vmsize']
294
- end
295
-
296
- def FileOff
297
- v['fileoff']
298
- end
299
-
300
- def FileSize
301
- v['filesize']
302
- end
303
- end
304
-
305
- class Thread < GenericHeader
306
- def initialize(rawdata)
307
- end
308
- end
309
- end
310
-
311
- FAT_MAGIC = 0xcafebabe
312
- FAT_CIGAM = 0xbebafeca
313
- FAT_HEADER_SIZE = 8
314
-
315
- FAT_HEADER_LSB = Rex::Struct2::CStructTemplate.new(
316
- ['uint32v', 'magic', 0],
317
- ['uint32v', 'nfat_arch',0]
318
- )
319
-
320
- FAT_HEADER_MSB = Rex::Struct2::CStructTemplate.new(
321
- ['uint32n', 'magic', 0],
322
- ['uint32n', 'nfat_arch',0]
323
- )
324
-
325
-
326
- FAT_ARCH_SIZE = 20
327
-
328
- FAT_ARCH_LSB = Rex::Struct2::CStructTemplate.new(
329
- ['uint32v', 'cpu_type', 0],
330
- ['uint32v', 'cpu_subtype',0],
331
- ['uint32v', 'offset', 0],
332
- ['uint32v', 'size', 0],
333
- ['uint32v', 'align', 0]
334
- )
335
-
336
- FAT_ARCH_MSB = Rex::Struct2::CStructTemplate.new(
337
- ['uint32n', 'cpu_type', 0],
338
- ['uint32n', 'cpu_subtype',0],
339
- ['uint32n', 'offset', 0],
340
- ['uint32n', 'size', 0],
341
- ['uint32n', 'align', 0]
342
- )
343
-
344
-
345
- class FatBase
346
-
347
- class FatHeader < GenericHeader
348
- attr_accessor :nfat_arch, :endian, :exists
349
-
350
- def initialize(rawdata)
351
- fat_header = FAT_HEADER_LSB.make_struct
352
- if !fat_header.from_s(rawdata)
353
- #raise something
354
- end
355
-
356
- magic = fat_header.v['magic']
357
- if magic == FAT_MAGIC
358
- endian = ENDIAN_LSB
359
- elsif magic == FAT_CIGAM
360
- endian = ENDIAN_MSB
361
- fat_header = FAT_HEADER_MSB.make_struct
362
- if !fat_header.from_s(rawdata)
363
- raise FatHeaderError, "Could not parse FAT header"
364
- end
365
- else
366
- self.exists = 0
367
- return
368
- end
369
-
370
- self.nfat_arch = fat_header.v['nfat_arch']
371
- self.struct = fat_header
372
- self.endian = endian
373
- end
374
- end
375
-
376
- class FatArch < GenericHeader
377
- attr_accessor :cpu_type, :cpu_subtype, :offset, :size
378
-
379
- def initialize(rawdata, endian)
380
- if endian == ENDIAN_LSB
381
- fat_arch = FAT_ARCH_LSB.make_struct
382
- else
383
- fat_arch = FAT_ARCH_MSB.make_struct
384
- end
385
-
386
- if !fat_arch.from_s(rawdata)
387
- raise FatHeaderError, "Could not parse arch from FAT header"
388
- end
389
-
390
- self.cpu_type = fat_arch.v['cpu_type']
391
- self.cpu_subtype = fat_arch.v['cpu_subtype']
392
- self.offset = fat_arch.v['offset']
393
- self.size = fat_arch.v['size']
394
- self.struct = fat_arch
395
- end
396
-
397
- end
398
-
399
- class Thread < GenericHeader
400
- def initialize(rawdata)
401
- end
402
- end
403
-
404
-
405
- end
406
-
407
- end
408
- end
data/lib/rex/machscan.rb DELETED
@@ -1,9 +0,0 @@
1
- #!/usr/bin/env ruby
2
-
3
- module Rex
4
- module MachScan
5
-
6
- end
7
- end
8
-
9
- require 'rex/machscan/scanner'
@@ -1,217 +0,0 @@
1
- #!/usr/bin/env ruby
2
-
3
- module Rex
4
- module MachScan
5
- module Scanner
6
- class Generic
7
-
8
- attr_accessor :mach, :fat, :regex
9
-
10
- def initialize(binary)
11
- if binary.class == Rex::MachParsey::Mach
12
- self.mach = binary
13
- else
14
- self.fat = binary
15
- end
16
- end
17
-
18
- def config(param)
19
- end
20
-
21
- def scan(param)
22
- config(param)
23
-
24
- $stdout.puts "[#{param['file']}]"
25
-
26
- if !self.mach
27
- for mach in fat.machos
28
- if mach.mach_header.cputype == 0x7 #since we only support intel for the time being its all we process
29
- self.mach = mach
30
- end
31
- end
32
- end
33
-
34
- self.mach.segments.each do |segment|
35
- if segment.segname.include? "__TEXT"
36
- scan_segment(segment, param).each do |hit|
37
- vaddr = hit[0]
38
- message = hit[1].is_a?(Array) ? hit[1].join(" ") : hit[1]
39
- $stdout.puts self.mach.ptr_s(vaddr - self.mach.fat_offset) + " " + message
40
- end
41
- end
42
- end
43
-
44
- end
45
-
46
- def scan_segment(segment, param={})
47
- []
48
- end
49
- end
50
-
51
- class JmpRegScanner < Generic
52
-
53
- def config(param)
54
- regnums = param['args']
55
-
56
- # build a list of the call bytes
57
- calls = _build_byte_list(0xd0, regnums - [4]) # note call esp's don't work..
58
- jmps = _build_byte_list(0xe0, regnums)
59
- pushs1 = _build_byte_list(0x50, regnums)
60
- pushs2 = _build_byte_list(0xf0, regnums)
61
-
62
- regexstr = '('
63
- if !calls.empty?
64
- regexstr += "\xff[#{calls}]|"
65
- end
66
-
67
- regexstr += "\xff[#{jmps}]|([#{pushs1}]|\xff[#{pushs2}])(\xc3|\xc2..))"
68
-
69
- self.regex = Regexp.new(regexstr, nil, 'n')
70
- end
71
-
72
- # build a list for regex of the possible bytes, based on a base
73
- # byte and a list of register numbers..
74
- def _build_byte_list(base, regnums)
75
- regnums.collect { |regnum| Regexp.escape((base | regnum).chr) }.join('')
76
- end
77
-
78
- def _ret_size(offset)
79
- case mach.read(offset, 1)
80
- when "\xc3"
81
- return 1
82
- when "\xc2"
83
- return 3
84
- end
85
- $stderr.puts("Invalid return instruction")
86
- end
87
-
88
- def _parse_ret(data)
89
- if data.length == 1
90
- return "ret"
91
- else
92
- return "retn 0x%04x" % data[1, 2].unpack('v')[0]
93
- end
94
- end
95
-
96
- def scan_segment(segment, param={})
97
- base_addr = segment.vmaddr
98
- segment_offset = segment.fileoff
99
- offset = segment_offset
100
-
101
- hits = []
102
-
103
- while (offset = mach.index(regex, offset)) != nil
104
-
105
- vaddr = base_addr + (offset - segment_offset)
106
- message = ''
107
-
108
- parse_ret = false
109
-
110
- byte1 = mach.read(offset, 1).unpack("C*")[0]
111
-
112
- if byte1 == 0xff
113
- byte2 = mach.read(offset+1, 1).unpack("C*")[0]
114
- regname = Rex::Arch::X86.reg_name32(byte2 & 0x7)
115
-
116
- case byte2 & 0xf8
117
- when 0xd0
118
- message = "call #{regname}"
119
- offset += 2
120
- when 0xe0
121
- message = "jmp #{regname}"
122
- offset += 2
123
- when 0xf0
124
- retsize = _ret_size(offset+2)
125
- message = "push #{regname}; " + _parse_ret(mach.read(offset+2, retsize))
126
- offset += 2 + retsize
127
- else
128
- raise "wtf"
129
- end
130
- else
131
- regname = Rex::Arch::X86.reg_name32(byte1 & 0x7)
132
- retsize = _ret_size(offset+1)
133
- message = "push #{regname}; " + _parse_ret(mach.read(offset+1, retsize))
134
- offset += 1 + retsize
135
- end
136
-
137
- hits << [ vaddr, message ]
138
- end
139
-
140
- return hits
141
- end
142
- end
143
-
144
- class PopPopRetScanner < JmpRegScanner
145
-
146
- def config(param)
147
- pops = _build_byte_list(0x58, (0 .. 7).to_a - [4]) # we don't want pop esp's...
148
- self.regex = Regexp.new("[#{pops}][#{pops}](\xc3|\xc2..)", nil, 'n')
149
- end
150
-
151
- def scan_segment(segment, param={})
152
- base_addr = segment.vmaddr
153
- segment_offset = segment.fileoff
154
- offset = segment_offset
155
-
156
- hits = []
157
-
158
- while offset < segment.fileoff + segment.filesize && (offset = mach.index(regex, offset)) != nil
159
-
160
- vaddr = base_addr + (offset - segment_offset)
161
- message = ''
162
-
163
- pops = mach.read(offset, 2)
164
- reg1 = Rex::Arch::X86.reg_name32(pops[0,1].unpack("C*")[0] & 0x7)
165
- reg2 = Rex::Arch::X86.reg_name32(pops[1,1].unpack("C*")[0] & 0x7)
166
-
167
- message = "pop #{reg1}; pop #{reg2}; "
168
-
169
- retsize = _ret_size(offset+2)
170
- message += _parse_ret(mach.read(offset+2, retsize))
171
-
172
- offset += 2 + retsize
173
-
174
- hits << [ vaddr, message ]
175
- end
176
-
177
- return hits
178
- end
179
- end
180
-
181
- class RegexScanner < JmpRegScanner
182
-
183
- def config(param)
184
- self.regex = Regexp.new(param['args'], nil, 'n')
185
- end
186
-
187
- def scan_segment(segment, param={})
188
- base_addr = segment.vmaddr
189
- segment_offset = segment.fileoff
190
- offset = segment_offset
191
-
192
- hits = []
193
-
194
- while offset < segment.fileoff + segment.filesize && (offset = mach.index(regex, offset)) != nil
195
-
196
- idx = offset
197
- buf = ''
198
- mat = nil
199
-
200
- while (! (mat = buf.match(regex)))
201
- buf << mach.read(idx, 1)
202
- idx += 1
203
- end
204
-
205
- vaddr = base_addr + (offset - segment_offset)
206
-
207
- hits << [ vaddr, buf.unpack("H*") ]
208
- offset += buf.length
209
- end
210
- return hits
211
- end
212
- end
213
-
214
- end
215
- end
216
- end
217
-