mirror of
https://github.com/silverstripe/silverstripe-cms
synced 2024-10-22 08:05:56 +02:00
Merge pull request #765 from jthomerson/enhancement_3.1_allow_disabling_generator_meta_tag
ENHANCEMENT: allow sites to override meta generator tag
This commit is contained in:
commit
a136170f55
@ -203,6 +203,14 @@ class SiteTree extends DataObject implements PermissionProvider,i18nEntityProvid
|
|||||||
*/
|
*/
|
||||||
private static $enforce_strict_hierarchy = true;
|
private static $enforce_strict_hierarchy = true;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The value used for the meta generator tag. Leave blank to omit the tag.
|
||||||
|
*
|
||||||
|
* @config
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
private static $meta_generator = 'SilverStripe - http://silverstripe.org';
|
||||||
|
|
||||||
protected $_cache_statusFlags = null;
|
protected $_cache_statusFlags = null;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -1298,7 +1306,10 @@ class SiteTree extends DataObject implements PermissionProvider,i18nEntityProvid
|
|||||||
$tags .= "<title>" . $this->Title . "</title>\n";
|
$tags .= "<title>" . $this->Title . "</title>\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
$tags .= "<meta name=\"generator\" content=\"SilverStripe - http://silverstripe.org\" />\n";
|
$generator = trim(Config::inst()->get('SiteTree', 'meta_generator'));
|
||||||
|
if (!empty($generator)) {
|
||||||
|
$tags .= "<meta name=\"generator\" content=\"" . Convert::raw2att($generator) . "\" />\n";
|
||||||
|
}
|
||||||
|
|
||||||
$charset = Config::inst()->get('ContentNegotiator', 'encoding');
|
$charset = Config::inst()->get('ContentNegotiator', 'encoding');
|
||||||
$tags .= "<meta http-equiv=\"Content-type\" content=\"text/html; charset=$charset\" />\n";
|
$tags .= "<meta http-equiv=\"Content-type\" content=\"text/html; charset=$charset\" />\n";
|
||||||
|
@ -889,6 +889,37 @@ class SiteTreeTest extends SapphireTest {
|
|||||||
$page = SiteTree::get()->byID($page->ID);
|
$page = SiteTree::get()->byID($page->ID);
|
||||||
$this->assertEquals(null, $page->getField('MenuTitle'));
|
$this->assertEquals(null, $page->getField('MenuTitle'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testMetaTagGeneratorDisabling() {
|
||||||
|
$generator = Config::inst()->get('SiteTree', 'meta_generator');
|
||||||
|
|
||||||
|
$page = new SiteTreeTest_PageNode();
|
||||||
|
|
||||||
|
$meta = $page->MetaTags();
|
||||||
|
$this->assertEquals(
|
||||||
|
1,
|
||||||
|
preg_match('/.*meta name="generator" content="SilverStripe - http:\/\/silverstripe.org".*/', $meta),
|
||||||
|
'test default functionality - uses value from Config');
|
||||||
|
|
||||||
|
// test proper escaping of quotes in attribute value
|
||||||
|
Config::inst()->update('SiteTree', 'meta_generator', 'Generator with "quotes" in it');
|
||||||
|
$meta = $page->MetaTags();
|
||||||
|
$this->assertEquals(
|
||||||
|
1,
|
||||||
|
preg_match('/.*meta name="generator" content="Generator with "quotes" in it".*/', $meta),
|
||||||
|
'test proper escaping of values from Config');
|
||||||
|
|
||||||
|
// test empty generator - no tag should appear at all
|
||||||
|
Config::inst()->update('SiteTree', 'meta_generator', '');
|
||||||
|
$meta = $page->MetaTags();
|
||||||
|
$this->assertEquals(
|
||||||
|
0,
|
||||||
|
preg_match('/.*meta name=.generator..*/', $meta),
|
||||||
|
'test blank value means no tag generated');
|
||||||
|
|
||||||
|
// reset original value
|
||||||
|
Config::inst()->update('SiteTree', 'meta_generator', $generator);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user