= ($a.$b.$c); } /** * returns true if the current internal SM version is at minimum a.b.c * These are plain integer comparisons, as our internal version is * constructed by us, as an array of 3 ints. * * Called: check_sm_version(1,3,3) */ function check_sm_version($a = 0, $b = 0, $c = 0) { global $SQM_INTERNAL_VERSION; if ( !isset($SQM_INTERNAL_VERSION) || $SQM_INTERNAL_VERSION[0] < $a || $SQM_INTERNAL_VERSION[1] < $b || ( $SQM_INTERNAL_VERSION[1] == $b && $SQM_INTERNAL_VERSION[2] < $c ) ) { return FALSE; } return TRUE; } /* recursively strip slashes from the values of an array */ function sqstripslashes(&$array) { if(count($array) > 0) { foreach ($array as $index=>$value) { if (is_array($array[$index])) { sqstripslashes($array[$index]); } else { $array[$index] = stripslashes($value); } } } } function sqsession_register ($var, $name) { sqsession_is_active(); if ( !check_php_version(4,1) ) { global $HTTP_SESSION_VARS; $HTTP_SESSION_VARS[$name] = $var; } else { $_SESSION["$name"] = $var; } session_register("$name"); } function sqsession_unregister ($name) { sqsession_is_active(); if ( !check_php_version(4,1) ) { global $HTTP_SESSION_VARS; unset($HTTP_SESSION_VARS[$name]); } else { unset($_SESSION[$name]); } session_unregister("$name"); } function sqsession_is_registered ($name) { $test_name = &$name; $result = false; if ( !check_php_version(4,1) ) { global $HTTP_SESSION_VARS; if (isset($HTTP_SESSION_VARS[$test_name])) { $result = true; } } else { if (isset($_SESSION[$test_name])) { $result = true; } } return $result; } define('SQ_INORDER',0); define('SQ_GET',1); define('SQ_POST',2); define('SQ_SESSION',3); /** * Search for the var $name in $_SESSION, $_POST, $_GET * and set it in provided var. * If $search is not provided, or == SQ_INORDER, it will search * $_SESSION, then $_POST, then $_GET. Otherwise, * use one of the defined constants to look for * a var in one place specifically. * Returns FALSE if variable is not found. * Returns TRUE if it is. */ function sqgetGlobalVar($name, &$value, $search = SQ_INORDER) { if ( !check_php_version(4,1) ) { global $_SESSION, $_GET, $_POST; } switch ($search) { /* we want the default case to be first here, so that if a valid value isn't specified, all three arrays will be searched. */ default: case SQ_INORDER: case SQ_SESSION: if( isset($_SESSION[$name]) ) { $value = $_SESSION[$name]; return TRUE; } elseif ( $search == SQ_SESSION ) { break; } case SQ_POST: if( isset($_POST[$name]) ) { $value = $_POST[$name]; return TRUE; } elseif ( $search == SQ_POST ) { break; } case SQ_GET: if ( isset($_GET[$name]) ) { $value = $_GET[$name]; return TRUE; } elseif ( $search == SQ_GET ) { break; } } return FALSE; } /** * Search for the var $name in $_SESSION, $_POST, $_GET * (in that order) and register it as a global var. */ function sqextractGlobalVar ($name) { if ( !check_php_version(4,1) ) { global $_SESSION, $_GET, $_POST; } global $$name; if( isset($_SESSION[$name]) ) { $$name = $_SESSION[$name]; } if( isset($_POST[$name]) ) { $$name = $_POST[$name]; } else if ( isset($_GET[$name]) ) { $$name = $_GET[$name]; } } function sqsession_destroy() { /* * php.net says we can kill the cookie by setting just the name: * http://www.php.net/manual/en/function.setcookie.php * maybe this will help fix the session merging again. * * Changed the theory on this to kill the cookies first starting * a new session will provide a new session for all instances of * the browser, we don't want that, as that is what is causing the * merging of sessions. */ global $base_uri; if (isset($_COOKIE[session_name()])) setcookie(session_name(), '', time() - 5, $base_uri); if (isset($_COOKIE['username'])) setcookie('username','',time() - 5,$base_uri); if (isset($_COOKIE['key'])) setcookie('key','',time() - 5,$base_uri); $sessid = session_id(); if (!empty( $sessid )) { if ( !check_php_version(4,1) ) { global $HTTP_SESSION_VARS; $HTTP_SESSION_VARS = array(); } else { $_SESSION = array(); } @session_destroy; } } /* * Function to verify a session has been started. If it hasn't * start a session up. php.net doesn't tell you that $_SESSION * (even though autoglobal), is not created unless a session is * started, unlike $_POST, $_GET and such */ function sqsession_is_active() { $sessid = session_id(); if ( empty( $sessid ) ) { session_start(); } } ?>