2008-08-12 02:59:27 +00:00
|
|
|
<?php
|
2009-02-04 20:18:12 +00:00
|
|
|
/**
|
|
|
|
* @package cms
|
|
|
|
* @subpackage publishers
|
|
|
|
*/
|
2011-04-15 19:37:15 +10:00
|
|
|
abstract class StaticPublisher extends DataExtension {
|
2008-08-12 02:59:27 +00:00
|
|
|
/**
|
|
|
|
* Defines whether to output information about publishing or not. By
|
|
|
|
* default, this is off, and should be turned on when you want debugging
|
|
|
|
* (for example, in a cron task)
|
|
|
|
*/
|
|
|
|
static $echo_progress = false;
|
|
|
|
|
2010-06-03 01:34:52 +00:00
|
|
|
/**
|
|
|
|
* Realtime static publishing... the second a page
|
|
|
|
* is saved, it is written to the cache
|
|
|
|
*/
|
2010-10-04 06:14:31 +00:00
|
|
|
static $disable_realtime = false;
|
2009-10-15 22:44:14 +00:00
|
|
|
|
2010-10-04 06:14:49 +00:00
|
|
|
/*
|
|
|
|
* This is the current static publishing theme, which can be set at any point
|
|
|
|
* If it's not set, then the last non-null theme, set via SSViewer::set_theme() is used
|
|
|
|
* The obvious place to set this is in _config.php
|
|
|
|
*/
|
|
|
|
static $static_publisher_theme=false;
|
|
|
|
|
2012-09-19 12:07:46 +02:00
|
|
|
abstract public function publishPages($pages);
|
|
|
|
abstract public function unpublishPages($pages);
|
2012-04-12 11:21:21 +12:00
|
|
|
|
2012-09-19 12:07:46 +02:00
|
|
|
static public function set_static_publisher_theme($theme){
|
2012-04-12 11:21:21 +12:00
|
|
|
self::$static_publisher_theme=$theme;
|
|
|
|
}
|
2012-12-17 15:51:09 +13:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @var boolean Includes a timestamp at the bottom of the generated HTML of each file,
|
|
|
|
* which can be useful for debugging issues with stale caches etc.
|
|
|
|
*/
|
|
|
|
static $include_caching_metadata = false;
|
2008-08-12 02:59:27 +00:00
|
|
|
|
2012-09-19 12:07:46 +02:00
|
|
|
static public function static_publisher_theme(){
|
2012-04-12 11:21:21 +12:00
|
|
|
return self::$static_publisher_theme;
|
|
|
|
}
|
|
|
|
|
2012-09-19 12:07:46 +02:00
|
|
|
static public function echo_progress() {
|
2008-08-12 02:59:27 +00:00
|
|
|
return (boolean)self::$echo_progress;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Either turns on (boolean true) or off (boolean false) the progress indicators.
|
|
|
|
* @see StaticPublisher::$echo_progress
|
|
|
|
*/
|
2012-09-19 12:07:46 +02:00
|
|
|
static public function set_echo_progress($progress) {
|
2008-08-12 02:59:27 +00:00
|
|
|
self::$echo_progress = (boolean)$progress;
|
|
|
|
}
|
|
|
|
|
2010-04-12 09:58:43 +00:00
|
|
|
/**
|
|
|
|
* Called after a page is published.
|
|
|
|
*/
|
2012-09-19 12:07:46 +02:00
|
|
|
public function onAfterPublish($original) {
|
2010-04-12 09:58:43 +00:00
|
|
|
$this->republish($original);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Called after link assets have been renamed, and the live site has been updated, without
|
|
|
|
* an actual publish event.
|
|
|
|
*
|
|
|
|
* Only called if the published content exists and has been modified.
|
|
|
|
*/
|
2012-09-19 12:07:46 +02:00
|
|
|
public function onRenameLinkedAsset($original) {
|
2010-04-12 09:58:43 +00:00
|
|
|
$this->republish($original);
|
|
|
|
}
|
|
|
|
|
2012-09-19 12:07:46 +02:00
|
|
|
public function republish($original) {
|
2009-10-15 22:44:14 +00:00
|
|
|
if (self::$disable_realtime) return;
|
2010-04-12 09:58:43 +00:00
|
|
|
|
2009-04-06 01:28:03 +00:00
|
|
|
$urls = array();
|
|
|
|
|
2008-08-12 02:59:27 +00:00
|
|
|
if($this->owner->hasMethod('pagesAffectedByChanges')) {
|
|
|
|
$urls = $this->owner->pagesAffectedByChanges($original);
|
|
|
|
} else {
|
2009-04-06 01:28:03 +00:00
|
|
|
$pages = Versioned::get_by_stage('SiteTree', 'Live', '', '', '', 10);
|
|
|
|
if($pages) {
|
|
|
|
foreach($pages as $page) {
|
2009-07-13 04:42:02 +00:00
|
|
|
$urls[] = $page->AbsoluteLink();
|
2009-04-06 01:28:03 +00:00
|
|
|
}
|
2008-08-12 02:59:27 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-10-15 01:31:54 +00:00
|
|
|
// Note: Similiar to RebuildStaticCacheTask->rebuildCache()
|
2008-08-12 02:59:27 +00:00
|
|
|
foreach($urls as $i => $url) {
|
2008-12-15 01:31:01 +00:00
|
|
|
if(!is_string($url)) {
|
|
|
|
user_error("Bad URL: " . var_export($url, true), E_USER_WARNING);
|
|
|
|
continue;
|
|
|
|
}
|
2010-10-15 01:31:54 +00:00
|
|
|
|
|
|
|
// Remove leading slashes from all URLs (apart from the homepage)
|
|
|
|
if(substr($url,-1) == '/' && $url != '/') $url = substr($url,0,-1);
|
|
|
|
|
2008-08-12 02:59:27 +00:00
|
|
|
$urls[$i] = $url;
|
|
|
|
}
|
|
|
|
|
|
|
|
$urls = array_unique($urls);
|
|
|
|
|
|
|
|
$this->publishPages($urls);
|
|
|
|
}
|
2009-07-22 22:57:02 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* On after unpublish, get changes and hook into underlying
|
|
|
|
* functionality
|
|
|
|
*/
|
2012-09-19 12:07:46 +02:00
|
|
|
public function onAfterUnpublish($page) {
|
2009-10-15 22:44:14 +00:00
|
|
|
if (self::$disable_realtime) return;
|
|
|
|
|
2010-04-13 03:26:47 +00:00
|
|
|
// Get the affected URLs
|
2009-07-22 22:57:02 +00:00
|
|
|
if($this->owner->hasMethod('pagesAffectedByUnpublishing')) {
|
|
|
|
$urls = $this->owner->pagesAffectedByUnpublishing();
|
|
|
|
$urls = array_unique($urls);
|
|
|
|
} else {
|
|
|
|
$urls = array($this->owner->AbsoluteLink());
|
|
|
|
}
|
|
|
|
|
2010-04-13 03:27:02 +00:00
|
|
|
$legalPages = singleton('Page')->allPagesToCache();
|
2010-04-13 03:26:47 +00:00
|
|
|
|
|
|
|
$urlsToRepublish = array_intersect($urls, $legalPages);
|
|
|
|
$urlsToUnpublish = array_diff($urls, $legalPages);
|
|
|
|
|
|
|
|
$this->unpublishPages($urlsToUnpublish);
|
|
|
|
$this->publishPages($urlsToRepublish);
|
2009-07-22 22:57:02 +00:00
|
|
|
}
|
2008-08-12 02:59:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get all external references to CSS, JS,
|
|
|
|
*/
|
2012-09-19 12:07:46 +02:00
|
|
|
public function externalReferencesFor($content) {
|
2008-08-12 02:59:27 +00:00
|
|
|
$CLI_content = escapeshellarg($content);
|
|
|
|
$tidy = `echo $CLI_content | tidy -numeric -asxhtml`;
|
|
|
|
$tidy = preg_replace('/xmlns="[^"]+"/','', $tidy);
|
|
|
|
$xContent = new SimpleXMLElement($tidy);
|
|
|
|
//Debug::message($xContent->asXML());
|
|
|
|
|
|
|
|
$xlinks = array(
|
|
|
|
"//link[@rel='stylesheet']/@href" => false,
|
|
|
|
"//script/@src" => false,
|
|
|
|
"//img/@src" => false,
|
|
|
|
"//a/@href" => true,
|
|
|
|
);
|
|
|
|
|
|
|
|
$urls = array();
|
|
|
|
foreach($xlinks as $xlink => $assetsOnly) {
|
|
|
|
$matches = $xContent->xpath($xlink);
|
|
|
|
if($matches) foreach($matches as $item) {
|
|
|
|
$url = $item . '';
|
2010-10-15 01:49:53 +00:00
|
|
|
if($assetsOnly && substr($url,0,7) != ASSETS_DIR . '/') continue;
|
2008-08-12 02:59:27 +00:00
|
|
|
|
|
|
|
$urls[] = $url;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $urls;
|
|
|
|
}
|
2012-12-17 15:51:09 +13:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Provides context for this URL, written as an HTML comment to the static file cache,
|
|
|
|
* which can be useful for debugging cache problems. For example, you could track the
|
|
|
|
* event or related page which triggered this republication. The returned data
|
|
|
|
* is unstructured and not intended to be consumed programmatically.
|
|
|
|
* Consider injecting standard HTML <meta> tags instead where applicable.
|
|
|
|
*
|
|
|
|
* Note: Only used when {@link $include_caching_metadata} is enabled.
|
|
|
|
*
|
|
|
|
* @param String
|
|
|
|
* @return Array A numeric array of all metadata.
|
|
|
|
*/
|
|
|
|
function getMetadata($url) {
|
|
|
|
return array(
|
|
|
|
'Cache generated on ' . date('Y-m-d H:i:s T (O)')
|
|
|
|
);
|
|
|
|
}
|
2008-08-12 02:59:27 +00:00
|
|
|
}
|
2008-12-04 22:38:58 +00:00
|
|
|
|