get('allowAnonymousLogin', false)) { $dest = 'dashboard'; } if (!isset($action)) { $action = $dest; } elseif ($action <> $dest) { // we have a controller link and auth has failed, so redirect to the login page // with the controller link as the redirect $url = generateControllerUrl('login'); $redirect = urlencode($_SERVER[PHP_SELF] . '?' . $_SERVER['QUERY_STRING']); if ((strlen($redirect) > 1)) { $url = $url . '&redirect=' . $redirect; } if (PEAR::isError($ret)) { $url = $url . '&errorMessage=' . urlencode($ret->getMessage()); } redirect($url); exit(0); } } } // we appear to have some encoding/decoding issues, so we need to force-check for %30 type situations $queryString = KTUtil::arrayGet($_REQUEST, 'qs', ''); if (is_array($queryString)) { $aStrings = array(); foreach ($queryString as $k => $v) { $aStrings[] = $k . '=' . $v; } $queryString = join('&', $aStrings); } elseif (count(preg_match('#\%#', $queryString) != 0)) { $queryString = urldecode($queryString); } if (empty($queryString)) { // need to strip query string params from action before attempting to retrieve from sitemap $queryString = ''; // check for the presence of additional params if (strstr($_SERVER['QUERY_STRING'], '&')) { // strip and save the querystring $queryString = substr($_SERVER['QUERY_STRING'], strpos($_SERVER['QUERY_STRING'], '&')+1, strlen($_SERVER['QUERY_STRING'])); } else if (strstr($_SERVER['QUERY_STRING'], '?')) { // strip and save the querystring $queryString = substr($_SERVER['QUERY_STRING'], strpos($_SERVER['QUERY_STRING'], '?')+1, strlen($_SERVER['QUERY_STRING'])); // update $action = substr($_SERVER['QUERY_STRING'], 0, strpos($_SERVER['QUERY_STRING'], '?')); } } if ($action == 'dashboard') { $oKTConfig = KTConfig::getSingleton(); if(!$oKTConfig->get('useNewDashboard')) $action = 'olddashboard'; } // retrieve the page from the sitemap (checks whether this user has access to the requested page) $page = $default->siteMap->getPage($action, isset($_SESSION['userID']) ? $_SESSION['userID'] : ''); if (!$page) { // this user doesn't have permission to access the page // or there is no page mapping for the requested action // redirect to no permission page $default->log->error("control.php getPage failed for ($action, " . $_SESSION['userID'] . ")"); redirect("$default->uiUrl/noAccess.php"); } else { $page = $default->rootUrl . $page; // set authorised flag and redirect // strip querystring from the page returned from the sitemap // before setting page authorisation flag (since checkSession checks page level // access by checking $_SESSION["pageAccess"][$_SERVER["PHP_SELF"] ie. without querystring(?) $paramStart=strpos($page, '?'); if ($paramStart !== false) { $accessPage = substr($page, 0, $paramStart); } else { $accessPage = $page; } $_SESSION['pageAccess'][$accessPage] = true; // if we have a querystring add it on if (strlen($queryString) > 0) { $page .= ($paramStart !== false)?'&':'?'; $page .= $queryString; $default->log->info("control.php: about to redirect to $page"); } redirect($page); } ?>