2008-12-15 01:31:01 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This static publisher can be used to deploy static content to multiple hosts, by generating the cache files locally and then rsyncing then to
|
|
|
|
* each destination box. This can be used to set up a load-balanced collection of static servers.
|
2009-02-04 20:18:12 +00:00
|
|
|
*
|
|
|
|
* @see http://doc.silverstripe.com/doku.php?id=staticpublisher
|
|
|
|
*
|
|
|
|
* @package cms
|
|
|
|
* @subpackage publishers
|
2008-12-15 01:31:01 +00:00
|
|
|
*/
|
|
|
|
class RsyncMultiHostPublisher extends FilesystemPublisher {
|
|
|
|
/**
|
|
|
|
* Array of rsync targets to publish to. These can either be local file names, or scp-style targets, in the form "user@server:path"
|
|
|
|
*/
|
2010-05-12 05:29:25 +00:00
|
|
|
protected static $targets = array();
|
2008-12-15 01:31:01 +00:00
|
|
|
|
2010-05-12 05:29:26 +00:00
|
|
|
protected static $excluded_folders = array();
|
|
|
|
|
2008-12-15 01:31:01 +00:00
|
|
|
/**
|
|
|
|
* Set the targets to publish to.
|
2009-02-04 20:18:12 +00:00
|
|
|
* If target is an scp-style remote path, no password is accepted - we assume key-based authentication to be set up on the application server
|
|
|
|
* initiating the publication.
|
|
|
|
*
|
2008-12-15 01:31:01 +00:00
|
|
|
* @param $targets An array of targets to publish to. These can either be local file names, or scp-style targets, in the form "user@server:path"
|
|
|
|
*/
|
|
|
|
static function set_targets($targets) {
|
|
|
|
self::$targets = $targets;
|
|
|
|
}
|
2010-05-12 05:29:26 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Specify folders to exclude from the rsync
|
|
|
|
* For example, you could exclude assets.
|
|
|
|
*/
|
|
|
|
static function set_excluded_folders($folders) {
|
|
|
|
self::$excluded_folders = $folders;
|
|
|
|
}
|
2008-12-15 01:31:01 +00:00
|
|
|
|
|
|
|
function publishPages($urls) {
|
|
|
|
parent::publishPages($urls);
|
|
|
|
$base = Director::baseFolder();
|
|
|
|
|
|
|
|
// Get variable that can turn off the rsync component of publication
|
|
|
|
if(isset($_GET['norsync']) && $_GET['norsync']) return;
|
|
|
|
|
2010-05-12 05:29:26 +00:00
|
|
|
$extraArg = "";
|
|
|
|
if(self::$excluded_folders) foreach(self::$excluded_folders as $folder) {
|
|
|
|
$extraArg .= " --exclude " . escapeshellarg($folder);
|
|
|
|
}
|
|
|
|
|
2008-12-15 01:31:01 +00:00
|
|
|
foreach(self::$targets as $target) {
|
|
|
|
// Transfer non-PHP content from everything to the target; that will ensure that we have all the JS/CSS/etc
|
2010-05-12 05:29:26 +00:00
|
|
|
$rsyncOutput = `cd $base; rsync -av -e ssh --exclude /.htaccess --exclude /web.config --exclude '*.php' --exclude '*.svn' --exclude '*.git' --exclude '*~' $extraArg --delete . $target`;
|
2008-12-15 01:31:01 +00:00
|
|
|
// Then transfer "safe" PHP from the cache/ directory
|
2010-05-12 05:29:26 +00:00
|
|
|
$rsyncOutput .= `cd $base; rsync -av -e ssh --exclude '*.svn' --exclude '*~' $extraArg --delete cache $target`;
|
2010-05-12 05:29:26 +00:00
|
|
|
// Transfer sapphire/static-main.php to the target
|
|
|
|
$rsyncOutput .= `cd $base; rsync -av -e ssh --delete sapphire/static-main.php $target/sapphire`;
|
2008-12-15 01:31:01 +00:00
|
|
|
if(StaticPublisher::echo_progress()) echo $rsyncOutput;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|