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
data/lib/rex/constants.rb DELETED
@@ -1,113 +0,0 @@
1
- #
2
- # Log severities
3
- #
4
- LOG_ERROR = 'error'
5
- LOG_DEBUG = 'debug'
6
- LOG_INFO = 'info'
7
- LOG_WARN = 'warn'
8
- LOG_RAW = 'raw'
9
-
10
- ##
11
- #
12
- # Log levels
13
- #
14
- ##
15
-
16
- #
17
- # LEV_0 - Default
18
- #
19
- # This log level is the default log level if none is specified. It should be
20
- # used when a log message should always be displayed when logging is enabled.
21
- # Very few log messages should occur at this level aside from necessary
22
- # information logging and error/warning logging. Debug logging at level zero
23
- # is not advised.
24
- #
25
- LEV_0 = 0
26
-
27
- #
28
- # LEV_1 - Extra
29
- #
30
- # This log level should be used when extra information may be needed to
31
- # understand the cause of an error or warning message or to get debugging
32
- # information that might give clues as to why something is happening. This
33
- # log level should be used only when information may be useful to understanding
34
- # the behavior of something at a basic level. This log level should not be
35
- # used in an exhaustively verbose fashion.
36
- #
37
- LEV_1 = 1
38
-
39
- #
40
- # LEV_2 - Verbose
41
- #
42
- # This log level should be used when verbose information may be needed to
43
- # analyze the behavior of the framework. This should be the default log
44
- # level for all detailed information not falling into LEV_0 or LEV_1.
45
- # It is recommended that this log level be used by default if you are
46
- # unsure.
47
- #
48
- LEV_2 = 2
49
-
50
- #
51
- # LEV_3 - Insanity
52
- #
53
- # This log level should contain very verbose information about the
54
- # behavior of the framework, such as detailed information about variable
55
- # states at certain phases including, but not limited to, loop iterations,
56
- # function calls, and so on. This log level will rarely be displayed,
57
- # but when it is the information provided should make it easy to analyze
58
- # any problem.
59
- #
60
- LEV_3 = 3
61
-
62
-
63
- #
64
- # Architecture constants
65
- #
66
- ARCH_ANY = '_any_'
67
- ARCH_X86 = 'x86'
68
- ARCH_X86_64 = 'x86_64'
69
- ARCH_X64 = 'x64' # To be used for compatability with ARCH_X86_64
70
- ARCH_MIPS = 'mips'
71
- ARCH_MIPSLE = 'mipsle'
72
- ARCH_MIPSBE = 'mipsbe'
73
- ARCH_PPC = 'ppc'
74
- ARCH_PPC64 = 'ppc64'
75
- ARCH_CBEA = 'cbea'
76
- ARCH_CBEA64 = 'cbea64'
77
- ARCH_SPARC = 'sparc'
78
- ARCH_CMD = 'cmd'
79
- ARCH_PHP = 'php'
80
- ARCH_TTY = 'tty'
81
- ARCH_ARMLE = 'armle'
82
- ARCH_ARMBE = 'armbe'
83
- ARCH_JAVA = 'java'
84
- ARCH_TYPES =
85
- [
86
- ARCH_X86,
87
- ARCH_X86_64,
88
- ARCH_MIPS,
89
- ARCH_MIPSLE,
90
- ARCH_MIPSBE,
91
- ARCH_PPC,
92
- ARCH_PPC64,
93
- ARCH_CBEA,
94
- ARCH_CBEA64,
95
- ARCH_SPARC,
96
- ARCH_ARMLE,
97
- ARCH_ARMBE,
98
- ARCH_CMD,
99
- ARCH_PHP,
100
- ARCH_TTY,
101
- ARCH_JAVA
102
- ]
103
-
104
- ARCH_ALL = ARCH_TYPES
105
-
106
- #
107
- # Endian constants
108
- #
109
- ENDIAN_LITTLE = 0
110
- ENDIAN_BIG = 1
111
-
112
- IS_ENDIAN_LITTLE = ( [1].pack('s') == "\x01\x00" ) ? true : false
113
- IS_ENDIAN_BIG = ( not IS_ENDIAN_LITTLE )
data/lib/rex/elfparsey.rb DELETED
@@ -1,11 +0,0 @@
1
- #!/usr/bin/env ruby
2
-
3
- # $Id: elfparsey.rb 5413 2008-02-13 02:43:56Z ramon $
4
-
5
- module Rex
6
- module ElfParsey
7
-
8
- end
9
- end
10
-
11
- require 'rex/elfparsey/elf'
@@ -1,123 +0,0 @@
1
- #!/usr/bin/env ruby
2
-
3
- # $Id: elf.rb 6615 2009-06-03 01:39:54Z hdm $
4
-
5
- require 'rex/elfparsey/elfbase'
6
- require 'rex/elfparsey/exceptions'
7
- require 'rex/image_source'
8
-
9
- module Rex
10
- module ElfParsey
11
- class Elf < ElfBase
12
-
13
- attr_accessor :elf_header, :program_header, :base_addr, :isource
14
-
15
- def initialize(isource)
16
- offset = 0
17
- base_addr = 0
18
-
19
- # ELF Header
20
- elf_header = ElfHeader.new(isource.read(offset, ELF_HEADER_SIZE))
21
-
22
- # Data encoding
23
- ei_data = elf_header.e_ident[EI_DATA,1].unpack("C")[0]
24
-
25
- e_phoff = elf_header.e_phoff
26
- e_phentsize = elf_header.e_phentsize
27
- e_phnum = elf_header.e_phnum
28
-
29
- # Program Header Table
30
- program_header = []
31
-
32
- e_phnum.times do |i|
33
- offset = e_phoff + (e_phentsize * i)
34
-
35
- program_header << ProgramHeader.new(
36
- isource.read(offset, PROGRAM_HEADER_SIZE), ei_data
37
- )
38
-
39
- if program_header[-1].p_type == PT_LOAD && base_addr == 0
40
- base_addr = program_header[-1].p_vaddr
41
- end
42
-
43
- end
44
-
45
- self.elf_header = elf_header
46
- self.program_header = program_header
47
- self.base_addr = base_addr
48
- self.isource = isource
49
- end
50
-
51
- def self.new_from_file(filename, disk_backed = false)
52
-
53
- file = ::File.new(filename)
54
- # file.binmode # windows... :\
55
-
56
- if disk_backed
57
- return self.new(ImageSource::Disk.new(file))
58
- else
59
- obj = new_from_string(file.read)
60
- file.close
61
- return obj
62
- end
63
- end
64
-
65
- def self.new_from_string(data)
66
- return self.new(ImageSource::Memory.new(data))
67
- end
68
-
69
- #
70
- # Returns true if this binary is for a 64-bit architecture.
71
- #
72
- def ptr_64?
73
- unless [ ELFCLASS32, ELFCLASS64 ].include?(
74
- elf_header.e_ident[EI_CLASS,1].unpack("C*")[0])
75
- raise ElfHeaderError, 'Invalid class', caller
76
- end
77
-
78
- elf_header.e_ident[EI_CLASS,1].unpack("C*")[0] == ELFCLASS64
79
- end
80
-
81
- #
82
- # Returns true if this binary is for a 32-bit architecture.
83
- # This check does not take into account 16-bit binaries at the moment.
84
- #
85
- def ptr_32?
86
- ptr_64? == false
87
- end
88
-
89
- #
90
- # Converts a virtual address to a string representation based on the
91
- # underlying architecture.
92
- #
93
- def ptr_s(rva)
94
- (ptr_32?) ? ("0x%.8x" % rva) : ("0x%.16x" % rva)
95
- end
96
-
97
- def offset_to_rva(offset)
98
- base_addr + offset
99
- end
100
-
101
- def rva_to_offset(rva)
102
- rva - base_addr
103
- end
104
-
105
- def read(offset, len)
106
- isource.read(offset, len)
107
- end
108
-
109
- def read_rva(rva, len)
110
- isource.read(rva_to_offset(rva), len)
111
- end
112
-
113
- def index(*args)
114
- isource.index(*args)
115
- end
116
-
117
- def close
118
- isource.close
119
- end
120
-
121
- end
122
- end
123
- end
@@ -1,258 +0,0 @@
1
- #!/usr/bin/env ruby
2
-
3
- # $Id: elfbase.rb 9937 2010-07-27 18:03:18Z jduck $
4
-
5
- require 'rex/struct2'
6
-
7
- module Rex
8
- module ElfParsey
9
- class ElfBase
10
-
11
- # ELF Header
12
-
13
- ELF_HEADER_SIZE = 52
14
-
15
- EI_NIDENT = 16
16
-
17
- ELF32_EHDR_LSB = Rex::Struct2::CStructTemplate.new(
18
- [ 'string', 'e_ident', EI_NIDENT, '' ],
19
- [ 'uint16v', 'e_type', 0 ],
20
- [ 'uint16v', 'e_machine', 0 ],
21
- [ 'uint32v', 'e_version', 0 ],
22
- [ 'uint32v', 'e_entry', 0 ],
23
- [ 'uint32v', 'e_phoff', 0 ],
24
- [ 'uint32v', 'e_shoff', 0 ],
25
- [ 'uint32v', 'e_flags', 0 ],
26
- [ 'uint16v', 'e_ehsize', 0 ],
27
- [ 'uint16v', 'e_phentsize', 0 ],
28
- [ 'uint16v', 'e_phnum', 0 ],
29
- [ 'uint16v', 'e_shentsize', 0 ],
30
- [ 'uint16v', 'e_shnum', 0 ],
31
- [ 'uint16v', 'e_shstrndx', 0 ]
32
- )
33
-
34
- ELF32_EHDR_MSB = Rex::Struct2::CStructTemplate.new(
35
- [ 'string', 'e_ident', EI_NIDENT, '' ],
36
- [ 'uint16n', 'e_type', 0 ],
37
- [ 'uint16n', 'e_machine', 0 ],
38
- [ 'uint32n', 'e_version', 0 ],
39
- [ 'uint32n', 'e_entry', 0 ],
40
- [ 'uint32n', 'e_phoff', 0 ],
41
- [ 'uint32n', 'e_shoff', 0 ],
42
- [ 'uint32n', 'e_flags', 0 ],
43
- [ 'uint16n', 'e_ehsize', 0 ],
44
- [ 'uint16n', 'e_phentsize', 0 ],
45
- [ 'uint16n', 'e_phnum', 0 ],
46
- [ 'uint16n', 'e_shentsize', 0 ],
47
- [ 'uint16n', 'e_shnum', 0 ],
48
- [ 'uint16n', 'e_shstrndx', 0 ]
49
- )
50
-
51
- # e_type This member identifies the object file type
52
-
53
- ET_NONE = 0 # No file type
54
- ET_REL = 1 # Relocatable file
55
- ET_EXEC = 2 # Executable file
56
- ET_DYN = 3 # Shared object file
57
- ET_CORE = 4 # Core file
58
- ET_LOPROC = 0xff00 # Processor-specific
59
- ET_HIPROC = 0xffff # Processor-specific
60
-
61
- #
62
- # e_machine This member's value specifies the required architecture for an
63
- # individual file.
64
- #
65
-
66
- # ET_NONE = 0 # No machine
67
- EM_M32 = 1 # AT&T WE 32100
68
- EM_SPARC = 2 # SPARC
69
- EM_386 = 3 # Intel Architecture
70
- EM_68K = 4 # Motorola 68000
71
- EM_88K = 5 # Motorola 88000
72
- EM_860 = 7 # Intel 80860
73
- EM_MIPS = 8 # MIPS RS3000 Big-Endian
74
- EM_MIPS_RS4_BE = 10 # MIPS RS4000 Big-Endian
75
-
76
- # e_version This member identifies the object file version
77
-
78
- EV_NONE = 0 # Invalid version
79
- EV_CURRENT = 1 # Current version
80
-
81
-
82
- # ELF Identification
83
-
84
- # e_ident[] Identification indexes
85
-
86
- EI_MAG0 = 0 # File identification
87
- EI_MAG1 = 1 # File identification
88
- EI_MAG2 = 2 # File identification
89
- EI_MAG3 = 3 # File identification
90
- EI_CLASS = 4 # File class
91
- EI_DATA = 5 # Data encoding
92
- EI_VERSION = 6 # File version
93
- EI_PAD = 7 # Start of padding bytes
94
- # EI_NIDENT = 16 # Size of e_ident[]
95
-
96
- #
97
- # EI_MAG0 to EI_MAG3 A file's first 4 bytes hold a "magic number",
98
- # identifying the file as an ELF object file.
99
- #
100
-
101
- ELFMAG0 = 0x7f # e_ident[EI_MAG0]
102
- ELFMAG1 = ?E # e_ident[EI_MAG1]
103
- ELFMAG2 = ?L # e_ident[EI_MAG2]
104
- ELFMAG3 = ?F # e_ident[EI_MAG3]
105
-
106
- ELFMAG = ELFMAG0.chr + ELFMAG1.chr + ELFMAG2.chr + ELFMAG3.chr
107
-
108
- # EI_CLASS Identifies the file's class, or capacity
109
-
110
- ELFCLASSNONE = 0 # Invalid class
111
- ELFCLASS32 = 1 # 32-bit objects
112
- ELFCLASS64 = 2 # 64-bit objects
113
-
114
- #
115
- # EI_DATA Specifies the data encoding of the processor-specific data in
116
- # the object file. The following encodings are currently defined.
117
- #
118
-
119
- ELFDATANONE = 0 # Invalid data encoding
120
- ELFDATA2LSB = 1 # Least significant byte first
121
- ELFDATA2MSB = 2 # Most significant byte first
122
-
123
- class GenericStruct
124
- attr_accessor :struct
125
- def initialize(_struct)
126
- self.struct = _struct
127
- end
128
-
129
- # The following methods are just pass-throughs for struct
130
-
131
- # Access a value
132
- def v
133
- struct.v
134
-
135
- end
136
-
137
- # Access a value by array
138
- def [](*args)
139
- struct[*args]
140
- end
141
-
142
- # Obtain an array of all fields
143
- def keys
144
- struct.keys
145
- end
146
-
147
- def method_missing(meth, *args)
148
- v[meth.to_s] || (raise NoMethodError.new, meth)
149
- end
150
- end
151
-
152
- class GenericHeader < GenericStruct
153
- end
154
-
155
- class ElfHeader < GenericHeader
156
- def initialize(rawdata)
157
-
158
- # Identify the data encoding and parse ELF Header
159
- elf_header = ELF32_EHDR_LSB.make_struct
160
-
161
- if !elf_header.from_s(rawdata)
162
- raise ElfHeaderError, "Couldn't parse ELF Header", caller
163
- end
164
-
165
- if elf_header.v['e_ident'][EI_DATA,1].unpack('C')[0] == ELFDATA2MSB
166
- elf_header = ELF32_EHDR_MSB.make_struct
167
-
168
- if !elf_header.from_s(rawdata)
169
- raise ElfHeaderError, "Couldn't parse ELF Header", caller
170
- end
171
- end
172
-
173
- unless [ ELFDATA2LSB, ELFDATA2MSB ].include?(
174
- elf_header.v['e_ident'][EI_DATA,1].unpack('C')[0])
175
- raise ElfHeaderError, "Invalid data encoding", caller
176
- end
177
-
178
- # Identify the file as an ELF object file
179
- unless elf_header.v['e_ident'][EI_MAG0, 4] == ELFMAG
180
- raise ElfHeaderError, 'Invalid magic number', caller
181
- end
182
-
183
- self.struct = elf_header
184
- end
185
-
186
- def e_ident
187
- struct.v['e_ident']
188
- end
189
-
190
- end
191
-
192
-
193
- # Program Header
194
-
195
- PROGRAM_HEADER_SIZE = 32
196
-
197
- ELF32_PHDR_LSB = Rex::Struct2::CStructTemplate.new(
198
- [ 'uint32v', 'p_type', 0 ],
199
- [ 'uint32v', 'p_offset', 0 ],
200
- [ 'uint32v', 'p_vaddr', 0 ],
201
- [ 'uint32v', 'p_paddr', 0 ],
202
- [ 'uint32v', 'p_filesz', 0 ],
203
- [ 'uint32v', 'p_memsz', 0 ],
204
- [ 'uint32v', 'p_flags', 0 ],
205
- [ 'uint32v', 'p_align', 0 ]
206
- )
207
-
208
- ELF32_PHDR_MSB = Rex::Struct2::CStructTemplate.new(
209
- [ 'uint32n', 'p_type', 0 ],
210
- [ 'uint32n', 'p_offset', 0 ],
211
- [ 'uint32n', 'p_vaddr', 0 ],
212
- [ 'uint32n', 'p_paddr', 0 ],
213
- [ 'uint32n', 'p_filesz', 0 ],
214
- [ 'uint32n', 'p_memsz', 0 ],
215
- [ 'uint32n', 'p_flags', 0 ],
216
- [ 'uint32n', 'p_align', 0 ]
217
- )
218
-
219
- #
220
- # p_type This member tells what kind of segment this array element
221
- # describes or how to interpret the array element's information.
222
- #
223
-
224
- # Segment Types
225
-
226
- PT_NULL = 0
227
- PT_LOAD = 1
228
- PT_DYNAMIC = 2
229
- PT_INTERP = 3
230
- PT_NOTE = 4
231
- PT_SHLIB = 5
232
- PT_PHDR = 6
233
- PT_LOPROC = 0x70000000
234
- PT_HIPROC = 0x7fffffff
235
-
236
- class ProgramHeader < GenericHeader
237
- def initialize(rawdata, ei_data)
238
- # Identify the data encoding and parse Program Header
239
- if ei_data == ELFDATA2LSB
240
- program_header = ELF32_PHDR_LSB.make_struct
241
- elsif ei_data == ELFDATA2MSB
242
- program_header = ELF32_PHDR_MSB.make_struct
243
- else
244
- raise ElfHeaderError, "Invalid data encoding", caller
245
- end
246
-
247
- if !program_header.from_s(rawdata)
248
- raise ProgramHeaderError, "Couldn't parse Program Header", caller
249
- end
250
-
251
- self.struct = program_header
252
- end
253
-
254
- end
255
-
256
- end
257
- end
258
- end