mirror of
https://github.com/silverstripe/silverstripe-cms
synced 2024-10-22 08:05:56 +02:00
API SiteTree->validURLSegment() prioritizes extension votes
Tri-state, use NULL to ignore the extension result
This commit is contained in:
parent
4bc942df76
commit
0c4b2f8157
@ -1588,20 +1588,20 @@ class SiteTree extends DataObject implements PermissionProvider,i18nEntityProvid
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$votes = array_filter(
|
||||||
|
(array)$this->extend('augmentValidURLSegment'),
|
||||||
|
function($v) {return !is_null($v);}
|
||||||
|
);
|
||||||
|
if($votes) {
|
||||||
|
return min($votes);
|
||||||
|
}
|
||||||
|
|
||||||
$existingPage = DataObject::get_one(
|
$existingPage = DataObject::get_one(
|
||||||
'SiteTree',
|
'SiteTree',
|
||||||
"\"URLSegment\" = '$this->URLSegment' $IDFilter $parentFilter"
|
"\"URLSegment\" = '$this->URLSegment' $IDFilter $parentFilter"
|
||||||
);
|
);
|
||||||
if ($existingPage) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$votes = $this->extend('augmentValidURLSegment');
|
|
||||||
if($votes) {
|
|
||||||
return min($votes);
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
return !($existingPage);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -4,8 +4,9 @@
|
|||||||
* @subpackage tests
|
* @subpackage tests
|
||||||
*/
|
*/
|
||||||
class SiteTreeTest extends SapphireTest {
|
class SiteTreeTest extends SapphireTest {
|
||||||
protected static $fixture_file = 'SiteTreeTest.yml';
|
|
||||||
|
|
||||||
|
protected static $fixture_file = 'SiteTreeTest.yml';
|
||||||
|
|
||||||
protected $illegalExtensions = array(
|
protected $illegalExtensions = array(
|
||||||
'SiteTree' => array('SiteTreeSubsites')
|
'SiteTree' => array('SiteTreeSubsites')
|
||||||
);
|
);
|
||||||
@ -700,6 +701,18 @@ class SiteTreeTest extends SapphireTest {
|
|||||||
$this->assertTrue($sitetree->validURLSegment(), 'Valid URLSegment values are allowed');
|
$this->assertTrue($sitetree->validURLSegment(), 'Valid URLSegment values are allowed');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testURLSegmentPrioritizesExtensionVotes() {
|
||||||
|
$sitetree = new SiteTree();
|
||||||
|
$sitetree->URLSegment = 'unique-segment';
|
||||||
|
$this->assertTrue($sitetree->validURLSegment());
|
||||||
|
|
||||||
|
SiteTree::add_extension('SiteTreeTest_Extension');
|
||||||
|
$sitetree = new SiteTree();
|
||||||
|
$sitetree->URLSegment = 'unique-segment';
|
||||||
|
$this->assertFalse($sitetree->validURLSegment());
|
||||||
|
SiteTree::remove_extension('SiteTreeTest_Extension');
|
||||||
|
}
|
||||||
|
|
||||||
public function testURLSegmentMultiByte() {
|
public function testURLSegmentMultiByte() {
|
||||||
$origAllow = Config::inst()->get('URLSegmentFilter', 'default_allow_multibyte');
|
$origAllow = Config::inst()->get('URLSegmentFilter', 'default_allow_multibyte');
|
||||||
Config::inst()->update('URLSegmentFilter', 'default_allow_multibyte', true);
|
Config::inst()->update('URLSegmentFilter', 'default_allow_multibyte', true);
|
||||||
@ -960,3 +973,11 @@ class SiteTreeTest_StageStatusInherit extends SiteTree implements TestOnly {
|
|||||||
return $flags;
|
return $flags;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class SiteTreeTest_Extension extends DataExtension implements TestOnly {
|
||||||
|
|
||||||
|
public function augmentValidURLSegment() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user