2013-10-04 00:20:32 +10:00
|
|
|
<?php
|
2015-12-07 17:25:27 +13:00
|
|
|
|
2013-10-04 00:20:32 +10:00
|
|
|
/**
|
|
|
|
* Initialises the versioned stage when a request is made.
|
|
|
|
*
|
|
|
|
* @package framework
|
|
|
|
* @subpackage control
|
|
|
|
*/
|
2014-03-04 17:43:17 +13:00
|
|
|
class VersionedRequestFilter implements RequestFilter {
|
2013-10-04 00:20:32 +10:00
|
|
|
|
2014-03-04 17:43:17 +13:00
|
|
|
public function preRequest(SS_HTTPRequest $request, Session $session, DataModel $model) {
|
2015-12-07 17:25:27 +13:00
|
|
|
// Bootstrap session so that Session::get() accesses the right instance
|
|
|
|
$dummyController = new Controller();
|
|
|
|
$dummyController->setSession($session);
|
|
|
|
$dummyController->setRequest($request);
|
|
|
|
$dummyController->pushCurrent();
|
|
|
|
|
|
|
|
// Block non-authenticated users from setting the stage mode
|
|
|
|
if(!Versioned::can_choose_site_stage($request)) {
|
|
|
|
$permissionMessage = sprintf(
|
|
|
|
_t(
|
|
|
|
"ContentController.DRAFT_SITE_ACCESS_RESTRICTION",
|
|
|
|
'You must log in with your CMS password in order to view the draft or archived content. '.
|
|
|
|
'<a href="%s">Click here to go back to the published site.</a>'
|
|
|
|
),
|
2016-05-03 12:13:01 +01:00
|
|
|
Convert::raw2xml(Controller::join_links(Director::baseURL(), $request->getURL(), "?stage=Live"))
|
2015-12-07 17:25:27 +13:00
|
|
|
);
|
|
|
|
|
|
|
|
// Force output since RequestFilter::preRequest doesn't support response overriding
|
|
|
|
$response = Security::permissionFailure($dummyController, $permissionMessage);
|
|
|
|
$session->inst_save();
|
|
|
|
$dummyController->popCurrent();
|
|
|
|
// Prevent output in testing
|
|
|
|
if(class_exists('SapphireTest', false) && SapphireTest::is_running_test()) {
|
2015-12-22 17:45:02 +13:00
|
|
|
throw new SS_HTTPResponse_Exception($response);
|
2015-12-07 17:25:27 +13:00
|
|
|
}
|
2018-06-08 00:56:31 +01:00
|
|
|
HTTP::add_cache_headers($response);
|
2015-12-07 17:25:27 +13:00
|
|
|
$response->output();
|
|
|
|
die;
|
|
|
|
}
|
|
|
|
|
2018-05-08 06:04:44 +08:00
|
|
|
Versioned::choose_site_stage($request);
|
2015-12-07 17:25:27 +13:00
|
|
|
$dummyController->popCurrent();
|
2014-03-04 17:43:17 +13:00
|
|
|
return true;
|
2013-10-04 00:20:32 +10:00
|
|
|
}
|
|
|
|
|
2014-03-04 17:43:17 +13:00
|
|
|
public function postRequest(SS_HTTPRequest $request, SS_HTTPResponse $response, DataModel $model) {
|
2018-06-08 00:56:31 +01:00
|
|
|
if (Versioned::current_stage() !== Versioned::LIVE && !HTTPCacheControl::singleton()->hasDirective('no-store')) {
|
|
|
|
HTTPCacheControl::singleton()->privateCache(true);
|
|
|
|
}
|
2014-03-04 17:43:17 +13:00
|
|
|
return true;
|
2013-10-04 00:20:32 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|