mirror of
https://github.com/phpseclib/phpseclib.git
synced 2024-12-31 21:21:55 +00:00
SSH/Agent: replace user_error's with exceptions
This commit is contained in:
parent
2e46aec03a
commit
2eb4ebf11c
26
phpseclib/Exception/BadConfigurationException.php
Normal file
26
phpseclib/Exception/BadConfigurationException.php
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* BadConfigurationException
|
||||||
|
*
|
||||||
|
* PHP version 5
|
||||||
|
*
|
||||||
|
* @category Exception
|
||||||
|
* @package BadConfigurationException
|
||||||
|
* @author Jim Wigginton <terrafrost@php.net>
|
||||||
|
* @copyright 2015 Jim Wigginton
|
||||||
|
* @license http://www.opensource.org/licenses/mit-license.html MIT License
|
||||||
|
* @link http://phpseclib.sourceforge.net
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace phpseclib\Exception;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* BadConfigurationException
|
||||||
|
*
|
||||||
|
* @package BadConfigurationException
|
||||||
|
* @author Jim Wigginton <terrafrost@php.net>
|
||||||
|
*/
|
||||||
|
class BadConfigurationException extends \RuntimeException
|
||||||
|
{
|
||||||
|
}
|
@ -18,7 +18,7 @@ namespace phpseclib\Exception;
|
|||||||
/**
|
/**
|
||||||
* FileNotFoundException
|
* FileNotFoundException
|
||||||
*
|
*
|
||||||
* @package UnsupportedAlgorithmException
|
* @package FileNotFoundException
|
||||||
* @author Jim Wigginton <terrafrost@php.net>
|
* @author Jim Wigginton <terrafrost@php.net>
|
||||||
*/
|
*/
|
||||||
class FileNotFoundException extends \RuntimeException
|
class FileNotFoundException extends \RuntimeException
|
||||||
|
@ -35,6 +35,7 @@ namespace phpseclib\System\SSH;
|
|||||||
|
|
||||||
use phpseclib\Crypt\RSA;
|
use phpseclib\Crypt\RSA;
|
||||||
use phpseclib\System\SSH\Agent\Identity;
|
use phpseclib\System\SSH\Agent\Identity;
|
||||||
|
use phpseclib\Exception\BadConfigurationException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Pure-PHP ssh-agent client identity factory
|
* Pure-PHP ssh-agent client identity factory
|
||||||
@ -115,6 +116,8 @@ class Agent
|
|||||||
* Default Constructor
|
* Default Constructor
|
||||||
*
|
*
|
||||||
* @return \phpseclib\System\SSH\Agent
|
* @return \phpseclib\System\SSH\Agent
|
||||||
|
* @throws \phpseclib\Exception\BadConfigurationException if SSH_AUTH_SOCK cannot be found
|
||||||
|
* @throws \RuntimeException on connection errors
|
||||||
* @access public
|
* @access public
|
||||||
*/
|
*/
|
||||||
function __construct()
|
function __construct()
|
||||||
@ -127,13 +130,12 @@ class Agent
|
|||||||
$address = $_ENV['SSH_AUTH_SOCK'];
|
$address = $_ENV['SSH_AUTH_SOCK'];
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
user_error('SSH_AUTH_SOCK not found');
|
throw new \BadConfigurationException('SSH_AUTH_SOCK not found');
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->fsock = fsockopen('unix://' . $address, 0, $errno, $errstr);
|
$this->fsock = fsockopen('unix://' . $address, 0, $errno, $errstr);
|
||||||
if (!$this->fsock) {
|
if (!$this->fsock) {
|
||||||
user_error("Unable to connect to ssh-agent (Error $errno: $errstr)");
|
throw new \RuntimeException("Unable to connect to ssh-agent (Error $errno: $errstr)");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -144,6 +146,7 @@ class Agent
|
|||||||
* Returns an array containing zero or more \phpseclib\System\SSH\Agent\Identity objects
|
* Returns an array containing zero or more \phpseclib\System\SSH\Agent\Identity objects
|
||||||
*
|
*
|
||||||
* @return Array
|
* @return Array
|
||||||
|
* @throws \RuntimeException on receipt of unexpected packets
|
||||||
* @access public
|
* @access public
|
||||||
*/
|
*/
|
||||||
function requestIdentities()
|
function requestIdentities()
|
||||||
@ -154,13 +157,13 @@ class Agent
|
|||||||
|
|
||||||
$packet = pack('NC', 1, self::SSH_AGENTC_REQUEST_IDENTITIES);
|
$packet = pack('NC', 1, self::SSH_AGENTC_REQUEST_IDENTITIES);
|
||||||
if (strlen($packet) != fputs($this->fsock, $packet)) {
|
if (strlen($packet) != fputs($this->fsock, $packet)) {
|
||||||
user_error('Connection closed while requesting identities');
|
throw new \RuntimeException('Connection closed while requesting identities');
|
||||||
}
|
}
|
||||||
|
|
||||||
$length = current(unpack('N', fread($this->fsock, 4)));
|
$length = current(unpack('N', fread($this->fsock, 4)));
|
||||||
$type = ord(fread($this->fsock, 1));
|
$type = ord(fread($this->fsock, 1));
|
||||||
if ($type != self::SSH_AGENT_IDENTITIES_ANSWER) {
|
if ($type != self::SSH_AGENT_IDENTITIES_ANSWER) {
|
||||||
user_error('Unable to request identities');
|
throw new \RuntimeException('Unable to request identities');
|
||||||
}
|
}
|
||||||
|
|
||||||
$identities = array();
|
$identities = array();
|
||||||
@ -265,6 +268,7 @@ class Agent
|
|||||||
*
|
*
|
||||||
* @param String $data
|
* @param String $data
|
||||||
* @return data from SSH Agent
|
* @return data from SSH Agent
|
||||||
|
* @throws \RuntimeException on connection errors
|
||||||
* @access private
|
* @access private
|
||||||
*/
|
*/
|
||||||
function _forward_data($data)
|
function _forward_data($data)
|
||||||
@ -283,7 +287,7 @@ class Agent
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (strlen($this->socket_buffer) != fwrite($this->fsock, $this->socket_buffer)) {
|
if (strlen($this->socket_buffer) != fwrite($this->fsock, $this->socket_buffer)) {
|
||||||
user_error('Connection closed attempting to forward data to SSH agent');
|
throw new \RuntimeException('Connection closed attempting to forward data to SSH agent');
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->socket_buffer = '';
|
$this->socket_buffer = '';
|
||||||
|
Loading…
Reference in New Issue
Block a user