class Net::SSH::Proxy::Jump
An implementation of a jump proxy. To use it, instantiate it, then pass the instantiated object via the :proxy key to Net::SSH.start:
require 'net/ssh/proxy/jump' proxy = Net::SSH::Proxy::Jump.new('user@proxy') Net::SSH.start('host', 'user', :proxy => proxy) do |ssh| ... end
Attributes
jump_proxies[R]
The jump proxies
Public Class Methods
new(jump_proxies)
click to toggle source
Create a new socket factory that tunnels via multiple jump proxes as [user@]host.
# File lib/net/ssh/proxy/jump.rb, line 24 def initialize(jump_proxies) @jump_proxies = jump_proxies end
Public Instance Methods
build_proxy_command_equivalent(connection_options = nil)
click to toggle source
We cannot build the ProxyCommand template until we know if the :config option was specified during `Net::SSH.start`.
# File lib/net/ssh/proxy/jump.rb, line 37 def build_proxy_command_equivalent(connection_options = nil) first_jump, extra_jumps = jump_proxies.split(",", 2) config = connection_options && connection_options[:config] uri = URI.parse("ssh://#{first_jump}") template = "ssh" template << " -l #{uri.user}" if uri.user template << " -p #{uri.port}" if uri.port template << " -J #{extra_jumps}" if extra_jumps template << " -F #{config}" if config != true && config template << " -W %h:%p " template << uri.host @command_line_template = template end
open(host, port, connection_options = nil)
click to toggle source
Return a new socket connected to the given host and port via the jump proxy that was requested when the socket factory was instantiated.
Calls superclass method
Net::SSH::Proxy::Command#open
# File lib/net/ssh/proxy/jump.rb, line 30 def open(host, port, connection_options = nil) build_proxy_command_equivalent(connection_options) super end