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: * * $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) * * * @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('varsettrue() is deprecated. 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('defsettrue() is deprecated. 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; } function e107_include($fname) { global $_E107; $ret = (isset($_E107['debug']) || deftrue('e_DEBUG')) ? include($fname) : @include($fname); return $ret; } 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 : ''; } function e107_require_once($fname) { global $_E107; $ret = ((isset($_E107['debug']) || deftrue('e_DEBUG')) ? require_once($fname) : @require_once($fname)); return $ret; } function e107_require($fname) { global $_E107; $ret = ((isset($_E107['debug']) || deftrue('e_DEBUG')) ? require($fname) : @require($fname)); return $ret; } function print_a($var, $return = FALSE) { if( ! $return) { echo '
'.htmlspecialchars(print_r($var, TRUE), ENT_QUOTES, 'utf-8').'
'; return TRUE; } return '
'.htmlspecialchars(print_r($var, true), ENT_QUOTES, 'utf-8').'
'; } function e_print($expr = null) { $args = func_get_args(); if(!$args) return; foreach ($args as $arg) { print_a($arg); } } function e_dump($expr = null) { $args = func_get_args(); if(!$args) return; echo '
';
	call_user_func_array('var_dump', $args);
	echo '
'; } /** * 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 mixed $value * @return mixed */ function array_stripslashes($data) { return is_array($data) ? array_map('array_stripslashes', $data) : stripslashes($data); } 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('getip() is deprecated. 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('loadLanFiles() is deprecated. 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('e107_ini_set() is deprecated. 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('plugInstalled() is deprecated. Use $k) { $sort_values[$i] = $array[$i][$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 "; $str .= "\n "; } $JS = " $('.addEmote').click(function(){ val = $(this).attr('data-emote') addtext(val,true); return false; }); "; e107::js('footer-inline',$JS); return "
".$str."
"; } } 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 "

e107::unserialize() Parser Error

". $message. "
"; echo "
";
					debug_print_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS, 3);
					echo "
"; 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 -

".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(''.__METHOD__.' is deprecated. Use e107::serialize() instead.', E_USER_DEPRECATED); // no LAN return $this->serialize($ArrayData, $AddSlashes); } 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(''.__METHOD__.' is deprecated. Use e107::unserialize() instead.', E_USER_DEPRECATED); // NO LAN return $this->unserialize($ArrayData); } 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 array|false 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; } }