Crypt: replace CRYPT_MODE_INTERNAL/MCRYPT/OPENSSL with CRYPT_ENGINE_*

This commit is contained in:
terrafrost 2014-12-13 13:58:41 -06:00
parent 4d6e7efda6
commit f5f9c3d409
8 changed files with 49 additions and 63 deletions

View File

@ -111,20 +111,6 @@ define('CRYPT_AES_MODE_CFB', CRYPT_MODE_CFB);
define('CRYPT_AES_MODE_OFB', CRYPT_MODE_OFB); define('CRYPT_AES_MODE_OFB', CRYPT_MODE_OFB);
/**#@-*/ /**#@-*/
/**#@+
* @access private
* @see Crypt_Base::Crypt_Base()
*/
/**
* Toggles the internal implementation
*/
define('CRYPT_AES_MODE_INTERNAL', CRYPT_MODE_INTERNAL);
/**
* Toggles the mcrypt implementation
*/
define('CRYPT_AES_MODE_MCRYPT', CRYPT_MODE_MCRYPT);
/**#@-*/
/** /**
* Pure-PHP implementation of AES. * Pure-PHP implementation of AES.
* *

View File

@ -105,15 +105,15 @@ define('CRYPT_MODE_STREAM', 5);
/** /**
* Base value for the internal implementation $engine switch * Base value for the internal implementation $engine switch
*/ */
define('CRYPT_MODE_INTERNAL', 1); define('CRYPT_ENGINE_INTERNAL', 1);
/** /**
* Base value for the mcrypt implementation $engine switch * Base value for the mcrypt implementation $engine switch
*/ */
define('CRYPT_MODE_MCRYPT', 2); define('CRYPT_ENGINE_MCRYPT', 2);
/** /**
* Base value for the OpenSSL implementation $engine switch * Base value for the OpenSSL implementation $engine switch
*/ */
define('CRYPT_MODE_OPENSSL', 3); define('CRYPT_ENGINE_OPENSSL', 3);
/**#@-*/ /**#@-*/
/** /**
@ -278,7 +278,7 @@ class Crypt_Base
* Optimizing value while CFB-encrypting * Optimizing value while CFB-encrypting
* *
* Only relevant if $continuousBuffer enabled * Only relevant if $continuousBuffer enabled
* and $engine == CRYPT_MODE_MCRYPT * and $engine == CRYPT_ENGINE_MCRYPT
* *
* It's faster to re-init $enmcrypt if * It's faster to re-init $enmcrypt if
* $buffer bytes > $cfb_init_len than * $buffer bytes > $cfb_init_len than
@ -330,9 +330,9 @@ class Crypt_Base
* which will be determined automatically on __construct() * which will be determined automatically on __construct()
* *
* Currently available $engines are: * Currently available $engines are:
* - CRYPT_MODE_OPENSSL (very fast, php-extension: openssl, extension_loaded('openssl') required) * - CRYPT_ENGINE_OPENSSL (very fast, php-extension: openssl, extension_loaded('openssl') required)
* - CRYPT_MODE_MCRYPT (fast, php-extension: mcrypt, extension_loaded('mcrypt') required) * - CRYPT_ENGINE_MCRYPT (fast, php-extension: mcrypt, extension_loaded('mcrypt') required)
* - CRYPT_MODE_INTERNAL (slower, pure php-engine, no php-extension required) * - CRYPT_ENGINE_INTERNAL (slower, pure php-engine, no php-extension required)
* *
* @see Crypt_Base::_setEngine() * @see Crypt_Base::_setEngine()
* @see Crypt_Base::encrypt() * @see Crypt_Base::encrypt()
@ -355,7 +355,7 @@ class Crypt_Base
/** /**
* The mcrypt specific name of the cipher * The mcrypt specific name of the cipher
* *
* Only used if $engine == CRYPT_MODE_MCRYPT * Only used if $engine == CRYPT_ENGINE_MCRYPT
* *
* @link http://www.php.net/mcrypt_module_open * @link http://www.php.net/mcrypt_module_open
* @link http://www.php.net/mcrypt_list_algorithms * @link http://www.php.net/mcrypt_list_algorithms
@ -368,7 +368,7 @@ class Crypt_Base
/** /**
* The openssl specific name of the cipher * The openssl specific name of the cipher
* *
* Only used if $engine == CRYPT_MODE_OPENSSL * Only used if $engine == CRYPT_ENGINE_OPENSSL
* *
* @link http://www.php.net/openssl-get-cipher-methods * @link http://www.php.net/openssl-get-cipher-methods
* @var String * @var String
@ -433,7 +433,7 @@ class Crypt_Base
* The name of the performance-optimized callback function * The name of the performance-optimized callback function
* *
* Used by encrypt() / decrypt() * Used by encrypt() / decrypt()
* only if $engine == CRYPT_MODE_INTERNAL * only if $engine == CRYPT_ENGINE_INTERNAL
* *
* @see Crypt_Base::encrypt() * @see Crypt_Base::encrypt()
* @see Crypt_Base::decrypt() * @see Crypt_Base::decrypt()
@ -685,7 +685,7 @@ class Crypt_Base
$plaintext = $this->_pad($plaintext); $plaintext = $this->_pad($plaintext);
} }
if ($this->engine === CRYPT_MODE_OPENSSL) { if ($this->engine === CRYPT_ENGINE_OPENSSL) {
if ($this->changed) { if ($this->changed) {
$this->_clearBuffers(); $this->_clearBuffers();
$this->changed = false; $this->changed = false;
@ -757,7 +757,7 @@ class Crypt_Base
} }
} }
if ($this->engine === CRYPT_MODE_MCRYPT) { if ($this->engine === CRYPT_ENGINE_MCRYPT) {
if ($this->changed) { if ($this->changed) {
$this->_setupMcrypt(); $this->_setupMcrypt();
$this->changed = false; $this->changed = false;
@ -984,7 +984,7 @@ class Crypt_Base
$ciphertext = str_pad($ciphertext, strlen($ciphertext) + ($this->block_size - strlen($ciphertext) % $this->block_size) % $this->block_size, chr(0)); $ciphertext = str_pad($ciphertext, strlen($ciphertext) + ($this->block_size - strlen($ciphertext) % $this->block_size) % $this->block_size, chr(0));
} }
if ($this->engine === CRYPT_MODE_OPENSSL) { if ($this->engine === CRYPT_ENGINE_OPENSSL) {
if ($this->changed) { if ($this->changed) {
$this->_clearBuffers(); $this->_clearBuffers();
$this->changed = false; $this->changed = false;
@ -1055,7 +1055,7 @@ class Crypt_Base
return $this->paddable ? $this->_unpad($plaintext) : $plaintext; return $this->paddable ? $this->_unpad($plaintext) : $plaintext;
} }
if ($this->engine === CRYPT_MODE_MCRYPT) { if ($this->engine === CRYPT_ENGINE_MCRYPT) {
$block_size = $this->block_size; $block_size = $this->block_size;
if ($this->changed) { if ($this->changed) {
$this->_setupMcrypt(); $this->_setupMcrypt();
@ -1525,7 +1525,7 @@ class Crypt_Base
function isValidEngine($engine) function isValidEngine($engine)
{ {
switch ($engine) { switch ($engine) {
case CRYPT_MODE_OPENSSL: case CRYPT_ENGINE_OPENSSL:
$this->openssl_emulate_ctr = false; $this->openssl_emulate_ctr = false;
$result = $this->cipher_name_openssl && $result = $this->cipher_name_openssl &&
extension_loaded('openssl') && extension_loaded('openssl') &&
@ -1556,11 +1556,11 @@ class Crypt_Base
} }
} }
return false; return false;
case CRYPT_MODE_MCRYPT: case CRYPT_ENGINE_MCRYPT:
return $this->cipher_name_mcrypt && return $this->cipher_name_mcrypt &&
extension_loaded('mcrypt') && extension_loaded('mcrypt') &&
in_array($this->cipher_name_mcrypt, mcrypt_list_algorithms()); in_array($this->cipher_name_mcrypt, mcrypt_list_algorithms());
case CRYPT_MODE_INTERNAL: case CRYPT_ENGINE_INTERNAL:
return true; return true;
} }
} }
@ -1570,11 +1570,11 @@ class Crypt_Base
* *
* Currently, $engine could be: * Currently, $engine could be:
* *
* - CRYPT_MODE_OPENSSL [very fast] * - CRYPT_ENGINE_OPENSSL [very fast]
* *
* - CRYPT_MODE_MCRYPT [fast] * - CRYPT_ENGINE_MCRYPT [fast]
* *
* - CRYPT_MODE_INTERNAL [slow] * - CRYPT_ENGINE_INTERNAL [slow]
* *
* If the preferred crypt engine is not available the fastest available one will be used * If the preferred crypt engine is not available the fastest available one will be used
* *
@ -1585,13 +1585,13 @@ class Crypt_Base
function setPreferredEngine($engine) function setPreferredEngine($engine)
{ {
switch ($engine) { switch ($engine) {
//case CRYPT_MODE_OPENSSL: //case CRYPT_ENGINE_OPENSSL:
case CRYPT_MODE_MCRYPT: case CRYPT_ENGINE_MCRYPT:
case CRYPT_MODE_INTERNAL: case CRYPT_ENGINE_INTERNAL:
$this->preferredEngine = $engine; $this->preferredEngine = $engine;
break; break;
default: default:
$this->preferredEngine = CRYPT_MODE_OPENSSL; $this->preferredEngine = CRYPT_ENGINE_OPENSSL;
} }
$this->_setEngine(); $this->_setEngine();
@ -1620,17 +1620,17 @@ class Crypt_Base
case $this->isValidEngine($this->preferredEngine): case $this->isValidEngine($this->preferredEngine):
$this->engine = $this->preferredEngine; $this->engine = $this->preferredEngine;
break; break;
case $this->isValidEngine(CRYPT_MODE_OPENSSL): case $this->isValidEngine(CRYPT_ENGINE_OPENSSL):
$this->engine = CRYPT_MODE_OPENSSL; $this->engine = CRYPT_ENGINE_OPENSSL;
break; break;
case $this->isValidEngine(CRYPT_MODE_MCRYPT): case $this->isValidEngine(CRYPT_ENGINE_MCRYPT):
$this->engine = CRYPT_MODE_MCRYPT; $this->engine = CRYPT_ENGINE_MCRYPT;
break; break;
default: default:
$this->engine = CRYPT_MODE_INTERNAL; $this->engine = CRYPT_ENGINE_INTERNAL;
} }
if ($this->engine != CRYPT_MODE_MCRYPT && $this->enmcrypt) { if ($this->engine != CRYPT_ENGINE_MCRYPT && $this->enmcrypt) {
// Closing the current mcrypt resource(s). _mcryptSetup() will, if needed, // Closing the current mcrypt resource(s). _mcryptSetup() will, if needed,
// (re)open them with the module named in $this->cipher_name_mcrypt // (re)open them with the module named in $this->cipher_name_mcrypt
mcrypt_module_close($this->enmcrypt); mcrypt_module_close($this->enmcrypt);
@ -1676,7 +1676,7 @@ class Crypt_Base
/** /**
* Setup the key (expansion) * Setup the key (expansion)
* *
* Only used if $engine == CRYPT_MODE_INTERNAL * Only used if $engine == CRYPT_ENGINE_INTERNAL
* *
* @see Crypt_Base::_setup() * @see Crypt_Base::_setup()
* @access private * @access private
@ -1688,10 +1688,10 @@ class Crypt_Base
} }
/** /**
* Setup the CRYPT_MODE_INTERNAL $engine * Setup the CRYPT_ENGINE_INTERNAL $engine
* *
* (re)init, if necessary, the internal cipher $engine and flush all $buffers * (re)init, if necessary, the internal cipher $engine and flush all $buffers
* Used (only) if $engine == CRYPT_MODE_INTERNAL * Used (only) if $engine == CRYPT_ENGINE_INTERNAL
* *
* _setup() will be called each time if $changed === true * _setup() will be called each time if $changed === true
* typically this happens when using one or more of following public methods: * typically this happens when using one or more of following public methods:
@ -1722,10 +1722,10 @@ class Crypt_Base
} }
/** /**
* Setup the CRYPT_MODE_MCRYPT $engine * Setup the CRYPT_ENGINE_MCRYPT $engine
* *
* (re)init, if necessary, the (ext)mcrypt resources and flush all $buffers * (re)init, if necessary, the (ext)mcrypt resources and flush all $buffers
* Used (only) if $engine = CRYPT_MODE_MCRYPT * Used (only) if $engine = CRYPT_ENGINE_MCRYPT
* *
* _setupMcrypt() will be called each time if $changed === true * _setupMcrypt() will be called each time if $changed === true
* typically this happens when using one or more of following public methods: * typically this happens when using one or more of following public methods:
@ -1935,7 +1935,7 @@ class Crypt_Base
* *
* _setupInlineCrypt() would be called only if: * _setupInlineCrypt() would be called only if:
* *
* - $engine == CRYPT_MODE_INTERNAL and * - $engine == CRYPT_ENGINE_INTERNAL and
* *
* - $use_inline_crypt === true * - $use_inline_crypt === true
* *

View File

@ -394,7 +394,7 @@ class Crypt_Blowfish extends Crypt_Base
*/ */
function isValidEngine($engine) function isValidEngine($engine)
{ {
if ($engine == CRYPT_MODE_OPENSSL) { if ($engine == CRYPT_ENGINE_OPENSSL) {
if (strlen($this->key) != 16) { if (strlen($this->key) != 16) {
return false; return false;
} }

View File

@ -675,7 +675,7 @@ class Crypt_DES extends Crypt_Base
*/ */
function isValidEngine($engine) function isValidEngine($engine)
{ {
if ($engine == CRYPT_MODE_OPENSSL) { if ($engine == CRYPT_ENGINE_OPENSSL) {
$this->cipher_name_openssl_ecb = 'des-ecb'; $this->cipher_name_openssl_ecb = 'des-ecb';
$this->cipher_name_openssl = 'des-' . $this->_openssl_translate_mode(); $this->cipher_name_openssl = 'des-' . $this->_openssl_translate_mode();
} }

View File

@ -366,7 +366,7 @@ class Crypt_RC2 extends Crypt_Base
function isValidEngine($engine) function isValidEngine($engine)
{ {
switch ($engine) { switch ($engine) {
case CRYPT_MODE_OPENSSL: case CRYPT_ENGINE_OPENSSL:
if ($this->current_key_length != 128 && strlen($this->orig_key) != 16) { if ($this->current_key_length != 128 && strlen($this->orig_key) != 16) {
return false; return false;
} }
@ -464,7 +464,7 @@ class Crypt_RC2 extends Crypt_Base
*/ */
function encrypt($plaintext) function encrypt($plaintext)
{ {
if ($this->engine == CRYPT_MODE_OPENSSL) { if ($this->engine == CRYPT_ENGINE_OPENSSL) {
$temp = $this->key; $temp = $this->key;
$this->key = $this->orig_key; $this->key = $this->orig_key;
$result = parent::encrypt($plaintext); $result = parent::encrypt($plaintext);
@ -487,7 +487,7 @@ class Crypt_RC2 extends Crypt_Base
*/ */
function decrypt($ciphertext) function decrypt($ciphertext)
{ {
if ($this->engine == CRYPT_MODE_OPENSSL) { if ($this->engine == CRYPT_ENGINE_OPENSSL) {
$temp = $this->key; $temp = $this->key;
$this->key = $this->orig_key; $this->key = $this->orig_key;
$result = parent::decrypt($ciphertext); $result = parent::decrypt($ciphertext);
@ -589,7 +589,7 @@ class Crypt_RC2 extends Crypt_Base
} }
/** /**
* Setup the CRYPT_MODE_MCRYPT $engine * Setup the CRYPT_ENGINE_MCRYPT $engine
* *
* @see Crypt_Base::_setupMcrypt() * @see Crypt_Base::_setupMcrypt()
* @access private * @access private

View File

@ -181,7 +181,7 @@ class Crypt_RC4 extends Crypt_Base
function isValidEngine($engine) function isValidEngine($engine)
{ {
switch ($engine) { switch ($engine) {
case CRYPT_MODE_OPENSSL: case CRYPT_ENGINE_OPENSSL:
switch (strlen($this->key)) { switch (strlen($this->key)) {
case 5: case 5:
$this->cipher_name_openssl = 'rc4-40'; $this->cipher_name_openssl = 'rc4-40';
@ -249,7 +249,7 @@ class Crypt_RC4 extends Crypt_Base
*/ */
function encrypt($plaintext) function encrypt($plaintext)
{ {
if ($this->engine == CRYPT_MODE_MCRYPT) { if ($this->engine == CRYPT_ENGINE_MCRYPT) {
return parent::encrypt($plaintext); return parent::encrypt($plaintext);
} }
return $this->_crypt($plaintext, CRYPT_RC4_ENCRYPT); return $this->_crypt($plaintext, CRYPT_RC4_ENCRYPT);
@ -269,7 +269,7 @@ class Crypt_RC4 extends Crypt_Base
*/ */
function decrypt($ciphertext) function decrypt($ciphertext)
{ {
if ($this->engine == CRYPT_MODE_MCRYPT) { if ($this->engine == CRYPT_ENGINE_MCRYPT) {
return parent::decrypt($ciphertext); return parent::decrypt($ciphertext);
} }
return $this->_crypt($ciphertext, CRYPT_RC4_DECRYPT); return $this->_crypt($ciphertext, CRYPT_RC4_DECRYPT);

View File

@ -411,14 +411,14 @@ class Crypt_Rijndael extends Crypt_Base
function isValidEngine($engine) function isValidEngine($engine)
{ {
switch ($engine) { switch ($engine) {
case CRYPT_MODE_OPENSSL: case CRYPT_ENGINE_OPENSSL:
if ($this->block_size != 16) { if ($this->block_size != 16) {
return false; return false;
} }
$this->cipher_name_openssl_ecb = 'aes-' . ($this->key_size << 3) . '-ecb'; $this->cipher_name_openssl_ecb = 'aes-' . ($this->key_size << 3) . '-ecb';
$this->cipher_name_openssl = 'aes-' . ($this->key_size << 3) . '-' . $this->_openssl_translate_mode(); $this->cipher_name_openssl = 'aes-' . ($this->key_size << 3) . '-' . $this->_openssl_translate_mode();
break; break;
case CRYPT_MODE_MCRYPT: case CRYPT_ENGINE_MCRYPT:
$this->cipher_name_mcrypt = 'rijndael-' . ($this->block_size << 3); $this->cipher_name_mcrypt = 'rijndael-' . ($this->block_size << 3);
if ($this->key_size % 8) { // is it a 160/224-bit key? if ($this->key_size % 8) { // is it a 160/224-bit key?
// mcrypt is not usable for them, only for 128/192/256-bit keys // mcrypt is not usable for them, only for 128/192/256-bit keys
@ -430,7 +430,7 @@ class Crypt_Rijndael extends Crypt_Base
} }
/** /**
* Setup the CRYPT_MODE_MCRYPT $engine * Setup the CRYPT_ENGINE_MCRYPT $engine
* *
* @see Crypt_Base::_setupMcrypt() * @see Crypt_Base::_setupMcrypt()
* @access private * @access private

View File

@ -230,7 +230,7 @@ class Crypt_TripleDES extends Crypt_DES
*/ */
function isValidEngine($engine) function isValidEngine($engine)
{ {
if ($engine == CRYPT_MODE_OPENSSL) { if ($engine == CRYPT_ENGINE_OPENSSL) {
$this->cipher_name_openssl_ecb = 'des-ede3'; $this->cipher_name_openssl_ecb = 'des-ede3';
$mode = $this->_openssl_translate_mode(); $mode = $this->_openssl_translate_mode();
$this->cipher_name_openssl = $mode == 'ecb' ? 'des-ede3' : 'des-ede3-' . $mode; $this->cipher_name_openssl = $mode == 'ecb' ? 'des-ede3' : 'des-ede3-' . $mode;