0
0
Fork 0
mirror of https://github.com/salesagility/SuiteCRM.git synced 2025-01-11 20:08:27 +00:00
salesagility_SuiteCRM/include/Pear/Crypt_Blowfish/Blowfish.php

338 lines
8.7 KiB
PHP
Raw Permalink Normal View History

2013-09-23 19:30:44 +00:00
<?php
/* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */
/**
* Crypt_Blowfish allows for encryption and decryption on the fly using
* the Blowfish algorithm. Crypt_Blowfish does not require the mcrypt
* PHP extension, it uses only PHP.
* Crypt_Blowfish support encryption/decryption with or without a secret key.
*
*
* PHP versions 4 and 5
*
* LICENSE: This source file is subject to version 3.0 of the PHP license
* that is available through the world-wide-web at the following URI:
* http://www.php.net/license/3_0.txt. If you did not receive a copy of
* the PHP License and are unable to obtain it through the web, please
* send a note to license@php.net so we can mail you a copy immediately.
*
* @category Encryption
* @package Crypt_Blowfish
* @author Matthew Fonda <mfonda@php.net>
* @copyright 2005 Matthew Fonda
* @license http://www.php.net/license/3_0.txt PHP License 3.0
* @link http://pear.php.net/package/Crypt_Blowfish
*/
/**
*
* Example usage:
* $bf = new Crypt_Blowfish('some secret key!');
* $encrypted = $bf->encrypt('this is some example plain text');
* $plaintext = $bf->decrypt($encrypted);
* echo "plain text: $plaintext";
*
*
* @category Encryption
* @package Crypt_Blowfish
* @author Matthew Fonda <mfonda@php.net>
* @copyright 2005 Matthew Fonda
* @license http://www.php.net/license/3_0.txt PHP License 3.0
* @link http://pear.php.net/package/Crypt_Blowfish
* @version @package_version@
* @access public
*/
class Crypt_Blowfish
{
/**
* P-Array contains 18 32-bit subkeys
*
* @var array
* @access private
*/
public $_P = array();
2016-03-24 09:22:57 +00:00
2013-09-23 19:30:44 +00:00
/**
* Array of four S-Blocks each containing 256 32-bit entries
*
* @var array
* @access private
*/
public $_S = array();
2013-09-23 19:30:44 +00:00
/**
* Mcrypt td resource
*
* @var resource
* @access private
*/
public $_td = null;
2013-09-23 19:30:44 +00:00
/**
* Initialization vector
*
* @var string
* @access private
*/
public $_iv = null;
2013-09-23 19:30:44 +00:00
2016-03-24 09:22:57 +00:00
2013-09-23 19:30:44 +00:00
/**
* Crypt_Blowfish Constructor
* Initializes the Crypt_Blowfish object, and gives a sets
* the secret key
*
* @param string $key
* @access public
*/
2016-03-24 09:22:57 +00:00
public function __construct($key)
2013-09-23 19:30:44 +00:00
{
/*
2013-09-23 19:30:44 +00:00
if (extension_loaded('mcrypt')) {
$this->_td = mcrypt_module_open(MCRYPT_BLOWFISH, '', 'ecb', '');
$this->_iv = mcrypt_create_iv(8, MCRYPT_RAND);
}
*/
$this->setKey($key);
}
2016-03-24 09:22:57 +00:00
/**
* @deprecated deprecated since version 7.6, PHP4 Style Constructors are deprecated and will be remove in 7.8, please update your code, use __construct instead
*/
public function Crypt_Blowfish($key)
{
$deprecatedMessage = 'PHP4 Style Constructors are deprecated and will be remove in 7.8, please update your code';
if (isset($GLOBALS['log'])) {
$GLOBALS['log']->deprecated($deprecatedMessage);
} else {
trigger_error($deprecatedMessage, E_USER_DEPRECATED);
}
self::__construct($key);
}
2013-09-23 19:30:44 +00:00
/**
* Deprecated isReady method
*
* @return bool
* @access public
* @deprecated
*/
public function isReady()
2013-09-23 19:30:44 +00:00
{
return true;
}
2016-03-24 09:22:57 +00:00
2013-09-23 19:30:44 +00:00
/**
* Deprecated init method - init is now a private
* method and has been replaced with _init
*
* @return bool
* @access public
* @deprecated
* @see Crypt_Blowfish::_init()
*/
public function init()
2013-09-23 19:30:44 +00:00
{
$this->_init();
}
2016-03-24 09:22:57 +00:00
2013-09-23 19:30:44 +00:00
/**
* Initializes the Crypt_Blowfish object
*
* @access private
*/
public function _init()
2013-09-23 19:30:44 +00:00
{
$defaults = new Crypt_Blowfish_DefaultKey();
$this->_P = $defaults->P;
$this->_S = $defaults->S;
}
2016-03-24 09:22:57 +00:00
2013-09-23 19:30:44 +00:00
/**
* Enciphers a single 64 bit block
*
* @param int &$Xl
* @param int &$Xr
* @access private
*/
public function _encipher(&$Xl, &$Xr)
2013-09-23 19:30:44 +00:00
{
for ($i = 0; $i < 16; $i++) {
$temp = $Xl ^ $this->_P[$i];
$Xl = ((($this->_S[0][($temp>>24) & 255] +
$this->_S[1][($temp>>16) & 255]) ^
$this->_S[2][($temp>>8) & 255]) +
$this->_S[3][$temp & 255]) ^ $Xr;
$Xr = $temp;
}
$Xr = $Xl ^ $this->_P[16];
$Xl = $temp ^ $this->_P[17];
}
2016-03-24 09:22:57 +00:00
2013-09-23 19:30:44 +00:00
/**
* Deciphers a single 64 bit block
*
* @param int &$Xl
* @param int &$Xr
* @access private
*/
public function _decipher(&$Xl, &$Xr)
2013-09-23 19:30:44 +00:00
{
for ($i = 17; $i > 1; $i--) {
$temp = $Xl ^ $this->_P[$i];
$Xl = ((($this->_S[0][($temp>>24) & 255] +
$this->_S[1][($temp>>16) & 255]) ^
$this->_S[2][($temp>>8) & 255]) +
$this->_S[3][$temp & 255]) ^ $Xr;
$Xr = $temp;
}
$Xr = $Xl ^ $this->_P[1];
$Xl = $temp ^ $this->_P[0];
}
2016-03-24 09:22:57 +00:00
2013-09-23 19:30:44 +00:00
/**
* Encrypts a string
*
* @param string $plainText
* @return string Returns cipher text on success, PEAR_Error on failure
* @access public
*/
public function encrypt($plainText)
2013-09-23 19:30:44 +00:00
{
if (!is_string($plainText)) {
$GLOBALS['log']->fatal('Plain text must be a string');
}
/*
2013-09-23 19:30:44 +00:00
if (extension_loaded('mcrypt')) {
return mcrypt_generic($this->_td, $plainText);
}
*/
$cipherText = '';
$len = strlen($plainText);
$plainText .= str_repeat(chr(0), (8 - ($len%8))%8);
2013-09-23 19:30:44 +00:00
for ($i = 0; $i < $len; $i += 8) {
list(, $Xl, $Xr) = unpack("N2", substr($plainText, $i, 8));
2013-09-23 19:30:44 +00:00
$this->_encipher($Xl, $Xr);
$cipherText .= pack("N2", $Xl, $Xr);
}
return $cipherText;
}
2016-03-24 09:22:57 +00:00
2013-09-23 19:30:44 +00:00
/**
* Decrypts an encrypted string
*
* @param string $cipherText
* @return string Returns plain text on success, PEAR_Error on failure
* @access public
*/
public function decrypt($cipherText)
2013-09-23 19:30:44 +00:00
{
if (!is_string($cipherText)) {
$GLOBALS['log']->fatal('Chiper text must be a string');
}
/*
2013-09-23 19:30:44 +00:00
if (extension_loaded('mcrypt')) {
return mdecrypt_generic($this->_td, $cipherText);
}
*/
$plainText = '';
$len = strlen($cipherText);
$cipherText .= str_repeat(chr(0), (8 - ($len%8))%8);
2013-09-23 19:30:44 +00:00
for ($i = 0; $i < $len; $i += 8) {
list(, $Xl, $Xr) = unpack("N2", substr($cipherText, $i, 8));
2013-09-23 19:30:44 +00:00
$this->_decipher($Xl, $Xr);
$plainText .= pack("N2", $Xl, $Xr);
}
return $plainText;
}
2016-03-24 09:22:57 +00:00
2013-09-23 19:30:44 +00:00
/**
* Sets the secret key
* The key must be non-zero, and less than or equal to
* 56 characters in length.
*
* @param string $key
* @return bool Returns true on success, PEAR_Error on failure
* @access public
*/
public function setKey($key)
2013-09-23 19:30:44 +00:00
{
if (!is_string($key)) {
$GLOBALS['log']->fatal('Key must be a string');
}
$len = strlen($key);
if ($len > 56 || $len == 0) {
$GLOBALS['log']->fatal('Key must be less than 56 characters and non-zero. Supplied key length: ' . $len);
}
/*
2013-09-23 19:30:44 +00:00
if (extension_loaded('mcrypt')) {
mcrypt_generic_init($this->_td, $key, $this->_iv);
return true;
}
*/
require_once 'include/Pear/Crypt_Blowfish/Blowfish/DefaultKey.php';
$this->_init();
2016-03-24 09:22:57 +00:00
2013-09-23 19:30:44 +00:00
$k = 0;
$data = 0;
$datal = 0;
$datar = 0;
2016-03-24 09:22:57 +00:00
2013-09-23 19:30:44 +00:00
for ($i = 0; $i < 18; $i++) {
$data = 0;
for ($j = 4; $j > 0; $j--) {
$data = $data << 8 | ord($key[$k]);
$k = ($k+1) % $len;
2013-09-23 19:30:44 +00:00
}
$this->_P[$i] ^= $data;
}
2016-03-24 09:22:57 +00:00
2013-09-23 19:30:44 +00:00
for ($i = 0; $i <= 16; $i += 2) {
$this->_encipher($datal, $datar);
$this->_P[$i] = $datal;
$this->_P[$i+1] = $datar;
}
for ($i = 0; $i < 256; $i += 2) {
$this->_encipher($datal, $datar);
$this->_S[0][$i] = $datal;
$this->_S[0][$i+1] = $datar;
}
for ($i = 0; $i < 256; $i += 2) {
$this->_encipher($datal, $datar);
$this->_S[1][$i] = $datal;
$this->_S[1][$i+1] = $datar;
}
for ($i = 0; $i < 256; $i += 2) {
$this->_encipher($datal, $datar);
$this->_S[2][$i] = $datal;
$this->_S[2][$i+1] = $datar;
}
for ($i = 0; $i < 256; $i += 2) {
$this->_encipher($datal, $datar);
$this->_S[3][$i] = $datal;
$this->_S[3][$i+1] = $datar;
}
2016-03-24 09:22:57 +00:00
2013-09-23 19:30:44 +00:00
return true;
}
2018-07-19 10:38:01 +00:00
}