dstruct 0.0.1
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.
- checksums.yaml +15 -0
- data/README.markdown +23 -0
- data/examples/smb_example.rb +35 -0
- data/lib/rex.rb +108 -0
- data/lib/rex/LICENSE +29 -0
- data/lib/rex/arch.rb +104 -0
- data/lib/rex/arch/sparc.rb +75 -0
- data/lib/rex/arch/x86.rb +524 -0
- data/lib/rex/assembly/nasm.rb +104 -0
- data/lib/rex/codepage.map +104 -0
- data/lib/rex/compat.rb +389 -0
- data/lib/rex/constants.rb +124 -0
- data/lib/rex/elfparsey.rb +9 -0
- data/lib/rex/elfparsey/elf.rb +121 -0
- data/lib/rex/elfparsey/elfbase.rb +256 -0
- data/lib/rex/elfparsey/exceptions.rb +25 -0
- data/lib/rex/elfscan.rb +10 -0
- data/lib/rex/elfscan/scanner.rb +226 -0
- data/lib/rex/elfscan/search.rb +44 -0
- data/lib/rex/encoder/alpha2.rb +31 -0
- data/lib/rex/encoder/alpha2/alpha_mixed.rb +68 -0
- data/lib/rex/encoder/alpha2/alpha_upper.rb +79 -0
- data/lib/rex/encoder/alpha2/generic.rb +90 -0
- data/lib/rex/encoder/alpha2/unicode_mixed.rb +116 -0
- data/lib/rex/encoder/alpha2/unicode_upper.rb +123 -0
- data/lib/rex/encoder/bloxor/bloxor.rb +327 -0
- data/lib/rex/encoder/ndr.rb +90 -0
- data/lib/rex/encoder/nonalpha.rb +61 -0
- data/lib/rex/encoder/nonupper.rb +64 -0
- data/lib/rex/encoder/xdr.rb +107 -0
- data/lib/rex/encoder/xor.rb +69 -0
- data/lib/rex/encoder/xor/dword.rb +13 -0
- data/lib/rex/encoder/xor/dword_additive.rb +13 -0
- data/lib/rex/encoders/xor_dword.rb +35 -0
- data/lib/rex/encoders/xor_dword_additive.rb +53 -0
- data/lib/rex/encoding/xor.rb +20 -0
- data/lib/rex/encoding/xor/byte.rb +15 -0
- data/lib/rex/encoding/xor/dword.rb +21 -0
- data/lib/rex/encoding/xor/dword_additive.rb +92 -0
- data/lib/rex/encoding/xor/exceptions.rb +17 -0
- data/lib/rex/encoding/xor/generic.rb +146 -0
- data/lib/rex/encoding/xor/qword.rb +15 -0
- data/lib/rex/encoding/xor/word.rb +21 -0
- data/lib/rex/exceptions.rb +275 -0
- data/lib/rex/exploitation/cmdstager.rb +10 -0
- data/lib/rex/exploitation/cmdstager/base.rb +190 -0
- data/lib/rex/exploitation/cmdstager/bourne.rb +105 -0
- data/lib/rex/exploitation/cmdstager/debug_asm.rb +140 -0
- data/lib/rex/exploitation/cmdstager/debug_write.rb +134 -0
- data/lib/rex/exploitation/cmdstager/echo.rb +164 -0
- data/lib/rex/exploitation/cmdstager/printf.rb +122 -0
- data/lib/rex/exploitation/cmdstager/tftp.rb +71 -0
- data/lib/rex/exploitation/cmdstager/vbs.rb +126 -0
- data/lib/rex/exploitation/egghunter.rb +425 -0
- data/lib/rex/exploitation/encryptjs.rb +78 -0
- data/lib/rex/exploitation/heaplib.js.b64 +331 -0
- data/lib/rex/exploitation/heaplib.rb +107 -0
- data/lib/rex/exploitation/js.rb +6 -0
- data/lib/rex/exploitation/js/detect.rb +69 -0
- data/lib/rex/exploitation/js/memory.rb +81 -0
- data/lib/rex/exploitation/js/network.rb +84 -0
- data/lib/rex/exploitation/js/utils.rb +33 -0
- data/lib/rex/exploitation/jsobfu.rb +513 -0
- data/lib/rex/exploitation/obfuscatejs.rb +336 -0
- data/lib/rex/exploitation/omelet.rb +321 -0
- data/lib/rex/exploitation/opcodedb.rb +819 -0
- data/lib/rex/exploitation/powershell.rb +62 -0
- data/lib/rex/exploitation/powershell/function.rb +63 -0
- data/lib/rex/exploitation/powershell/obfu.rb +98 -0
- data/lib/rex/exploitation/powershell/output.rb +151 -0
- data/lib/rex/exploitation/powershell/param.rb +23 -0
- data/lib/rex/exploitation/powershell/parser.rb +183 -0
- data/lib/rex/exploitation/powershell/psh_methods.rb +70 -0
- data/lib/rex/exploitation/powershell/script.rb +99 -0
- data/lib/rex/exploitation/ropdb.rb +190 -0
- data/lib/rex/exploitation/seh.rb +93 -0
- data/lib/rex/file.rb +160 -0
- data/lib/rex/image_source.rb +10 -0
- data/lib/rex/image_source/disk.rb +58 -0
- data/lib/rex/image_source/image_source.rb +44 -0
- data/lib/rex/image_source/memory.rb +35 -0
- data/lib/rex/io/bidirectional_pipe.rb +161 -0
- data/lib/rex/io/datagram_abstraction.rb +35 -0
- data/lib/rex/io/ring_buffer.rb +369 -0
- data/lib/rex/io/stream.rb +312 -0
- data/lib/rex/io/stream_abstraction.rb +209 -0
- data/lib/rex/io/stream_server.rb +221 -0
- data/lib/rex/job_container.rb +200 -0
- data/lib/rex/logging.rb +4 -0
- data/lib/rex/logging/log_dispatcher.rb +180 -0
- data/lib/rex/logging/log_sink.rb +43 -0
- data/lib/rex/logging/sinks/flatfile.rb +56 -0
- data/lib/rex/logging/sinks/stderr.rb +44 -0
- data/lib/rex/mac_oui.rb +16581 -0
- data/lib/rex/machparsey.rb +9 -0
- data/lib/rex/machparsey/exceptions.rb +34 -0
- data/lib/rex/machparsey/mach.rb +209 -0
- data/lib/rex/machparsey/machbase.rb +408 -0
- data/lib/rex/machscan.rb +9 -0
- data/lib/rex/machscan/scanner.rb +217 -0
- data/lib/rex/mime.rb +10 -0
- data/lib/rex/mime/encoding.rb +17 -0
- data/lib/rex/mime/header.rb +78 -0
- data/lib/rex/mime/message.rb +150 -0
- data/lib/rex/mime/part.rb +50 -0
- data/lib/rex/nop/opty2.rb +109 -0
- data/lib/rex/nop/opty2_tables.rb +301 -0
- data/lib/rex/ole.rb +202 -0
- data/lib/rex/ole/clsid.rb +44 -0
- data/lib/rex/ole/difat.rb +138 -0
- data/lib/rex/ole/directory.rb +228 -0
- data/lib/rex/ole/direntry.rb +237 -0
- data/lib/rex/ole/docs/dependencies.txt +8 -0
- data/lib/rex/ole/docs/references.txt +1 -0
- data/lib/rex/ole/fat.rb +96 -0
- data/lib/rex/ole/header.rb +201 -0
- data/lib/rex/ole/minifat.rb +74 -0
- data/lib/rex/ole/propset.rb +141 -0
- data/lib/rex/ole/samples/create_ole.rb +27 -0
- data/lib/rex/ole/samples/dir.rb +35 -0
- data/lib/rex/ole/samples/dump_stream.rb +34 -0
- data/lib/rex/ole/samples/ole_info.rb +23 -0
- data/lib/rex/ole/storage.rb +392 -0
- data/lib/rex/ole/stream.rb +50 -0
- data/lib/rex/ole/substorage.rb +46 -0
- data/lib/rex/ole/util.rb +154 -0
- data/lib/rex/parser/acunetix_nokogiri.rb +406 -0
- data/lib/rex/parser/apple_backup_manifestdb.rb +132 -0
- data/lib/rex/parser/appscan_nokogiri.rb +367 -0
- data/lib/rex/parser/arguments.rb +108 -0
- data/lib/rex/parser/burp_session_nokogiri.rb +291 -0
- data/lib/rex/parser/ci_nokogiri.rb +193 -0
- data/lib/rex/parser/foundstone_nokogiri.rb +342 -0
- data/lib/rex/parser/fusionvm_nokogiri.rb +109 -0
- data/lib/rex/parser/group_policy_preferences.rb +185 -0
- data/lib/rex/parser/ini.rb +186 -0
- data/lib/rex/parser/ip360_aspl_xml.rb +103 -0
- data/lib/rex/parser/ip360_xml.rb +98 -0
- data/lib/rex/parser/mbsa_nokogiri.rb +256 -0
- data/lib/rex/parser/nessus_xml.rb +121 -0
- data/lib/rex/parser/netsparker_xml.rb +109 -0
- data/lib/rex/parser/nexpose_raw_nokogiri.rb +686 -0
- data/lib/rex/parser/nexpose_simple_nokogiri.rb +330 -0
- data/lib/rex/parser/nexpose_xml.rb +172 -0
- data/lib/rex/parser/nmap_nokogiri.rb +394 -0
- data/lib/rex/parser/nmap_xml.rb +166 -0
- data/lib/rex/parser/nokogiri_doc_mixin.rb +233 -0
- data/lib/rex/parser/openvas_nokogiri.rb +172 -0
- data/lib/rex/parser/outpost24_nokogiri.rb +240 -0
- data/lib/rex/parser/retina_xml.rb +110 -0
- data/lib/rex/parser/unattend.rb +171 -0
- data/lib/rex/parser/wapiti_nokogiri.rb +105 -0
- data/lib/rex/payloads.rb +2 -0
- data/lib/rex/payloads/win32.rb +3 -0
- data/lib/rex/payloads/win32/common.rb +27 -0
- data/lib/rex/payloads/win32/kernel.rb +54 -0
- data/lib/rex/payloads/win32/kernel/common.rb +55 -0
- data/lib/rex/payloads/win32/kernel/migration.rb +13 -0
- data/lib/rex/payloads/win32/kernel/recovery.rb +51 -0
- data/lib/rex/payloads/win32/kernel/stager.rb +195 -0
- data/lib/rex/peparsey.rb +10 -0
- data/lib/rex/peparsey/exceptions.rb +30 -0
- data/lib/rex/peparsey/pe.rb +210 -0
- data/lib/rex/peparsey/pe_memdump.rb +61 -0
- data/lib/rex/peparsey/pebase.rb +1662 -0
- data/lib/rex/peparsey/section.rb +128 -0
- data/lib/rex/pescan.rb +11 -0
- data/lib/rex/pescan/analyze.rb +366 -0
- data/lib/rex/pescan/scanner.rb +230 -0
- data/lib/rex/pescan/search.rb +68 -0
- data/lib/rex/platforms.rb +2 -0
- data/lib/rex/platforms/windows.rb +52 -0
- data/lib/rex/poly.rb +134 -0
- data/lib/rex/poly/block.rb +480 -0
- data/lib/rex/poly/machine.rb +13 -0
- data/lib/rex/poly/machine/machine.rb +830 -0
- data/lib/rex/poly/machine/x86.rb +509 -0
- data/lib/rex/poly/register.rb +101 -0
- data/lib/rex/poly/register/x86.rb +41 -0
- data/lib/rex/post.rb +7 -0
- data/lib/rex/post/dir.rb +51 -0
- data/lib/rex/post/file.rb +172 -0
- data/lib/rex/post/file_stat.rb +220 -0
- data/lib/rex/post/gen.pl +13 -0
- data/lib/rex/post/io.rb +182 -0
- data/lib/rex/post/meterpreter.rb +5 -0
- data/lib/rex/post/meterpreter/channel.rb +446 -0
- data/lib/rex/post/meterpreter/channel_container.rb +54 -0
- data/lib/rex/post/meterpreter/channels/pool.rb +160 -0
- data/lib/rex/post/meterpreter/channels/pools/file.rb +62 -0
- data/lib/rex/post/meterpreter/channels/pools/stream_pool.rb +103 -0
- data/lib/rex/post/meterpreter/channels/stream.rb +87 -0
- data/lib/rex/post/meterpreter/client.rb +483 -0
- data/lib/rex/post/meterpreter/client_core.rb +352 -0
- data/lib/rex/post/meterpreter/dependencies.rb +3 -0
- data/lib/rex/post/meterpreter/extension.rb +32 -0
- data/lib/rex/post/meterpreter/extensions/android/android.rb +128 -0
- data/lib/rex/post/meterpreter/extensions/android/tlv.rb +40 -0
- data/lib/rex/post/meterpreter/extensions/espia/espia.rb +58 -0
- data/lib/rex/post/meterpreter/extensions/espia/tlv.rb +17 -0
- data/lib/rex/post/meterpreter/extensions/extapi/adsi/adsi.rb +71 -0
- data/lib/rex/post/meterpreter/extensions/extapi/clipboard/clipboard.rb +169 -0
- data/lib/rex/post/meterpreter/extensions/extapi/extapi.rb +45 -0
- data/lib/rex/post/meterpreter/extensions/extapi/service/service.rb +104 -0
- data/lib/rex/post/meterpreter/extensions/extapi/tlv.rb +77 -0
- data/lib/rex/post/meterpreter/extensions/extapi/window/window.rb +56 -0
- data/lib/rex/post/meterpreter/extensions/extapi/wmi/wmi.rb +75 -0
- data/lib/rex/post/meterpreter/extensions/incognito/incognito.rb +94 -0
- data/lib/rex/post/meterpreter/extensions/incognito/tlv.rb +22 -0
- data/lib/rex/post/meterpreter/extensions/kiwi/kiwi.rb +361 -0
- data/lib/rex/post/meterpreter/extensions/kiwi/tlv.rb +76 -0
- data/lib/rex/post/meterpreter/extensions/lanattacks/dhcp/dhcp.rb +78 -0
- data/lib/rex/post/meterpreter/extensions/lanattacks/lanattacks.rb +43 -0
- data/lib/rex/post/meterpreter/extensions/lanattacks/tftp/tftp.rb +49 -0
- data/lib/rex/post/meterpreter/extensions/lanattacks/tlv.rb +17 -0
- data/lib/rex/post/meterpreter/extensions/mimikatz/mimikatz.rb +128 -0
- data/lib/rex/post/meterpreter/extensions/mimikatz/tlv.rb +16 -0
- data/lib/rex/post/meterpreter/extensions/networkpug/networkpug.rb +57 -0
- data/lib/rex/post/meterpreter/extensions/networkpug/tlv.rb +16 -0
- data/lib/rex/post/meterpreter/extensions/priv/fs.rb +118 -0
- data/lib/rex/post/meterpreter/extensions/priv/passwd.rb +61 -0
- data/lib/rex/post/meterpreter/extensions/priv/priv.rb +109 -0
- data/lib/rex/post/meterpreter/extensions/priv/tlv.rb +29 -0
- data/lib/rex/post/meterpreter/extensions/sniffer/sniffer.rb +117 -0
- data/lib/rex/post/meterpreter/extensions/sniffer/tlv.rb +27 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/constants.rb +396 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/fs/dir.rb +284 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/fs/file.rb +399 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/fs/file_stat.rb +104 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/fs/io.rb +48 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/net/arp.rb +59 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/net/config.rb +256 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/net/interface.rb +129 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/net/netstat.rb +97 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/net/resolve.rb +106 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/net/route.rb +67 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/net/socket.rb +139 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/tcp_client_channel.rb +180 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/tcp_server_channel.rb +168 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/udp_channel.rb +209 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/railgun/api_constants.rb +38146 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/railgun/buffer_item.rb +48 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_advapi32.rb +2102 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_crypt32.rb +32 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_iphlpapi.rb +97 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_kernel32.rb +3852 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_netapi32.rb +100 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_ntdll.rb +168 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_psapi.rb +32 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_shell32.rb +32 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_user32.rb +3170 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_version.rb +41 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_wlanapi.rb +87 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_wldap32.rb +128 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_ws2_32.rb +613 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll.rb +388 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_function.rb +111 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_helper.rb +149 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_wrapper.rb +27 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/railgun/mock_magic.rb +515 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/railgun/multicall.rb +319 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/railgun/platform_util.rb +23 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/railgun/railgun.rb +301 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/railgun/tlv.rb +56 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/railgun/type/pointer_util.rb +106 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/railgun/util.rb +676 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/railgun/win_const_manager.rb +96 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/stdapi.rb +151 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/sys/config.rb +128 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/sys/event_log.rb +192 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/sys/event_log_subsystem/event_record.rb +41 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/sys/power.rb +60 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/sys/process.rb +408 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/image.rb +129 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/io.rb +55 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/memory.rb +336 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/thread.rb +141 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry.rb +328 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry_subsystem/registry_key.rb +193 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry_subsystem/registry_value.rb +102 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry_subsystem/remote_registry_key.rb +188 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/sys/thread.rb +180 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/tlv.rb +236 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/ui.rb +259 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/webcam/webcam.rb +201 -0
- data/lib/rex/post/meterpreter/inbound_packet_handler.rb +30 -0
- data/lib/rex/post/meterpreter/object_aliases.rb +83 -0
- data/lib/rex/post/meterpreter/packet.rb +709 -0
- data/lib/rex/post/meterpreter/packet_dispatcher.rb +543 -0
- data/lib/rex/post/meterpreter/packet_parser.rb +94 -0
- data/lib/rex/post/meterpreter/packet_response_waiter.rb +83 -0
- data/lib/rex/post/meterpreter/ui/console.rb +142 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher.rb +86 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/android.rb +383 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/core.rb +939 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/espia.rb +109 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/extapi.rb +65 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/extapi/adsi.rb +198 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/extapi/clipboard.rb +444 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/extapi/service.rb +199 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/extapi/window.rb +118 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/extapi/wmi.rb +108 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/incognito.rb +242 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/kiwi.rb +509 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/lanattacks.rb +60 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/lanattacks/dhcp.rb +254 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/lanattacks/tftp.rb +159 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/mimikatz.rb +182 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/networkpug.rb +232 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv.rb +62 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/elevate.rb +97 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/passwd.rb +52 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/timestomp.rb +133 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/sniffer.rb +204 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi.rb +66 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/fs.rb +527 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/net.rb +448 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/sys.rb +906 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/ui.rb +318 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/webcam.rb +343 -0
- data/lib/rex/post/meterpreter/ui/console/interactive_channel.rb +99 -0
- data/lib/rex/post/permission.rb +26 -0
- data/lib/rex/post/process.rb +57 -0
- data/lib/rex/post/thread.rb +57 -0
- data/lib/rex/post/ui.rb +52 -0
- data/lib/rex/proto.rb +15 -0
- data/lib/rex/proto/addp.rb +218 -0
- data/lib/rex/proto/dcerpc.rb +7 -0
- data/lib/rex/proto/dcerpc/client.rb +362 -0
- data/lib/rex/proto/dcerpc/exceptions.rb +151 -0
- data/lib/rex/proto/dcerpc/handle.rb +48 -0
- data/lib/rex/proto/dcerpc/ndr.rb +73 -0
- data/lib/rex/proto/dcerpc/packet.rb +264 -0
- data/lib/rex/proto/dcerpc/response.rb +188 -0
- data/lib/rex/proto/dcerpc/uuid.rb +85 -0
- data/lib/rex/proto/dcerpc/wdscp.rb +3 -0
- data/lib/rex/proto/dcerpc/wdscp/constants.rb +89 -0
- data/lib/rex/proto/dcerpc/wdscp/packet.rb +94 -0
- data/lib/rex/proto/dhcp.rb +7 -0
- data/lib/rex/proto/dhcp/constants.rb +34 -0
- data/lib/rex/proto/dhcp/server.rb +334 -0
- data/lib/rex/proto/drda.rb +6 -0
- data/lib/rex/proto/drda/constants.rb +50 -0
- data/lib/rex/proto/drda/packet.rb +253 -0
- data/lib/rex/proto/drda/utils.rb +124 -0
- data/lib/rex/proto/http.rb +7 -0
- data/lib/rex/proto/http/client.rb +722 -0
- data/lib/rex/proto/http/client_request.rb +472 -0
- data/lib/rex/proto/http/handler.rb +47 -0
- data/lib/rex/proto/http/handler/erb.rb +129 -0
- data/lib/rex/proto/http/handler/proc.rb +61 -0
- data/lib/rex/proto/http/header.rb +173 -0
- data/lib/rex/proto/http/packet.rb +414 -0
- data/lib/rex/proto/http/request.rb +354 -0
- data/lib/rex/proto/http/response.rb +151 -0
- data/lib/rex/proto/http/server.rb +385 -0
- data/lib/rex/proto/iax2.rb +2 -0
- data/lib/rex/proto/iax2/call.rb +326 -0
- data/lib/rex/proto/iax2/client.rb +218 -0
- data/lib/rex/proto/iax2/codecs.rb +5 -0
- data/lib/rex/proto/iax2/codecs/alaw.rb +16 -0
- data/lib/rex/proto/iax2/codecs/g711.rb +2176 -0
- data/lib/rex/proto/iax2/codecs/mulaw.rb +17 -0
- data/lib/rex/proto/iax2/constants.rb +262 -0
- data/lib/rex/proto/ipmi.rb +57 -0
- data/lib/rex/proto/ipmi/channel_auth_reply.rb +89 -0
- data/lib/rex/proto/ipmi/open_session_reply.rb +36 -0
- data/lib/rex/proto/ipmi/rakp2.rb +36 -0
- data/lib/rex/proto/ipmi/utils.rb +125 -0
- data/lib/rex/proto/natpmp.rb +7 -0
- data/lib/rex/proto/natpmp/constants.rb +19 -0
- data/lib/rex/proto/natpmp/packet.rb +45 -0
- data/lib/rex/proto/ntlm.rb +8 -0
- data/lib/rex/proto/ntlm/base.rb +327 -0
- data/lib/rex/proto/ntlm/constants.rb +75 -0
- data/lib/rex/proto/ntlm/crypt.rb +412 -0
- data/lib/rex/proto/ntlm/exceptions.rb +17 -0
- data/lib/rex/proto/ntlm/message.rb +534 -0
- data/lib/rex/proto/ntlm/utils.rb +765 -0
- data/lib/rex/proto/ntp.rb +3 -0
- data/lib/rex/proto/ntp/constants.rb +12 -0
- data/lib/rex/proto/ntp/modes.rb +130 -0
- data/lib/rex/proto/pjl.rb +31 -0
- data/lib/rex/proto/pjl/client.rb +163 -0
- data/lib/rex/proto/proxy/socks4a.rb +441 -0
- data/lib/rex/proto/rfb.rb +13 -0
- data/lib/rex/proto/rfb/cipher.rb +82 -0
- data/lib/rex/proto/rfb/client.rb +205 -0
- data/lib/rex/proto/rfb/constants.rb +50 -0
- data/lib/rex/proto/sip.rb +4 -0
- data/lib/rex/proto/sip/response.rb +61 -0
- data/lib/rex/proto/smb.rb +8 -0
- data/lib/rex/proto/smb/client.rb +2064 -0
- data/lib/rex/proto/smb/constants.rb +1064 -0
- data/lib/rex/proto/smb/crypt.rb +37 -0
- data/lib/rex/proto/smb/evasions.rb +67 -0
- data/lib/rex/proto/smb/exceptions.rb +867 -0
- data/lib/rex/proto/smb/simpleclient.rb +173 -0
- data/lib/rex/proto/smb/simpleclient/open_file.rb +106 -0
- data/lib/rex/proto/smb/simpleclient/open_pipe.rb +57 -0
- data/lib/rex/proto/smb/utils.rb +104 -0
- data/lib/rex/proto/sunrpc.rb +2 -0
- data/lib/rex/proto/sunrpc/client.rb +196 -0
- data/lib/rex/proto/tftp.rb +13 -0
- data/lib/rex/proto/tftp/client.rb +344 -0
- data/lib/rex/proto/tftp/constants.rb +39 -0
- data/lib/rex/proto/tftp/server.rb +497 -0
- data/lib/rex/random_identifier_generator.rb +177 -0
- data/lib/rex/registry.rb +14 -0
- data/lib/rex/registry/hive.rb +132 -0
- data/lib/rex/registry/lfkey.rb +51 -0
- data/lib/rex/registry/nodekey.rb +54 -0
- data/lib/rex/registry/regf.rb +25 -0
- data/lib/rex/registry/valuekey.rb +67 -0
- data/lib/rex/registry/valuelist.rb +29 -0
- data/lib/rex/ropbuilder.rb +8 -0
- data/lib/rex/ropbuilder/rop.rb +271 -0
- data/lib/rex/script.rb +42 -0
- data/lib/rex/script/base.rb +61 -0
- data/lib/rex/script/meterpreter.rb +16 -0
- data/lib/rex/script/shell.rb +10 -0
- data/lib/rex/service.rb +49 -0
- data/lib/rex/service_manager.rb +154 -0
- data/lib/rex/services/local_relay.rb +424 -0
- data/lib/rex/socket.rb +788 -0
- data/lib/rex/socket/comm.rb +120 -0
- data/lib/rex/socket/comm/local.rb +526 -0
- data/lib/rex/socket/ip.rb +132 -0
- data/lib/rex/socket/parameters.rb +363 -0
- data/lib/rex/socket/range_walker.rb +470 -0
- data/lib/rex/socket/ssl_tcp.rb +345 -0
- data/lib/rex/socket/ssl_tcp_server.rb +188 -0
- data/lib/rex/socket/subnet_walker.rb +76 -0
- data/lib/rex/socket/switch_board.rb +289 -0
- data/lib/rex/socket/tcp.rb +79 -0
- data/lib/rex/socket/tcp_server.rb +67 -0
- data/lib/rex/socket/udp.rb +165 -0
- data/lib/rex/sslscan/result.rb +201 -0
- data/lib/rex/sslscan/scanner.rb +206 -0
- data/lib/rex/struct2.rb +5 -0
- data/lib/rex/struct2/c_struct.rb +181 -0
- data/lib/rex/struct2/c_struct_template.rb +39 -0
- data/lib/rex/struct2/constant.rb +26 -0
- data/lib/rex/struct2/element.rb +44 -0
- data/lib/rex/struct2/generic.rb +73 -0
- data/lib/rex/struct2/restraint.rb +54 -0
- data/lib/rex/struct2/s_string.rb +72 -0
- data/lib/rex/struct2/s_struct.rb +111 -0
- data/lib/rex/sync.rb +6 -0
- data/lib/rex/sync/event.rb +85 -0
- data/lib/rex/sync/read_write_lock.rb +177 -0
- data/lib/rex/sync/ref.rb +58 -0
- data/lib/rex/sync/thread_safe.rb +83 -0
- data/lib/rex/text.rb +1813 -0
- data/lib/rex/thread_factory.rb +43 -0
- data/lib/rex/time.rb +66 -0
- data/lib/rex/transformer.rb +116 -0
- data/lib/rex/ui.rb +22 -0
- data/lib/rex/ui/interactive.rb +304 -0
- data/lib/rex/ui/output.rb +85 -0
- data/lib/rex/ui/output/none.rb +19 -0
- data/lib/rex/ui/progress_tracker.rb +97 -0
- data/lib/rex/ui/subscriber.rb +160 -0
- data/lib/rex/ui/text/color.rb +98 -0
- data/lib/rex/ui/text/dispatcher_shell.rb +538 -0
- data/lib/rex/ui/text/input.rb +119 -0
- data/lib/rex/ui/text/input/buffer.rb +79 -0
- data/lib/rex/ui/text/input/readline.rb +129 -0
- data/lib/rex/ui/text/input/socket.rb +96 -0
- data/lib/rex/ui/text/input/stdio.rb +46 -0
- data/lib/rex/ui/text/irb_shell.rb +62 -0
- data/lib/rex/ui/text/output.rb +86 -0
- data/lib/rex/ui/text/output/buffer.rb +62 -0
- data/lib/rex/ui/text/output/buffer/stdout.rb +26 -0
- data/lib/rex/ui/text/output/file.rb +44 -0
- data/lib/rex/ui/text/output/socket.rb +44 -0
- data/lib/rex/ui/text/output/stdio.rb +53 -0
- data/lib/rex/ui/text/output/tee.rb +56 -0
- data/lib/rex/ui/text/progress_tracker.rb +57 -0
- data/lib/rex/ui/text/shell.rb +403 -0
- data/lib/rex/ui/text/table.rb +346 -0
- data/lib/rex/zip.rb +96 -0
- data/lib/rex/zip/archive.rb +130 -0
- data/lib/rex/zip/blocks.rb +184 -0
- data/lib/rex/zip/entry.rb +122 -0
- data/lib/rex/zip/jar.rb +283 -0
- data/lib/rex/zip/samples/comment.rb +32 -0
- data/lib/rex/zip/samples/mkwar.rb +138 -0
- data/lib/rex/zip/samples/mkzip.rb +19 -0
- data/lib/rex/zip/samples/recursive.rb +58 -0
- metadata +536 -0
|
@@ -0,0 +1,209 @@
|
|
|
1
|
+
# -*- coding: binary -*-
|
|
2
|
+
|
|
3
|
+
require 'socket'
|
|
4
|
+
require 'fcntl'
|
|
5
|
+
|
|
6
|
+
module Rex
|
|
7
|
+
module IO
|
|
8
|
+
|
|
9
|
+
###
|
|
10
|
+
#
|
|
11
|
+
# This class provides an abstraction to a stream based
|
|
12
|
+
# connection through the use of a streaming socketpair.
|
|
13
|
+
#
|
|
14
|
+
###
|
|
15
|
+
module StreamAbstraction
|
|
16
|
+
|
|
17
|
+
###
|
|
18
|
+
#
|
|
19
|
+
# Extension information for required Stream interface.
|
|
20
|
+
#
|
|
21
|
+
###
|
|
22
|
+
module Ext
|
|
23
|
+
|
|
24
|
+
#
|
|
25
|
+
# Initializes peer information.
|
|
26
|
+
#
|
|
27
|
+
def initinfo(peer,local)
|
|
28
|
+
@peer = peer
|
|
29
|
+
@local = local
|
|
30
|
+
end
|
|
31
|
+
|
|
32
|
+
#
|
|
33
|
+
# Symbolic peer information.
|
|
34
|
+
#
|
|
35
|
+
def peerinfo
|
|
36
|
+
(@peer || "Remote Pipe")
|
|
37
|
+
end
|
|
38
|
+
|
|
39
|
+
#
|
|
40
|
+
# Symbolic local information.
|
|
41
|
+
#
|
|
42
|
+
def localinfo
|
|
43
|
+
(@local || "Local Pipe")
|
|
44
|
+
end
|
|
45
|
+
end
|
|
46
|
+
|
|
47
|
+
#
|
|
48
|
+
# This method creates a streaming socket pair and initializes it.
|
|
49
|
+
#
|
|
50
|
+
def initialize_abstraction
|
|
51
|
+
self.lsock, self.rsock = Rex::Socket.tcp_socket_pair()
|
|
52
|
+
self.lsock.extend(Rex::IO::Stream)
|
|
53
|
+
self.lsock.extend(Ext)
|
|
54
|
+
self.rsock.extend(Rex::IO::Stream)
|
|
55
|
+
|
|
56
|
+
self.monitor_rsock
|
|
57
|
+
end
|
|
58
|
+
|
|
59
|
+
#
|
|
60
|
+
# This method cleans up the abstraction layer.
|
|
61
|
+
#
|
|
62
|
+
def cleanup_abstraction
|
|
63
|
+
self.lsock.close if (self.lsock)
|
|
64
|
+
self.rsock.close if (self.rsock)
|
|
65
|
+
|
|
66
|
+
self.lsock = nil
|
|
67
|
+
self.rsock = nil
|
|
68
|
+
end
|
|
69
|
+
|
|
70
|
+
#
|
|
71
|
+
# Low-level write to the local side.
|
|
72
|
+
#
|
|
73
|
+
def syswrite(buffer)
|
|
74
|
+
lsock.syswrite(buffer)
|
|
75
|
+
end
|
|
76
|
+
|
|
77
|
+
#
|
|
78
|
+
# Low-level read from the local side.
|
|
79
|
+
#
|
|
80
|
+
def sysread(length)
|
|
81
|
+
lsock.sysread(length)
|
|
82
|
+
end
|
|
83
|
+
|
|
84
|
+
#
|
|
85
|
+
# Shuts down the local side of the stream abstraction.
|
|
86
|
+
#
|
|
87
|
+
def shutdown(how)
|
|
88
|
+
lsock.shutdown(how)
|
|
89
|
+
end
|
|
90
|
+
|
|
91
|
+
#
|
|
92
|
+
# Closes both sides of the stream abstraction.
|
|
93
|
+
#
|
|
94
|
+
def close
|
|
95
|
+
cleanup_abstraction
|
|
96
|
+
end
|
|
97
|
+
|
|
98
|
+
#
|
|
99
|
+
# Symbolic peer information.
|
|
100
|
+
#
|
|
101
|
+
def peerinfo
|
|
102
|
+
"Remote-side of Pipe"
|
|
103
|
+
end
|
|
104
|
+
|
|
105
|
+
#
|
|
106
|
+
# Symbolic local information.
|
|
107
|
+
#
|
|
108
|
+
def localinfo
|
|
109
|
+
"Local-side of Pipe"
|
|
110
|
+
end
|
|
111
|
+
|
|
112
|
+
#
|
|
113
|
+
# The left side of the stream.
|
|
114
|
+
#
|
|
115
|
+
attr_reader :lsock
|
|
116
|
+
#
|
|
117
|
+
# The right side of the stream.
|
|
118
|
+
#
|
|
119
|
+
attr_reader :rsock
|
|
120
|
+
|
|
121
|
+
protected
|
|
122
|
+
|
|
123
|
+
def monitor_rsock
|
|
124
|
+
self.monitor_thread = Rex::ThreadFactory.spawn("StreamMonitorRemote", false) {
|
|
125
|
+
loop do
|
|
126
|
+
closed = false
|
|
127
|
+
buf = nil
|
|
128
|
+
|
|
129
|
+
if not self.rsock
|
|
130
|
+
wlog("monitor_rsock: the remote socket is nil, exiting loop")
|
|
131
|
+
break
|
|
132
|
+
end
|
|
133
|
+
|
|
134
|
+
begin
|
|
135
|
+
s = Rex::ThreadSafe.select( [ self.rsock ], nil, nil, 0.2 )
|
|
136
|
+
if( s == nil || s[0] == nil )
|
|
137
|
+
next
|
|
138
|
+
end
|
|
139
|
+
rescue Exception => e
|
|
140
|
+
wlog("monitor_rsock: exception during select: #{e.class} #{e}")
|
|
141
|
+
closed = true
|
|
142
|
+
end
|
|
143
|
+
|
|
144
|
+
if( closed == false )
|
|
145
|
+
begin
|
|
146
|
+
buf = self.rsock.sysread( 32768 )
|
|
147
|
+
if buf == nil
|
|
148
|
+
closed = true
|
|
149
|
+
wlog("monitor_rsock: closed remote socket due to nil read")
|
|
150
|
+
end
|
|
151
|
+
rescue EOFError => e
|
|
152
|
+
closed = true
|
|
153
|
+
dlog("monitor_rsock: EOF in rsock")
|
|
154
|
+
rescue ::Exception => e
|
|
155
|
+
closed = true
|
|
156
|
+
wlog("monitor_rsock: exception during read: #{e.class} #{e}")
|
|
157
|
+
end
|
|
158
|
+
end
|
|
159
|
+
|
|
160
|
+
if( closed == false )
|
|
161
|
+
total_sent = 0
|
|
162
|
+
total_length = buf.length
|
|
163
|
+
while( total_sent < total_length )
|
|
164
|
+
begin
|
|
165
|
+
data = buf[total_sent, buf.length]
|
|
166
|
+
|
|
167
|
+
# Note that this must be write() NOT syswrite() or put() or anything like it.
|
|
168
|
+
# Using syswrite() breaks SSL streams.
|
|
169
|
+
sent = self.write( data )
|
|
170
|
+
|
|
171
|
+
# sf: Only remove the data off the queue is write was successfull.
|
|
172
|
+
# This way we naturally perform a resend if a failure occured.
|
|
173
|
+
# Catches an edge case with meterpreter TCP channels where remote send
|
|
174
|
+
# failes gracefully and a resend is required.
|
|
175
|
+
if (sent.nil?)
|
|
176
|
+
closed = true
|
|
177
|
+
wlog("monitor_rsock: failed writing, socket must be dead")
|
|
178
|
+
break
|
|
179
|
+
elsif (sent > 0)
|
|
180
|
+
total_sent += sent
|
|
181
|
+
end
|
|
182
|
+
rescue ::IOError, ::EOFError => e
|
|
183
|
+
closed = true
|
|
184
|
+
wlog("monitor_rsock: exception during write: #{e.class} #{e}")
|
|
185
|
+
break
|
|
186
|
+
end
|
|
187
|
+
end
|
|
188
|
+
end
|
|
189
|
+
|
|
190
|
+
if( closed )
|
|
191
|
+
begin
|
|
192
|
+
self.close_write if self.respond_to?('close_write')
|
|
193
|
+
rescue IOError
|
|
194
|
+
end
|
|
195
|
+
break
|
|
196
|
+
end
|
|
197
|
+
end
|
|
198
|
+
}
|
|
199
|
+
end
|
|
200
|
+
|
|
201
|
+
protected
|
|
202
|
+
attr_accessor :monitor_thread
|
|
203
|
+
attr_writer :lsock
|
|
204
|
+
attr_writer :rsock
|
|
205
|
+
|
|
206
|
+
end
|
|
207
|
+
|
|
208
|
+
end; end
|
|
209
|
+
|
|
@@ -0,0 +1,221 @@
|
|
|
1
|
+
# -*- coding: binary -*-
|
|
2
|
+
require 'thread'
|
|
3
|
+
|
|
4
|
+
module Rex
|
|
5
|
+
module IO
|
|
6
|
+
|
|
7
|
+
###
|
|
8
|
+
#
|
|
9
|
+
# This mixin provides the framework and interface for implementing a streaming
|
|
10
|
+
# server that can listen for and accept stream client connections. Stream
|
|
11
|
+
# servers extend this class and are required to implement the following
|
|
12
|
+
# methods:
|
|
13
|
+
#
|
|
14
|
+
# accept
|
|
15
|
+
# fd
|
|
16
|
+
#
|
|
17
|
+
###
|
|
18
|
+
module StreamServer
|
|
19
|
+
|
|
20
|
+
##
|
|
21
|
+
#
|
|
22
|
+
# Abstract methods
|
|
23
|
+
#
|
|
24
|
+
##
|
|
25
|
+
|
|
26
|
+
##
|
|
27
|
+
#
|
|
28
|
+
# Default server monitoring and client management implementation follows
|
|
29
|
+
# below.
|
|
30
|
+
#
|
|
31
|
+
##
|
|
32
|
+
|
|
33
|
+
#
|
|
34
|
+
# This callback is notified when a client connects.
|
|
35
|
+
#
|
|
36
|
+
def on_client_connect(client)
|
|
37
|
+
if (on_client_connect_proc)
|
|
38
|
+
on_client_connect_proc.call(client)
|
|
39
|
+
end
|
|
40
|
+
end
|
|
41
|
+
|
|
42
|
+
#
|
|
43
|
+
# This callback is notified when a client connection has data that needs to
|
|
44
|
+
# be processed.
|
|
45
|
+
#
|
|
46
|
+
def on_client_data(client)
|
|
47
|
+
if (on_client_data_proc)
|
|
48
|
+
on_client_data_proc.call(client)
|
|
49
|
+
end
|
|
50
|
+
end
|
|
51
|
+
|
|
52
|
+
#
|
|
53
|
+
# This callback is notified when a client connection has closed.
|
|
54
|
+
#
|
|
55
|
+
def on_client_close(client)
|
|
56
|
+
if (on_client_close_proc)
|
|
57
|
+
on_client_close_proc.call(client)
|
|
58
|
+
end
|
|
59
|
+
end
|
|
60
|
+
|
|
61
|
+
#
|
|
62
|
+
# Start monitoring the listener socket for connections and keep track of
|
|
63
|
+
# all client connections.
|
|
64
|
+
#
|
|
65
|
+
def start
|
|
66
|
+
self.clients = []
|
|
67
|
+
self.client_waiter = ::Queue.new
|
|
68
|
+
|
|
69
|
+
self.listener_thread = Rex::ThreadFactory.spawn("StreamServerListener", false) {
|
|
70
|
+
monitor_listener
|
|
71
|
+
}
|
|
72
|
+
self.clients_thread = Rex::ThreadFactory.spawn("StreamServerClientMonitor", false) {
|
|
73
|
+
monitor_clients
|
|
74
|
+
}
|
|
75
|
+
end
|
|
76
|
+
|
|
77
|
+
#
|
|
78
|
+
# Terminates the listener monitoring threads and closes all active clients.
|
|
79
|
+
#
|
|
80
|
+
def stop
|
|
81
|
+
self.listener_thread.kill
|
|
82
|
+
self.clients_thread.kill
|
|
83
|
+
|
|
84
|
+
self.clients.each { |cli|
|
|
85
|
+
close_client(cli)
|
|
86
|
+
}
|
|
87
|
+
end
|
|
88
|
+
|
|
89
|
+
#
|
|
90
|
+
# This method closes a client connection and cleans up the resources
|
|
91
|
+
# associated with it.
|
|
92
|
+
#
|
|
93
|
+
def close_client(client)
|
|
94
|
+
if (client)
|
|
95
|
+
clients.delete(client)
|
|
96
|
+
|
|
97
|
+
begin
|
|
98
|
+
client.close
|
|
99
|
+
rescue IOError
|
|
100
|
+
end
|
|
101
|
+
end
|
|
102
|
+
end
|
|
103
|
+
|
|
104
|
+
#
|
|
105
|
+
# This method waits on the server listener thread
|
|
106
|
+
#
|
|
107
|
+
def wait
|
|
108
|
+
self.listener_thread.join if self.listener_thread
|
|
109
|
+
end
|
|
110
|
+
|
|
111
|
+
##
|
|
112
|
+
#
|
|
113
|
+
# Callback procedures.
|
|
114
|
+
#
|
|
115
|
+
##
|
|
116
|
+
|
|
117
|
+
#
|
|
118
|
+
# This callback procedure can be set and will be called when new clients
|
|
119
|
+
# connect.
|
|
120
|
+
#
|
|
121
|
+
attr_accessor :on_client_connect_proc
|
|
122
|
+
#
|
|
123
|
+
# This callback procedure can be set and will be called when clients
|
|
124
|
+
# have data to be processed.
|
|
125
|
+
#
|
|
126
|
+
attr_accessor :on_client_data_proc
|
|
127
|
+
#
|
|
128
|
+
# This callback procedure can be set and will be called when a client
|
|
129
|
+
# disconnects from the server.
|
|
130
|
+
#
|
|
131
|
+
attr_accessor :on_client_close_proc
|
|
132
|
+
|
|
133
|
+
attr_accessor :clients # :nodoc:
|
|
134
|
+
attr_accessor :listener_thread, :clients_thread # :nodoc:
|
|
135
|
+
attr_accessor :client_waiter
|
|
136
|
+
|
|
137
|
+
protected
|
|
138
|
+
|
|
139
|
+
#
|
|
140
|
+
# This method monitors the listener socket for new connections and calls
|
|
141
|
+
# the +on_client_connect+ callback routine.
|
|
142
|
+
#
|
|
143
|
+
def monitor_listener
|
|
144
|
+
|
|
145
|
+
while true
|
|
146
|
+
begin
|
|
147
|
+
cli = accept
|
|
148
|
+
if not cli
|
|
149
|
+
elog("The accept() returned nil in stream server listener monitor: #{fd.inspect}")
|
|
150
|
+
::IO.select(nil, nil, nil, 0.10)
|
|
151
|
+
next
|
|
152
|
+
end
|
|
153
|
+
|
|
154
|
+
# Append to the list of clients
|
|
155
|
+
self.clients << cli
|
|
156
|
+
|
|
157
|
+
# Initialize the connection processing
|
|
158
|
+
on_client_connect(cli)
|
|
159
|
+
|
|
160
|
+
# Notify the client monitor
|
|
161
|
+
self.client_waiter.push(cli)
|
|
162
|
+
|
|
163
|
+
# Skip exceptions caused by accept() [ SSL ]
|
|
164
|
+
rescue ::EOFError, ::Errno::ECONNRESET, ::Errno::ENOTCONN, ::Errno::ECONNABORTED
|
|
165
|
+
rescue ::Interrupt
|
|
166
|
+
raise $!
|
|
167
|
+
rescue ::Exception
|
|
168
|
+
elog("Error in stream server server monitor: #{$!}")
|
|
169
|
+
rlog(ExceptionCallStack)
|
|
170
|
+
break
|
|
171
|
+
end
|
|
172
|
+
end
|
|
173
|
+
end
|
|
174
|
+
|
|
175
|
+
#
|
|
176
|
+
# This method monitors client connections for data and calls the
|
|
177
|
+
# +on_client_data+ routine when new data arrives.
|
|
178
|
+
#
|
|
179
|
+
def monitor_clients
|
|
180
|
+
begin
|
|
181
|
+
|
|
182
|
+
# Wait for a notify if our client list is empty
|
|
183
|
+
if (clients.length == 0)
|
|
184
|
+
self.client_waiter.pop
|
|
185
|
+
next
|
|
186
|
+
end
|
|
187
|
+
|
|
188
|
+
sd = Rex::ThreadSafe.select(clients, nil, nil, nil)
|
|
189
|
+
|
|
190
|
+
sd[0].each { |cfd|
|
|
191
|
+
begin
|
|
192
|
+
on_client_data(cfd)
|
|
193
|
+
rescue ::EOFError, ::Errno::ECONNRESET, ::Errno::ENOTCONN, ::Errno::ECONNABORTED
|
|
194
|
+
on_client_close(cfd)
|
|
195
|
+
close_client(cfd)
|
|
196
|
+
rescue ::Interrupt
|
|
197
|
+
raise $!
|
|
198
|
+
rescue ::Exception
|
|
199
|
+
close_client(cfd)
|
|
200
|
+
elog("Error in stream server client monitor: #{$!}")
|
|
201
|
+
rlog(ExceptionCallStack)
|
|
202
|
+
|
|
203
|
+
end
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
rescue ::Rex::StreamClosedError => e
|
|
207
|
+
# Remove the closed stream from the list
|
|
208
|
+
clients.delete(e.stream)
|
|
209
|
+
rescue ::Interrupt
|
|
210
|
+
raise $!
|
|
211
|
+
rescue ::Exception
|
|
212
|
+
elog("Error in stream server client monitor: #{$!}")
|
|
213
|
+
rlog(ExceptionCallStack)
|
|
214
|
+
end while true
|
|
215
|
+
end
|
|
216
|
+
|
|
217
|
+
end
|
|
218
|
+
|
|
219
|
+
end
|
|
220
|
+
end
|
|
221
|
+
|
|
@@ -0,0 +1,200 @@
|
|
|
1
|
+
# -*- coding: binary -*-
|
|
2
|
+
module Rex
|
|
3
|
+
|
|
4
|
+
###
|
|
5
|
+
#
|
|
6
|
+
# This class is the concrete representation of an abstract job.
|
|
7
|
+
#
|
|
8
|
+
###
|
|
9
|
+
class Job
|
|
10
|
+
|
|
11
|
+
#
|
|
12
|
+
# Creates an individual job instance and initializes it with the supplied
|
|
13
|
+
# parameters.
|
|
14
|
+
#
|
|
15
|
+
def initialize(container, jid, name, ctx, run_proc, clean_proc)
|
|
16
|
+
self.container = container
|
|
17
|
+
self.jid = jid
|
|
18
|
+
self.name = name
|
|
19
|
+
self.run_proc = run_proc
|
|
20
|
+
self.clean_proc = clean_proc
|
|
21
|
+
self.ctx = ctx
|
|
22
|
+
self.start_time = nil
|
|
23
|
+
end
|
|
24
|
+
|
|
25
|
+
#
|
|
26
|
+
# Runs the job in the context of its own thread if the async flag is false.
|
|
27
|
+
# Otherwise, the job is run inline.
|
|
28
|
+
#
|
|
29
|
+
def start(async = false)
|
|
30
|
+
self.start_time = Time.now
|
|
31
|
+
if (async)
|
|
32
|
+
self.job_thread = Rex::ThreadFactory.spawn("JobID(#{jid})-#{name}", false) {
|
|
33
|
+
# Deschedule our thread momentarily
|
|
34
|
+
::IO.select(nil, nil, nil, 0.01)
|
|
35
|
+
|
|
36
|
+
begin
|
|
37
|
+
run_proc.call(ctx)
|
|
38
|
+
ensure
|
|
39
|
+
clean_proc.call(ctx)
|
|
40
|
+
container.remove_job(self)
|
|
41
|
+
end
|
|
42
|
+
}
|
|
43
|
+
else
|
|
44
|
+
begin
|
|
45
|
+
run_proc.call(ctx)
|
|
46
|
+
rescue ::Exception
|
|
47
|
+
container.stop_job(jid)
|
|
48
|
+
raise $!
|
|
49
|
+
end
|
|
50
|
+
end
|
|
51
|
+
end
|
|
52
|
+
|
|
53
|
+
#
|
|
54
|
+
# Stops the job if it's currently running and calls its cleanup procedure
|
|
55
|
+
#
|
|
56
|
+
def stop
|
|
57
|
+
if (self.job_thread)
|
|
58
|
+
self.job_thread.kill
|
|
59
|
+
self.job_thread = nil
|
|
60
|
+
end
|
|
61
|
+
|
|
62
|
+
clean_proc.call(ctx) if (clean_proc)
|
|
63
|
+
end
|
|
64
|
+
|
|
65
|
+
#
|
|
66
|
+
# The name of the job.
|
|
67
|
+
#
|
|
68
|
+
attr_reader :name
|
|
69
|
+
|
|
70
|
+
#
|
|
71
|
+
# The job identifier as assigned by the job container.
|
|
72
|
+
#
|
|
73
|
+
attr_reader :jid
|
|
74
|
+
|
|
75
|
+
#
|
|
76
|
+
# The time at which this job was started.
|
|
77
|
+
#
|
|
78
|
+
attr_reader :start_time
|
|
79
|
+
|
|
80
|
+
#
|
|
81
|
+
# Some job context.
|
|
82
|
+
#
|
|
83
|
+
attr_reader :ctx
|
|
84
|
+
|
|
85
|
+
protected
|
|
86
|
+
|
|
87
|
+
attr_writer :name #:nodoc:
|
|
88
|
+
attr_writer :jid #:nodoc:
|
|
89
|
+
attr_accessor :job_thread #:nodoc:
|
|
90
|
+
attr_accessor :container #:nodoc:
|
|
91
|
+
attr_accessor :run_proc #:nodoc:
|
|
92
|
+
attr_accessor :clean_proc #:nodoc:
|
|
93
|
+
attr_writer :ctx #:nodoc:
|
|
94
|
+
attr_writer :start_time #:nodoc:
|
|
95
|
+
|
|
96
|
+
end
|
|
97
|
+
|
|
98
|
+
###
|
|
99
|
+
#
|
|
100
|
+
# This class contains zero or more abstract jobs that can be enumerated and
|
|
101
|
+
# stopped in a generic fashion. This is used to provide a mechanism for
|
|
102
|
+
# keeping track of arbitrary contexts that may or may not require a dedicated
|
|
103
|
+
# thread.
|
|
104
|
+
#
|
|
105
|
+
###
|
|
106
|
+
class JobContainer < Hash
|
|
107
|
+
|
|
108
|
+
def initialize
|
|
109
|
+
self.job_id_pool = 0
|
|
110
|
+
end
|
|
111
|
+
|
|
112
|
+
#
|
|
113
|
+
# Adds an already running task as a symbolic job to the container.
|
|
114
|
+
#
|
|
115
|
+
def add_job(name, ctx, run_proc, clean_proc)
|
|
116
|
+
real_name = name
|
|
117
|
+
count = 0
|
|
118
|
+
jid = job_id_pool
|
|
119
|
+
|
|
120
|
+
self.job_id_pool += 1
|
|
121
|
+
|
|
122
|
+
# If we were not supplied with a job name, pick one from the hat
|
|
123
|
+
if (real_name == nil)
|
|
124
|
+
real_name = '#' + jid.to_s
|
|
125
|
+
end
|
|
126
|
+
|
|
127
|
+
# Find a unique job name
|
|
128
|
+
while (j = self[real_name])
|
|
129
|
+
real_name = name + " #{count}"
|
|
130
|
+
count += 1
|
|
131
|
+
end
|
|
132
|
+
|
|
133
|
+
j = Job.new(self, jid, real_name, ctx, run_proc, clean_proc)
|
|
134
|
+
|
|
135
|
+
self[jid.to_s] = j
|
|
136
|
+
end
|
|
137
|
+
|
|
138
|
+
#
|
|
139
|
+
# Starts a job using the supplied name and run/clean procedures.
|
|
140
|
+
#
|
|
141
|
+
def start_job(name, ctx, run_proc, clean_proc = nil)
|
|
142
|
+
j = add_job(name, ctx, run_proc, clean_proc)
|
|
143
|
+
j.start
|
|
144
|
+
|
|
145
|
+
j.jid
|
|
146
|
+
end
|
|
147
|
+
|
|
148
|
+
#
|
|
149
|
+
# Starts a background job that doesn't call the cleanup routine or run
|
|
150
|
+
# the run_proc in its own thread. Rather, the run_proc is called
|
|
151
|
+
# immediately and the clean_proc is never called until the job is removed
|
|
152
|
+
# from the job container.
|
|
153
|
+
#
|
|
154
|
+
def start_bg_job(name, ctx, run_proc, clean_proc = nil, async = true)
|
|
155
|
+
j = add_job(name, ctx, run_proc, clean_proc)
|
|
156
|
+
j.start(async)
|
|
157
|
+
|
|
158
|
+
j.jid
|
|
159
|
+
end
|
|
160
|
+
|
|
161
|
+
#
|
|
162
|
+
# Stops the job with the supplied name and forces it to cleanup. Stopping
|
|
163
|
+
# the job also leads to its removal.
|
|
164
|
+
#
|
|
165
|
+
def stop_job(jid)
|
|
166
|
+
if (j = self[jid.to_s])
|
|
167
|
+
j.stop
|
|
168
|
+
|
|
169
|
+
remove_job(j)
|
|
170
|
+
end
|
|
171
|
+
end
|
|
172
|
+
|
|
173
|
+
#
|
|
174
|
+
# Removes a job that was previously running. This is typically called when
|
|
175
|
+
# a job completes its task.
|
|
176
|
+
#
|
|
177
|
+
def remove_job(inst)
|
|
178
|
+
self.delete(inst.jid.to_s)
|
|
179
|
+
end
|
|
180
|
+
|
|
181
|
+
#
|
|
182
|
+
# Overrides the builtin 'each' operator to avoid the following exception on Ruby 1.9.2+
|
|
183
|
+
# "can't add a new key into hash during iteration"
|
|
184
|
+
#
|
|
185
|
+
def each(&block)
|
|
186
|
+
list = []
|
|
187
|
+
self.keys.sort.each do |sidx|
|
|
188
|
+
list << [sidx, self[sidx]]
|
|
189
|
+
end
|
|
190
|
+
list.each(&block)
|
|
191
|
+
end
|
|
192
|
+
|
|
193
|
+
protected
|
|
194
|
+
|
|
195
|
+
attr_accessor :job_id_pool # :nodoc:
|
|
196
|
+
|
|
197
|
+
end
|
|
198
|
+
|
|
199
|
+
end
|
|
200
|
+
|