mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
ENHANCEMENT Added File.ShowInSearch flag to mirror the existing SiteTree.ShowInSearch flag - e.g. useful to limit visibility of user-uploaded files. Enforced in MySQLDatabase->searchEngine().
This commit is contained in:
parent
73cca09960
commit
83ad8d48a9
@ -768,6 +768,11 @@ class MySQLDatabase extends SS_Database {
|
|||||||
// Always ensure that only pages with ShowInSearch = 1 can be searched
|
// Always ensure that only pages with ShowInSearch = 1 can be searched
|
||||||
$extraFilters['SiteTree'] .= " AND ShowInSearch <> 0";
|
$extraFilters['SiteTree'] .= " AND ShowInSearch <> 0";
|
||||||
|
|
||||||
|
// File.ShowInSearch was added later, keep the database driver backwards compatible
|
||||||
|
// by checking for its existence first
|
||||||
|
$fields = $this->fieldList('File');
|
||||||
|
if(array_key_exists('ShowInSearch', $fields)) $extraFilters['File'] .= " AND ShowInSearch <> 0";
|
||||||
|
|
||||||
$limit = $start . ", " . (int) $pageLength;
|
$limit = $start . ", " . (int) $pageLength;
|
||||||
|
|
||||||
$notMatch = $invertedMatch ? "NOT " : "";
|
$notMatch = $invertedMatch ? "NOT " : "";
|
||||||
|
@ -74,7 +74,9 @@ class File extends DataObject {
|
|||||||
"Title" => "Varchar(255)",
|
"Title" => "Varchar(255)",
|
||||||
"Filename" => "Text",
|
"Filename" => "Text",
|
||||||
"Content" => "Text",
|
"Content" => "Text",
|
||||||
"Sort" => "Int"
|
"Sort" => "Int",
|
||||||
|
// Only applies to files, doesn't inherit for folder
|
||||||
|
'ShowInSearch' => 'Boolean(1)',
|
||||||
);
|
);
|
||||||
|
|
||||||
static $has_one = array(
|
static $has_one = array(
|
||||||
@ -90,7 +92,9 @@ class File extends DataObject {
|
|||||||
"BackLinkTracking" => "SiteTree",
|
"BackLinkTracking" => "SiteTree",
|
||||||
);
|
);
|
||||||
|
|
||||||
static $defaults = array();
|
static $defaults = array(
|
||||||
|
"ShowInSearch" => 1,
|
||||||
|
);
|
||||||
|
|
||||||
static $extensions = array(
|
static $extensions = array(
|
||||||
"Hierarchy",
|
"Hierarchy",
|
||||||
|
@ -170,7 +170,7 @@ class SearchFormTest extends FunctionalTest {
|
|||||||
$member->logOut();
|
$member->logOut();
|
||||||
}
|
}
|
||||||
|
|
||||||
function testDisabledShowInSearchFlagNotIncluded() {
|
function testDisabledShowInSearchFlagNotIncludedForSiteTree() {
|
||||||
$sf = new SearchForm($this->mockController, 'SearchForm');
|
$sf = new SearchForm($this->mockController, 'SearchForm');
|
||||||
|
|
||||||
$page = $this->objFromFixture('SiteTree', 'dontShowInSearchPage');
|
$page = $this->objFromFixture('SiteTree', 'dontShowInSearchPage');
|
||||||
@ -182,6 +182,26 @@ class SearchFormTest extends FunctionalTest {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function testDisabledShowInSearchFlagNotIncludedForFiles() {
|
||||||
|
$sf = new SearchForm($this->mockController, 'SearchForm');
|
||||||
|
|
||||||
|
$dontShowInSearchFile = $this->objFromFixture('File', 'dontShowInSearchFile');
|
||||||
|
$showInSearchFile = $this->objFromFixture('File', 'showInSearchFile');
|
||||||
|
$results = $sf->getResults(null, array('Search'=>'dontShowInSearchFile'));
|
||||||
|
$this->assertNotContains(
|
||||||
|
$dontShowInSearchFile->ID,
|
||||||
|
$results->column('ID'),
|
||||||
|
'File with "Show in Search" disabled doesnt show'
|
||||||
|
);
|
||||||
|
|
||||||
|
$results = $sf->getResults(null, array('Search'=>'showInSearchFile'));
|
||||||
|
$this->assertContains(
|
||||||
|
$showInSearchFile->ID,
|
||||||
|
$results->column('ID'),
|
||||||
|
'File with "Show in Search" enabled can be found'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
function testSearchTitleAndContentWithSpecialCharacters() {
|
function testSearchTitleAndContentWithSpecialCharacters() {
|
||||||
$sf = new SearchForm($this->mockController, 'SearchForm');
|
$sf = new SearchForm($this->mockController, 'SearchForm');
|
||||||
|
|
||||||
|
@ -34,3 +34,10 @@ SiteTree:
|
|||||||
pageWithSpecialChars:
|
pageWithSpecialChars:
|
||||||
Title: Brötchen
|
Title: Brötchen
|
||||||
Content: Frisch vom Bäcker
|
Content: Frisch vom Bäcker
|
||||||
|
File:
|
||||||
|
showInSearchFile:
|
||||||
|
Title: showInSearchFile
|
||||||
|
ShowInSearch: 1
|
||||||
|
dontShowInSearchFile:
|
||||||
|
Title: dontShowInSearchFile
|
||||||
|
ShowInSearch: 0
|
Loading…
Reference in New Issue
Block a user