Check for array or object on decrypt/unserialize. Return this even if empty.

This commit is contained in:
Miles Lott 2005-04-13 13:03:04 +00:00
parent 93c063bd6c
commit 3cfb82e06d

View File

@ -37,9 +37,9 @@
function crypto($vars='') function crypto($vars='')
{ {
if($GLOBALS['phpgw_info']['flags']['currentapp'] == 'login' || if($GLOBALS['egw_info']['flags']['currentapp'] == 'login' ||
$GLOBALS['phpgw_info']['flags']['currentapp'] == 'logout' || $GLOBALS['egw_info']['flags']['currentapp'] == 'logout' ||
$GLOBALS['phpgw_info']['flags']['currentapp'] == 'home' $GLOBALS['egw_info']['flags']['currentapp'] == 'home'
) )
{ {
$this->debug = False; $this->debug = False;
@ -56,15 +56,15 @@
$key = $vars[0]; $key = $vars[0];
$iv = $vars[1]; $iv = $vars[1];
if($GLOBALS['phpgw_info']['server']['mcrypt_enabled'] && extension_loaded('mcrypt')) if($GLOBALS['egw_info']['server']['mcrypt_enabled'] && extension_loaded('mcrypt'))
{ {
if($GLOBALS['phpgw_info']['server']['mcrypt_algo']) if($GLOBALS['egw_info']['server']['mcrypt_algo'])
{ {
$this->algo = $GLOBALS['phpgw_info']['server']['mcrypt_algo']; $this->algo = $GLOBALS['egw_info']['server']['mcrypt_algo'];
} }
if($GLOBALS['phpgw_info']['server']['mcrypt_mode']) if($GLOBALS['egw_info']['server']['mcrypt_mode'])
{ {
$this->mode = $GLOBALS['phpgw_info']['server']['mcrypt_mode']; $this->mode = $GLOBALS['egw_info']['server']['mcrypt_mode'];
} }
if($this->debug) if($this->debug)
@ -74,7 +74,7 @@
} }
$this->enabled = True; $this->enabled = True;
$this->mcrypt_version = $GLOBALS['phpgw_info']['server']['versions']['mcrypt']; $this->mcrypt_version = $GLOBALS['egw_info']['server']['versions']['mcrypt'];
if($this->mcrypt_version == 'old') if($this->mcrypt_version == 'old')
{ {
$this->td = False; $this->td = False;
@ -155,7 +155,7 @@
echo '<br>' . time() . ' crypto->encrypt() unencrypted data: ---->>>>' . $data . "\n"; echo '<br>' . time() . ' crypto->encrypt() unencrypted data: ---->>>>' . $data . "\n";
} }
if(is_array($data) || is_object($data)) if(@is_array($data) || @is_object($data))
{ {
if($this->debug) if($this->debug)
{ {
@ -273,8 +273,10 @@
$data = chop($data); $data = chop($data);
$newdata = @unserialize($data); $newdata = @unserialize($data);
if($newdata) /* Check whether an array or object exists, even if empty. These should be the only ones originally serialized. */
if(@is_array($newdata) || @is_object($newdata))
{ {
/* array or object */
if($this->debug) if($this->debug)
{ {
echo '<br>' . time() . ' crypto->decrypt() found serialized "' . gettype($newdata) . '". Unserializing...' . "\n"; echo '<br>' . time() . ' crypto->decrypt() found serialized "' . gettype($newdata) . '". Unserializing...' . "\n";
@ -284,6 +286,7 @@
} }
else else
{ {
/* Other types */
if($this->debug) if($this->debug)
{ {
echo '<br>' . time() . ' crypto->decrypt() found UNserialized "' . gettype($data) . '". No unserialization...' . "\n"; echo '<br>' . time() . ' crypto->decrypt() found UNserialized "' . gettype($data) . '". No unserialization...' . "\n";