diff --git a/code/Model/SiteTree.php b/code/Model/SiteTree.php index 3f525f4b4c..c633962cf7 100755 --- a/code/Model/SiteTree.php +++ b/code/Model/SiteTree.php @@ -21,6 +21,7 @@ use SilverStripe\Core\Injector\Injector; use SilverStripe\Core\Manifest\ModuleResource; use SilverStripe\Core\Manifest\ModuleResourceLoader; +use SilverStripe\Core\Manifest\VersionProvider; use SilverStripe\Core\Resettable; use SilverStripe\Dev\Deprecation; use SilverStripe\Forms\CheckboxField; @@ -339,7 +340,16 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi * @config * @var string */ - private static $meta_generator = 'SilverStripe - https://www.silverstripe.org'; + private static $meta_generator = 'Silverstripe CMS'; + + /** + * Whether to display the version portion of the meta generator tag + * Set to false if it's viewed as a concern. + * + * @config + * @var bool + */ + private static $show_meta_generator_version = true; protected $_cache_statusFlags = null; @@ -395,6 +405,11 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi */ protected $creatableChildrenCache; + /** + * @var VersionProvider + */ + private $versionProvider; + /** * Fetches the {@link SiteTree} object that maps to a link. * @@ -1401,13 +1416,13 @@ public function MetaComponents() 'content' => $this->obj('Title')->forTemplate() ]; - $generator = trim(Config::inst()->get(self::class, 'meta_generator')); - if (!empty($generator)) { + $generator = $this->getGenerator(); + if ($generator) { $tags['generator'] = [ 'attributes' => [ 'name' => 'generator', - 'content' => $generator, - ], + 'content' => $generator + ] ]; } @@ -1449,6 +1464,49 @@ public function MetaComponents() return $tags; } + /** + * Create the value for the meta generator tag + * Will suffix on the major.minor version of a stable tag + * + * @return string + */ + private function getGenerator(): string + { + $generator = trim(Config::inst()->get(self::class, 'meta_generator')); + if ($generator === '') { + return ''; + } + if (self::config()->get('show_meta_generator_version')) { + $version = $this->getVersionProvider()->getModuleVersion('silverstripe/framework'); + // Only include stable version numbers so as not to clutter any aggregate reports + // with non-standard versions e.g. forks + if (preg_match('#^([0-9]+\.[0-9]+)\.[0-9]+$#', $version, $m)) { + $generator .= ' ' . $m[1]; + } + } + return $generator; + } + + /** + * @return VersionProvider + */ + public function getVersionProvider(): VersionProvider + { + if ($this->versionProvider === null) { + $this->versionProvider = VersionProvider::singleton(); + } + return $this->versionProvider; + } + + /** + * @param VersionProvider $versionProvider + */ + public function setVersionProvider(VersionProvider $versionProvider): void + { + $this->versionProvider = $versionProvider; + } + + /** * Return the title, description, keywords and language metatags. * diff --git a/composer.json b/composer.json index 012df5a66b..617e9250c5 100644 --- a/composer.json +++ b/composer.json @@ -21,7 +21,7 @@ "require": { "silverstripe/admin": "^1.9@dev", "silverstripe/campaign-admin": "^1.7@dev", - "silverstripe/framework": "^4.10", + "silverstripe/framework": "^4.11", "silverstripe/reports": "^4.7@dev", "silverstripe/siteconfig": "^4.7@dev", "silverstripe/versioned": "^1.7@dev", diff --git a/tests/php/Model/SiteTreeTest.php b/tests/php/Model/SiteTreeTest.php index b58d1bfd2d..f801b7a532 100644 --- a/tests/php/Model/SiteTreeTest.php +++ b/tests/php/Model/SiteTreeTest.php @@ -14,6 +14,7 @@ use SilverStripe\Control\Director; use SilverStripe\Core\Config\Config; use SilverStripe\Core\Injector\Injector; +use SilverStripe\Core\Manifest\VersionProvider; use SilverStripe\Dev\SapphireTest; use SilverStripe\i18n\i18n; use SilverStripe\ORM\DataObject; @@ -1432,6 +1433,12 @@ public function testMetaComponents() $charset = Config::inst()->get(ContentNegotiator::class, 'encoding'); + $mockVersionProvider = $this->getMockBuilder(VersionProvider::class) + ->setMethods(['getModuleVersion']) + ->getMock(); + $mockVersionProvider->method('getModuleVersion')->willReturn('4.50.99'); + $page->setVersionProvider($mockVersionProvider); + $expected = [ 'title' => [ 'tag' => 'title', @@ -1440,7 +1447,11 @@ public function testMetaComponents() 'generator' => [ 'attributes' => [ 'name' => 'generator', - 'content' => Config::inst()->get(SiteTree::class, 'meta_generator') + 'content' => sprintf( + '%s %s', + Config::inst()->get(SiteTree::class, 'meta_generator'), + '4.50' + ) ], ], 'contentType' => [ @@ -1470,6 +1481,12 @@ public function testMetaComponents() ]; $this->assertEquals($expected, $page->MetaComponents()); + + // test the meta generator tag version can be configured off + Config::modify()->set(SiteTree::class, 'show_meta_generator_version', false); + $content = $expected['generator']['attributes']['content']; + $expected['generator']['attributes']['content'] = str_replace(' 4.50', '', $content); + $this->assertEquals($expected, $page->MetaComponents()); } /**