mirror of
https://github.com/phpseclib/phpseclib.git
synced 2025-01-13 10:01:47 +00:00
SSH2: enhance logging
log the time it took for fsockopen to connect and the time it took for the SSH identification strings to be sent
This commit is contained in:
parent
621c73f7dc
commit
25761222fe
@ -1348,8 +1348,6 @@ class SSH2
|
|||||||
|
|
||||||
$this->curTimeout = $this->timeout;
|
$this->curTimeout = $this->timeout;
|
||||||
|
|
||||||
$this->last_packet = microtime(true);
|
|
||||||
|
|
||||||
if (!is_resource($this->fsock)) {
|
if (!is_resource($this->fsock)) {
|
||||||
$start = microtime(true);
|
$start = microtime(true);
|
||||||
// with stream_select a timeout of 0 means that no timeout takes place;
|
// with stream_select a timeout of 0 means that no timeout takes place;
|
||||||
@ -1368,12 +1366,21 @@ class SSH2
|
|||||||
throw new \RuntimeException('Connection timed out whilst attempting to open socket connection');
|
throw new \RuntimeException('Connection timed out whilst attempting to open socket connection');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (defined('NET_SSH2_LOGGING')) {
|
||||||
|
$this->append_log('(fsockopen took ' . round($elapsed, 4) . 's)', '');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->identifier = $this->generate_identifier();
|
$this->identifier = $this->generate_identifier();
|
||||||
|
|
||||||
if ($this->send_id_string_first) {
|
if ($this->send_id_string_first) {
|
||||||
|
$start = microtime(true);
|
||||||
fputs($this->fsock, $this->identifier . "\r\n");
|
fputs($this->fsock, $this->identifier . "\r\n");
|
||||||
|
$elapsed = round(microtime(true) - $start, 4);
|
||||||
|
if (defined('NET_SSH2_LOGGING')) {
|
||||||
|
$this->append_log("-> (network: $elapsed)", $this->identifier . "\r\n");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* According to the SSH2 specs,
|
/* According to the SSH2 specs,
|
||||||
@ -1384,6 +1391,7 @@ class SSH2
|
|||||||
in ISO-10646 UTF-8 [RFC3629] (language is not specified). Clients
|
in ISO-10646 UTF-8 [RFC3629] (language is not specified). Clients
|
||||||
MUST be able to process such lines." */
|
MUST be able to process such lines." */
|
||||||
$data = '';
|
$data = '';
|
||||||
|
$totalElapsed = 0;
|
||||||
while (!feof($this->fsock) && !preg_match('#(.*)^(SSH-(\d\.\d+).*)#ms', $data, $matches)) {
|
while (!feof($this->fsock) && !preg_match('#(.*)^(SSH-(\d\.\d+).*)#ms', $data, $matches)) {
|
||||||
$line = '';
|
$line = '';
|
||||||
while (true) {
|
while (true) {
|
||||||
@ -1400,6 +1408,7 @@ class SSH2
|
|||||||
throw new \RuntimeException('Connection timed out whilst receiving server identification string');
|
throw new \RuntimeException('Connection timed out whilst receiving server identification string');
|
||||||
}
|
}
|
||||||
$elapsed = microtime(true) - $start;
|
$elapsed = microtime(true) - $start;
|
||||||
|
$totalElapsed+= $elapsed;
|
||||||
$this->curTimeout -= $elapsed;
|
$this->curTimeout -= $elapsed;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1429,6 +1438,10 @@ class SSH2
|
|||||||
$data .= $line;
|
$data .= $line;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (defined('NET_SSH2_LOGGING')) {
|
||||||
|
$this->append_log('<- (network: ' . round($totalElapsed, 4) . ')', $line);
|
||||||
|
}
|
||||||
|
|
||||||
if (feof($this->fsock)) {
|
if (feof($this->fsock)) {
|
||||||
$this->bitmap = 0;
|
$this->bitmap = 0;
|
||||||
throw new ConnectionClosedException('Connection closed by server');
|
throw new ConnectionClosedException('Connection closed by server');
|
||||||
@ -1436,11 +1449,6 @@ class SSH2
|
|||||||
|
|
||||||
$extra = $matches[1];
|
$extra = $matches[1];
|
||||||
|
|
||||||
if (defined('NET_SSH2_LOGGING')) {
|
|
||||||
$this->append_log('<-', $matches[0]);
|
|
||||||
$this->append_log('->', $this->identifier . "\r\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
$this->server_identifier = trim($temp, "\r\n");
|
$this->server_identifier = trim($temp, "\r\n");
|
||||||
if (strlen($extra)) {
|
if (strlen($extra)) {
|
||||||
$this->errors[] = $data;
|
$this->errors[] = $data;
|
||||||
@ -1464,9 +1472,16 @@ class SSH2
|
|||||||
$this->errorOnMultipleChannels = $match;
|
$this->errorOnMultipleChannels = $match;
|
||||||
|
|
||||||
if (!$this->send_id_string_first) {
|
if (!$this->send_id_string_first) {
|
||||||
|
$start = microtime(true);
|
||||||
fputs($this->fsock, $this->identifier . "\r\n");
|
fputs($this->fsock, $this->identifier . "\r\n");
|
||||||
|
$elapsed = round(microtime(true) - $start, 4);
|
||||||
|
if (defined('NET_SSH2_LOGGING')) {
|
||||||
|
$this->append_log("-> (network: $elapsed)", $this->identifier . "\r\n");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$this->last_packet = microtime(true);
|
||||||
|
|
||||||
if (!$this->send_kex_first) {
|
if (!$this->send_kex_first) {
|
||||||
$response = $this->get_binary_packet_or_close(NET_SSH2_MSG_KEXINIT);
|
$response = $this->get_binary_packet_or_close(NET_SSH2_MSG_KEXINIT);
|
||||||
$this->key_exchange($response);
|
$this->key_exchange($response);
|
||||||
@ -4664,9 +4679,12 @@ class SSH2
|
|||||||
{
|
{
|
||||||
$output = '';
|
$output = '';
|
||||||
for ($i = 0; $i < count($message_log); $i++) {
|
for ($i = 0; $i < count($message_log); $i++) {
|
||||||
$output .= $message_number_log[$i] . "\r\n";
|
$output .= $message_number_log[$i];
|
||||||
$current_log = $message_log[$i];
|
$current_log = $message_log[$i];
|
||||||
$j = 0;
|
$j = 0;
|
||||||
|
if (strlen($current_log)) {
|
||||||
|
$output .= "\r\n";
|
||||||
|
}
|
||||||
do {
|
do {
|
||||||
if (strlen($current_log)) {
|
if (strlen($current_log)) {
|
||||||
$output .= str_pad(dechex($j), 7, '0', STR_PAD_LEFT) . '0 ';
|
$output .= str_pad(dechex($j), 7, '0', STR_PAD_LEFT) . '0 ';
|
||||||
|
Loading…
Reference in New Issue
Block a user