mirror of
				https://github.com/e107inc/e107.git
				synced 2025-10-25 03:36:42 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			837 lines
		
	
	
		
			20 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			837 lines
		
	
	
		
			20 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /*
 | |
|  * e107 website system
 | |
|  *
 | |
|  * Copyright (C) 2008-2009 e107 Inc (e107.org)
 | |
|  * Released under the terms and conditions of the
 | |
|  * GNU General Public License (http://www.gnu.org/licenses/gpl.txt)
 | |
|  *
 | |
|  * e107 Core functions
 | |
|  *
 | |
|  * $Source: /cvs_backup/e107_0.8/e107_handlers/core_functions.php,v $
 | |
|  * $Revision$
 | |
|  * $Date$
 | |
|  * $Author$
 | |
| */
 | |
| 
 | |
| //
 | |
| 
 | |
| //
 | |
| 
 | |
| /**
 | |
|  * Use these to combine isset() and use of the set value. or defined and use of a constant
 | |
|  * i.e. to fix  if($pref['foo']) ==> if ( varset($pref['foo']) ) will use the pref, or ''.
 | |
|  * Can set 2nd param to any other default value you like (e.g. false, 0, or whatever)
 | |
|  * $testvalue adds additional test of the value (not just isset())
 | |
|  * Examples:
 | |
|  * <code>
 | |
|  * $something = pref;  Bug if pref not set         ==> $something = varset(pref);
 | |
|  * $something = isset(pref) ? pref : "";              ==> $something = varset(pref);
 | |
|  * $something = isset(pref) ? pref : default;         ==> $something = varset(pref,default);
 | |
|  * $something = isset(pref) && pref ? pref : default; ==> use varsettrue(pref,default)
 | |
|  * </code>
 | |
|  * 
 | |
|  * @param mixed $val
 | |
|  * @param mixed $default [optional]
 | |
|  * @return mixed
 | |
|  */
 | |
| function varset(&$val, $default='')
 | |
| {
 | |
| 	if (isset($val)) { return $val; }
 | |
| 	return $default;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Check if the given string is defined (constant)
 | |
|  * 
 | |
|  * @param string $str
 | |
|  * @param mixed $default [optional]
 | |
|  * @return mixed 
 | |
|  */
 | |
| function defset($str, $default='')
 | |
| {
 | |
| 	if(is_array($str))
 | |
| 	{
 | |
| 		return false;
 | |
| 	}
 | |
| 
 | |
| 	if (defined($str)) { return constant($str); }
 | |
| 	return $default;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Variant of {@link varset()}, but only return the value if both set AND 'true'
 | |
|  * @deprecated - use vartrue();
 | |
|  * @param mixed $val
 | |
|  * @param mixed $default [optional]
 | |
|  * @return mixed
 | |
|  */
 | |
| function varsettrue(&$val, $default='')
 | |
| {
 | |
| 	trigger_error('<b>varsettrue() is deprecated.</b> Use vartrue() instead.', E_USER_DEPRECATED); // NO LAN
 | |
| 	return vartrue($val, $default);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Alias of {@link varsettrue()}
 | |
|  * 
 | |
|  * @param mixed $val
 | |
|  * @param mixed $default [optional]
 | |
|  * @return mixed
 | |
|  */
 | |
| function vartrue(&$val, $default='')
 | |
| {
 | |
| 
 | |
| 	if (isset($val) && $val) { return $val; }
 | |
| 	return $default;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Variant of {@link defset()}, but only return the value if both defined AND 'true'
 | |
|  * @deprecated  - use deftrue()
 | |
|  * @param string $str
 | |
|  * @param mixed $default [optional]
 | |
|  * @return mixed
 | |
|  */
 | |
| function defsettrue($str, $default='')
 | |
| {
 | |
|     trigger_error('<b>defsettrue() is deprecated.</b> Use deftrue() instead.', E_USER_DEPRECATED); // NO LAN
 | |
| 	if (defined($str) && constant($str)) { return constant($str); }
 | |
| 	return $default;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Alias of {@link defsettrue()}
 | |
|  * 
 | |
|  * @param string $str
 | |
|  * @param mixed $default [optional]
 | |
|  * @return mixed
 | |
|  */
 | |
| function deftrue($str, $default='')
 | |
| {
 | |
| 	if (defined($str) && constant($str)) { return constant($str); }
 | |
| 	return $default;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @param $fname
 | |
|  * @return mixed
 | |
|  */
 | |
| function e107_include($fname)
 | |
| {
 | |
| 	global $_E107;
 | |
| 	$ret = (isset($_E107['debug']) || deftrue('e_DEBUG')) ? include($fname) : @include($fname);
 | |
| 	return $ret;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @param $fname
 | |
|  * @return mixed|string
 | |
|  */
 | |
| function e107_include_once($fname)
 | |
| {
 | |
| 	global $_E107;
 | |
| 	if(is_readable($fname))
 | |
| 	{
 | |
| 		$ret = (isset($_E107['debug']) || deftrue('e_DEBUG')) ? include_once($fname) : @include_once($fname);
 | |
| 	}
 | |
| 	return (isset($ret)) ? $ret : '';
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @param $fname
 | |
|  * @return mixed
 | |
|  */
 | |
| function e107_require_once($fname)
 | |
| {
 | |
| 	global $_E107;
 | |
| 	
 | |
| 	$ret = ((isset($_E107['debug']) || deftrue('e_DEBUG')) ? require_once($fname) : @require_once($fname));
 | |
| 	
 | |
| 	return $ret;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @param $fname
 | |
|  * @return mixed
 | |
|  */
 | |
| function e107_require($fname)
 | |
| {
 | |
| 	global $_E107;
 | |
| 	$ret = ((isset($_E107['debug']) || deftrue('e_DEBUG')) ? require($fname) : @require($fname));
 | |
| 	return $ret;
 | |
| }
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * @param $var
 | |
|  * @param $return
 | |
|  * @return bool|string
 | |
|  */
 | |
| function print_a($var, $return = FALSE)
 | |
| {
 | |
| 	if( ! $return)
 | |
| 	{
 | |
| 		echo '<pre>'.htmlspecialchars(print_r($var, TRUE), ENT_QUOTES, 'utf-8').'</pre>';
 | |
| 		return TRUE;
 | |
| 	}
 | |
| 
 | |
| 	return '<pre>'.htmlspecialchars(print_r($var, true), ENT_QUOTES, 'utf-8').'</pre>';
 | |
| 
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @param $expr
 | |
|  * @return void
 | |
|  */
 | |
| function e_print($expr = null)
 | |
| {
 | |
| 	$args = func_get_args();
 | |
| 	if(!$args) return;
 | |
| 	foreach ($args as $arg) 
 | |
| 	{
 | |
| 		print_a($arg);
 | |
| 	}
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @param $expr
 | |
|  * @return void
 | |
|  */
 | |
| function e_dump($expr = null)
 | |
| {
 | |
| 	$args = func_get_args();
 | |
| 	if(!$args) return;
 | |
| 	
 | |
| 	echo '<pre>';
 | |
| 	call_user_func_array('var_dump', $args);
 | |
| 	echo '</pre>';
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Strips slashes from a var if magic_quotes_gqc is enabled
 | |
|  * @deprecated
 | |
|  * @param mixed $data
 | |
|  * @return mixed
 | |
|  */
 | |
| function strip_if_magic($data)
 | |
| {
 | |
| 	if (MAGIC_QUOTES_GPC === true)
 | |
| 	{
 | |
| 		return array_stripslashes($data);
 | |
| 	}
 | |
| 
 | |
| 	return $data;
 | |
| 
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Return an array with changes between 2 arrays. 
 | |
|  */
 | |
| function array_diff_recursive($array1, $array2) 
 | |
| {
 | |
| 	$ret = array();
 | |
| 
 | |
| 	foreach($array1 as $key => $val) 
 | |
| 	{
 | |
|     	if(is_array($array2) && array_key_exists($key, $array2))
 | |
|     	{
 | |
|       		if(is_array($val)) 
 | |
|       		{
 | |
|         		$diff = array_diff_recursive($val, $array2[$key]);
 | |
| 
 | |
| 				if(count($diff)) 
 | |
| 	        	{
 | |
| 	        	 	$ret[$key] = $diff; 
 | |
| 				}
 | |
| 			} 
 | |
| 			else 
 | |
| 			{
 | |
| 				if($val != $array2[$key]) 
 | |
| 	        	{
 | |
| 					$ret[$key] = $val;
 | |
| 				}
 | |
| 			}
 | |
| 		} 
 | |
|     	else 
 | |
|     	{
 | |
|     	  $ret[$key] = $val;
 | |
| 		}
 | |
| 	}
 | |
| 	
 | |
|   return $ret;
 | |
| }
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * Strips slashes from a string or an array
 | |
|  *
 | |
|  * @param $data
 | |
|  * @return array|string
 | |
|  */
 | |
| function array_stripslashes($data)
 | |
| {
 | |
| 	return is_array($data) ? array_map('array_stripslashes', $data) : stripslashes($data);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @return void
 | |
|  */
 | |
| function echo_gzipped_page()
 | |
| {
 | |
| 
 | |
|     if(headers_sent())
 | |
| 	{
 | |
|         $encoding = false;
 | |
|     }
 | |
| 	elseif( strpos($_SERVER["HTTP_ACCEPT_ENCODING"], 'x-gzip') !== false )
 | |
| 	{
 | |
|         $encoding = 'x-gzip';
 | |
|     }
 | |
| 	elseif( strpos($_SERVER["HTTP_ACCEPT_ENCODING"],'gzip') !== false )
 | |
| 	{
 | |
|         $encoding = 'gzip';
 | |
|     }
 | |
| 	else
 | |
| 	{
 | |
|         $encoding = false;
 | |
|     }
 | |
| 
 | |
|     if($encoding)
 | |
| 	{
 | |
|         $contents = ob_get_clean();
 | |
| 		header('Content-Encoding: '.$encoding);
 | |
|         print("\x1f\x8b\x08\x00\x00\x00\x00\x00");
 | |
|         $size = strlen($contents);
 | |
|         $contents = gzcompress($contents, 9);
 | |
|         $contents = substr($contents, 0, $size);
 | |
|         print($contents);
 | |
|         exit();
 | |
|     }
 | |
| 
 | |
|     ob_end_flush();
 | |
|     exit();
 | |
| 
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @deprecated but necessary. BC Fix.
 | |
|  * @return string
 | |
|  */
 | |
| function getip()
 | |
| {
 | |
| 	trigger_error('<b>getip() is deprecated.</b> Use e107::getIPHandler()->ipDecode(USERIP) instead.', E_USER_DEPRECATED); // NO LAN
 | |
| 
 | |
| 	return e107::getIPHandler()->ipDecode(USERIP);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @deprecated - use e107::loadLanFiles();
 | |
|  * @param $unitName
 | |
|  * @param string $type
 | |
|  * @return bool|string
 | |
|  * Routine looks in standard paths for language files associated with a plugin or theme - primarily for core routines, which won't know
 | |
|  * for sure where the author has put them.
 | |
|  * $unitName is the name (directory path) of the plugin or theme
 | |
|  * $type determines what is to be loaded:
 | |
|  * 'runtime'	- the standard runtime language file for a plugin
 | |
|  * 'admin'		- the standard admin language file for a plugin
 | |
|  * 'theme'		- the standard language file for a plugin (these are usually pretty small, so one is enough)
 | |
|  * Otherwise, $type is treated as part of a filename within the plugin's language directory, prefixed with the current language
 | |
|  * Returns false on failure (not found).
 | |
|  * Returns the include_once error return if there is one
 | |
|  * Otherwise returns an empty string.
 | |
|  *
 | |
|  * Note - if the code knows precisely where the language file is located, use include_lan()
 | |
|  *
 | |
|  * $pref['noLanguageSubs'] can be set true to prevent searching for the English files if the files for the current site language don't exist.
 | |
|  */
 | |
| function loadLanFiles($unitName, $type='runtime')
 | |
| {
 | |
| 	trigger_error('<b>loadLanFiles() is deprecated.</b> Use e107::loadLanFiles() instead.', E_USER_DEPRECATED); // NO LAN
 | |
| 
 | |
| 	$info = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS,2);
 | |
| 	e107::getMessage()->addDebug("Using deprecated function loanLanFiles(). Replace with e107::loadLanFiles().".print_a($info,true));
 | |
| 	return e107::loadLanFiles($unitName, $type);
 | |
| }
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * @deprecated Use ini_set() directly.
 | |
|  * @param $var
 | |
|  * @param $value
 | |
|  * @return false|string
 | |
|  */
 | |
| function e107_ini_set($var, $value)
 | |
| {
 | |
| 	trigger_error('<b>e107_ini_set() is deprecated.</b> Use ini_set() instead.', E_USER_DEPRECATED); // NO LAN
 | |
| 
 | |
| 	if (function_exists('ini_set'))
 | |
| 	{
 | |
| 		return ini_set($var, $value);
 | |
| 	}
 | |
| 
 | |
| 	return false;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @deprecated - use e107::isInstalled();
 | |
|  * @param $plugname
 | |
|  * @return bool
 | |
|  */
 | |
| function plugInstalled($plugname)
 | |
| {
 | |
| 	trigger_error('<b>plugInstalled() is deprecated.</b> Use <e107::isInstalled() instead.', E_USER_DEPRECATED); // NO LAN
 | |
| 
 | |
| 	return e107::isInstalled($plugname);
 | |
| 	/*global $pref;
 | |
| 	// Could add more checks here later if appropriate
 | |
| 	return isset($pref['plug_installed'][$plugname]);*/
 | |
| }
 | |
| 
 | |
| /*
 | |
| // -----------------------------------------------------------------------------
 | |
| function table_exists($check)
 | |
| {
 | |
| 	if (!$GLOBALS['mySQLtablelist'])
 | |
| 	{
 | |
| 		$tablist=mysql_list_tables($GLOBALS['mySQLdefaultdb']);
 | |
| 		while (list($temp) = mysql_fetch_array($tablist))
 | |
| 		{
 | |
| 			$GLOBALS['mySQLtablelist'][] = $temp;
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	$mltable=MPREFIX.strtolower($check);
 | |
| 
 | |
| 	foreach ($GLOBALS['mySQLtablelist'] as $lang)
 | |
| 	{
 | |
| 		if (strpos($lang, $mltable) !== false)
 | |
| 		{
 | |
| 			return true;
 | |
| 		}
 | |
| 	}
 | |
| }
 | |
| */
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| // Better Array-sort by key function by acecream (22-Apr-2003 11:02) http://php.net/manual/en/function.asort.php
 | |
| if (!function_exists('asortbyindex')) 
 | |
| {
 | |
| 	/**
 | |
| 	 * @param $array
 | |
| 	 * @param $key
 | |
| 	 * @return array
 | |
| 	 */
 | |
| 	function asortbyindex($array, $key)
 | |
|     {
 | |
|        foreach ($array as $i => $k)
 | |
|        {
 | |
|             $sort_values[$i] = $k[$key];
 | |
|        }
 | |
|        asort ($sort_values);
 | |
|        reset ($sort_values);
 | |
| 
 | |
|        $sorted_arr = array();
 | |
| 
 | |
|        foreach($sort_values as $arr_key =>$arr_val)
 | |
|        {
 | |
|               $sorted_arr[] = $array[$arr_key];
 | |
|        }
 | |
| 
 | |
|        return $sorted_arr;
 | |
|     }
 | |
| }
 | |
| 
 | |
| if (!function_exists('r_emote')) 
 | |
| {
 | |
| 	/**
 | |
| 	 * Still in use.
 | |
| 	 */
 | |
| 	function r_emote()
 | |
| 	{
 | |
| 
 | |
| 		$pack = e107::getPref('emotepack');
 | |
| 
 | |
| 		$list = e107::getEmote()->getList();
 | |
| 
 | |
| 		$str = '';
 | |
| 		foreach($list as $key => $value)		// filename => text code
 | |
| 		{
 | |
| 			$key = str_replace("!", ".", $key);					// Usually '.' was replaced by '!' when saving
 | |
| 			$key = preg_replace("#_(\w{3})$#", ".\\1", $key);	// '_' followed by exactly 3 chars is file extension
 | |
| 			$key = e_IMAGE_ABS."emotes/" . $pack . "/" .$key;		// Add in the file path
 | |
| 	
 | |
| 			$value2 = substr($value, 0, strpos($value, " "));
 | |
| 			$value = ($value2 ? $value2 : $value);
 | |
| 			$value = ($value === '&|') ? ':((' : $value;
 | |
| 			$value = " ".$value." ";
 | |
| 
 | |
| 		//	$str .= "\n<a class='addEmote' data-emote=\"".$value."\" href=\"javascript:addtext('$value',true)\"><img src='$key' alt='' /></a> ";
 | |
| 			$str .= "\n<a class='addEmote' data-emote=\"".$value."\" href=\"#\"><img src='$key' alt='' /></a> ";
 | |
| 		}
 | |
| 
 | |
| 		$JS = "
 | |
| 
 | |
| 		$('.addEmote').click(function(){
 | |
| 
 | |
| 			val = $(this).attr('data-emote')
 | |
| 			addtext(val,true);
 | |
| 			return false;
 | |
| 		});
 | |
| 		";
 | |
| 
 | |
| 		e107::js('footer-inline',$JS);
 | |
| 
 | |
| 
 | |
| 		return "<div class='spacer'>".$str."</div>";
 | |
| 	}
 | |
| }
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| if (!function_exists('multiarray_sort')) 
 | |
| {
 | |
| 	
 | |
| 	
 | |
| 	/**
 | |
| 	 * Sort a Multi-Dimensional array
 | |
| 	 * @param $array
 | |
| 	 * @param $key
 | |
| 	 * @param $order
 | |
| 	 * @param $natsort
 | |
| 	 * @param $case
 | |
| 	 * @return array sorted array.
 | |
| 	 */
 | |
|     function multiarray_sort(&$array, $key, $order = 'asc', $natsort = true, $case = true)
 | |
|     {
 | |
|         if(!is_array($array)) return $array;
 | |
| 
 | |
|         $order = strtolower($order);
 | |
|         foreach ($array as $i => $arr)
 | |
|         {
 | |
|            $sort_values[$i] = varset($arr[$key]);
 | |
|         }
 | |
| 
 | |
|         if(!$natsort) 
 | |
|         {
 | |
|             ($order==='asc')? asort($sort_values) : arsort($sort_values);
 | |
|         }
 | |
|         elseif(isset($sort_values))
 | |
|         {
 | |
|              $case ? natsort($sort_values) : natcasesort($sort_values);
 | |
|              if($order !== 'asc') $sort_values = array_reverse($sort_values, true);
 | |
|         }
 | |
|         
 | |
| 
 | |
|         if(!isset($sort_values))
 | |
|         {
 | |
|             return $array;
 | |
|         }
 | |
|             
 | |
|         reset ($sort_values);
 | |
| /*
 | |
|         while (list ($arr_key, $arr_val) = each ($sort_values))
 | |
|         {
 | |
|  			$key = is_numeric($arr_key) ? "" : $arr_key; // retain assoc-array keys. 
 | |
|  			$sorted_arr[$key] = $array[$arr_key];
 | |
|         }*/
 | |
| 		$sorted_arr = array();
 | |
| 
 | |
|         foreach($sort_values as $arr_key=>$arr_val)
 | |
|         {
 | |
|             $key = is_numeric($arr_key) ? "" : $arr_key; // retain assoc-array keys.
 | |
|  			$sorted_arr[$key] = $array[$arr_key];
 | |
|         }
 | |
|         return $sorted_arr;
 | |
|     }
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Array Storage Class. 
 | |
|  */
 | |
| class e_array {
 | |
| 
 | |
|     /**
 | |
|     * Returns an array from stored array data in php serialized, e107 var_export and json-encoded data. 
 | |
|     *
 | |
|     * @param string $sourceArrayData
 | |
|     * @return array|bool stored data
 | |
|     */
 | |
|     public function unserialize($sourceArrayData)
 | |
|     {
 | |
|         $ArrayData = $sourceArrayData;
 | |
| 
 | |
| 
 | |
|         if (empty($ArrayData))
 | |
|         {
 | |
|             return false;
 | |
|         }
 | |
| 
 | |
|         if(is_array($ArrayData))
 | |
|         {
 | |
|             return $ArrayData;
 | |
|         }
 | |
|         
 | |
|         // Saftety mechanism for 0.7 -> 0.8 transition.
 | |
|         $first2Chars = substr($ArrayData,0,2);
 | |
|         if($first2Chars === 'a:' || $first2Chars === 's:') // php serialize.
 | |
|         {
 | |
|             if(PHP_MAJOR_VERSION > 5)
 | |
|             {
 | |
|                  $dat = unserialize($ArrayData, ['allowed_classes' => false]);
 | |
|             }
 | |
|             else
 | |
|             {
 | |
|                 $dat = unserialize($ArrayData);
 | |
|             }
 | |
| 
 | |
|             $ArrayData = $this->serialize($dat,FALSE);
 | |
|         }
 | |
| 		elseif(strpos($ArrayData,'{') === 0 || strpos($ArrayData,'[') === 0) // json
 | |
| 	    {
 | |
| 	        $dat = json_decode($ArrayData, true);
 | |
| 
 | |
| 	     //   e107::getDebug()->log("Json data found");
 | |
| 
 | |
| 	        if(deftrue('e_DEBUG') && json_last_error() !=  JSON_ERROR_NONE && !e107::isCli())
 | |
| 	        {
 | |
| 	            e107::getDebug()->log("e107::unserialize() Parser Error (json)");
 | |
| 
 | |
| 				$dbg = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS, 9);
 | |
| 
 | |
| 				$fileName = e_LOG.'unserializeError_'.time().'.log';
 | |
| 
 | |
| 	            file_put_contents($fileName, "input:". $sourceArrayData."\nbacktrace:\n".print_r($dbg,true));
 | |
| 
 | |
| 				return null;
 | |
| 	        }
 | |
| 
 | |
| 	        return $dat;
 | |
| 	    }
 | |
| 
 | |
| 		// below is var_export() format using eval();
 | |
| 
 | |
|         $ArrayData = trim($ArrayData);
 | |
| 
 | |
|         if(strpos($ArrayData, "\$data = ") === 0) // Fix for buggy old value.
 | |
| 		{
 | |
| 			$ArrayData = (string) substr($ArrayData,8);
 | |
| 		}
 | |
| 
 | |
|         if(stripos($ArrayData, 'array') !== 0)
 | |
|         {
 | |
|             return false;
 | |
|         }
 | |
| 
 | |
| 		if(strpos($ArrayData,"0 => \'")!==false)
 | |
| 		{
 | |
|              $ArrayData = stripslashes($ArrayData);
 | |
| 		}
 | |
| 		elseif(strpos($ArrayData,'array') === 0 && strpos($ArrayData,"\' => \'") !== false && strpos($ArrayData,"' => 'array") === false) // FIX for old corrupted link-words preference.
 | |
| 		{
 | |
| 			$ArrayData = stripslashes($ArrayData);
 | |
| 		}
 | |
| 
 | |
| 	    $ArrayData = str_replace('=>','=>',$ArrayData); //FIX for PDO encoding of strings. .
 | |
| 
 | |
| 
 | |
| 	    if(trim($ArrayData) === 'Array') // Something went wrong with storage.
 | |
|         {
 | |
|             $debug = debug_backtrace(false);
 | |
|             e107::getMessage()->addDebug("Bad Array Storage found: ". print_a($debug,true));
 | |
| 
 | |
|             return array();
 | |
|         }
 | |
| 
 | |
|         $data = "";
 | |
|         $ArrayData = '$data = '.$ArrayData.';';
 | |
| 
 | |
| 		if(PHP_MAJOR_VERSION > 6) // catch parser error.
 | |
| 	    {
 | |
| 	        try
 | |
| 	        {
 | |
| 			    @eval($ArrayData);
 | |
| 			}
 | |
| 			catch (ParseError $e)
 | |
| 			{
 | |
| 
 | |
| 				if(e_DEBUG === true)
 | |
| 				{
 | |
| 					$message = $e->getMessage();
 | |
| 					$message .= print_a($ArrayData,true);
 | |
| 					echo "<div class='alert alert-danger'><h4>e107::unserialize() Parser Error</h4>". $message. "</div>";
 | |
| 					echo "<pre>";
 | |
| 					debug_print_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS, 3);
 | |
| 					echo "</pre>";
 | |
| 					file_put_contents(e_LOG.'unserializeError_'.time().'.log', $sourceArrayData);
 | |
| 				}
 | |
| 
 | |
| 			//	e107::getAdminLog()->addError($sourceArrayData)->toFile('unserializeError_'.time().'.log','e107::unserialize',false);
 | |
| 
 | |
| 
 | |
| 			    return array();
 | |
| 
 | |
| 			}
 | |
| 
 | |
| 	    }
 | |
| 		else
 | |
| 		{
 | |
| 
 | |
| 			@eval($ArrayData);
 | |
| 	        if (!isset($data) || !is_array($data))
 | |
| 	        {
 | |
| 	            if(e_DEBUG === true)
 | |
| 				{
 | |
| 	                file_put_contents(e_LOG.'unserializeError_'.time().'.log', $sourceArrayData);
 | |
| 				}
 | |
| 
 | |
| 	            trigger_error("Bad stored array data - <br /><br />".htmlentities($ArrayData), E_USER_ERROR);
 | |
| 
 | |
| 	        }
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 
 | |
|         return $data;        
 | |
|     }
 | |
|     
 | |
|     
 | |
|     /**
 | |
|     * Return a string containg exported array data.
 | |
|     *
 | |
|     * @param array $ArrayData array to be stored
 | |
|     * @param bool|string $mode true = var_export with addedslashes, false = var_export (default), 'json' = json encoded
 | |
|     * @return null|string
 | |
|     */
 | |
|     public function serialize($ArrayData, $mode = false)
 | |
|     {       
 | |
|         if (!is_array($ArrayData) || empty($ArrayData))
 | |
|         {
 | |
|             return null;
 | |
|         }
 | |
| 
 | |
|         if($mode === 'json')
 | |
|         {
 | |
|             //todo discuss - move to e_parse::toJSON() ?
 | |
|             $encoded =  json_encode($ArrayData, JSON_PRETTY_PRINT);
 | |
|             if(json_last_error() === JSON_ERROR_UTF8)
 | |
|             {
 | |
|                 $ArrayData = e107::getParser()->toUTF8($ArrayData);
 | |
|                 $encoded = json_encode($ArrayData, JSON_PRETTY_PRINT);
 | |
|                 //todo log
 | |
|             }
 | |
| 
 | |
|             return $encoded;
 | |
|         }
 | |
| 
 | |
|         $Array = var_export($ArrayData, true);
 | |
| 
 | |
|         if ($mode === true)
 | |
|         {
 | |
|             $Array = addslashes($Array);
 | |
|         }
 | |
| 
 | |
|         return $Array;        
 | |
|     }
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
|     /**
 | |
|      * @deprecated - Backwards Compatible. Use e107::serialize() instead;
 | |
|     * @param array $ArrayData array to be stored
 | |
|     * @param bool $AddSlashes default true, add slashes for db storage, else false
 | |
|     * @return string a string containg exported array data.
 | |
|      */
 | |
|     function WriteArray($ArrayData, $AddSlashes = true)
 | |
|     {
 | |
|         trigger_error('<b>'.__METHOD__.' is deprecated.</b> Use e107::serialize() instead.', E_USER_DEPRECATED); // no LAN
 | |
|         return  $this->serialize($ArrayData, $AddSlashes);   
 | |
| 
 | |
|     }
 | |
| 
 | |
| 	/**
 | |
| 	 * @param $ArrayData
 | |
| 	 * @param $AddSlashes
 | |
| 	 * @return string|null
 | |
| 	 */
 | |
| 	function write($ArrayData, $AddSlashes = true)
 | |
| 	{
 | |
|         return  $this->serialize($ArrayData, $AddSlashes);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|     * @deprecated: Use e107::unserialize(); instead.
 | |
|     * Returns an array from stored array data.
 | |
|     * @deprecated
 | |
|     * @param string $ArrayData
 | |
|     * @return array stored data
 | |
|     */
 | |
|     function ReadArray($ArrayData) 
 | |
|     {
 | |
|         trigger_error('<b>'.__METHOD__.' is deprecated.</b> Use e107::unserialize() instead.', E_USER_DEPRECATED); // NO LAN
 | |
|         return $this->unserialize($ArrayData);
 | |
|     }
 | |
| 
 | |
| 	/**
 | |
| 	 * @param $ArrayData
 | |
| 	 * @return array|bool|string|null
 | |
| 	 */
 | |
| 	function read($ArrayData)
 | |
|     {
 | |
|         return $this->unserialize($ArrayData);
 | |
|     }
 | |
| 	
 | |
| 	/**
 | |
| 	 * Load and unserialize stored data from a local file inside SYSTEM folder
 | |
| 	 * @example e107::getArrayStorage()->load('import/somefile'); // -> e_SYSTEM/import/somefile.php
 | |
| 	 * @example e107::getArrayStorage()->load('somefile', 'weird'); // -> e_SYSTEM/somefile.weird
 | |
| 	 * 
 | |
| 	 * @param string $systemLocationFile relative to e_SYSTEM file path (without the extension)
 | |
| 	 * @param string $extension [optional] file extension, default is 'php'
 | |
| 	 * @return array|false false when file not found (or on error)
 | |
| 	 */
 | |
| 	public function load($systemLocationFile, $extension = 'php')
 | |
| 	{
 | |
| 		if($extension) $extension = '.'.$extension;
 | |
| 		$_f = e_SYSTEM.preg_replace('#[^\w/]#', '', trim($systemLocationFile, '/')).$extension;
 | |
| 		if(!file_exists($_f))
 | |
| 		{
 | |
| 			return false;
 | |
| 		}
 | |
| 		$content = file_get_contents($_f);
 | |
| 
 | |
| 		return $this->read($content);
 | |
| 	}
 | |
| 
 | |
|     /**
 | |
|      * Serialize and store data to a local file inside SYSTEM folder
 | |
|      * @example e107::getArrayStorage()->store($arrayData, 'import/somefile'); // -> e_SYSTEM/import/somefile.php
 | |
|      * @example e107::getArrayStorage()->store($arrayData, 'somefile', 'weird'); // -> e_SYSTEM/somefile.weird
 | |
|      *
 | |
|      * @param array $array
 | |
|      * @param string $systemLocationFile relative to e_SYSTEM file path (without the extension)
 | |
|      * @param string $extension [optional] file extension, default is 'php'
 | |
|      * @return bool when file not found (or on error)
 | |
|      */
 | |
| 	public function store($array, $systemLocationFile, $extension = 'php')
 | |
| 	{
 | |
| 		if($extension) $extension = '.'.$extension;
 | |
| 		$_f = e_SYSTEM.preg_replace('#[^\w/]#', '', trim($systemLocationFile, '/')).$extension;
 | |
| 
 | |
| 		$content = $this->write($array, false);
 | |
| 		
 | |
| 		if(false !== $content)
 | |
| 		{
 | |
| 			return file_put_contents($_f, $content) ? true : false;
 | |
| 		}
 | |
| 
 | |
| 		return false;
 | |
| 	}
 | |
| }
 | |
| 
 |