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:
Ingo Schommer 2011-09-15 16:00:54 +02:00
parent 73cca09960
commit 83ad8d48a9
4 changed files with 41 additions and 5 deletions

View File

@ -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 " : "";

View File

@ -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",

View File

@ -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');

View File

@ -34,3 +34,10 @@ SiteTree:
pageWithSpecialChars: pageWithSpecialChars:
Title: Brötchen Title: Brötchen
Content: Frisch vom B&auml;cker Content: Frisch vom B&auml;cker
File:
showInSearchFile:
Title: showInSearchFile
ShowInSearch: 1
dontShowInSearchFile:
Title: dontShowInSearchFile
ShowInSearch: 0