2007-07-19 10:40:28 +00:00
|
|
|
<?php
|
2012-03-31 20:09:45 +13:00
|
|
|
|
2008-12-04 22:38:32 +00:00
|
|
|
/************************************************************************************
|
|
|
|
************************************************************************************
|
|
|
|
** **
|
|
|
|
** If you can read this text in your browser then you don't have PHP installed. **
|
2012-04-20 15:08:01 +12:00
|
|
|
** Please install PHP 5.3.2 or higher, preferably PHP 5.3.4+. **
|
2008-12-04 22:38:32 +00:00
|
|
|
** **
|
|
|
|
************************************************************************************
|
|
|
|
************************************************************************************/
|
|
|
|
|
2009-03-22 22:59:14 +00:00
|
|
|
/**
|
2012-04-12 18:02:46 +12:00
|
|
|
* @package framework
|
2009-03-22 22:59:14 +00:00
|
|
|
* @subpackage core
|
|
|
|
*/
|
2009-08-11 03:50:40 +00:00
|
|
|
|
2012-04-13 13:12:48 +12:00
|
|
|
if (version_compare(phpversion(), '5.3.2', '<')) {
|
2008-12-04 22:38:32 +00:00
|
|
|
header("HTTP/1.1 500 Server Error");
|
|
|
|
echo str_replace('$PHPVersion', phpversion(), file_get_contents("dev/install/php5-required.html"));
|
|
|
|
die();
|
|
|
|
}
|
|
|
|
|
2007-07-19 10:40:28 +00:00
|
|
|
/**
|
2008-01-09 04:18:36 +00:00
|
|
|
* Main file that handles every page request.
|
2008-02-25 02:10:37 +00:00
|
|
|
*
|
|
|
|
* The main.php does a number of set-up activities for the request.
|
|
|
|
*
|
2008-08-10 23:29:30 +00:00
|
|
|
* - Includes the first one of the following files that it finds: (root)/_ss_environment.php,
|
|
|
|
* (root)/../_ss_environment.php, or (root)/../../_ss_environment.php
|
2008-02-25 02:10:37 +00:00
|
|
|
* - Gets an up-to-date manifest from {@link ManifestBuilder}
|
|
|
|
* - Sets up error handlers with {@link Debug::loadErrorHandlers()}
|
2008-08-10 23:29:30 +00:00
|
|
|
* - Calls {@link DB::connect()}, passing it the global variable $databaseConfig that should
|
2009-03-22 22:59:14 +00:00
|
|
|
* be defined in an _config.php
|
2013-03-21 19:48:54 +01:00
|
|
|
* - Sets up the default director rules using {@link Director::$rules}
|
2008-02-25 02:10:37 +00:00
|
|
|
*
|
2008-08-10 23:29:30 +00:00
|
|
|
* After that, it calls {@link Director::direct()}, which is responsible for doing most of the
|
|
|
|
* real work.
|
2008-02-25 02:10:37 +00:00
|
|
|
*
|
|
|
|
* CONFIGURING THE WEBSERVER
|
|
|
|
*
|
2012-03-24 16:38:57 +13:00
|
|
|
* To use SilverStripe, every request that doesn't point directly to a file should be rewritten to
|
|
|
|
* framework/main.php?url=(url). For example, http://www.example.com/about-us/rss would be rewritten
|
|
|
|
* to http://www.example.com/framework/main.php?url=about-us/rss
|
2008-02-25 02:10:37 +00:00
|
|
|
*
|
2008-08-10 23:29:30 +00:00
|
|
|
* It's important that requests that point directly to a file aren't rewritten; otherwise, visitors
|
|
|
|
* won't be able to download any CSS, JS, image files, or other downloads.
|
2008-02-25 02:10:37 +00:00
|
|
|
*
|
|
|
|
* On Apache, RewriteEngine can be used to do this.
|
|
|
|
*
|
2012-04-12 18:02:46 +12:00
|
|
|
* @package framework
|
2008-02-25 02:10:37 +00:00
|
|
|
* @subpackage core
|
|
|
|
* @see Director::direct()
|
2007-07-19 10:40:28 +00:00
|
|
|
*/
|
|
|
|
|
2013-07-22 13:52:00 +12:00
|
|
|
/**
|
|
|
|
* Include the defines that set BASE_PATH, etc
|
|
|
|
*/
|
|
|
|
require_once('core/Constants.php');
|
|
|
|
|
2013-07-24 12:09:44 +12:00
|
|
|
// IIS will sometimes generate this.
|
|
|
|
if(!empty($_SERVER['HTTP_X_ORIGINAL_URL'])) {
|
|
|
|
$_SERVER['REQUEST_URI'] = $_SERVER['HTTP_X_ORIGINAL_URL'];
|
|
|
|
}
|
|
|
|
|
2013-07-22 13:52:00 +12:00
|
|
|
/**
|
|
|
|
* Figure out the request URL
|
|
|
|
*/
|
|
|
|
global $url;
|
|
|
|
|
2013-07-24 12:09:44 +12:00
|
|
|
// PHP 5.4's built-in webserver uses this
|
|
|
|
if (php_sapi_name() == 'cli-server') {
|
|
|
|
$url = $_SERVER['REQUEST_URI'];
|
2013-07-22 13:52:00 +12:00
|
|
|
|
2013-07-24 12:09:44 +12:00
|
|
|
// Querystring args need to be explicitly parsed
|
|
|
|
if(strpos($url,'?') !== false) {
|
|
|
|
list($url, $query) = explode('?',$url,2);
|
|
|
|
parse_str($query, $_GET);
|
|
|
|
if ($_GET) $_REQUEST = array_merge((array)$_REQUEST, (array)$_GET);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Pass back to the webserver for files that exist
|
|
|
|
if(file_exists(BASE_PATH . $url) && is_file(BASE_PATH . $url)) return false;
|
|
|
|
|
|
|
|
// Apache rewrite rules use this
|
|
|
|
} else if (isset($_GET['url'])) {
|
2013-07-22 13:52:00 +12:00
|
|
|
$url = $_GET['url'];
|
|
|
|
// IIS includes get variables in url
|
|
|
|
$i = strpos($url, '?');
|
|
|
|
if($i !== false) {
|
|
|
|
$url = substr($url, 0, $i);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Lighttpd uses this
|
|
|
|
} else {
|
|
|
|
if(strpos($_SERVER['REQUEST_URI'],'?') !== false) {
|
|
|
|
list($url, $query) = explode('?', $_SERVER['REQUEST_URI'], 2);
|
|
|
|
parse_str($query, $_GET);
|
|
|
|
if ($_GET) $_REQUEST = array_merge((array)$_REQUEST, (array)$_GET);
|
|
|
|
} else {
|
|
|
|
$url = $_SERVER["REQUEST_URI"];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Remove base folders from the URL if webroot is hosted in a subfolder
|
|
|
|
if (substr(strtolower($url), 0, strlen(BASE_URL)) == strtolower(BASE_URL)) $url = substr($url, strlen(BASE_URL));
|
2008-02-25 02:10:37 +00:00
|
|
|
|
|
|
|
/**
|
2012-03-24 16:38:57 +13:00
|
|
|
* Include SilverStripe's core code
|
2008-02-25 02:10:37 +00:00
|
|
|
*/
|
2013-07-18 17:09:21 +12:00
|
|
|
require_once('core/startup/ErrorControlChain.php');
|
|
|
|
require_once('core/startup/ParameterConfirmationToken.php');
|
2007-07-19 10:40:28 +00:00
|
|
|
|
2013-07-18 17:09:21 +12:00
|
|
|
$chain = new ErrorControlChain();
|
|
|
|
$token = new ParameterConfirmationToken('flush');
|
2009-05-14 23:14:51 +00:00
|
|
|
|
2013-07-18 17:09:21 +12:00
|
|
|
$chain
|
|
|
|
->then(function($chain) use ($token){
|
2013-07-22 13:52:00 +12:00
|
|
|
// First, if $_GET['flush'] was set, but no valid token, suppress the flush
|
2013-07-18 17:09:21 +12:00
|
|
|
if (isset($_GET['flush']) && !$token->tokenProvided()) {
|
|
|
|
unset($_GET['flush']);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
$chain->setSuppression(false);
|
|
|
|
}
|
2007-10-02 04:59:06 +00:00
|
|
|
|
2013-07-22 13:52:00 +12:00
|
|
|
// Load in core
|
|
|
|
require_once('core/Core.php');
|
2007-07-19 10:40:28 +00:00
|
|
|
|
2013-07-22 13:52:00 +12:00
|
|
|
// Connect to database
|
2013-07-18 17:09:21 +12:00
|
|
|
require_once('model/DB.php');
|
|
|
|
global $databaseConfig;
|
|
|
|
if ($databaseConfig) DB::connect($databaseConfig);
|
2013-07-22 13:52:00 +12:00
|
|
|
|
|
|
|
// Then if a flush was requested, redirect to it
|
2013-07-18 17:09:21 +12:00
|
|
|
if ($token->parameterProvided() && !$token->tokenProvided()) {
|
|
|
|
// First, check if we're in dev mode, or the database doesn't have any security data
|
|
|
|
$canFlush = Director::isDev() || !Security::database_is_ready();
|
|
|
|
|
|
|
|
// Otherwise, we start up the session if needed, then check for admin
|
|
|
|
if (!$canFlush) {
|
|
|
|
if(!isset($_SESSION) && (isset($_COOKIE[session_name()]) || isset($_REQUEST[session_name()]))) {
|
|
|
|
Session::start();
|
|
|
|
}
|
|
|
|
|
|
|
|
if (Permission::check('ADMIN')) {
|
|
|
|
$canFlush = true;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
$loginPage = Director::absoluteURL(Config::inst()->get('Security', 'login_url'));
|
|
|
|
$loginPage .= "?BackURL=" . urlencode($_SERVER['REQUEST_URI']);
|
|
|
|
|
|
|
|
header('location: '.$loginPage, true, 302);
|
|
|
|
die;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// And if we can flush, reload with an authority token
|
|
|
|
if ($canFlush) $token->reloadWithToken();
|
|
|
|
}
|
|
|
|
})
|
|
|
|
// Finally if a flush was requested but there was an error while figuring out if it's allowed, do it anyway
|
|
|
|
->thenIfErrored(function() use ($token){
|
|
|
|
if ($token->parameterProvided() && !$token->tokenProvided()) {
|
|
|
|
$token->reloadWithToken();
|
|
|
|
}
|
|
|
|
})
|
|
|
|
->execute();
|
2007-07-19 10:40:28 +00:00
|
|
|
|
2012-09-21 19:56:56 +12:00
|
|
|
global $databaseConfig;
|
|
|
|
|
2008-11-18 01:48:37 +00:00
|
|
|
// Redirect to the installer if no database is selected
|
|
|
|
if(!isset($databaseConfig) || !isset($databaseConfig['database']) || !$databaseConfig['database']) {
|
2011-10-29 10:31:58 +13:00
|
|
|
if(!file_exists(BASE_PATH . '/install.php')) {
|
|
|
|
die('SilverStripe Framework requires a $databaseConfig defined.');
|
|
|
|
}
|
2009-01-05 06:19:48 +00:00
|
|
|
$s = (isset($_SERVER['SSL']) || (isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] != 'off')) ? 's' : '';
|
2010-04-14 03:47:37 +00:00
|
|
|
$installURL = "http$s://" . $_SERVER['HTTP_HOST'] . BASE_URL . '/install.php';
|
2013-07-18 17:09:21 +12:00
|
|
|
|
2010-04-14 03:46:40 +00:00
|
|
|
// The above dirname() will equate to "\" on Windows when installing directly from http://localhost (not using
|
|
|
|
// a sub-directory), this really messes things up in some browsers. Let's get rid of the backslashes
|
|
|
|
$installURL = str_replace('\\', '', $installURL);
|
2013-07-18 17:09:21 +12:00
|
|
|
|
2008-11-18 01:48:37 +00:00
|
|
|
header("Location: $installURL");
|
|
|
|
die();
|
|
|
|
}
|
|
|
|
|
2007-07-19 10:40:28 +00:00
|
|
|
// Direct away - this is the "main" function, that hands control to the appropriate controller
|
2011-05-01 17:33:02 +12:00
|
|
|
DataModel::set_inst(new DataModel());
|
2012-09-11 11:49:42 +12:00
|
|
|
Director::direct($url, DataModel::inst());
|