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)
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)
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