metasploit-framework/lib/rex/ui/text/input/socket.rb

97 lines
1.4 KiB
Ruby
Raw Normal View History

# -*- coding: binary -*-
require 'rex/ui'
module Rex
module Ui
module Text
###
#
# This class implements input against a socket.
#
###
class Input::Socket < Rex::Ui::Text::Input
def initialize(sock)
@sock = sock
end
#
# Sockets do not currently support readline.
#
def supports_readline
false
end
#
# Reads input from the raw socket.
#
def sysread(len = 1)
@sock.sysread(len)
end
#
# Wait for a line of input to be read from a socket.
#
def gets
2013-03-08 00:16:57 +00:00
# Initialize the line buffer
line = ''
2013-03-08 00:16:57 +00:00
# Read data one byte at a time until we see a LF
while (true)
break if line.include?("\n")
2013-03-08 00:16:57 +00:00
# Read another character of input
char = @sock.getc
if char.nil?
@sock.close
return
end
2013-03-08 00:16:57 +00:00
# Telnet sends 0x04 as EOF
if (char == 4)
@sock.write("[*] Caught ^D, closing the socket...\n")
@sock.close
return
end
2013-03-08 00:16:57 +00:00
# Append this character to the string
line << char
# Handle telnet sequences
case line
when /\xff\xf4\xff\xfd\x06/
@sock.write("[*] Caught ^C, closing the socket...\n")
@sock.close
return
2013-03-08 00:16:57 +00:00
when /\xff\xed\xff\xfd\x06/
@sock.write("[*] Caught ^Z\n")
2013-03-08 00:16:57 +00:00
return
end
end
2013-03-08 00:16:57 +00:00
return line
end
#
# Returns whether or not EOF has been reached on stdin.
#
def eof?
@sock.closed?
end
#
# Returns the file descriptor associated with a socket.
#
def fd
return @sock
end
end
end
end
end