Merge pull request #24 from mateusz/standard-error-pages

NEW Generate static versions of ErrorPages.
This commit is contained in:
Stig Lindqvist 2013-09-15 19:28:54 -07:00
commit bacc1d44ba

View File

@ -230,16 +230,25 @@ class FilesystemPublisher extends StaticPublisher {
if(Director::is_relative_url($url)) $url = Director::absoluteURL($url); if(Director::is_relative_url($url)) $url = Director::absoluteURL($url);
$response = Director::test(str_replace('+', ' ', $url)); $response = Director::test(str_replace('+', ' ', $url));
if (!$response) continue;
if($response) { if($response) {
$result[$origUrl]['statuscode'] = $response->getStatusCode(); $result[$origUrl]['statuscode'] = $response->getStatusCode();
} }
Requirements::clear(); Requirements::clear();
singleton('DataObject')->flushCache(); singleton('DataObject')->flushCache();
//skip any responses with a 404 status code. We don't want to turn those into statically cached pages // Check for ErrorPages generating output - we want to handle this in a special way below.
if (!$response || $response->getStatusCode() == '404') continue; $isErrorPage = false;
$pageObject = null;
if ($response && is_object($response) && ((int)$response->getStatusCode())>=400) {
$pageObject = SiteTree::get_by_link($url);
if ($pageObject && $pageObject instanceof ErrorPage) $isErrorPage = true;
}
// Skip any responses with a 404 status code unless it's the ErrorPage itself.
if (!$isErrorPage && is_object($response) && $response->getStatusCode()=='404') continue;
// Generate file content // Generate file content
// PHP file caching will generate a simple script from a template // PHP file caching will generate a simple script from a template
@ -277,12 +286,27 @@ class FilesystemPublisher extends StaticPublisher {
); );
} }
if (!$isErrorPage) {
$files[$origUrl] = array( $files[$origUrl] = array(
'Content' => $content, 'Content' => $content,
'Folder' => dirname($path).'/', 'Folder' => dirname($path).'/',
'Filename' => basename($path), 'Filename' => basename($path),
); );
} else {
// Generate a static version of the error page with a standardised name, so they can be plugged
// into catch-all webserver statements such as Apache's ErrorDocument.
$code = (int)$response->getStatusCode();
$files[$origUrl] = array(
'Content' => $content,
'Folder' => dirname($path).'/',
'Filename' => "error-$code.html",
);
}
// Add externals // Add externals
/* /*
$externals = $this->externalReferencesFor($content); $externals = $this->externalReferencesFor($content);