$chain->setSuppression(false); } // Load in core require_once 'Core/Core.php'; // Connect to database global $databaseConfig; if ($databaseConfig) { DB::connect($databaseConfig); } // Check if a token is requesting a redirect if (!$reloadToken) { return; } // Otherwise, we start up the session if needed if (!isset($_SESSION) && Session::request_contains_session_id()) { Session::start(); } // Next, check if we're in dev mode, or the database doesn't have any security data, or we are admin if (Director::isDev() || !Security::database_is_ready() || Permission::check('ADMIN')) { return $reloadToken->reloadWithToken(); } // Fail and redirect the user to the login page $loginPage = Director::absoluteURL(Security::config()->login_url); $loginPage .= "?BackURL=" . urlencode($_SERVER['REQUEST_URI']); header('location: ' . $loginPage, true, 302); die; })->thenIfErrored(function () use($reloadToken) { if ($reloadToken) { $reloadToken->reloadWithToken(); } })->execute();
public function testNonStandardPath() { Config::inst()->update('SilverStripe\\Control\\Session', 'store_path', realpath(dirname($_SERVER['DOCUMENT_ROOT']) . '/../session')); Session::start(); $this->assertEquals(Config::inst()->get('SilverStripe\\Control\\Session', 'store_path'), ''); }