class Net::SSH::Proxy::Command

end

Net::SSH.start(‘host’, ‘user’, :proxy => proxy) do |ssh|
proxy = Net::SSH::Proxy::Command.new(‘ssh relay nc %h %p’)
require ‘net/ssh/proxy/command’
Net::SSH.start:
then pass the instantiated object via the :proxy key to
An implementation of a command proxy. To use it, instantiate it,

def initialize(command_line_template)

the host name to connect and `%p' by the port.
template. In the command template, `%h' will be substituted by
with the user's shell, which is composed from the given command
Create a new socket factory that tunnels via a command executed
def initialize(command_line_template)
  @command_line_template = command_line_template
  @command_line = nil
end

def open(host, port)

proxy that was requested when the socket factory was instantiated.
Return a new socket connected to the given host and port via the
def open(host, port)
  command_line = @command_line_template.gsub(/%(.)/) {
    case $1
    when 'h'
      host
    when 'p'
      port.to_s
    when '%'
      '%'
    else
      raise ArgumentError, "unknown key: #{$1}"
    end
  }
  begin
    io = IO.popen(command_line, "r+")
    if result = Net::SSH::Compat.io_select([io], nil, [io], 60)
      if result.last.any?
        raise "command failed"
      end
    else
      raise "command timed out"
    end
  rescue => e
    raise ConnectError, "#{e}: #{command_line}"
  end
  @command_line = command_line
  class << io
    def send(data, flag)
      write_nonblock(data)
    end
    def recv(size)
      read_nonblock(size)
    end
  end
  io
end

def recv(size)

def recv(size)
  read_nonblock(size)
end

def send(data, flag)

def send(data, flag)
  write_nonblock(data)
end