From 8799a26dd2d2b0d0c6fd1dd379e488864b17bc6b Mon Sep 17 00:00:00 2001 From: rlehmann Date: Tue, 7 Jun 2011 11:37:38 -0700 Subject: [PATCH] DataObjects with a detail page in the frontend (eg forum threads) can now be added to sitemap.xml. --- code/GoogleSitemap.php | 83 +++++++++++++++++++++++++++++++++++++----- 1 file changed, 73 insertions(+), 10 deletions(-) diff --git a/code/GoogleSitemap.php b/code/GoogleSitemap.php index 8f61704..3ca990c 100644 --- a/code/GoogleSitemap.php +++ b/code/GoogleSitemap.php @@ -1,5 +1,4 @@ + * * @@ -19,7 +18,6 @@ * * @package googlesitemaps */ - class GoogleSitemap extends Controller { /** @@ -41,8 +39,70 @@ class GoogleSitemap extends Controller { * @var boolean */ protected static $use_show_in_search = true; - - public function Items() { + + /** + * List of DataObjects to show in sitemap.xml + * + * @var array + */ + public static $google_sitemap_dataobjects = array(); + + /** + * List of DataObjects change frequency + * + * @var array + */ + public static $google_sitemap_dataobjects_changefreq = array(); + + + /** + * Decorates the given DataObject with GoogleSitemapDecorator and pushes + * the class name to the registered DataObjects. + * Note that all registered DataObjects need the method AbsoluteLink(). + * + * @param string $className name of DataObject to register + */ + public static function registerDataObject($className, $changeFreq = 'monthly') { + if (!self::isRegistered($className)) { + Object::add_extension($className, 'GoogleSitemapDecorator'); + self::$google_sitemap_dataobjects[] = $className; + self::$google_sitemap_dataobjects_changefreq[] = $changeFreq; + } + } + + /** + * Checks whether the given class name is already registered or not. + * + * @param string $className Name of DataObject to check + * + * @return bool + */ + public static function isRegistered($className) { + return in_array($className, self::$google_sitemap_dataobjects); + } + + /** + * Adds DataObjects to the existing DataObjectSet with pages from the + * site tree + * + * @param DataObjectSet $newPages + * + * @return void + */ + protected function addRegisteredDataObjects($newPages) { + foreach (self::$google_sitemap_dataobjects as $index => $className) { + $dataObjectSet = DataObject::get($className); + foreach ($dataObjectSet as $dataObject) { + if ($dataObject->canView() && (!isset($dataObject->Priority) || $dataObject->Priority > 0)) { + $dataObject->ChangeFreq = self::$google_sitemap_dataobjects_changefreq[$index]; + $newPages->push($dataObject); + } + } + } + } + + + public function Items() { $filter = ''; $bt = defined('DB::USE_ANSI_SQL') ? "\"" : "`"; @@ -62,12 +122,14 @@ class GoogleSitemap extends Controller { // If the page has been set to 0 priority, we set a flag so it won't be included if($page->canView() && (!isset($page->Priority) || $page->Priority > 0)) { - - $created = $page->dbObject('Created'); - + // The one field that isn't easy to deal with in the template is + // Change frequency, so we set that here. + $properties = $page->toMap(); + $created = new SS_Datetime(); + $created->value = $properties['Created']; $now = new SS_Datetime(); $now->value = date('Y-m-d H:i:s'); - $versions = $page->Version; + $versions = $properties['Version']; $timediff = $now->format('U') - $created->format('U'); // Check how many revisions have been made over the lifetime of the @@ -93,6 +155,7 @@ class GoogleSitemap extends Controller { } } } + $this->addRegisteredDataObjects($newPages); return $newPages; } } @@ -156,4 +219,4 @@ class GoogleSitemap extends Controller { public static function disable() { self::$enabled = false; } -} \ No newline at end of file +}