getPlatformDetails(); // by default we connect ot the first configured platform if ($platform_id == '') { $platform_id = $platformsAll[0]['id']; } $platformDetails = $platformObject->getPlatformDetails($platform_id); // init user functions require '../app/classes/user.php'; include '../app/helpers/profile.php'; $userObject = new User($dbWeb); // logout is a special case, as we can't use session vars for notices if ($page == 'logout') { // clean up session session_unset(); session_destroy(); setcookie('username', "", time() - 100, $config['folder'], $config['domain'], isset($_SERVER['HTTPS']), true); $notice = "You were logged out.
You can log in again."; $user_id = $userObject->getUserId($currentUser)[0]['id']; $logObject->insertLog($user_id, "Logout: User \"$currentUser\" logged out. IP: $user_IP", 'user'); include '../app/templates/page-header.php'; include '../app/templates/page-menu.php'; include '../app/templates/block-message.php'; include '../app/pages/login.php'; } elseif ($page === 'security') { // Security settings require login if (!isset($currentUser)) { include '../app/templates/error-unauthorized.php'; exit; } // Get user details and rights $user_id = $userObject->getUserId($currentUser)[0]['id']; $userDetails = $userObject->getUserDetails($user_id); $userRights = $userObject->getUserRights($user_id); $userTimezone = isset($userDetails[0]['timezone']) ? $userDetails[0]['timezone'] : 'UTC'; // Initialize RateLimiter require_once '../app/classes/ratelimiter.php'; $rateLimiter = new RateLimiter($dbWeb); include '../app/templates/page-header.php'; include '../app/templates/page-menu.php'; include '../app/templates/page-sidebar.php'; include '../app/pages/security.php'; include '../app/templates/page-footer.php'; } else { // if user is logged in, we need user details and rights if (isset($currentUser)) { $user_id = $userObject->getUserId($currentUser)[0]['id']; $userDetails = $userObject->getUserDetails($user_id); $userRights = $userObject->getUserRights($user_id); $userTimezone = isset($userDetails[0]['timezone']) ? $userDetails[0]['timezone'] : 'UTC'; // Default to UTC if no timezone is set // If by error a logged in user requests the login page if ($page === 'login') { header('Location: ' . htmlspecialchars($app_root)); exit(); } // check if the Jilo Server is running require '../app/classes/server.php'; $serverObject = new Server($dbWeb); $server_host = '127.0.0.1'; $server_port = '8080'; $server_endpoint = '/health'; $server_status = $serverObject->getServerStatus($server_host, $server_port, $server_endpoint); if (!$server_status) { $error = 'The Jilo Server is not running. Some data may be old and incorrect.'; Messages::get('SECURITY', 'RATE_LIMIT_INFO'); Messages::render('SECURITY', 'RATE_LIMIT_INFO'); } } // page building include '../app/templates/page-header.php'; include '../app/templates/page-menu.php'; if (isset($currentUser)) { include '../app/templates/page-sidebar.php'; } include '../app/templates/block-message.php'; if (in_array($page, $allowed_urls)) { // all normal pages include "../app/pages/{$page}.php"; } else { // the page is not in allowed urls, loading "not found" page include '../app/templates/error-notfound.php'; } } // end with the footer include '../app/templates/page-footer.php'; // flush the output buffer and show the page ob_end_flush(); // clear errors and notices before next page just in case unset($_SESSION['error']); unset($_SESSION['notice']); ?>