librex 0.0.19 → 0.0.20

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/Rakefile +0 -1
  2. metadata +1 -434
  3. data/lib/rex/LICENSE +0 -29
  4. data/lib/rex/arch.rb +0 -103
  5. data/lib/rex/arch/sparc.rb +0 -75
  6. data/lib/rex/arch/sparc.rb.ut.rb +0 -18
  7. data/lib/rex/arch/x86.rb +0 -513
  8. data/lib/rex/arch/x86.rb.ut.rb +0 -93
  9. data/lib/rex/assembly/nasm.rb +0 -104
  10. data/lib/rex/assembly/nasm.rb.ut.rb +0 -22
  11. data/lib/rex/codepage.map +0 -104
  12. data/lib/rex/compat.rb +0 -311
  13. data/lib/rex/constants.rb +0 -113
  14. data/lib/rex/elfparsey.rb +0 -11
  15. data/lib/rex/elfparsey/elf.rb +0 -123
  16. data/lib/rex/elfparsey/elfbase.rb +0 -258
  17. data/lib/rex/elfparsey/exceptions.rb +0 -27
  18. data/lib/rex/elfscan.rb +0 -12
  19. data/lib/rex/elfscan/scanner.rb +0 -207
  20. data/lib/rex/elfscan/search.rb +0 -46
  21. data/lib/rex/encoder/alpha2.rb +0 -31
  22. data/lib/rex/encoder/alpha2/alpha_mixed.rb +0 -68
  23. data/lib/rex/encoder/alpha2/alpha_upper.rb +0 -79
  24. data/lib/rex/encoder/alpha2/generic.rb +0 -114
  25. data/lib/rex/encoder/alpha2/unicode_mixed.rb +0 -117
  26. data/lib/rex/encoder/alpha2/unicode_upper.rb +0 -129
  27. data/lib/rex/encoder/ndr.rb +0 -89
  28. data/lib/rex/encoder/ndr.rb.ut.rb +0 -44
  29. data/lib/rex/encoder/nonalpha.rb +0 -61
  30. data/lib/rex/encoder/nonupper.rb +0 -64
  31. data/lib/rex/encoder/xdr.rb +0 -106
  32. data/lib/rex/encoder/xdr.rb.ut.rb +0 -29
  33. data/lib/rex/encoder/xor.rb +0 -69
  34. data/lib/rex/encoder/xor/dword.rb +0 -13
  35. data/lib/rex/encoder/xor/dword_additive.rb +0 -13
  36. data/lib/rex/encoders/xor_dword.rb +0 -35
  37. data/lib/rex/encoders/xor_dword_additive.rb +0 -53
  38. data/lib/rex/encoders/xor_dword_additive.rb.ut.rb +0 -12
  39. data/lib/rex/encoding/xor.rb +0 -20
  40. data/lib/rex/encoding/xor.rb.ts.rb +0 -14
  41. data/lib/rex/encoding/xor/byte.rb +0 -15
  42. data/lib/rex/encoding/xor/byte.rb.ut.rb +0 -21
  43. data/lib/rex/encoding/xor/dword.rb +0 -21
  44. data/lib/rex/encoding/xor/dword.rb.ut.rb +0 -15
  45. data/lib/rex/encoding/xor/dword_additive.rb +0 -92
  46. data/lib/rex/encoding/xor/dword_additive.rb.ut.rb +0 -15
  47. data/lib/rex/encoding/xor/exceptions.rb +0 -17
  48. data/lib/rex/encoding/xor/generic.rb +0 -146
  49. data/lib/rex/encoding/xor/generic.rb.ut.rb +0 -120
  50. data/lib/rex/encoding/xor/qword.rb +0 -15
  51. data/lib/rex/encoding/xor/word.rb +0 -21
  52. data/lib/rex/encoding/xor/word.rb.ut.rb +0 -13
  53. data/lib/rex/exceptions.rb +0 -275
  54. data/lib/rex/exceptions.rb.ut.rb +0 -44
  55. data/lib/rex/exploitation/cmdstager.rb +0 -9
  56. data/lib/rex/exploitation/cmdstager/base.rb +0 -175
  57. data/lib/rex/exploitation/cmdstager/debug_asm.rb +0 -142
  58. data/lib/rex/exploitation/cmdstager/debug_write.rb +0 -136
  59. data/lib/rex/exploitation/cmdstager/tftp.rb +0 -63
  60. data/lib/rex/exploitation/cmdstager/vbs.rb +0 -128
  61. data/lib/rex/exploitation/egghunter.rb +0 -277
  62. data/lib/rex/exploitation/egghunter.rb.ut.rb +0 -25
  63. data/lib/rex/exploitation/encryptjs.rb +0 -77
  64. data/lib/rex/exploitation/heaplib.js.b64 +0 -331
  65. data/lib/rex/exploitation/heaplib.rb +0 -94
  66. data/lib/rex/exploitation/javascriptosdetect.rb +0 -897
  67. data/lib/rex/exploitation/obfuscatejs.rb +0 -335
  68. data/lib/rex/exploitation/omelet.rb +0 -320
  69. data/lib/rex/exploitation/omelet.rb.ut.rb +0 -13
  70. data/lib/rex/exploitation/opcodedb.rb +0 -818
  71. data/lib/rex/exploitation/opcodedb.rb.ut.rb +0 -279
  72. data/lib/rex/exploitation/seh.rb +0 -92
  73. data/lib/rex/exploitation/seh.rb.ut.rb +0 -19
  74. data/lib/rex/file.rb +0 -112
  75. data/lib/rex/file.rb.ut.rb +0 -16
  76. data/lib/rex/image_source.rb +0 -12
  77. data/lib/rex/image_source/disk.rb +0 -60
  78. data/lib/rex/image_source/image_source.rb +0 -46
  79. data/lib/rex/image_source/memory.rb +0 -37
  80. data/lib/rex/io/bidirectional_pipe.rb +0 -157
  81. data/lib/rex/io/datagram_abstraction.rb +0 -35
  82. data/lib/rex/io/ring_buffer.rb +0 -364
  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 -97
  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 -136
  133. data/lib/rex/parser/nmap_xml.rb +0 -137
  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 -16
  323. data/lib/rex/proto/ntlm/message.rb +0 -536
  324. data/lib/rex/proto/ntlm/utils.rb +0 -764
  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 -66
  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 -1163
  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 -298
  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,42 +0,0 @@
1
- require 'rex/constants'
2
-
3
- module Rex
4
- module Logging
5
-
6
- ###
7
- #
8
- # This abstract interface is what must be implemented by any class
9
- # that would like to register as a log sink on a given LogDispatcher
10
- # instance, such as the Framework object.
11
- #
12
- ###
13
- module LogSink
14
-
15
- def cleanup
16
- end
17
-
18
- #
19
- # This method must be implemented by any derived log sink classes and is
20
- # intended to take the supplied parameters and persist them to an arbitrary
21
- # medium.
22
- #
23
- def log(sev, src, level, msg, from)
24
- raise NotImplementedError
25
- end
26
-
27
- protected
28
-
29
- #
30
- # This method returns the current timestamp in MM/DD/YYYY HH:Mi:SS format.
31
- #
32
- def get_current_timestamp
33
- return Time.now.strftime("%m/%d/%Y %H:%M:%S")
34
- end
35
-
36
- end
37
-
38
- end
39
- end
40
-
41
- require 'rex/logging/sinks/flatfile'
42
- require 'rex/logging/sinks/stderr'
@@ -1,55 +0,0 @@
1
- module Rex
2
- module Logging
3
- module Sinks
4
-
5
- ###
6
- #
7
- # This class implements the LogSink interface and backs it against a
8
- # file on disk.
9
- #
10
- ###
11
- class Flatfile
12
-
13
- include Rex::Logging::LogSink
14
-
15
- #
16
- # Creates a flatfile log sink instance that will be configured to log to
17
- # the supplied file path.
18
- #
19
- def initialize(file)
20
- self.fd = File.new(file, "a")
21
- end
22
-
23
- def cleanup # :nodoc:
24
- fd.close
25
- end
26
-
27
- def log(sev, src, level, msg, from) # :nodoc:
28
- if (sev == LOG_RAW)
29
- fd.write(msg)
30
- else
31
- code = 'i'
32
-
33
- case sev
34
- when LOG_DEBUG
35
- code = 'd'
36
- when LOG_ERROR
37
- code = 'e'
38
- when LOG_INFO
39
- code = 'i'
40
- when LOG_WARN
41
- code = 'w'
42
- end
43
- fd.write("[#{get_current_timestamp}] [#{code}(#{level})] #{src}: #{msg}\n")
44
- end
45
-
46
- fd.flush
47
- end
48
-
49
- protected
50
-
51
- attr_accessor :fd # :nodoc:
52
-
53
- end
54
-
55
- end end end
@@ -1,43 +0,0 @@
1
- module Rex
2
- module Logging
3
- module Sinks
4
-
5
- ###
6
- #
7
- # This class implements the LogSink interface and backs it against stderr
8
- ###
9
- class Stderr
10
-
11
- include Rex::Logging::LogSink
12
-
13
- #
14
- # Writes log data to stderr
15
- #
16
-
17
- def log(sev, src, level, msg, from) # :nodoc:
18
- if (sev == LOG_RAW)
19
- $stderr.write(msg)
20
- else
21
- code = 'i'
22
-
23
- case sev
24
- when LOG_DEBUG
25
- code = 'd'
26
- when LOG_ERROR
27
- code = 'e'
28
- when LOG_INFO
29
- code = 'i'
30
- when LOG_WARN
31
- code = 'w'
32
- end
33
- $stderr.write("[#{get_current_timestamp}] [#{code}(#{level})] #{src}: #{msg}\n")
34
- end
35
-
36
- $stderr.flush
37
- end
38
-
39
- protected
40
-
41
- end
42
-
43
- end end end
@@ -1,9 +0,0 @@
1
- #!/usr/bin/env ruby
2
-
3
- module Rex
4
- module MachParsey
5
-
6
- end
7
- end
8
-
9
- require 'rex/machparsey/mach'
@@ -1,34 +0,0 @@
1
- #!/usr/bin/env ruby
2
-
3
- module Rex
4
- module MachParsey
5
-
6
- class MachError < ::RuntimeError
7
- end
8
-
9
- class MachParseError < MachError
10
- end
11
-
12
- class MachHeaderError < MachParseError
13
- end
14
-
15
- class ProgramHeaderError < MachParseError
16
- end
17
-
18
- class BoundsError < MachError
19
- end
20
-
21
- #class WtfError < MachError
22
- #end
23
-
24
- class FatError < ::RuntimeError
25
- end
26
-
27
- class FatParseError < FatError
28
- end
29
-
30
- class FatHeaderError < FatParseError
31
- end
32
-
33
- end
34
- end
@@ -1,209 +0,0 @@
1
- #!/usr/bin/env ruby
2
-
3
- require 'rex/machparsey/machbase'
4
- require 'rex/machparsey/exceptions'
5
- require 'rex/image_source'
6
-
7
- module Rex
8
- module MachParsey
9
-
10
-
11
- class Mach < MachBase
12
- attr_accessor :mach_header, :segments, :isource, :bits, :endian, :arch, :fat_offset
13
-
14
- def initialize(isource, offset = 0, fat = false)
15
- _parse_mach_header(isource, offset)
16
- if fat == true
17
- self.fat_offset = offset
18
- else
19
- self.fat_offset = 0
20
- end
21
-
22
- self.isource = isource
23
- end
24
-
25
- def _parse_mach_header(isource, offset)
26
- self.mach_header = MachHeader.new(isource.read(offset, MACH_HEADER_SIZE_64))
27
- bits = mach_header.bits
28
- endian = mach_header.endian
29
- ncmds = mach_header.ncmds
30
-
31
- if bits == BITS_32
32
- offset += MACH_HEADER_SIZE
33
- else
34
- offset += MACH_HEADER_SIZE_64
35
- end
36
-
37
-
38
- segments = []
39
- ncmds.times do
40
- load_command = LoadCommand.new(isource.read(offset, LOAD_COMMAND_SIZE), endian)
41
-
42
- case load_command.cmd
43
- when LC_SEGMENT
44
- segments << Segment.new(isource.read(offset, SEGMENT_COMMAND_SIZE), bits, endian)
45
- when LC_SEGMENT_64
46
- segments << Segment.new(isource.read(offset, SEGMENT_COMMAND_SIZE_64), bits, endian)
47
- end
48
-
49
- offset += load_command.cmdsize
50
- end
51
-
52
- self.mach_header = mach_header
53
- self.segments = segments
54
- self.isource = isource
55
- self.bits = bits
56
- self.endian = endian
57
-
58
- return segments
59
- end
60
-
61
- def self.new_from_file(filename, disk_backed = false)
62
-
63
- file = ::File.open(filename, "rb")
64
-
65
- if disk_backed
66
- return self.new(ImageSource::Disk.new(file))
67
- else
68
- obj = new_from_string(file.read)
69
- file.close
70
- return obj
71
- end
72
- end
73
-
74
- def self.new_from_string(data)
75
- return self.new(ImageSource::Memory.new(data))
76
- end
77
-
78
- def ptr_64?
79
- mach_header.bits == BITS_64
80
- end
81
-
82
- def ptr_32?
83
- ptr_64? == false
84
- end
85
-
86
- def ptr_s(vaddr)
87
- (ptr_32?) ? ("0x%.8x" % vaddr) : ("0x%.16x" % vaddr)
88
- end
89
-
90
- def read(offset, len)
91
- isource.read(fat_offset + offset, len)
92
- end
93
-
94
- def index(*args)
95
- isource.index(*args)
96
- end
97
-
98
- def close
99
- isource.close
100
- end
101
-
102
- end
103
-
104
- class Fat < FatBase
105
- attr_accessor :fat_header, :fat_archs, :machos, :isource
106
-
107
- def initialize(isource, offset = 0)
108
- self.fat_archs = []
109
- self.machos = []
110
- self.isource = isource
111
- self.fat_header = FatHeader.new(isource.read(offset, FAT_HEADER_SIZE))
112
-
113
- if !self.fat_header
114
- raise FatHeaderError, "Could not parse FAT header"
115
- end
116
-
117
- print "Detected " + self.fat_header.nfat_arch.to_s + " archs in binary.\n"
118
-
119
- offset += FAT_HEADER_SIZE
120
-
121
- self.fat_header.nfat_arch.times do
122
- fat_arch = FatArch.new(isource.read(offset, FAT_ARCH_SIZE), self.fat_header.endian)
123
- self.fat_archs << fat_arch
124
- self.machos << Mach.new(isource, fat_arch.offset, true)
125
- offset += FAT_ARCH_SIZE
126
- end
127
-
128
-
129
- end
130
-
131
- #this is useful for debugging but we don't use it for anything.
132
- def _parse_fat_header(isource, offset)
133
- archs = []
134
- nfat_arch = self.fat_header.nfat_arch
135
-
136
- print "Number of archs in binary: " + nfat_arch.to_s + "\n"
137
-
138
- nfat_arch.times do
139
- arch = FatArch.new(isource.read(offset, FAT_ARCH_SIZE), self.endian)
140
-
141
- case arch.cpu_type
142
-
143
- when CPU_TYPE_I386
144
- print "i386\n"
145
-
146
- when CPU_TYPE_X86_64
147
- print "x86_64\n"
148
-
149
- when CPU_TYPE_ARM
150
- print "Arm\n"
151
-
152
- when CPU_TYPE_POWERPC
153
- print "Power PC\n"
154
-
155
- when CPU_TYPE_POWERPC64
156
- print "Power PC 64\n"
157
- end
158
-
159
- offset += FAT_ARCH_SIZE
160
- end
161
- end
162
-
163
- def self.new_from_file(filename, disk_backed = false)
164
-
165
- file = ::File.open(filename, "rb")
166
-
167
- if disk_backed
168
- return self.new(ImageSource::Disk.new(file))
169
- else
170
- obj = new_from_string(file.read)
171
- file.close
172
- return obj
173
- end
174
- end
175
-
176
-
177
- def self.new_from_string(data)
178
- return self.new(ImageSource::Memory.new(data))
179
- end
180
-
181
- def ptr_64?
182
- mach_header.bits == BITS_64
183
- end
184
-
185
- def ptr_32?
186
- ptr_64? == false
187
- end
188
-
189
- def ptr_s(vaddr)
190
- (ptr_32?) ? ("0x%.8x" % vaddr) : ("0x%.16x" % vaddr)
191
- end
192
-
193
- def read(offset, len)
194
- isource.read(offset, len)
195
- end
196
-
197
- def index(*args)
198
- isource.index(*args)
199
- end
200
-
201
- def close
202
- isource.close
203
- end
204
-
205
- end
206
-
207
-
208
- end
209
- end
@@ -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