librex 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.
- data/README +4 -0
- data/lib/rex.rb +101 -0
- data/lib/rex.rb.ts.rb +70 -0
- data/lib/rex/LICENSE +29 -0
- data/lib/rex/arch.rb +103 -0
- data/lib/rex/arch/sparc.rb +75 -0
- data/lib/rex/arch/sparc.rb.ut.rb +18 -0
- data/lib/rex/arch/x86.rb +513 -0
- data/lib/rex/arch/x86.rb.ut.rb +93 -0
- data/lib/rex/assembly/nasm.rb +100 -0
- data/lib/rex/assembly/nasm.rb.ut.rb +22 -0
- data/lib/rex/codepage.map +104 -0
- data/lib/rex/compat.rb +281 -0
- data/lib/rex/constants.rb +113 -0
- data/lib/rex/elfparsey.rb +11 -0
- data/lib/rex/elfparsey/elf.rb +123 -0
- data/lib/rex/elfparsey/elfbase.rb +260 -0
- data/lib/rex/elfparsey/exceptions.rb +27 -0
- data/lib/rex/elfscan.rb +12 -0
- data/lib/rex/elfscan/scanner.rb +207 -0
- data/lib/rex/elfscan/search.rb +46 -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 +113 -0
- data/lib/rex/encoder/alpha2/unicode_mixed.rb +117 -0
- data/lib/rex/encoder/alpha2/unicode_upper.rb +129 -0
- data/lib/rex/encoder/ndr.rb +89 -0
- data/lib/rex/encoder/ndr.rb.ut.rb +44 -0
- data/lib/rex/encoder/nonalpha.rb +61 -0
- data/lib/rex/encoder/nonupper.rb +64 -0
- data/lib/rex/encoder/xdr.rb +106 -0
- data/lib/rex/encoder/xdr.rb.ut.rb +29 -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/encoders/xor_dword_additive.rb.ut.rb +12 -0
- data/lib/rex/encoding/xor.rb +20 -0
- data/lib/rex/encoding/xor.rb.ts.rb +14 -0
- data/lib/rex/encoding/xor/byte.rb +15 -0
- data/lib/rex/encoding/xor/byte.rb.ut.rb +21 -0
- data/lib/rex/encoding/xor/dword.rb +21 -0
- data/lib/rex/encoding/xor/dword.rb.ut.rb +15 -0
- data/lib/rex/encoding/xor/dword_additive.rb +92 -0
- data/lib/rex/encoding/xor/dword_additive.rb.ut.rb +15 -0
- data/lib/rex/encoding/xor/exceptions.rb +17 -0
- data/lib/rex/encoding/xor/generic.rb +146 -0
- data/lib/rex/encoding/xor/generic.rb.ut.rb +120 -0
- data/lib/rex/encoding/xor/qword.rb +15 -0
- data/lib/rex/encoding/xor/word.rb +21 -0
- data/lib/rex/encoding/xor/word.rb.ut.rb +13 -0
- data/lib/rex/exceptions.rb +275 -0
- data/lib/rex/exceptions.rb.ut.rb +44 -0
- data/lib/rex/exploitation/cmdstager.rb +133 -0
- data/lib/rex/exploitation/egghunter.rb +143 -0
- data/lib/rex/exploitation/egghunter.rb.ut.rb +25 -0
- data/lib/rex/exploitation/encryptjs.rb +77 -0
- data/lib/rex/exploitation/heaplib.js.b64 +331 -0
- data/lib/rex/exploitation/heaplib.rb +94 -0
- data/lib/rex/exploitation/javascriptosdetect.rb +735 -0
- data/lib/rex/exploitation/obfuscatejs.rb +335 -0
- data/lib/rex/exploitation/opcodedb.rb +818 -0
- data/lib/rex/exploitation/opcodedb.rb.ut.rb +279 -0
- data/lib/rex/exploitation/seh.rb +92 -0
- data/lib/rex/exploitation/seh.rb.ut.rb +19 -0
- data/lib/rex/file.rb +84 -0
- data/lib/rex/file.rb.ut.rb +16 -0
- data/lib/rex/image_source.rb +12 -0
- data/lib/rex/image_source/disk.rb +60 -0
- data/lib/rex/image_source/image_source.rb +46 -0
- data/lib/rex/image_source/memory.rb +37 -0
- data/lib/rex/io/bidirectional_pipe.rb +157 -0
- data/lib/rex/io/datagram_abstraction.rb +35 -0
- data/lib/rex/io/stream.rb +313 -0
- data/lib/rex/io/stream_abstraction.rb +186 -0
- data/lib/rex/io/stream_server.rb +211 -0
- data/lib/rex/job_container.rb +202 -0
- data/lib/rex/logging.rb +4 -0
- data/lib/rex/logging/log_dispatcher.rb +179 -0
- data/lib/rex/logging/log_sink.rb +42 -0
- data/lib/rex/logging/sinks/flatfile.rb +55 -0
- data/lib/rex/logging/sinks/stderr.rb +43 -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 +9 -0
- data/lib/rex/mime/header.rb +75 -0
- data/lib/rex/mime/message.rb +112 -0
- data/lib/rex/mime/part.rb +20 -0
- data/lib/rex/nop/opty2.rb +108 -0
- data/lib/rex/nop/opty2.rb.ut.rb +23 -0
- data/lib/rex/nop/opty2_tables.rb +300 -0
- data/lib/rex/ole.rb +128 -0
- data/lib/rex/ole/clsid.rb +47 -0
- data/lib/rex/ole/difat.rb +141 -0
- data/lib/rex/ole/directory.rb +230 -0
- data/lib/rex/ole/direntry.rb +240 -0
- data/lib/rex/ole/fat.rb +99 -0
- data/lib/rex/ole/header.rb +204 -0
- data/lib/rex/ole/minifat.rb +77 -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 +395 -0
- data/lib/rex/ole/stream.rb +53 -0
- data/lib/rex/ole/substorage.rb +49 -0
- data/lib/rex/ole/util.rb +157 -0
- data/lib/rex/parser/arguments.rb +97 -0
- data/lib/rex/parser/arguments.rb.ut.rb +67 -0
- data/lib/rex/parser/ini.rb +185 -0
- data/lib/rex/parser/ini.rb.ut.rb +29 -0
- data/lib/rex/parser/nmap_xml.rb +111 -0
- data/lib/rex/payloads.rb +1 -0
- data/lib/rex/payloads/win32.rb +2 -0
- data/lib/rex/payloads/win32/common.rb +26 -0
- data/lib/rex/payloads/win32/kernel.rb +53 -0
- data/lib/rex/payloads/win32/kernel/common.rb +54 -0
- data/lib/rex/payloads/win32/kernel/migration.rb +12 -0
- data/lib/rex/payloads/win32/kernel/recovery.rb +50 -0
- data/lib/rex/payloads/win32/kernel/stager.rb +171 -0
- data/lib/rex/peparsey.rb +12 -0
- data/lib/rex/peparsey/exceptions.rb +32 -0
- data/lib/rex/peparsey/pe.rb +188 -0
- data/lib/rex/peparsey/pe_memdump.rb +63 -0
- data/lib/rex/peparsey/pebase.rb +1655 -0
- data/lib/rex/peparsey/section.rb +136 -0
- data/lib/rex/pescan.rb +13 -0
- data/lib/rex/pescan/analyze.rb +309 -0
- data/lib/rex/pescan/scanner.rb +206 -0
- data/lib/rex/pescan/search.rb +56 -0
- data/lib/rex/platforms.rb +1 -0
- data/lib/rex/platforms/windows.rb +51 -0
- data/lib/rex/poly.rb +132 -0
- data/lib/rex/poly/block.rb +468 -0
- data/lib/rex/poly/register.rb +100 -0
- data/lib/rex/poly/register/x86.rb +40 -0
- data/lib/rex/post.rb +8 -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 +4 -0
- data/lib/rex/post/meterpreter/channel.rb +438 -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 +335 -0
- data/lib/rex/post/meterpreter/client_core.rb +274 -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/espia/espia.rb +58 -0
- data/lib/rex/post/meterpreter/extensions/espia/tlv.rb +16 -0
- data/lib/rex/post/meterpreter/extensions/incognito/incognito.rb +94 -0
- data/lib/rex/post/meterpreter/extensions/incognito/tlv.rb +21 -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 +104 -0
- data/lib/rex/post/meterpreter/extensions/priv/tlv.rb +28 -0
- data/lib/rex/post/meterpreter/extensions/sniffer/sniffer.rb +100 -0
- data/lib/rex/post/meterpreter/extensions/sniffer/tlv.rb +24 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/constants.rb +333 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/fs/dir.rb +273 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/fs/file.rb +235 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/fs/file_stat.rb +103 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/fs/io.rb +48 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/net/config.rb +144 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/net/interface.rb +73 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/net/route.rb +56 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/net/socket.rb +137 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/tcp_client_channel.rb +167 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/tcp_server_channel.rb +167 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/udp_channel.rb +192 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/stdapi.rb +139 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/sys/config.rb +97 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/sys/event_log.rb +184 -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 +61 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/sys/process.rb +361 -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 +279 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry_subsystem/registry_key.rb +182 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry_subsystem/registry_value.rb +102 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/sys/thread.rb +174 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/tlv.rb +185 -0
- data/lib/rex/post/meterpreter/extensions/stdapi/ui.rb +227 -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 +596 -0
- data/lib/rex/post/meterpreter/packet_dispatcher.rb +409 -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 +135 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher.rb +62 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/core.rb +595 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/espia.rb +108 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/incognito.rb +241 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv.rb +61 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/elevate.rb +98 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/passwd.rb +51 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/timestomp.rb +132 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/sniffer.rb +187 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi.rb +63 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/fs.rb +376 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/net.rb +270 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/sys.rb +484 -0
- data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/ui.rb +315 -0
- data/lib/rex/post/meterpreter/ui/console/interactive_channel.rb +95 -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 +12 -0
- data/lib/rex/proto.rb.ts.rb +8 -0
- data/lib/rex/proto/dcerpc.rb +6 -0
- data/lib/rex/proto/dcerpc.rb.ts.rb +9 -0
- data/lib/rex/proto/dcerpc/client.rb +358 -0
- data/lib/rex/proto/dcerpc/client.rb.ut.rb +491 -0
- data/lib/rex/proto/dcerpc/exceptions.rb +150 -0
- data/lib/rex/proto/dcerpc/handle.rb +47 -0
- data/lib/rex/proto/dcerpc/handle.rb.ut.rb +85 -0
- data/lib/rex/proto/dcerpc/ndr.rb +72 -0
- data/lib/rex/proto/dcerpc/ndr.rb.ut.rb +41 -0
- data/lib/rex/proto/dcerpc/packet.rb +253 -0
- data/lib/rex/proto/dcerpc/packet.rb.ut.rb +56 -0
- data/lib/rex/proto/dcerpc/response.rb +186 -0
- data/lib/rex/proto/dcerpc/response.rb.ut.rb +15 -0
- data/lib/rex/proto/dcerpc/uuid.rb +84 -0
- data/lib/rex/proto/dcerpc/uuid.rb.ut.rb +46 -0
- data/lib/rex/proto/drda.rb +5 -0
- data/lib/rex/proto/drda.rb.ts.rb +17 -0
- data/lib/rex/proto/drda/constants.rb +49 -0
- data/lib/rex/proto/drda/constants.rb.ut.rb +23 -0
- data/lib/rex/proto/drda/packet.rb +252 -0
- data/lib/rex/proto/drda/packet.rb.ut.rb +109 -0
- data/lib/rex/proto/drda/utils.rb +123 -0
- data/lib/rex/proto/drda/utils.rb.ut.rb +84 -0
- data/lib/rex/proto/http.rb +5 -0
- data/lib/rex/proto/http.rb.ts.rb +12 -0
- data/lib/rex/proto/http/client.rb +817 -0
- data/lib/rex/proto/http/client.rb.ut.rb +93 -0
- data/lib/rex/proto/http/handler.rb +46 -0
- data/lib/rex/proto/http/handler/erb.rb +128 -0
- data/lib/rex/proto/http/handler/erb.rb.ut.rb +21 -0
- data/lib/rex/proto/http/handler/erb.rb.ut.rb.rhtml +1 -0
- data/lib/rex/proto/http/handler/proc.rb +54 -0
- data/lib/rex/proto/http/handler/proc.rb.ut.rb +24 -0
- data/lib/rex/proto/http/header.rb +161 -0
- data/lib/rex/proto/http/header.rb.ut.rb +46 -0
- data/lib/rex/proto/http/packet.rb +394 -0
- data/lib/rex/proto/http/packet.rb.ut.rb +165 -0
- data/lib/rex/proto/http/request.rb +356 -0
- data/lib/rex/proto/http/request.rb.ut.rb +214 -0
- data/lib/rex/proto/http/response.rb +85 -0
- data/lib/rex/proto/http/response.rb.ut.rb +149 -0
- data/lib/rex/proto/http/server.rb +367 -0
- data/lib/rex/proto/http/server.rb.ut.rb +79 -0
- data/lib/rex/proto/smb.rb +7 -0
- data/lib/rex/proto/smb.rb.ts.rb +8 -0
- data/lib/rex/proto/smb/client.rb +1733 -0
- data/lib/rex/proto/smb/client.rb.ut.rb +223 -0
- data/lib/rex/proto/smb/constants.rb +1062 -0
- data/lib/rex/proto/smb/constants.rb.ut.rb +18 -0
- data/lib/rex/proto/smb/crypt.rb +95 -0
- data/lib/rex/proto/smb/crypt.rb.ut.rb +20 -0
- data/lib/rex/proto/smb/evasions.rb +65 -0
- data/lib/rex/proto/smb/exceptions.rb +846 -0
- data/lib/rex/proto/smb/simpleclient.rb +292 -0
- data/lib/rex/proto/smb/simpleclient.rb.ut.rb +128 -0
- data/lib/rex/proto/smb/utils.rb +514 -0
- data/lib/rex/proto/smb/utils.rb.ut.rb +20 -0
- data/lib/rex/proto/sunrpc.rb +1 -0
- data/lib/rex/proto/sunrpc/client.rb +195 -0
- data/lib/rex/script.rb +42 -0
- data/lib/rex/script/base.rb +59 -0
- data/lib/rex/script/meterpreter.rb +9 -0
- data/lib/rex/script/shell.rb +9 -0
- data/lib/rex/service.rb +48 -0
- data/lib/rex/service_manager.rb +141 -0
- data/lib/rex/service_manager.rb.ut.rb +32 -0
- data/lib/rex/services/local_relay.rb +423 -0
- data/lib/rex/socket.rb +586 -0
- data/lib/rex/socket.rb.ut.rb +86 -0
- data/lib/rex/socket/comm.rb +119 -0
- data/lib/rex/socket/comm/local.rb +409 -0
- data/lib/rex/socket/comm/local.rb.ut.rb +75 -0
- data/lib/rex/socket/ip.rb +129 -0
- data/lib/rex/socket/parameters.rb +345 -0
- data/lib/rex/socket/parameters.rb.ut.rb +51 -0
- data/lib/rex/socket/range_walker.rb +295 -0
- data/lib/rex/socket/range_walker.rb.ut.rb +55 -0
- data/lib/rex/socket/ssl_tcp.rb +184 -0
- data/lib/rex/socket/ssl_tcp.rb.ut.rb +39 -0
- data/lib/rex/socket/ssl_tcp_server.rb +122 -0
- data/lib/rex/socket/ssl_tcp_server.rb.ut.rb +51 -0
- data/lib/rex/socket/subnet_walker.rb +75 -0
- data/lib/rex/socket/subnet_walker.rb.ut.rb +28 -0
- data/lib/rex/socket/switch_board.rb +272 -0
- data/lib/rex/socket/switch_board.rb.ut.rb +52 -0
- data/lib/rex/socket/tcp.rb +76 -0
- data/lib/rex/socket/tcp.rb.ut.rb +64 -0
- data/lib/rex/socket/tcp_server.rb +67 -0
- data/lib/rex/socket/tcp_server.rb.ut.rb +44 -0
- data/lib/rex/socket/udp.rb +157 -0
- data/lib/rex/socket/udp.rb.ut.rb +44 -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 +94 -0
- data/lib/rex/sync/read_write_lock.rb +176 -0
- data/lib/rex/sync/ref.rb +57 -0
- data/lib/rex/sync/thread_safe.rb +82 -0
- data/lib/rex/test.rb +35 -0
- data/lib/rex/text.rb +1029 -0
- data/lib/rex/text.rb.ut.rb +168 -0
- data/lib/rex/time.rb +65 -0
- data/lib/rex/transformer.rb +115 -0
- data/lib/rex/transformer.rb.ut.rb +38 -0
- data/lib/rex/ui.rb +21 -0
- data/lib/rex/ui/interactive.rb +252 -0
- data/lib/rex/ui/output.rb +80 -0
- data/lib/rex/ui/output/none.rb +18 -0
- data/lib/rex/ui/progress_tracker.rb +96 -0
- data/lib/rex/ui/subscriber.rb +149 -0
- data/lib/rex/ui/text/color.rb +97 -0
- data/lib/rex/ui/text/color.rb.ut.rb +18 -0
- data/lib/rex/ui/text/dispatcher_shell.rb +382 -0
- data/lib/rex/ui/text/input.rb +117 -0
- data/lib/rex/ui/text/input/buffer.rb +75 -0
- data/lib/rex/ui/text/input/readline.rb +129 -0
- data/lib/rex/ui/text/input/socket.rb +95 -0
- data/lib/rex/ui/text/input/stdio.rb +45 -0
- data/lib/rex/ui/text/irb_shell.rb +55 -0
- data/lib/rex/ui/text/output.rb +80 -0
- data/lib/rex/ui/text/output/buffer.rb +65 -0
- data/lib/rex/ui/text/output/file.rb +37 -0
- data/lib/rex/ui/text/output/socket.rb +43 -0
- data/lib/rex/ui/text/output/stdio.rb +40 -0
- data/lib/rex/ui/text/progress_tracker.rb +56 -0
- data/lib/rex/ui/text/progress_tracker.rb.ut.rb +34 -0
- data/lib/rex/ui/text/shell.rb +321 -0
- data/lib/rex/ui/text/table.rb +254 -0
- data/lib/rex/ui/text/table.rb.ut.rb +55 -0
- data/lib/rex/zip.rb +93 -0
- data/lib/rex/zip/archive.rb +91 -0
- data/lib/rex/zip/blocks.rb +182 -0
- data/lib/rex/zip/entry.rb +95 -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 +435 -0
|
@@ -0,0 +1,167 @@
|
|
|
1
|
+
#!/usr/bin/env ruby
|
|
2
|
+
|
|
3
|
+
require 'thread'
|
|
4
|
+
require 'rex/post/meterpreter/channel'
|
|
5
|
+
require 'rex/post/meterpreter/channels/stream'
|
|
6
|
+
require 'rex/post/meterpreter/extensions/stdapi/tlv'
|
|
7
|
+
|
|
8
|
+
module Rex
|
|
9
|
+
module Post
|
|
10
|
+
module Meterpreter
|
|
11
|
+
module Extensions
|
|
12
|
+
module Stdapi
|
|
13
|
+
module Net
|
|
14
|
+
module SocketSubsystem
|
|
15
|
+
|
|
16
|
+
###
|
|
17
|
+
#
|
|
18
|
+
# This class represents a logical TCP client connection
|
|
19
|
+
# that is established from the remote machine and tunnelled
|
|
20
|
+
# through the established meterpreter connection, similar to an
|
|
21
|
+
# SSH port forward.
|
|
22
|
+
#
|
|
23
|
+
###
|
|
24
|
+
class TcpClientChannel < Rex::Post::Meterpreter::Stream
|
|
25
|
+
|
|
26
|
+
class << self
|
|
27
|
+
def cls
|
|
28
|
+
return CHANNEL_CLASS_STREAM
|
|
29
|
+
end
|
|
30
|
+
end
|
|
31
|
+
|
|
32
|
+
module SocketInterface
|
|
33
|
+
def type?
|
|
34
|
+
'tcp'
|
|
35
|
+
end
|
|
36
|
+
|
|
37
|
+
def getsockname
|
|
38
|
+
return super if not channel
|
|
39
|
+
# Find the first host in our chain (our address)
|
|
40
|
+
hops = 0
|
|
41
|
+
csock = channel.client.sock
|
|
42
|
+
while(csock.respond_to?('channel'))
|
|
43
|
+
csock = csock.channel.client.sock
|
|
44
|
+
hops += 1
|
|
45
|
+
end
|
|
46
|
+
tmp,caddr,cport = csock.getsockname
|
|
47
|
+
tmp,raddr,rport = csock.getpeername
|
|
48
|
+
maddr,mport = [ channel.params.localhost, channel.params.localport ]
|
|
49
|
+
[ tmp, "#{caddr}#{(hops > 0) ? "-_#{hops}_" : ""}-#{raddr}", "#{mport}" ]
|
|
50
|
+
end
|
|
51
|
+
|
|
52
|
+
def getpeername
|
|
53
|
+
return super if not channel
|
|
54
|
+
tmp,caddr,cport = channel.client.sock.getpeername
|
|
55
|
+
maddr,mport = [ channel.params.peerhost, channel.params.peerport ]
|
|
56
|
+
[ tmp, "#{maddr}", "#{mport}" ]
|
|
57
|
+
end
|
|
58
|
+
|
|
59
|
+
attr_accessor :channel
|
|
60
|
+
end
|
|
61
|
+
|
|
62
|
+
#
|
|
63
|
+
# Simple mixin for lsock in order to help avoid a ruby interpreter issue with ::Socket.pair
|
|
64
|
+
# Instead of writing to the lsock, reading from the rsock and then writing to the channel,
|
|
65
|
+
# we use this mixin to directly write to the channel.
|
|
66
|
+
#
|
|
67
|
+
# Note: This does not work with OpenSSL as OpenSSL is implemented nativly and requires a real
|
|
68
|
+
# socket to write to and we cant intercept the sockets syswrite at a native level.
|
|
69
|
+
#
|
|
70
|
+
# Note: The deadlock only seems to effect the Ruby build for cygwin.
|
|
71
|
+
#
|
|
72
|
+
module DirectChannelWrite
|
|
73
|
+
|
|
74
|
+
def syswrite( buf )
|
|
75
|
+
channel._write( buf )
|
|
76
|
+
end
|
|
77
|
+
|
|
78
|
+
attr_accessor :channel
|
|
79
|
+
end
|
|
80
|
+
|
|
81
|
+
##
|
|
82
|
+
#
|
|
83
|
+
# Factory
|
|
84
|
+
#
|
|
85
|
+
##
|
|
86
|
+
|
|
87
|
+
#
|
|
88
|
+
# Opens a TCP client channel using the supplied parameters.
|
|
89
|
+
#
|
|
90
|
+
def TcpClientChannel.open(client, params)
|
|
91
|
+
c = Channel.create(client, 'stdapi_net_tcp_client', self, CHANNEL_FLAG_SYNCHRONOUS,
|
|
92
|
+
[
|
|
93
|
+
{
|
|
94
|
+
'type' => TLV_TYPE_PEER_HOST,
|
|
95
|
+
'value' => params.peerhost
|
|
96
|
+
},
|
|
97
|
+
{
|
|
98
|
+
'type' => TLV_TYPE_PEER_PORT,
|
|
99
|
+
'value' => params.peerport
|
|
100
|
+
},
|
|
101
|
+
{
|
|
102
|
+
'type' => TLV_TYPE_LOCAL_HOST,
|
|
103
|
+
'value' => params.localhost
|
|
104
|
+
},
|
|
105
|
+
{
|
|
106
|
+
'type' => TLV_TYPE_LOCAL_PORT,
|
|
107
|
+
'value' => params.localport
|
|
108
|
+
},
|
|
109
|
+
{
|
|
110
|
+
'type' => TLV_TYPE_CONNECT_RETRIES,
|
|
111
|
+
'value' => params.retries
|
|
112
|
+
}
|
|
113
|
+
])
|
|
114
|
+
c.params = params
|
|
115
|
+
c
|
|
116
|
+
end
|
|
117
|
+
|
|
118
|
+
##
|
|
119
|
+
#
|
|
120
|
+
# Constructor
|
|
121
|
+
#
|
|
122
|
+
##
|
|
123
|
+
|
|
124
|
+
#
|
|
125
|
+
# Passes the channel initialization information up to the base class.
|
|
126
|
+
#
|
|
127
|
+
def initialize( client, cid, type, flags )
|
|
128
|
+
super( client, cid, type, flags )
|
|
129
|
+
|
|
130
|
+
lsock.extend( SocketInterface )
|
|
131
|
+
lsock.extend( DirectChannelWrite )
|
|
132
|
+
lsock.channel = self
|
|
133
|
+
|
|
134
|
+
rsock.extend( SocketInterface )
|
|
135
|
+
rsock.channel = self
|
|
136
|
+
|
|
137
|
+
end
|
|
138
|
+
|
|
139
|
+
#
|
|
140
|
+
# Closes the write half of the connection.
|
|
141
|
+
#
|
|
142
|
+
def close_write
|
|
143
|
+
return shutdown(1)
|
|
144
|
+
end
|
|
145
|
+
|
|
146
|
+
#
|
|
147
|
+
# Shutdown the connection
|
|
148
|
+
#
|
|
149
|
+
# 0 -> future reads
|
|
150
|
+
# 1 -> future sends
|
|
151
|
+
# 2 -> both
|
|
152
|
+
#
|
|
153
|
+
def shutdown(how = 1)
|
|
154
|
+
request = Packet.create_request('stdapi_net_socket_tcp_shutdown')
|
|
155
|
+
|
|
156
|
+
request.add_tlv(TLV_TYPE_SHUTDOWN_HOW, how)
|
|
157
|
+
request.add_tlv(TLV_TYPE_CHANNEL_ID, self.cid)
|
|
158
|
+
|
|
159
|
+
response = client.send_request(request)
|
|
160
|
+
|
|
161
|
+
return true
|
|
162
|
+
end
|
|
163
|
+
|
|
164
|
+
end
|
|
165
|
+
|
|
166
|
+
end; end; end; end; end; end; end
|
|
167
|
+
|
|
@@ -0,0 +1,167 @@
|
|
|
1
|
+
require 'timeout'
|
|
2
|
+
require 'thread'
|
|
3
|
+
require 'rex/socket/parameters'
|
|
4
|
+
require 'rex/post/meterpreter/channels/stream'
|
|
5
|
+
require 'rex/post/meterpreter/extensions/stdapi/tlv'
|
|
6
|
+
require 'rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/tcp_client_channel'
|
|
7
|
+
|
|
8
|
+
module Rex
|
|
9
|
+
module Post
|
|
10
|
+
module Meterpreter
|
|
11
|
+
module Extensions
|
|
12
|
+
module Stdapi
|
|
13
|
+
module Net
|
|
14
|
+
module SocketSubsystem
|
|
15
|
+
|
|
16
|
+
class TcpServerChannel < Rex::Post::Meterpreter::Channel
|
|
17
|
+
|
|
18
|
+
#
|
|
19
|
+
# This is a class variable to store all pending client tcp connections which have not been passed
|
|
20
|
+
# off via a call to the respective server tcp channels accept method. The dictionary key is the
|
|
21
|
+
# tcp server channel instance and the values held are an array of pending tcp client channels
|
|
22
|
+
# connected to the tcp server channel.
|
|
23
|
+
#
|
|
24
|
+
@@server_channels = {}
|
|
25
|
+
|
|
26
|
+
class << self
|
|
27
|
+
include Rex::Post::Meterpreter::InboundPacketHandler
|
|
28
|
+
|
|
29
|
+
#
|
|
30
|
+
# This is the request handler which is registerd to the respective meterpreter instance via
|
|
31
|
+
# Rex::Post::Meterpreter::Extensions::Stdapi::Net::Socket. All incoming requests from the meterpreter
|
|
32
|
+
# for a 'tcp_channel_open' will be processed here. We create a new TcpClientChannel for each request
|
|
33
|
+
# received and store it in the respective tcp server channels list of new pending client channels.
|
|
34
|
+
# These new tcp client channels are passed off via a call the the tcp server channels accept() method.
|
|
35
|
+
#
|
|
36
|
+
def request_handler( client, packet )
|
|
37
|
+
|
|
38
|
+
if( packet.method == "tcp_channel_open" )
|
|
39
|
+
|
|
40
|
+
cid = packet.get_tlv_value( TLV_TYPE_CHANNEL_ID )
|
|
41
|
+
pid = packet.get_tlv_value( TLV_TYPE_CHANNEL_PARENTID )
|
|
42
|
+
localhost = packet.get_tlv_value( TLV_TYPE_LOCAL_HOST )
|
|
43
|
+
localport = packet.get_tlv_value( TLV_TYPE_LOCAL_PORT )
|
|
44
|
+
peerhost = packet.get_tlv_value( TLV_TYPE_PEER_HOST )
|
|
45
|
+
peerport = packet.get_tlv_value( TLV_TYPE_PEER_PORT )
|
|
46
|
+
|
|
47
|
+
if( cid == nil or pid == nil )
|
|
48
|
+
return false
|
|
49
|
+
end
|
|
50
|
+
|
|
51
|
+
server_channel = client.find_channel( pid )
|
|
52
|
+
if( server_channel == nil )
|
|
53
|
+
return false
|
|
54
|
+
end
|
|
55
|
+
|
|
56
|
+
params = Rex::Socket::Parameters.from_hash(
|
|
57
|
+
{
|
|
58
|
+
'Proto' => 'tcp',
|
|
59
|
+
'LocalHost' => localhost,
|
|
60
|
+
'LocalPort' => localport,
|
|
61
|
+
'PeerHost' => peerhost,
|
|
62
|
+
'PeerPort' => peerport,
|
|
63
|
+
'Comm' => server_channel.client
|
|
64
|
+
}
|
|
65
|
+
)
|
|
66
|
+
|
|
67
|
+
client_channel = TcpClientChannel.new( client, cid, TcpClientChannel, CHANNEL_FLAG_SYNCHRONOUS )
|
|
68
|
+
|
|
69
|
+
client_channel.params = params
|
|
70
|
+
|
|
71
|
+
if( @@server_channels[server_channel] == nil )
|
|
72
|
+
@@server_channels[server_channel] = []
|
|
73
|
+
end
|
|
74
|
+
|
|
75
|
+
@@server_channels[server_channel] << client_channel
|
|
76
|
+
|
|
77
|
+
return true
|
|
78
|
+
end
|
|
79
|
+
|
|
80
|
+
return false
|
|
81
|
+
end
|
|
82
|
+
|
|
83
|
+
def cls
|
|
84
|
+
return CHANNEL_CLASS_STREAM
|
|
85
|
+
end
|
|
86
|
+
|
|
87
|
+
end
|
|
88
|
+
|
|
89
|
+
#
|
|
90
|
+
# Open a new tcp server channel on the remote end.
|
|
91
|
+
#
|
|
92
|
+
def TcpServerChannel.open(client, params)
|
|
93
|
+
c = Channel.create(client, 'stdapi_net_tcp_server', self, CHANNEL_FLAG_SYNCHRONOUS,
|
|
94
|
+
[
|
|
95
|
+
{
|
|
96
|
+
'type' => TLV_TYPE_LOCAL_HOST,
|
|
97
|
+
'value' => params.localhost
|
|
98
|
+
},
|
|
99
|
+
{
|
|
100
|
+
'type' => TLV_TYPE_LOCAL_PORT,
|
|
101
|
+
'value' => params.localport
|
|
102
|
+
}
|
|
103
|
+
] )
|
|
104
|
+
c.params = params
|
|
105
|
+
c
|
|
106
|
+
end
|
|
107
|
+
|
|
108
|
+
#
|
|
109
|
+
# Simply initilize this instance.
|
|
110
|
+
#
|
|
111
|
+
def initialize(client, cid, type, flags)
|
|
112
|
+
super(client, cid, type, flags)
|
|
113
|
+
# add this instance to the class variables dictionary of tcp server channels
|
|
114
|
+
@@server_channels[self] = []
|
|
115
|
+
end
|
|
116
|
+
|
|
117
|
+
#
|
|
118
|
+
# Accept a new tcp client connection form this tcp server channel. This method does not block
|
|
119
|
+
# and returns nil if no new client connection is available.
|
|
120
|
+
#
|
|
121
|
+
def accept_nonblock
|
|
122
|
+
result = nil
|
|
123
|
+
if( @@server_channels[self].length > 0 )
|
|
124
|
+
channel = @@server_channels[self].shift
|
|
125
|
+
result = channel.lsock
|
|
126
|
+
end
|
|
127
|
+
return result
|
|
128
|
+
end
|
|
129
|
+
|
|
130
|
+
#
|
|
131
|
+
# Accept a new tcp client connection form this tcp server channel. This method will block indefinatly
|
|
132
|
+
# if no timeout is specified.
|
|
133
|
+
#
|
|
134
|
+
def accept( opts={} )
|
|
135
|
+
timeout = opts['Timeout'] || -1
|
|
136
|
+
if( timeout == -1 )
|
|
137
|
+
result = _accept
|
|
138
|
+
else
|
|
139
|
+
begin
|
|
140
|
+
::Timeout.timeout( timeout ) {
|
|
141
|
+
result = _accept
|
|
142
|
+
}
|
|
143
|
+
rescue Timeout::Error
|
|
144
|
+
result = nil
|
|
145
|
+
end
|
|
146
|
+
end
|
|
147
|
+
return result
|
|
148
|
+
end
|
|
149
|
+
|
|
150
|
+
protected
|
|
151
|
+
|
|
152
|
+
def _accept
|
|
153
|
+
while( true )
|
|
154
|
+
if( @@server_channels[self].empty? )
|
|
155
|
+
Rex::ThreadSafe.sleep( 0.2 )
|
|
156
|
+
next
|
|
157
|
+
end
|
|
158
|
+
result = accept_nonblock
|
|
159
|
+
break if result != nil
|
|
160
|
+
end
|
|
161
|
+
return result
|
|
162
|
+
end
|
|
163
|
+
|
|
164
|
+
end
|
|
165
|
+
|
|
166
|
+
end; end; end; end; end; end; end
|
|
167
|
+
|
|
@@ -0,0 +1,192 @@
|
|
|
1
|
+
require 'timeout'
|
|
2
|
+
require 'rex/sync/thread_safe'
|
|
3
|
+
require 'rex/socket/udp'
|
|
4
|
+
require 'rex/socket/parameters'
|
|
5
|
+
require 'rex/post/meterpreter/extensions/stdapi/tlv'
|
|
6
|
+
require 'rex/post/meterpreter/channel'
|
|
7
|
+
|
|
8
|
+
module Rex
|
|
9
|
+
module Post
|
|
10
|
+
module Meterpreter
|
|
11
|
+
module Extensions
|
|
12
|
+
module Stdapi
|
|
13
|
+
module Net
|
|
14
|
+
module SocketSubsystem
|
|
15
|
+
|
|
16
|
+
class UdpChannel < Rex::Post::Meterpreter::Channel
|
|
17
|
+
|
|
18
|
+
#
|
|
19
|
+
# We inclue Rex::Socket::Udp as this channel is effectivly a UDP socket.
|
|
20
|
+
#
|
|
21
|
+
include Rex::Socket::Udp
|
|
22
|
+
|
|
23
|
+
#
|
|
24
|
+
# We are a datagram channel.
|
|
25
|
+
#
|
|
26
|
+
class << self
|
|
27
|
+
def cls
|
|
28
|
+
return CHANNEL_CLASS_DATAGRAM
|
|
29
|
+
end
|
|
30
|
+
end
|
|
31
|
+
|
|
32
|
+
#
|
|
33
|
+
# Open a new UDP channel on the remote end. The local host/port are optional, if none are specified
|
|
34
|
+
# the remote end will bind to INADDR_ANY with a random port number. The peer host/port are also
|
|
35
|
+
# optional, if specified all default send(), write() call will sendto the specified peer. If no peer
|
|
36
|
+
# host/port is specified you must use sendto() and specify the remote peer you wish to send to. This
|
|
37
|
+
# effectivly lets us create bound/unbound and connected/unconnected UDP sockets with ease.
|
|
38
|
+
#
|
|
39
|
+
def UdpChannel.open(client, params)
|
|
40
|
+
c = Channel.create(client, 'stdapi_net_udp_client', self, CHANNEL_FLAG_SYNCHRONOUS,
|
|
41
|
+
[
|
|
42
|
+
{
|
|
43
|
+
'type' => TLV_TYPE_LOCAL_HOST,
|
|
44
|
+
'value' => params.localhost
|
|
45
|
+
},
|
|
46
|
+
{
|
|
47
|
+
'type' => TLV_TYPE_LOCAL_PORT,
|
|
48
|
+
'value' => params.localport
|
|
49
|
+
},
|
|
50
|
+
{
|
|
51
|
+
'type' => TLV_TYPE_PEER_HOST,
|
|
52
|
+
'value' => params.peerhost
|
|
53
|
+
},
|
|
54
|
+
{
|
|
55
|
+
'type' => TLV_TYPE_PEER_PORT,
|
|
56
|
+
'value' => params.peerport
|
|
57
|
+
}
|
|
58
|
+
] )
|
|
59
|
+
c.params = params
|
|
60
|
+
c
|
|
61
|
+
end
|
|
62
|
+
|
|
63
|
+
#
|
|
64
|
+
# Simply initilize this instance.
|
|
65
|
+
#
|
|
66
|
+
def initialize(client, cid, type, flags)
|
|
67
|
+
super(client, cid, type, flags)
|
|
68
|
+
# the instance variable that holds all incoming datagrams.
|
|
69
|
+
@datagrams = []
|
|
70
|
+
end
|
|
71
|
+
|
|
72
|
+
#
|
|
73
|
+
# We overwrite Rex::Socket::Udp.timed_read in order to avoid the call to Kernel.select
|
|
74
|
+
# which wont be of use as we are not a natively backed ::Socket or ::IO instance.
|
|
75
|
+
#
|
|
76
|
+
def timed_read( length=65535, timeout=def_read_timeout )
|
|
77
|
+
result = ''
|
|
78
|
+
|
|
79
|
+
begin
|
|
80
|
+
Timeout.timeout( timeout ) {
|
|
81
|
+
while( true )
|
|
82
|
+
if( @datagrams.empty? )
|
|
83
|
+
Rex::ThreadSafe.sleep( 0.2 )
|
|
84
|
+
next
|
|
85
|
+
end
|
|
86
|
+
result = self.read( length )
|
|
87
|
+
break
|
|
88
|
+
end
|
|
89
|
+
}
|
|
90
|
+
rescue Timeout::Error
|
|
91
|
+
result = ''
|
|
92
|
+
end
|
|
93
|
+
|
|
94
|
+
return result
|
|
95
|
+
end
|
|
96
|
+
|
|
97
|
+
#
|
|
98
|
+
# We overwrite Rex::Socket::Udp.recvfrom in order to correctly hand out the
|
|
99
|
+
# datagrams which the remote end of this channel has received and are in the
|
|
100
|
+
# queue.
|
|
101
|
+
#
|
|
102
|
+
def recvfrom( length=65535, timeout=def_read_timeout )
|
|
103
|
+
result = nil
|
|
104
|
+
# force a timeout on the wait for an incoming datagram
|
|
105
|
+
begin
|
|
106
|
+
Timeout.timeout( timeout ) {
|
|
107
|
+
while( true )
|
|
108
|
+
# wait untill we have at least one datagram in the queue
|
|
109
|
+
if( @datagrams.empty? )
|
|
110
|
+
Rex::ThreadSafe.sleep( 0.2 )
|
|
111
|
+
next
|
|
112
|
+
end
|
|
113
|
+
# grab the oldest datagram we have received...
|
|
114
|
+
result = @datagrams.shift
|
|
115
|
+
# break as we have a result...
|
|
116
|
+
break
|
|
117
|
+
end
|
|
118
|
+
}
|
|
119
|
+
rescue Timeout::Error
|
|
120
|
+
result = nil
|
|
121
|
+
end
|
|
122
|
+
# if no result return nothing
|
|
123
|
+
if( result == nil )
|
|
124
|
+
return [ '', nil, nil ]
|
|
125
|
+
end
|
|
126
|
+
# get the data from this datagram
|
|
127
|
+
data = result[0]
|
|
128
|
+
# if its only a partial read of this datagram, slice it, loosing the remainder.
|
|
129
|
+
result[0] = data[0,length-1] if data.length > length
|
|
130
|
+
# return the result in the form [ data, host, port ]
|
|
131
|
+
return result
|
|
132
|
+
end
|
|
133
|
+
|
|
134
|
+
#
|
|
135
|
+
# Overwrite the low level sysread to read data off our datagram queue. Calls
|
|
136
|
+
# to read() will end up calling this.
|
|
137
|
+
#
|
|
138
|
+
def sysread( length )
|
|
139
|
+
result = self.recvfrom( length )
|
|
140
|
+
return result[0]
|
|
141
|
+
end
|
|
142
|
+
|
|
143
|
+
#
|
|
144
|
+
# Overwrite the low level syswrite to write data to the remote end of the channel.
|
|
145
|
+
# Calls to write() will end up calling this.
|
|
146
|
+
#
|
|
147
|
+
def syswrite( buf )
|
|
148
|
+
return _write( buf )
|
|
149
|
+
end
|
|
150
|
+
|
|
151
|
+
#
|
|
152
|
+
# This function is called by Rex::Socket::Udp.sendto and writes data to a specified
|
|
153
|
+
# remote peer host/port via the remote end of the channel.
|
|
154
|
+
#
|
|
155
|
+
def send( buf, flags, saddr )
|
|
156
|
+
af, peerhost, peerport = Rex::Socket.from_sockaddr( saddr )
|
|
157
|
+
|
|
158
|
+
addends = [
|
|
159
|
+
{
|
|
160
|
+
'type' => TLV_TYPE_PEER_HOST,
|
|
161
|
+
'value' => peerhost
|
|
162
|
+
},
|
|
163
|
+
{
|
|
164
|
+
'type' => TLV_TYPE_PEER_PORT,
|
|
165
|
+
'value' => peerport
|
|
166
|
+
}
|
|
167
|
+
]
|
|
168
|
+
|
|
169
|
+
return _write( buf, buf.length, addends )
|
|
170
|
+
end
|
|
171
|
+
|
|
172
|
+
#
|
|
173
|
+
# The channels direct io write handler for any incoming data from the remote end
|
|
174
|
+
# of the channel. We extract the data and peer host/port, and save this to a queue
|
|
175
|
+
# of incoming datagrams which are passed out via calls to self.recvfrom()
|
|
176
|
+
#
|
|
177
|
+
def dio_write_handler( packet, data )
|
|
178
|
+
|
|
179
|
+
peerhost = packet.get_tlv_value( TLV_TYPE_PEER_HOST )
|
|
180
|
+
peerport = packet.get_tlv_value( TLV_TYPE_PEER_PORT )
|
|
181
|
+
|
|
182
|
+
if( peerhost and peerport )
|
|
183
|
+
@datagrams << [ data, peerhost, peerport ]
|
|
184
|
+
return true
|
|
185
|
+
end
|
|
186
|
+
|
|
187
|
+
return false
|
|
188
|
+
end
|
|
189
|
+
|
|
190
|
+
end
|
|
191
|
+
|
|
192
|
+
end; end; end; end; end; end; end
|