0) { session_name('PPA_ID'); session_start(); } } // Do basic PHP configuration checks if (ini_get('magic_quotes_gpc')) { $misc->stripVar($_GET); $misc->stripVar($_POST); $misc->stripVar($_COOKIE); $misc->stripVar($_REQUEST); } // This has to be deferred until after stripVar above $misc->setHREF(); $misc->setForm(); // Enforce PHP environment ini_set('magic_quotes_runtime', 0); ini_set('magic_quotes_sybase', 0); ini_set('arg_separator.output', '&'); // If login action is set, then set session variables if (isset($_POST['loginServer']) && isset($_POST['loginUsername']) && isset($_POST['loginPassword_'.md5($_POST['loginServer'])])) { $_server_info = $misc->getServerInfo($_POST['loginServer']); $_server_info['username'] = $_POST['loginUsername']; $_server_info['password'] = $_POST['loginPassword_'.md5($_POST['loginServer'])]; $misc->setServerInfo(null, $_server_info, $_POST['loginServer']); // Check for shared credentials if (isset($_POST['loginShared'])) { $_SESSION['sharedUsername'] = $_POST['loginUsername']; $_SESSION['sharedPassword'] = $_POST['loginPassword_'.md5($_POST['loginServer'])]; } $_reload_browser = true; } /* select the theme */ unset($_theme); if (!isset($conf['theme'])) $conf['theme'] = 'default'; // 1. Check for the theme from a request var if (isset($_REQUEST['theme']) && is_file("./themes/{$_REQUEST['theme']}/global.css")) { /* save the selected theme in cookie for a year */ setcookie('ppaTheme', $_REQUEST['theme'], time()+31536000); $_theme = $_SESSION['ppaTheme'] = $conf['theme'] = $_REQUEST['theme']; } // 2. Check for theme session var if (!isset($_theme) && isset($_SESSION['ppaTheme']) && is_file("./themes/{$_SESSION['ppaTheme']}/global.css")) { $conf['theme'] = $_SESSION['ppaTheme']; } // 3. Check for theme in cookie var if (!isset($_theme) && isset($_COOKIE['ppaTheme']) && is_file("./themes/{$_COOKIE['ppaTheme']}/global.css")) { $conf['theme'] = $_COOKIE['ppaTheme']; } // 4. Check for theme by server/db/user $info = $misc->getServerInfo(); if (!is_null($info)) { $_theme = ''; if ( (isset($info['theme']['default'])) and is_file("./themes/{$info['theme']['default']}/global.css") ) $_theme = $info['theme']['default']; if ( isset($_REQUEST['database']) and isset($info['theme']['db'][$_REQUEST['database']]) and is_file("./themes/{$info['theme']['db'][$_REQUEST['database']]}/global.css") ) $_theme = $info['theme']['db'][$_REQUEST['database']]; if ( isset($info['username']) and isset($info['theme']['user'][$info['username']]) and is_file("./themes/{$info['theme']['user'][$info['username']]}/global.css") ) $_theme = $info['theme']['user'][$info['username']]; if ($_theme !== '') { setcookie('ppaTheme', $_theme, time()+31536000); $conf['theme'] = $_theme; } } // Determine language file to import: unset($_language); // 1. Check for the language from a request var if (isset($_REQUEST['language']) && isset($appLangFiles[$_REQUEST['language']])) { /* save the selected language in cookie for a year */ setcookie('webdbLanguage', $_REQUEST['language'], time()+31536000); $_language = $_REQUEST['language']; } // 2. Check for language session var if (!isset($_language) && isset($_SESSION['webdbLanguage']) && isset($appLangFiles[$_SESSION['webdbLanguage']])) { $_language = $_SESSION['webdbLanguage']; } // 3. Check for language in cookie var if (!isset($_language) && isset($_COOKIE['webdbLanguage']) && isset($appLangFiles[$_COOKIE['webdbLanguage']])) { $_language = $_COOKIE['webdbLanguage']; } // 4. Check for acceptable languages in HTTP_ACCEPT_LANGUAGE var if (!isset($_language) && $conf['default_lang'] == 'auto' && isset($_SERVER['HTTP_ACCEPT_LANGUAGE'])) { // extract acceptable language tags // (http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html#sec14.4) preg_match_all('/\s*([a-z]{1,8}(?:-[a-z]{1,8})*)(?:;q=([01](?:.[0-9]{0,3})?))?\s*(?:,|$)/', strtolower($_SERVER['HTTP_ACCEPT_LANGUAGE']), $_m, PREG_SET_ORDER); foreach($_m as $_l) { // $_l[1] = language tag, [2] = quality if (!isset($_l[2])) $_l[2] = 1; // Default quality to 1 if ($_l[2] > 0 && $_l[2] <= 1 && isset($availableLanguages[$_l[1]])) { // Build up array of (quality => language_file) $_acceptLang[$_l[2]] = $availableLanguages[$_l[1]]; } } unset($_m); unset($_l); if (isset($_acceptLang)) { // Sort acceptable languages by quality krsort($_acceptLang, SORT_NUMERIC); $_language = reset($_acceptLang); unset($_acceptLang); } } // 5. Otherwise resort to the default set in the config file if (!isset($_language) && $conf['default_lang'] != 'auto' && isset($appLangFiles[$conf['default_lang']])) { $_language = $conf['default_lang']; } // 6. Otherwise, default to english. if (!isset($_language)) $_language = 'english'; // Import the language file if (isset($_language)) { include("./lang/{$_language}.php"); $_SESSION['webdbLanguage'] = $_language; } // Check for config file version mismatch if (!isset($conf['version']) || $conf['base_version'] > $conf['version']) { echo $lang['strbadconfig']; exit; } // Check php libraries $php_libraries_requirements = [ // required_function => name_of_the_php_library 'pg_connect' => 'pgsql', 'mb_strlen' => 'mbstring']; $missing_libraries = []; foreach($php_libraries_requirements as $funcname => $lib) if (!function_exists($funcname)) $missing_libraries[] = $lib; if ($missing_libraries) { $missing_list = implode(', ', $missing_libraries); $error_missing_template_string = count($missing_libraries) <= 1 ? $lang['strlibnotfound'] : $lang['strlibnotfound_plural']; printf($error_missing_template_string, $missing_list); exit; } // Manage the plugins require_once('./classes/PluginManager.php'); // Create data accessor object, if necessary if (!isset($_no_db_connection)) { if (!isset($_REQUEST['server'])) { echo $lang['strnoserversupplied']; exit; } $_server_info = $misc->getServerInfo(); /* starting with PostgreSQL 9.0, we can set the application name */ if(isset($_server_info['pgVersion']) && $_server_info['pgVersion'] >= 9) putenv("PGAPPNAME={$appName}_{$appVersion}"); // Redirect to the login form if not logged in if (!isset($_server_info['username'])) { include('./login.php'); exit; } // Connect to the current database, or if one is not specified // then connect to the default database. if (isset($_REQUEST['database'])) $_curr_db = $_REQUEST['database']; else $_curr_db = $_server_info['defaultdb']; include_once('./classes/database/Connection.php'); // Connect to database and set the global $data variable $data = $misc->getDatabaseAccessor($_curr_db); // If schema is defined and database supports schemas, then set the // schema explicitly. if (isset($_REQUEST['database']) && isset($_REQUEST['schema'])) { $status = $data->setSchema($_REQUEST['schema']); if ($status != 0) { echo $lang['strbadschema']; exit; } } } if (!function_exists("htmlspecialchars_decode")) { function htmlspecialchars_decode($string, $quote_style = ENT_COMPAT) { return strtr($string, array_flip(get_html_translation_table(HTML_SPECIALCHARS, $quote_style))); } } $plugin_manager = new PluginManager($_language); ?>