mirror of
https://github.com/phpseclib/phpseclib.git
synced 2024-12-26 03:27:31 +00:00
SSH2: tweaks to isConnected()
This commit is contained in:
parent
8f3a66547a
commit
d27429a236
@ -3344,11 +3344,38 @@ class SSH2
|
||||
/**
|
||||
* Is the connection still active?
|
||||
*
|
||||
* $level has 3x possible values:
|
||||
* 0 (default): phpseclib takes a passive approach to see if the connection is still active by calling feof()
|
||||
* on the socket
|
||||
* 1: phpseclib takes an active approach to see if the connection is still active by sending an SSH_MSG_IGNORE
|
||||
* packet that doesn't require a response
|
||||
* 2: phpseclib takes an active approach to see if the connection is still active by sending an SSH_MSG_CHANNEL_OPEN
|
||||
* packet and imediately trying to close that channel. some routers, in particular, however, will only let you
|
||||
* open one channel, so this approach could yield false positives
|
||||
*
|
||||
* @param int $level
|
||||
* @return bool
|
||||
*/
|
||||
public function isConnected()
|
||||
public function isConnected($level = 0)
|
||||
{
|
||||
return ($this->bitmap & self::MASK_CONNECTED) && is_resource($this->fsock) && !feof($this->fsock);
|
||||
if (!is_int($level) || $level < 0 || $level > 2) {
|
||||
throw new \InvalidArgumentException('$level must be 0, 1 or 2');
|
||||
}
|
||||
|
||||
if ($level == 0) {
|
||||
return ($this->bitmap & self::MASK_CONNECTED) && is_resource($this->fsock) && !feof($this->fsock);
|
||||
}
|
||||
try {
|
||||
if ($level == 1) {
|
||||
$this->send_binary_packet(pack('CN', NET_SSH2_MSG_IGNORE, 0));
|
||||
} else {
|
||||
$this->openChannel(self::CHANNEL_KEEP_ALIVE);
|
||||
$this->close_channel(self::CHANNEL_KEEP_ALIVE);
|
||||
}
|
||||
return true;
|
||||
} catch (\Exception $e) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
|
Loading…
Reference in New Issue
Block a user