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,111 @@
|
|
|
1
|
+
# -*- coding: binary -*-
|
|
2
|
+
|
|
3
|
+
# Rex::Struct2
|
|
4
|
+
module Rex
|
|
5
|
+
module Struct2
|
|
6
|
+
|
|
7
|
+
class SStruct
|
|
8
|
+
|
|
9
|
+
require 'rex/struct2/element'
|
|
10
|
+
include Rex::Struct2::Element
|
|
11
|
+
|
|
12
|
+
attr_reader :leftover, :elements
|
|
13
|
+
attr_writer :leftover, :elements
|
|
14
|
+
|
|
15
|
+
private :elements, :elements=
|
|
16
|
+
|
|
17
|
+
# watch out!, leftover returns our copy of the string! so don't do
|
|
18
|
+
# anything stupid like struct.leftover.slice! !!
|
|
19
|
+
|
|
20
|
+
def initialize(*opts)
|
|
21
|
+
self.elements = [ ]
|
|
22
|
+
self.add_element(*opts)
|
|
23
|
+
end
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+
def reset
|
|
27
|
+
elements.each {|e| e.reset}
|
|
28
|
+
return self
|
|
29
|
+
end
|
|
30
|
+
|
|
31
|
+
def add_element(*objs)
|
|
32
|
+
objs.each { |o|
|
|
33
|
+
elements << o
|
|
34
|
+
o.container = self
|
|
35
|
+
}
|
|
36
|
+
return self
|
|
37
|
+
end
|
|
38
|
+
|
|
39
|
+
def <<(obj)
|
|
40
|
+
self.add_element(obj)
|
|
41
|
+
end
|
|
42
|
+
|
|
43
|
+
def to_s
|
|
44
|
+
# !!! what do we do on mix restraint issues? just fail?
|
|
45
|
+
# maybe throw an exception, because that is most likely
|
|
46
|
+
# a usage error
|
|
47
|
+
|
|
48
|
+
buff = ""
|
|
49
|
+
elements.each do |e|
|
|
50
|
+
buff << e.to_s
|
|
51
|
+
end
|
|
52
|
+
|
|
53
|
+
if restraint && restraint.max
|
|
54
|
+
return buff.slice(0, restraint.max)
|
|
55
|
+
else
|
|
56
|
+
return buff
|
|
57
|
+
end
|
|
58
|
+
end
|
|
59
|
+
|
|
60
|
+
def length
|
|
61
|
+
return elements.length
|
|
62
|
+
end
|
|
63
|
+
|
|
64
|
+
def [](obj)
|
|
65
|
+
return elements[obj]
|
|
66
|
+
end
|
|
67
|
+
|
|
68
|
+
def each(&block)
|
|
69
|
+
return elements.each(&block)
|
|
70
|
+
end
|
|
71
|
+
|
|
72
|
+
def from_s(obytes)
|
|
73
|
+
# make my own copy so I can chop it up
|
|
74
|
+
bytes = obytes.dup
|
|
75
|
+
length = 0
|
|
76
|
+
|
|
77
|
+
# I don't think we should call update_restraint here, but
|
|
78
|
+
# I could have mis thought or something
|
|
79
|
+
|
|
80
|
+
# if we have a restraint (and if there is a val) truncate
|
|
81
|
+
if restraint
|
|
82
|
+
max = restraint.max
|
|
83
|
+
bytes = bytes.slice(0, max) if max
|
|
84
|
+
end
|
|
85
|
+
|
|
86
|
+
elements.each { |e|
|
|
87
|
+
used = e.from_s(bytes)
|
|
88
|
+
return if !used
|
|
89
|
+
bytes.slice!(0, used)
|
|
90
|
+
length += used
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
# make sure we matched out min restraint, else return failure
|
|
94
|
+
if restraint
|
|
95
|
+
min = restraint.min
|
|
96
|
+
return if min && length < min
|
|
97
|
+
end
|
|
98
|
+
|
|
99
|
+
# I guess this is me getting "set", so I should have a value
|
|
100
|
+
# and I should update my restraints on set
|
|
101
|
+
self.value = obytes.slice(0, length)
|
|
102
|
+
|
|
103
|
+
self.leftover = bytes
|
|
104
|
+
return(length)
|
|
105
|
+
end
|
|
106
|
+
|
|
107
|
+
end
|
|
108
|
+
|
|
109
|
+
# end Rex::Struct2
|
|
110
|
+
end
|
|
111
|
+
end
|
data/lib/rex/sync.rb
ADDED
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
# -*- coding: binary -*-
|
|
2
|
+
require 'thread'
|
|
3
|
+
|
|
4
|
+
module Rex
|
|
5
|
+
module Sync
|
|
6
|
+
|
|
7
|
+
###
|
|
8
|
+
#
|
|
9
|
+
# This class wraps the logical ConditionVariable class to make it an easier to
|
|
10
|
+
# work with interface that is similar to Windows' synchronization events.
|
|
11
|
+
#
|
|
12
|
+
###
|
|
13
|
+
class Event
|
|
14
|
+
|
|
15
|
+
Infinite = 10000
|
|
16
|
+
|
|
17
|
+
#
|
|
18
|
+
# Initializes a waitable event. The state parameter initializes the
|
|
19
|
+
# default state of the event. If auto_reset is true, any calls to set()
|
|
20
|
+
# will automatically reset the event back to an unset state.
|
|
21
|
+
#
|
|
22
|
+
def initialize(state = false, auto_reset = true, param = nil)
|
|
23
|
+
self.state = state
|
|
24
|
+
self.auto_reset = auto_reset
|
|
25
|
+
self.param = param
|
|
26
|
+
self.mutex = Mutex.new
|
|
27
|
+
self.cond = ConditionVariable.new
|
|
28
|
+
end
|
|
29
|
+
|
|
30
|
+
#
|
|
31
|
+
# Sets the event and wakes up anyone who was waiting.
|
|
32
|
+
#
|
|
33
|
+
def set(param = nil)
|
|
34
|
+
self.param = param
|
|
35
|
+
|
|
36
|
+
self.mutex.synchronize {
|
|
37
|
+
# If this event does not automatically reset its state,
|
|
38
|
+
# set the state to true
|
|
39
|
+
if (auto_reset == false)
|
|
40
|
+
self.state = true
|
|
41
|
+
end
|
|
42
|
+
|
|
43
|
+
self.cond.broadcast
|
|
44
|
+
}
|
|
45
|
+
end
|
|
46
|
+
|
|
47
|
+
#
|
|
48
|
+
# Resets the signaled state to false.
|
|
49
|
+
#
|
|
50
|
+
def reset
|
|
51
|
+
self.param = nil
|
|
52
|
+
self.state = false
|
|
53
|
+
end
|
|
54
|
+
|
|
55
|
+
#
|
|
56
|
+
# Alias notify with set.
|
|
57
|
+
#
|
|
58
|
+
alias notify set
|
|
59
|
+
|
|
60
|
+
#
|
|
61
|
+
# Waits for the event to become signaled. Timeout is measured in
|
|
62
|
+
# seconds. Raises TimeoutError if the condition does not become signaled.
|
|
63
|
+
#
|
|
64
|
+
def wait(t = Infinite)
|
|
65
|
+
self.mutex.synchronize {
|
|
66
|
+
break if (self.state == true)
|
|
67
|
+
|
|
68
|
+
Timeout.timeout(t) {
|
|
69
|
+
self.cond.wait(self.mutex)
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
return self.param
|
|
74
|
+
end
|
|
75
|
+
|
|
76
|
+
protected
|
|
77
|
+
|
|
78
|
+
attr_accessor :state, :auto_reset # :nodoc:
|
|
79
|
+
attr_accessor :param, :mutex, :cond # :nodoc:
|
|
80
|
+
|
|
81
|
+
end
|
|
82
|
+
|
|
83
|
+
end
|
|
84
|
+
end
|
|
85
|
+
|
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
# -*- coding: binary -*-
|
|
2
|
+
require 'thread'
|
|
3
|
+
|
|
4
|
+
module Rex
|
|
5
|
+
|
|
6
|
+
###
|
|
7
|
+
#
|
|
8
|
+
# This class implements a read/write lock synchronization
|
|
9
|
+
# primitive. It is meant to allow for more efficient access to
|
|
10
|
+
# resources that are more often read from than written to and many
|
|
11
|
+
# times can have concurrent reader threads. By allowing the reader
|
|
12
|
+
# threads to lock the resource concurrently rather than serially,
|
|
13
|
+
# a large performance boost can be seen. Acquiring a write lock
|
|
14
|
+
# results in exclusive access to the resource and thereby prevents
|
|
15
|
+
# any read operations during the time that a write lock is acquired.
|
|
16
|
+
# Only one write lock may be acquired at a time.
|
|
17
|
+
#
|
|
18
|
+
###
|
|
19
|
+
class ReadWriteLock
|
|
20
|
+
|
|
21
|
+
#
|
|
22
|
+
# Initializes a reader/writer lock instance.
|
|
23
|
+
#
|
|
24
|
+
def initialize
|
|
25
|
+
@read_sync_mutex = Mutex.new
|
|
26
|
+
@write_sync_mutex = Mutex.new
|
|
27
|
+
@exclusive_mutex = Mutex.new
|
|
28
|
+
@readers = 0
|
|
29
|
+
@writer = false
|
|
30
|
+
end
|
|
31
|
+
|
|
32
|
+
#
|
|
33
|
+
# Acquires the read lock for the calling thread.
|
|
34
|
+
#
|
|
35
|
+
def lock_read
|
|
36
|
+
read_sync_mutex.lock
|
|
37
|
+
|
|
38
|
+
begin
|
|
39
|
+
# If there are a non-zero number of readers and a
|
|
40
|
+
# writer is waiting to acquire the exclusive lock,
|
|
41
|
+
# free up the sync mutex temporarily and lock/unlock
|
|
42
|
+
# the exclusive lock. This is to give the writer
|
|
43
|
+
# thread a chance to acquire the lock and prevents
|
|
44
|
+
# it from being constantly starved.
|
|
45
|
+
if ((@readers > 0) and
|
|
46
|
+
(@writer))
|
|
47
|
+
read_sync_mutex.unlock
|
|
48
|
+
exclusive_mutex.lock
|
|
49
|
+
exclusive_mutex.unlock
|
|
50
|
+
read_sync_mutex.lock
|
|
51
|
+
end
|
|
52
|
+
|
|
53
|
+
# Increment the active reader count
|
|
54
|
+
@readers += 1
|
|
55
|
+
|
|
56
|
+
# If we now have just one reader, acquire the exclusive
|
|
57
|
+
# lock. Track the thread owner so that we release the
|
|
58
|
+
# lock from within the same thread context later on.
|
|
59
|
+
if (@readers == 1)
|
|
60
|
+
exclusive_mutex.lock
|
|
61
|
+
|
|
62
|
+
@owner = Thread.current
|
|
63
|
+
end
|
|
64
|
+
ensure
|
|
65
|
+
read_sync_mutex.unlock
|
|
66
|
+
end
|
|
67
|
+
end
|
|
68
|
+
|
|
69
|
+
#
|
|
70
|
+
# Releases the read lock for the calling thread.
|
|
71
|
+
#
|
|
72
|
+
def unlock_read
|
|
73
|
+
read_sync_mutex.lock
|
|
74
|
+
|
|
75
|
+
begin
|
|
76
|
+
unlocked = false
|
|
77
|
+
|
|
78
|
+
# Keep looping until we've lost this thread's reader
|
|
79
|
+
# lock
|
|
80
|
+
while (!unlocked)
|
|
81
|
+
# If there are no more readers left after this one
|
|
82
|
+
if (@readers - 1 == 0)
|
|
83
|
+
# If the calling thread is the owner of the exclusive
|
|
84
|
+
# reader lock, then let's release it
|
|
85
|
+
if (Thread.current == @owner)
|
|
86
|
+
@owner = nil
|
|
87
|
+
|
|
88
|
+
exclusive_mutex.unlock
|
|
89
|
+
end
|
|
90
|
+
# If there is more than one reader left and this thread is
|
|
91
|
+
# the owner of the exclusive lock, then keep looping so that
|
|
92
|
+
# we can eventually unlock the exclusive mutex in this thread's
|
|
93
|
+
# context
|
|
94
|
+
elsif (Thread.current == @owner)
|
|
95
|
+
read_sync_mutex.unlock
|
|
96
|
+
|
|
97
|
+
next
|
|
98
|
+
end
|
|
99
|
+
|
|
100
|
+
# Unlocked!
|
|
101
|
+
unlocked = true
|
|
102
|
+
|
|
103
|
+
# Decrement the active reader count
|
|
104
|
+
@readers -= 1
|
|
105
|
+
end
|
|
106
|
+
ensure
|
|
107
|
+
read_sync_mutex.unlock
|
|
108
|
+
end
|
|
109
|
+
end
|
|
110
|
+
|
|
111
|
+
#
|
|
112
|
+
# Acquire the exclusive write lock.
|
|
113
|
+
#
|
|
114
|
+
def lock_write
|
|
115
|
+
write_sync_mutex.lock
|
|
116
|
+
|
|
117
|
+
begin
|
|
118
|
+
@writer = true
|
|
119
|
+
|
|
120
|
+
exclusive_mutex.lock
|
|
121
|
+
|
|
122
|
+
@owner = Thread.current
|
|
123
|
+
ensure
|
|
124
|
+
write_sync_mutex.unlock
|
|
125
|
+
end
|
|
126
|
+
end
|
|
127
|
+
|
|
128
|
+
#
|
|
129
|
+
# Release the exclusive write lock.
|
|
130
|
+
#
|
|
131
|
+
def unlock_write
|
|
132
|
+
# If the caller is not the owner of the write lock, then someone is
|
|
133
|
+
# doing something broken, let's let them know.
|
|
134
|
+
if (Thread.current != @owner)
|
|
135
|
+
raise RuntimeError, "Non-owner calling thread attempted to release write lock", caller
|
|
136
|
+
end
|
|
137
|
+
|
|
138
|
+
# Otherwise, release the exclusive write lock
|
|
139
|
+
@writer = false
|
|
140
|
+
|
|
141
|
+
exclusive_mutex.unlock
|
|
142
|
+
end
|
|
143
|
+
|
|
144
|
+
#
|
|
145
|
+
# Synchronize a block for read access.
|
|
146
|
+
#
|
|
147
|
+
def synchronize_read
|
|
148
|
+
lock_read
|
|
149
|
+
begin
|
|
150
|
+
yield
|
|
151
|
+
ensure
|
|
152
|
+
unlock_read
|
|
153
|
+
end
|
|
154
|
+
end
|
|
155
|
+
|
|
156
|
+
#
|
|
157
|
+
# Synchronize a block for write access.
|
|
158
|
+
#
|
|
159
|
+
def synchronize_write
|
|
160
|
+
lock_write
|
|
161
|
+
begin
|
|
162
|
+
yield
|
|
163
|
+
ensure
|
|
164
|
+
unlock_write
|
|
165
|
+
end
|
|
166
|
+
end
|
|
167
|
+
|
|
168
|
+
protected
|
|
169
|
+
|
|
170
|
+
attr_accessor :read_sync_mutex # :nodoc:
|
|
171
|
+
attr_accessor :write_sync_mutex # :nodoc:
|
|
172
|
+
attr_accessor :exclusive_mutex # :nodoc:
|
|
173
|
+
|
|
174
|
+
end
|
|
175
|
+
|
|
176
|
+
end
|
|
177
|
+
|
data/lib/rex/sync/ref.rb
ADDED
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
# -*- coding: binary -*-
|
|
2
|
+
require 'thread'
|
|
3
|
+
|
|
4
|
+
module Rex
|
|
5
|
+
|
|
6
|
+
###
|
|
7
|
+
#
|
|
8
|
+
# This module provides a uniform reference counted interface for classes to
|
|
9
|
+
# use.
|
|
10
|
+
#
|
|
11
|
+
###
|
|
12
|
+
module Ref
|
|
13
|
+
|
|
14
|
+
#
|
|
15
|
+
# Initializes the reference count to one.
|
|
16
|
+
#
|
|
17
|
+
def refinit
|
|
18
|
+
@_references = 1
|
|
19
|
+
@_references_mutex = Mutex.new
|
|
20
|
+
|
|
21
|
+
self
|
|
22
|
+
end
|
|
23
|
+
|
|
24
|
+
#
|
|
25
|
+
# Increments the total number of references.
|
|
26
|
+
#
|
|
27
|
+
def ref
|
|
28
|
+
@_references_mutex.synchronize {
|
|
29
|
+
@_references += 1
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
self
|
|
33
|
+
end
|
|
34
|
+
|
|
35
|
+
#
|
|
36
|
+
# Decrements the total number of references. If the reference count
|
|
37
|
+
# reaches zero, true is returned. Otherwise, false is returned.
|
|
38
|
+
#
|
|
39
|
+
def deref
|
|
40
|
+
@_references_mutex.synchronize {
|
|
41
|
+
if ((@_references -= 1) == 0)
|
|
42
|
+
cleanup
|
|
43
|
+
|
|
44
|
+
true
|
|
45
|
+
else
|
|
46
|
+
false
|
|
47
|
+
end
|
|
48
|
+
}
|
|
49
|
+
end
|
|
50
|
+
|
|
51
|
+
#
|
|
52
|
+
# Called to clean up resources once the ref count drops to zero.
|
|
53
|
+
#
|
|
54
|
+
def cleanup
|
|
55
|
+
end
|
|
56
|
+
|
|
57
|
+
end
|
|
58
|
+
end
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
# -*- coding: binary -*-
|
|
2
|
+
require 'timeout'
|
|
3
|
+
|
|
4
|
+
module Rex
|
|
5
|
+
|
|
6
|
+
###
|
|
7
|
+
#
|
|
8
|
+
# This module provides a set of methods for performing various blocking
|
|
9
|
+
# operations in a manner that is compatible with ruby style threads.
|
|
10
|
+
#
|
|
11
|
+
###
|
|
12
|
+
module ThreadSafe
|
|
13
|
+
|
|
14
|
+
DefaultCycle = 0.2
|
|
15
|
+
|
|
16
|
+
#
|
|
17
|
+
# Wraps calls to select with a lower timeout period and does the
|
|
18
|
+
# calculations to walk down to zero timeout. This has a little room for
|
|
19
|
+
# improvement in that it should probably check how much time actually
|
|
20
|
+
# elapsed during the select call considering ruby threading wont be exactly
|
|
21
|
+
# accurate perhaps.
|
|
22
|
+
#
|
|
23
|
+
def self.select(rfd = nil, wfd = nil, efd = nil, t = nil)
|
|
24
|
+
left = t
|
|
25
|
+
|
|
26
|
+
# Immediately raise a StreamClosedError if the socket was closed. This
|
|
27
|
+
# prevents a bad fd from being passed downstream and solves an issue
|
|
28
|
+
# with Ruby on Windows.
|
|
29
|
+
rfd.each { |fd| raise StreamClosedError.new(fd) if (fd.closed?) } if rfd
|
|
30
|
+
|
|
31
|
+
begin
|
|
32
|
+
orig_size = rfd.length if (rfd)
|
|
33
|
+
|
|
34
|
+
# Poll the set supplied to us at least once.
|
|
35
|
+
begin
|
|
36
|
+
rv = ::IO.select(rfd, wfd, efd, DefaultCycle)
|
|
37
|
+
rescue ::IOError, ::Errno::EBADF, ::Errno::ENOTSOCK
|
|
38
|
+
# If a stream was detected as being closed, re-raise the error as
|
|
39
|
+
# a StreamClosedError with the specific file descriptor that was
|
|
40
|
+
# detected as being closed. This is to better handle the case of
|
|
41
|
+
# a closed socket being detected so that it can be cleaned up and
|
|
42
|
+
# removed.
|
|
43
|
+
rfd.each { |fd| raise StreamClosedError.new(fd) if (fd.closed?) } if rfd
|
|
44
|
+
|
|
45
|
+
# If the original rfd length is not the same as the current
|
|
46
|
+
# length, then the list may have been altered and as such may not
|
|
47
|
+
# contain the socket that caused the IOError. This is a bad way
|
|
48
|
+
# to do this since it's possible that the array length could be
|
|
49
|
+
# back to the size that it was originally and yet have had the
|
|
50
|
+
# socket that caused the IOError to be removed.
|
|
51
|
+
return nil if (rfd and rfd.length != orig_size)
|
|
52
|
+
|
|
53
|
+
# Re-raise the exception since we didn't handle it here.
|
|
54
|
+
raise $!
|
|
55
|
+
# rescue ::Exception => e
|
|
56
|
+
# $stderr.puts "SELECT(#{t}) #{[rfd,wfd,efd].inspect} #{e.class} #{e} #{e.backtrace}"
|
|
57
|
+
end
|
|
58
|
+
|
|
59
|
+
return rv if (rv)
|
|
60
|
+
|
|
61
|
+
# Decrement the amount of time left by the polling cycle
|
|
62
|
+
left -= DefaultCycle if (left)
|
|
63
|
+
|
|
64
|
+
# Keep chugging until we run out of time, if time was supplied.
|
|
65
|
+
end while ((left == nil) or (left > 0))
|
|
66
|
+
|
|
67
|
+
# Nothin.
|
|
68
|
+
nil
|
|
69
|
+
end
|
|
70
|
+
|
|
71
|
+
#
|
|
72
|
+
# Simulates a sleep operation by selecting on nil until a timeout period
|
|
73
|
+
# expires.
|
|
74
|
+
#
|
|
75
|
+
def self.sleep(seconds=nil)
|
|
76
|
+
self.select(nil, nil, nil, seconds)
|
|
77
|
+
|
|
78
|
+
seconds
|
|
79
|
+
end
|
|
80
|
+
|
|
81
|
+
end
|
|
82
|
+
|
|
83
|
+
end
|