mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
MINOR smarter static-main.php, now detects automatically if you are using domain based cacheing
git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/trunk@81712 467b73ca-7a2a-4603-9d3b-597d59a354a9
This commit is contained in:
parent
3a4518c804
commit
a81f387945
@ -1,18 +1,22 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
$domainBasedCaching = true;
|
/**
|
||||||
|
* This file is designed to be the new 'server' of sites using StaticPublisher.
|
||||||
|
* to use this, you need to modify your .htaccess to point all requests to
|
||||||
|
* static-main.php, rather than main.php. This file also allows for using
|
||||||
|
* static publisher with the subsites module.
|
||||||
|
*
|
||||||
|
* If you are using StaticPublisher+Subsites, set the following in _config.php:
|
||||||
|
* FilesystemPublisher::$domain_based_caching = true;
|
||||||
|
*/
|
||||||
|
|
||||||
if ($domainBasedCaching) {
|
if (file_exists('../subsites/host-map.php')) {
|
||||||
// Host -> cache dir mapping
|
|
||||||
if (file_exists('../subsites/host-map.php')) {
|
|
||||||
include_once '../subsites/host-map.php';
|
include_once '../subsites/host-map.php';
|
||||||
} else {
|
$siteHostmap['default'] = isset($siteHostmap['default']) ? $siteHostmap['default'] : '';
|
||||||
$subsiteHostmap = array();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Look for the host, and find the cache dir
|
// Look for the host, and find the cache dir
|
||||||
$host = str_replace('www.', '', $_SERVER['HTTP_HOST']);
|
$host = str_replace('www.', '', $_SERVER['HTTP_HOST']);
|
||||||
$cacheDir = isset($siteHostmap[$host]) ? $siteHostmap[$host] : $siteHostmap['default'];
|
$cacheDir = (isset($siteHostmap[$host]) ? $siteHostmap[$host] : $siteHostmap['default']) . '/';
|
||||||
} else {
|
} else {
|
||||||
$cacheDir = '';
|
$cacheDir = '';
|
||||||
}
|
}
|
||||||
@ -21,10 +25,10 @@ if ($domainBasedCaching) {
|
|||||||
$file = preg_replace('/[^a-zA-Z0-9]/si', '_', trim($_SERVER['REQUEST_URI'], '/'));
|
$file = preg_replace('/[^a-zA-Z0-9]/si', '_', trim($_SERVER['REQUEST_URI'], '/'));
|
||||||
$file = $file ? $file : 'index';
|
$file = $file ? $file : 'index';
|
||||||
|
|
||||||
if (file_exists('../cache/'.$cacheDir.'/'.$file.'.html')) {
|
if (file_exists('../cache/'.$cacheDir.$file.'.html')) {
|
||||||
echo file_get_contents('../cache/'.$cacheDir.'/'.$file.'.html');
|
echo file_get_contents('../cache/'.$cacheDir.$file.'.html');
|
||||||
} elseif (file_exists('../cache/'.$cacheDir.'/'.$file.'.php')) {
|
} elseif (file_exists('../cache/'.$cacheDir.$file.'.php')) {
|
||||||
include_once '../cache/'.$cacheDir.'/'.$file.'.php';
|
include_once '../cache/'.$cacheDir.$file.'.php';
|
||||||
} else {
|
} else {
|
||||||
// No cache hit... fallback!!!
|
// No cache hit... fallback!!!
|
||||||
include 'main.php';
|
include 'main.php';
|
||||||
|
Loading…
Reference in New Issue
Block a user