2013-10-10 13:44:53 +11:00
|
|
|
<?php defined('SYSPATH') or die('No direct access allowed.');
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This class is for access to SSL information
|
|
|
|
*
|
|
|
|
* @package SSL
|
|
|
|
* @category Helpers
|
|
|
|
* @author Deon George
|
|
|
|
* @copyright (c) 2009-2013 Open Source Billing
|
|
|
|
* @license http://dev.osbill.net/license.html
|
|
|
|
*/
|
|
|
|
class SSL {
|
|
|
|
private $cert = '';
|
|
|
|
private $_details = array();
|
|
|
|
|
|
|
|
public function __construct($cert) {
|
|
|
|
$this->cert = $cert;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static function instance($cert) {
|
|
|
|
return new SSL($cert);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This function will convert a large decimal number into hex
|
|
|
|
* @param $number Large decimal number
|
|
|
|
*/
|
|
|
|
private static function _dec_to_hex($number) {
|
|
|
|
$hex = array();
|
|
|
|
|
2015-09-29 11:54:45 +10:00
|
|
|
if ($number == 0 OR ! $number)
|
2013-10-10 13:44:53 +11:00
|
|
|
return '00';
|
|
|
|
|
|
|
|
while ($number > 0) {
|
|
|
|
if ($number == 0) {
|
|
|
|
array_push($hex, '0');
|
|
|
|
|
|
|
|
} else {
|
|
|
|
$x = (int) ($number/16);
|
|
|
|
array_push($hex,strtoupper(dechex((int)($number-($x*16)))));
|
|
|
|
$number = $x;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return preg_replace('/^:/','',preg_replace('/(..)/',":$1",implode(array_reverse($hex))));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Parse our AuthorityKeyIndentifier Extension to extract information
|
|
|
|
* @param $key Return just that index
|
|
|
|
*/
|
|
|
|
private function _aki($key=NULL) {
|
|
|
|
$result = array();
|
|
|
|
|
|
|
|
$aki = $this->_extensions('authorityKeyIdentifier');
|
|
|
|
if (! $aki)
|
|
|
|
return '';
|
|
|
|
|
|
|
|
foreach (explode("\n",preg_replace("/\n$/",'',$aki)) as $x) {
|
|
|
|
if (! $x)
|
|
|
|
continue;
|
|
|
|
|
|
|
|
if (strstr($x,':')) {
|
|
|
|
list($a,$b) = explode(':',$x,2);
|
|
|
|
$result[strtolower($a)] = $b;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return is_null($key) ? $result : (isset($result[$key]) ? $result[$key] : '');
|
|
|
|
}
|
|
|
|
|
|
|
|
private function _bc() {
|
|
|
|
return $this->_extensions('basicConstraints');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Parse our Sign Certifcate to extract information
|
|
|
|
* @param $key Return just that index
|
|
|
|
*/
|
|
|
|
private function _details($key=NULL) {
|
|
|
|
if (! $this->cert)
|
|
|
|
return array();
|
|
|
|
|
|
|
|
if (! $this->_details)
|
|
|
|
$this->_details = openssl_x509_parse($this->cert);
|
|
|
|
|
|
|
|
return is_null($key) ? $this->_details : (isset($this->_details[$key]) ? $this->_details[$key] : array());
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Parse our Sign Certifcate Extensions to extract information
|
|
|
|
* @param $key Return just that index
|
|
|
|
*/
|
|
|
|
private function _extensions($key=NULL) {
|
|
|
|
$result = $this->_details('extensions');
|
|
|
|
|
|
|
|
return is_null($key) ? $result : (isset($result[$key]) ? $result[$key] : '');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Render a DN array as a string
|
|
|
|
*/
|
|
|
|
private function _dn(array $array) {
|
|
|
|
$result = '';
|
|
|
|
$i = 0;
|
|
|
|
|
|
|
|
foreach ($array as $k=>$v) {
|
|
|
|
if ($i++)
|
|
|
|
$result .= ',';
|
|
|
|
|
2016-07-27 14:25:17 +10:00
|
|
|
$result .= sprintf('%s=%s',$k,(is_array($v) ? join(','.$k.'=',$v) : $v));
|
2013-10-10 13:44:53 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function get_aki_dirname() {
|
|
|
|
return $this->_aki('dirname');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function get_aki_keyid() {
|
|
|
|
return $this->_aki('keyid');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function get_aki_serial() {
|
|
|
|
return $this->_aki('serial');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function get_algorithm() {
|
|
|
|
$e = '';
|
|
|
|
openssl_x509_export(openssl_x509_read($this->cert),$e,FALSE);
|
|
|
|
|
|
|
|
// @todo There must be a nice way to get this?
|
|
|
|
return (preg_match('/^\s+Signature Algorithm:\s*(.*)\s*$/m',$e,$match)) ? $match[1] : _('Unknown');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function get_ca_path_len() {
|
|
|
|
$m = array();
|
|
|
|
$x = preg_match('/.*pathlen:\s*([0-9]+).*$/',$this->_bc(),$m);
|
|
|
|
|
|
|
|
return isset($m[1]) ? (int)$m[1] : 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function get_dn() {
|
|
|
|
return $this->_dn($this->_details('subject'));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function get_hash() {
|
|
|
|
return $this->_details('hash');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function get_isCA() {
|
2013-12-02 15:16:28 +11:00
|
|
|
return preg_match('/CA:TRUE/',$this->_bc()) ? TRUE : FALSE;
|
2013-10-10 13:44:53 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
public function get_isCert() {
|
2013-12-02 15:16:28 +11:00
|
|
|
return is_array($this->_details()) ? TRUE : FALSE;
|
2013-10-10 13:44:53 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
public function get_isRoot() {
|
|
|
|
return $this->get_aki_keyid() == $this->get_ski();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function get_issuer() {
|
2016-11-28 22:09:40 +11:00
|
|
|
if ($this->get_isRoot())
|
|
|
|
return '-';
|
|
|
|
|
2013-10-10 13:44:53 +11:00
|
|
|
$k = $this->_details('issuer');
|
|
|
|
|
|
|
|
return isset($k['CN']) ? $k['CN'] : '';
|
|
|
|
}
|
|
|
|
|
|
|
|
public function get_issuerdn() {
|
|
|
|
return $this->_dn($this->_details('issuer'));
|
|
|
|
}
|
|
|
|
|
2018-06-13 21:34:58 +10:00
|
|
|
public function get_ian() {
|
|
|
|
return $this->_extensions('issuerAltName');
|
|
|
|
}
|
|
|
|
|
2013-10-10 13:44:53 +11:00
|
|
|
public function get_serial() {
|
|
|
|
return $this->_dec_to_hex($this->_details('serialNumber'));
|
|
|
|
}
|
|
|
|
|
2018-06-13 21:34:58 +10:00
|
|
|
public function get_san() {
|
|
|
|
return $this->_extensions('subjectAltName');
|
|
|
|
}
|
|
|
|
|
2013-10-10 13:44:53 +11:00
|
|
|
public function get_subject() {
|
|
|
|
$k = $this->_details('subject');
|
|
|
|
|
|
|
|
return isset($k['CN']) ? $k['CN'] : '';
|
|
|
|
}
|
|
|
|
|
|
|
|
public function get_ski() {
|
|
|
|
return $this->_extensions('subjectKeyIdentifier');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function get_valid_to($format=FALSE) {
|
|
|
|
$k = $this->_details('validTo_time_t');
|
|
|
|
|
2018-06-13 21:34:58 +10:00
|
|
|
return $format ? Site::Date($k,'d-M-Y H:i:s') : $k;
|
2013-10-10 13:44:53 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
public function get_valid_from($format=FALSE) {
|
|
|
|
$k = $this->_details('validFrom_time_t');
|
|
|
|
|
2018-06-13 21:34:58 +10:00
|
|
|
return $format ? Site::Date($k,'d-M-Y H:i:s') : $k;
|
2013-10-10 13:44:53 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
public function get_version() {
|
|
|
|
return $this->_details('version');
|
|
|
|
}
|
|
|
|
|
|
|
|
public static function subject($cert) {
|
2013-12-20 10:00:32 +11:00
|
|
|
return self::instance($cert)->get_subject();
|
2013-10-10 13:44:53 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
public static function csrsubject($csr) {
|
|
|
|
$c = openssl_csr_get_subject($csr);
|
|
|
|
|
|
|
|
return $c['CN'];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
?>
|