Tcl
Tcl
Multi-Hop SSH (SSH Through SSH)
See more SSH Examples
Demonstrates how to SSH through one SSH server to get to another SSH server. The scheme looks like this:Application => ServerSSH1 => ServerSSH2
The ConnectThroughSsh method is added in Chilkat version 9.5.0.55 to accomplish this task. Technically, it should be possible to chain any number of servers using the ConnectThroughSsh multiple times:
Application => ServerSSH1 => ServerSSH2 ==> ServerSSH3 => ... => ServerSSHN
Chilkat Tcl Downloads
load ./chilkat.dll
set success 0
# This example assumes the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.
set ssh1 [new_CkSsh]
# Hostname may be an IP address or domain name:
set hostname "192.168.1.108"
set port 22
# Connect directly to the 1st SSH server:
set success [CkSsh_Connect $ssh1 $hostname $port]
if {$success != 1} then {
puts [CkSsh_lastErrorText $ssh1]
delete_CkSsh $ssh1
exit
}
# Wait a max of 15 seconds when reading responses..
CkSsh_put_IdleTimeoutMs $ssh1 15000
# Authenticate using login/password:
set success [CkSsh_AuthenticatePw $ssh1 "myLogin" "myPassword"]
if {$success != 1} then {
puts [CkSsh_lastErrorText $ssh1]
delete_CkSsh $ssh1
exit
}
# Connect through the 1st SSH connection to reach a 2nd SSH server.
# Note: Any number of SSH connections may be simultaneously tunneled through a single
# existing SSH connection.
set ssh2 [new_CkSsh]
set success [CkSsh_ConnectThroughSsh $ssh2 $ssh1 "someremoteserver.com" 22]
if {$success != 1} then {
puts [CkSsh_lastErrorText $ssh2]
delete_CkSsh $ssh1
delete_CkSsh $ssh2
exit
}
CkSsh_put_IdleTimeoutMs $ssh2 15000
# Authenticate with ssh2...
set success [CkSsh_AuthenticatePw $ssh2 "myLogin2" "myPassword2"]
if {$success != 1} then {
puts [CkSsh_lastErrorText $ssh2]
delete_CkSsh $ssh1
delete_CkSsh $ssh2
exit
}
# The application may now is connected and authenticated with ssh2.
# The application can do whatever it desires just as if it was directly
# connected to ssh2. For example, the application might open
# a session channel to send commands or start a remote shell..
set channelNum [CkSsh_OpenSessionChannel $ssh2]
if {$channelNum < 0} then {
puts [CkSsh_lastErrorText $ssh2]
delete_CkSsh $ssh1
delete_CkSsh $ssh2
exit
}
# ...
# ...
# ...
# Close the connection with ssh2. (This closes the the tunnel through ssh1.)
# The connection with ssh1 is still alive, and may be used for more connections.
CkSsh_Disconnect $ssh2
# ...
# ...
# ...
CkSsh_Disconnect $ssh1
delete_CkSsh $ssh1
delete_CkSsh $ssh2