2009-10-15 00:02:06 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Rewrites plain internal HTML links into shortcode form, using existing link tracking information.
|
|
|
|
*
|
|
|
|
* @package sapphire
|
|
|
|
* @subpackage tasks
|
|
|
|
*/
|
|
|
|
class MigrateSiteTreeLinkingTask extends BuildTask {
|
|
|
|
|
|
|
|
protected $title = 'Migrate SiteTree Linking Task';
|
|
|
|
|
|
|
|
protected $description = 'Rewrites plain internal HTML links into shortcode form, using existing link tracking information.';
|
|
|
|
|
|
|
|
public function run($request) {
|
|
|
|
$pages = 0;
|
|
|
|
$links = 0;
|
|
|
|
|
2009-11-12 04:16:31 +00:00
|
|
|
$linkedPages = DataObject::get(
|
2009-10-15 00:02:06 +00:00
|
|
|
'SiteTree',
|
|
|
|
null,
|
|
|
|
null,
|
|
|
|
'INNER JOIN "SiteTree_LinkTracking" ON "SiteTree_LinkTracking"."SiteTreeID" = "SiteTree"."ID"'
|
|
|
|
);
|
|
|
|
|
2009-11-12 04:16:31 +00:00
|
|
|
// Databases like MSSQL will give duplicate results - remove them
|
|
|
|
// This would normally be fixed by using SELECT DISTINCT, but DataObject::get() doesn't support it
|
|
|
|
$linkedPages->removeDuplicates();
|
|
|
|
|
2009-10-15 00:02:06 +00:00
|
|
|
if($linkedPages) foreach($linkedPages as $page) {
|
|
|
|
$tracking = DB::query(sprintf (
|
|
|
|
'SELECT "ChildID", "FieldName" FROM "SiteTree_LinkTracking" WHERE "SiteTreeID" = %d',
|
|
|
|
$page->ID
|
|
|
|
));
|
|
|
|
|
|
|
|
foreach($tracking as $link) {
|
|
|
|
$linked = DataObject::get_by_id('SiteTree', $link['ChildID']);
|
|
|
|
|
2009-10-19 05:29:46 +00:00
|
|
|
// TOOD: Replace in all HTMLText fields
|
|
|
|
$page->Content = preg_replace (
|
2009-10-15 00:02:06 +00:00
|
|
|
"/href *= *([\"']?){$linked->URLSegment}\/?/i",
|
|
|
|
"href=$1[sitetree_link id={$linked->ID}]",
|
2009-10-19 05:29:46 +00:00
|
|
|
$page->Content,
|
2009-10-15 00:02:06 +00:00
|
|
|
-1,
|
|
|
|
$replaced
|
|
|
|
);
|
|
|
|
|
|
|
|
if($replaced) {
|
|
|
|
$page->write();
|
|
|
|
$links += $replaced;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$pages++;
|
|
|
|
}
|
|
|
|
|
|
|
|
echo "Rewrote $links link(s) on $pages page(s) to use shortcodes.\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|