* Copyright 1999-2001 (c) VA Linux Systems
* http://sourceforge.net
*
- * @version $Id$
*/
+// escaping lib
+require_once $gfcommon.'include/escapingUtils.php';
+
+if (isset($_SERVER) && array_key_exists('PHP_SELF', $_SERVER) && $_SERVER['PHP_SELF']) {
+ $_SERVER['PHP_SELF'] = htmlspecialchars($_SERVER['PHP_SELF']);
+}
+
+if (isset($GLOBALS) && array_key_exists('PHP_SELF', $GLOBALS) && $GLOBALS['PHP_SELF']) {
+ $GLOBALS['PHP_SELF'] = htmlspecialchars($GLOBALS['PHP_SELF']);
+}
+
+// Just say no to link prefetching (Moz prefetching, Google Web Accelerator, others)
+// http://www.google.com/webmasters/faq.html#prefetchblock
+if (getStringFromServer('HTTP_X_moz') === 'prefetch'){
+ header(getStringFromServer('SERVER_PROTOCOL') . ' 404 Prefetch Forbidden');
+ trigger_error('Prefetch request forbidden.');
+ exit;
+}
+
if (!isset($no_gz_buffer) || !$no_gz_buffer) {
ob_start("ob_gzhandler");
}
-/*
- redirect to proper hostname to get around certificate problem on IE 5
-*/
+require $gfcgfile;
+require $gfcommon.'include/config.php';
+fusionforge_define_config_item ('core', 'forge_name', $GLOBALS['sys_name']) ;
+fusionforge_define_config_item ('core', 'user_registration_restricted', $GLOBALS['sys_user_reg_restricted']) ;
+fusionforge_read_config_file ($gfconfig.'/fusionforge.ini') ;
// get constants used for flags or status
-require('common/include/constants.php');
+require $gfcommon.'include/constants.php';
-// Defines all of the GForge hosts, databases, etc.
-// This needs to be loaded first because the lines below depend upon it.
-$sys_localinc=getenv('sys_localinc');
-if (is_file($sys_localinc)) {
- require($sys_localinc);
-} else {
- if (is_file('/etc/gforge/local.inc')) {
- require ('/etc/gforge/local.inc');
- } else {
- if (is_file('etc/local.inc')) {
- require('etc/local.inc');
- }
- }
-}
-
-if ($HTTP_HOST != $GLOBALS['sys_default_domain'] && $HTTP_HOST != $GLOBALS['sys_fallback_domain']) {
- if ($SERVER_PORT == '443') {
- header ("Location: https://".$GLOBALS['sys_default_domain']."$REQUEST_URI");
- } else {
- header ("Location: http://".$GLOBALS['sys_default_domain']."$REQUEST_URI");
- }
- exit;
-}
//
if ($sys_use_jabber) {
- require_once('common/include/Jabber.class');
+ require_once $gfcommon.'include/Jabber.class.php';
}
//library to determine browser settings
-require_once('www/include/browser.php');
+require_once $gfwww.'include/browser.php';
//base error library for new objects
-require_once('common/include/Error.class');
+require_once $gfcommon.'include/Error.class.php';
// HTML layout class, may be overriden by the Theme class
-require_once('www/include/Layout.class');
+require_once $gfwww.'include/Layout.class.php';
//various html utilities
-require_once('common/include/utils.php');
+require_once $gfcommon.'include/utils.php';
//database abstraction
-require_once('common/include/database.php');
+require_once $gfcommon.'include/database-'.$sys_database_type.'.php';
//security library
-require_once('common/include/session.php');
+require_once $gfcommon.'include/session.php';
//system library
-require_once('common/include/System.class');
-require_once('common/include/system/'.$sys_account_manager_type.'.class');
+require_once $gfcommon.'include/System.class.php';
+if (!$sys_account_manager_type) {
+ $sys_account_manager_type='UNIX';
+}
+require_once $gfcommon.'include/system/'.$sys_account_manager_type.'.class.php';
$SYS=new $sys_account_manager_type();
//user functions like get_name, logged_in, etc
-require_once('common/include/User.class');
+require_once $gfcommon.'include/User.class.php';
//group functions like get_name, etc
-require_once('common/include/Group.class');
+require_once $gfcommon.'include/Group.class.php';
//permission functions
-require_once('common/include/Permission.class');
-
-// escaping lib
-require_once('common/include/escapingUtils.php');
+require_once $gfcommon.'include/Permission.class.php';
//library to set up context help
-require_once('www/include/help.php');
+require_once $gfwww.'include/help.php';
//exit_error library
-require_once('www/include/exit.php');
+require_once $gfwww.'include/exit.php';
//various html libs like button bar, themable
-require_once('www/include/html.php');
+require_once $gfwww.'include/html.php';
+
+//forms key generation
+require_once $gfcommon.'include/forms.php';
// #### Connect to db
db_connect();
-if (!$conn) {
- print "$sys_name Could Not Connect to Database: ".db_error();
+if (!$GLOBALS['gfconn']) {
+ print fusionforge_get_config ('core', 'forge_name')." Could Not Connect to Database: ".db_error();
exit;
}
// Plugins subsystem
-require_once('common/include/Plugin.class') ;
-require_once('common/include/PluginManager.class') ;
+require_once $gfcommon.'include/Plugin.class.php' ;
+require_once $gfcommon.'include/PluginManager.class.php' ;
// SCM-specific plugins subsystem
-require_once('common/include/SCM.class') ;
+require_once $gfcommon.'include/SCMPlugin.class.php' ;
setup_plugin_manager () ;
+
//determine if they're logged in
session_set();
+plugin_hook('after_session_set');
+
//mandatory login
if (!session_loggedin() && $sys_force_login == 1 ) {
- $expl_pathinfo = explode('/',$REQUEST_URI);
- if ($REQUEST_URI!='/' && $expl_pathinfo[1]!='account') exit_not_logged_in();
+ $expl_pathinfo = explode('/',getStringFromServer('REQUEST_URI'));
+ if (getStringFromServer('REQUEST_URI')!='/' && $expl_pathinfo[1]!='account' && $expl_pathinfo[1]!='export' ) exit_not_logged_in();
+ // Show proj* export even if not logged in when force login
+ // If not default web project page would be broken
+ if ($expl_pathinfo[1]=='export' && !ereg("^proj", $expl_pathinfo[2])) exit_not_logged_in();
}
//insert this page view into the database
-require_once('www/include/logger.php');
+require_once $gfwww.'include/logger.php';
//
// If logged in, set up a $LUSER var referencing
//set up the user's timezone if they are logged in
$LUSER =& session_get_user();
$LUSER->setUpTheme();
+ header('Cache-Control: private');
}
//
// Include user Theme
//
-require_once($sys_themeroot.$sys_theme.'/Theme.class');
+require_once $sys_themeroot.$sys_theme.'/Theme.class.php';
$HTML=new Theme();
*/
-require_once('www/include/BaseLanguage.class');
+require_once $gfcommon.'include/gettext.php';
+require_once $gfcommon.'include/group_section_texts.php';
-if (!$sys_lang) {
- $sys_lang="English";
-}
-if (session_loggedin()) {
- $Language=new BaseLanguage();
- $Language->loadLanguageID($LUSER->getLanguage());
-} else {
- //if you aren't logged in, check your browser settings
- //and see if we support that language
- //if we don't support it, just use English as default
- if ($HTTP_ACCEPT_LANGUAGE) {
- $res = language_code_to_result ($HTTP_ACCEPT_LANGUAGE);
- $classname=db_result($res,0,'classname');
- }
- if (!$classname) {
- $classname=$sys_lang;
- }
- $Language=new BaseLanguage();
- $Language->loadLanguage($classname);
-}
-
-setlocale (LC_TIME, $Language->getText('system','locale'));
-$sys_strftimefmt = $Language->getText('system','strftimefmt');
-$sys_datefmt = $Language->getText('system','datefmt');
+setup_gettext_from_context();
/*
RESERVED VARIABLES
-$conn
+$gfconn
$session_hash
-$Language
$LUSER - Logged in user object
$HTML
-$sys_datefmt
*/
+
+// Local Variables:
+// mode: php
+// c-file-style: "bsd"
+// End:
+
?>