TYPO3 Logo
Apache Solr for TYPO3
Release: main

Loading data.

  • Introduction
  • Getting Started
    • Solr
    • Install EXT:solr
    • Configure Extension
    • Index the first time
    • Display search and results
  • Backend
    • ConnectionManager
    • IndexQueue Configuration
    • Backend Modules
    • Index Inspector
    • Page properties
    • Scheduler
    • Plugins
    • Results Plugin
  • Frontend
    • Concepts
    • Fluid Template Structure
    • Result List
    • Facets
    • Autosuggest
    • Sorting
    • Results per Page
    • Ajaxified Results
    • Customize
    • Languages
  • Routing
    • Configure Routing
    • Facets in path segments
    • Simplify facets inside of the query
    • Example
  • Logging
    • Configure Logging
    • Show Logging Output
  • The Apache Solr Server
    • Configuration Structure
    • Setup steps
    • Index Maintenance
    • SolrConfig Parameters
  • Configuration Reference
    • tx_solr
    • tx_solr.general
    • tx_solr.view
    • tx_solr.solr
    • tx_solr.index
    • tx_solr.search
    • tx_solr.suggest
    • tx_solr.statistics
    • tx_solr.logging
    • Extension Configuration
    • Solr Connection
  • Database
  • Development
    • Indexing
    • Developing Backend Modules
    • Development Environment
    • Testing and Continues Integration
    • Code Structure
    • Signals
    • ViewHelpers
  • FAQ - Frequently Asked Questions
  • Appendix - Dynamic Fields
  • Appendix - Version Matrix
  • Releases
    • Apache Solr for TYPO3 7.0.0
    • Apache Solr for TYPO3 8.0.0
    • Apache Solr for TYPO3 8.1.0
    • Apache Solr for TYPO3 9.0.0
    • Apache Solr for TYPO3 10.0.0
    • Apache Solr for TYPO3 11.0.0
    • Apache Solr for TYPO3 11.1.0
    • Apache Solr for TYPO3 11.2.0
    • Apache Solr for TYPO3 11.5.0
  • Sitemap
  • Index

PAGE CONTENTS

  • tx_solr.search
    • targetPage
    • trustedFields
    • initializeWithEmptyQuery
    • showResultsOfInitialEmptyQuery
    • keepExistingParametersForNewSearches
    • ignoreGlobalQParameter
    • additionalPersistentArgumentNames
    • query
      • query.allowEmptyQuery
      • query.allowedSites
      • query.getParameter
      • query.queryFields (query.fields)
      • query.returnFields
      • query.minimumMatch
      • query.boostFunction
      • query.boostQuery
      • query.tieParameter
      • query.filter
      • query.filter.__pageSections
      • query.sortBy
      • query.phrase
      • query.phrase.fields
      • query.phrase.slop
      • query.phrase.querySlop
      • query.bigramPhrase
      • query.bigramPhrase.fields
      • query.bigramPhrase.slop
      • query.trigramPhrase
      • query.trigramPhrase.fields
      • query.trigramPhrase.slop
    • results
      • results.resultsHighlighting
      • results.resultsHighlighting.highlightFields
      • results.resultsHighlighting.fragmentSize
      • results.resultsHighlighting.fragmentSeparator
      • results.resultsHighlighting.wrap
      • results.siteHighlighting
      • results.resultsPerPage
      • results.resultsPerPageSwitchOptions
      • results.maxPaginatorLinks
      • results.showDocumentScoreAnalysis
    • spellchecking
      • spellchecking
      • spellchecking.searchUsingSpellCheckerSuggestion
    • lastSearches
      • lastSearches
      • lastSearches.limit
      • lastSearches.mode
    • frequentSearches
      • frequentSearches
      • frequentSearches.useLowercaseKeywords
      • frequentSearches.minSize
      • frequentSearches.maxSize
      • frequentSearches.limit
      • frequentSearches.select
    • sorting
      • sorting
      • sorting.defaultOrder
      • sorting.options
      • sorting.options.[optionName].label
      • sorting.options.[optionName].field
      • sorting.options.[optionName].defaultOrder
    • faceting
      • faceting
      • faceting.minimumCount
      • faceting.sortBy
      • faceting.limit
      • faceting.facetLimit
      • faceting.keepAllFacetsOnSelection
      • faceting.countAllFacetsForSelection
      • faceting.showAllLink.wrap
      • faceting.showEmptyFacets
      • faceting.urlParameterStyle
      • faceting.urlParameterSort
      • faceting.facetLinkUrlParameters
      • faceting.facetLinkUrlParameters.useForFacetResetLinkUrl
      • faceting.facets
      • faceting.facets.[facetName] - single facet configuration
      • faceting.facets.[facetName].additionalExcludeTags
      • faceting.facets.[facetName].addFieldAsTag
      • faceting.facets.[facetName].field
      • faceting.facets.[facetName].label
      • faceting.facets.[facetName].excludeValues
      • faceting.facets.[facetName].facetLimit
      • faceting.facets.[facetName].metrics
      • faceting.facets.[facetName].partialName
      • faceting.facets.[facetName].keepAllOptionsOnSelection
      • faceting.facets.[facetName].operator
      • faceting.facets.[facetName].sortBy
      • faceting.facets.[facetName].manualSortOrder
      • faceting.facets.[facetName].manualSortOrderDelimiter
      • faceting.facets.[facetName].minimumCount
      • faceting.facets.[facetName].reverseOrder
      • faceting.facets.[facetName].showEvenWhenEmpty
      • faceting.facets.[facetName].includeInAvailableFacets
      • faceting.facets.[facetName].includeInUsedFacets
      • faceting.facets.[facetName].type
      • faceting.facets.[facetName].[type]
      • faceting.facets.[facetName].requirements.[requirementName]
      • faceting.facets.[facetName].renderingInstruction
    • elevation
      • elevation
      • elevation.forceElevation
      • elevation.markElevatedResults
    • variants
      • variants.expand
      • variants.variantField
      • variants.limit
  1. Start
  2. Configuration Reference
  3. tx_solr.search
View source How to edit Edit on GitHub

Display settings


Color scheme of code blocks:


tx_solr.search¶

The search section, you probably already guessed it, provides configuration options for the all things related to actually searching the index, setting query parameters, formatting and processing result documents and the result listing.

targetPage¶

Type

Integer

TS Path

plugin.tx_solr.search.targetPage

Default

0

Since

1.0

Sets the target page ID for links. If it is empty or 0, the current page ID will be used.

Note: This setting can be overwritten by the plugins flexform.

trustedFields¶

Type

String

TS Path

plugin.tx_solr.search.trustedFields

Default

url

Since

3.1

The data in EXT:solr is escaped right after the retrieval from Solr. In rare cases when you need to store HTML in Solr documents you can use this configuration to mark these fields as trusted fields and skip the escaping. Typically this is needed when you want to retrieve html from solr.

The following example shows how to avoid html in the content field:

plugin.tx_solr.search.trustedFields = url, content

initializeWithEmptyQuery¶

Type

Boolean

TS Path

plugin.tx_solr.search.initializeWithEmptyQuery

Default

0

Options

0,1

Since

1.0

If enabled, the results plugin (pi_results) issues a "get everything" query during initialization. This is useful, if you want to create a page that shows all available facets although no search has been issued by the user yet. Note: Enabling this option alone will not show results of the get everything query. To also show the results of the query, see option showResultsOfInitialEmptyQuery below.

showResultsOfInitialEmptyQuery¶

Type

Boolean

TS Path

plugin.tx_solr.search.showResultsOfInitialEmptyQuery

Default

0

Options

0,1

Since

1.0

Requires initializeWithEmptyQuery (above) to be enabled to have any effect. If enabled together with initializeWithEmptyQuery the results of the initial "get everything" query are shown. This way, in combination with a filter you can easily list a predefined set of results.

keepExistingParametersForNewSearches¶

Type

Boolean

TS Path

plugin.tx_solr.search.keepExistingParametersForNewSearches

Default

0

Options

0,1

Since

2.0

When doing a new search, existing parameters like filters will be carried over to the new search. This is useful for a scenario where you want to list all available documents first, then allow the user to filter the documents using facets and finally allow him to specify a search term to refine the search.

ignoreGlobalQParameter¶

Type

Boolean

TS Path

plugin.tx_solr.search.ignoreGlobalQParameter

Default

0

Options

0,1

Since

7.0

In some cases you want EXT:solr to react on the parameter "q" in the url. Normally plugins are bounded to a namespace to allow multiple instances of the search on the same page. In this case you might want to disable this and let EXT:solr only react on the namespaced query parameter (tx_solr[q] by default).

additionalPersistentArgumentNames¶

Type

String

TS Path

plugin.tx_solr.search.additionalPersistentArgumentNames

Since

8.0

Comma-separated list of additional argument names, that should be added to the persistent arguments that are kept for sub request, like the facet and sorting urls. Hard coded argument names are q, filter and sort.

Till solr version 6.5.x all parameters of the plugin namespace was added to the url again. With this setting you could enable this behavior again, but only with a whitelist of argument names.

query¶

The query sub-section defines a few query parameters for the query that will be sent to the Solr server later on. Some query parameters are also generated and set by the extension itself, f.e. when using facets.

query.allowEmptyQuery¶

Type

Boolean

TS Path

plugin.tx_solr.search.query.allowEmptyQuery

Default

0

Options

0,1

Since

1.4

If enabled, empty queries are allowed.

query.allowedSites¶

Type

String

TS Path

plugin.tx_solr.search.query.allowedSites

Since

2.2

Default

__solr_current_site

When indexing documents (pages, records, files, ...) into the Solr index, the solr extension adds a "siteHash". The siteHash is used to allow indexing multiple sites into one index and still have each site only find its own documents. This is achieved by adding a filter on the siteHash.

Sometimes though, you want to search across multiple domains, then the siteHash is a blocker. Using the allowedSites setting you can set a comma-separated list of domains who's documents are allowed to be included in the current domain's search results. The default value is __solr_current_site which is a magic string/variable that is replaced with the current site's domain when querying the Solr server.

Since

3.0

Version 3.0 introduced a couple more magic keywords that get replaced:

  • __current_site same as __solr_current_site

  • __all Adds all domains as allowed sites

  • * (asterisk character) Everything is allowed as siteHash (same as no siteHash check). This option should only be used when you need a search across multiple system and you know the impact of turning of the siteHash check.

query.getParameter¶

Type

String

TS Path

plugin.tx_solr.search.query.getParameter

Since

2.2

Default

tx_solr|q

The GET query parameter name used in URLs. Useful for cases f.e. when a website tracking tool does not support the default array GET parameters.

The option expects a string, you can also define an array in the form of arrayName|arrayKey.

Example:

plugin.tx_solr.search.query.getParameter = q

query.queryFields (query.fields)¶

Type

String

TS Path

plugin.tx_solr.search.query.queryFields

Since

1.0

Default

content^40.0, title^5.0, keywords^2.0, tagsH1^5.0, tagsH2H3^3.0, tagsH4H5H6^2.0, tagsInline^1.0, description^4.0, abstract^1.0, subtitle^1.0, navtitle^1.0, author^1.0

Note

query.fields has been renamed to query.queryFields in version 3.0

Defines what fields to search in the index. Fields are defined as a comma separated list. Each field can be given a boost by appending the boost value separated by the ^ character, that's Lucene query language. The boost value itself is a float value, pay attention to using a dot as the separator for the fractions. Use this option to add more fields to search.

The boost take influence on what score a document gets when searching and thus how documents are ranked and listed in the search results. A higher score will move documents up in the result listing. The boost is a multiplier for the original score value of a document for a search term.

By default if a search term is found in the content field the documents gets scored / ranked higher as if a term was found in the title or keywords field. Although the default should provide a good setting, you can play around with the boost values to find the best ranking for your content.

query.returnFields¶

Type

String

TS Path

plugin.tx_solr.search.query.returnFields

Since

3.0

Default

*, score

Limits the fields returned in the result documents, by default returns all field plus the virtual score field.

query.minimumMatch¶

Type

String

TS Path

plugin.tx_solr.search.query.minimumMatch

Since

1.2, 2.0

Default

(empty)

See

Apache Solr Wiki mm / Minimum Should Match

Sets the minimum match mm query parameter. By default the mm query parameter is set in solrconfig.xml as 2<-35%. This means that for queries with less than three words they all must match the searched fields of a document. For queries with three or more words at least 65% of them must match rounded up.

Please consult the link to the Solr wiki for a more detailed description of the mm syntax.

query.boostFunction¶

Type

String

TS Path

plugin.tx_solr.search.query.boostFunction

Since

1.2, 2.0

Default

(empty)

See

Apache Solr Wiki / TheDisMaxQueryParser BoostFunction

See

Apache Solr Wiki / Function Queries

Example

recip(ms(NOW,created),3.16e-11,1,1)

A boost function can be useful to influence the relevance calculation and boost some documents to appear more at the beginning of the result list. Technically the parameter will be mapped to the "bf" parameter in the solr query.

Use cases for example could be:

"Give newer documents a higher priority":

This could be done with a recip function:

recip(ms(NOW,created),3.16e-11,1,1)

"Give documents with a certain field value a higher priority":

This could be done with:

termfreq(type,'tx_solr_file')

query.boostQuery¶

Type

String

TS Path

plugin.tx_solr.search.query.boostQuery

Since

2.0

Default

(empty)

See

Apache Solr Wiki / TheDisMaxQueryParser BoostQuery

Sets the boost function bq query parameter.

Allows to further manipulate the score of a document by using Lucene syntax queries. A common use case for boost queries is to rank documents of a specific type higher than others.

Please consult the link to the Solr wiki for a more detailed description of boost functions.

Example (boosts tt_news documents by factor 10):

plugin.tx_solr.search.query.boostQuery = (type:tt_news)^10

query.tieParameter¶

Type

String

TS Path

plugin.tx_solr.search.query.tieParameter

Since

8.0

See

Lucene Documentation / TheDisMaxQueryParser TieParameter <http://lucene.apache.org/solr/guide/7_0/the-dismax-query-parser.html#the-tie-tie-breaker-parameter>

This parameter ties the scores together. Setting is to "0" (default) uses the maximum score of all computed scores. A value of "1.0" adds all scores. The value is a number between "0.0" and "1.0".

query.filter¶

Type

Array

TS Path

plugin.tx_solr.search.query.filter

Since

1.0

See

Lucene Documentation / Query Parser Syntax

Allows to predefine filters to apply to a search query. You can add multiple filters through a name to Lucene filter mapping. The filters support stdWrap.

Example:

plugin.tx_solr.search.query.filter {
    pagesOnly = type:pages
    johnsPages = author:John
    badKeywords = {foo}
    badKeywords.wrap = -keywords:|
    badKeywords.data = GP:q
}

Note: When you want to filter for something with whitespaces you might need to quote the filter term.

plugin.tx_solr.search.query.filter {
    johnsDoesPages = author:"John Doe"
}

query.filter.__pageSections¶

Type

comma-separated list of page IDs

TS Path

plugin.tx_solr.search.query.filter.__pageSections

Since

3.0

This is a magic/reserved filter (thus the double underscore). It limits the query and the results to certain branches/sections of the page tree. Multiple starting points can be provided as a comma-separated list of page IDs.

query.sortBy¶

Type

String

TS Path

plugin.tx_solr.search.query.sortBy

Since

1.0

Allows to set a custom sorting for the query. By default Solr will sort by relevance, using this setting you can sort by any sortable field.

Needs a Solr field name followed by asc for ascending order or desc for descending.

Example:

plugin.tx_solr.search.query.sortBy = title asc

query.phrase¶

Type

Boolean

TS Path

plugin.tx_solr.search.query.phrase

Since

8.0

Default

0

See

"pf", "ps", "qs" https://lucene.apache.org/solr/guide/6_6/the-dismax-query-parser.html#TheDisMaxQueryParser-Thepf_PhraseFields_Parameter

This parameter enables the phrase search feature from Apache Solr. Setting is to "0" (default) does not change behaviour from Apache Solr if user searches for two and more words. Enabling phrase search feature influences the document set and/or the scores of documents.

query.phrase.fields¶

Type

String

TS Path

plugin.tx_solr.search.query.phrase.fields

Since

8.0

Default

content^10.0, title^10.0, tagsH1^10.0, tagsH2H3^10.0, tagsH4H5H6^10.0, tagsInline^10.0, description^10.0, abstract^10.0, subtitle^10.0, navtitle^10.0

See

"pf" parameter https://lucene.apache.org/solr/guide/6_6/the-dismax-query-parser.html#TheDisMaxQueryParser-Thepf_PhraseFields_Parameter

This parameter defines what fields should be used to search in the given phrase. Matched documents will be boosted according to fields boost value. Fields are defined as a comma separated list and same way as queryFields.

Note: The value of this setting has NO influence on explicit phrase search.

query.phrase.slop¶

Type

Integer

TS Path

plugin.tx_solr.search.query.phrase.slop

Since

8.0

Default

0

See

"ps" parameter https://lucene.apache.org/solr/guide/6_6/the-dismax-query-parser.html#TheDisMaxQueryParser-Theps_PhraseSlop_Parameter

This parameter defines the "phrase slop" value, which represents the number of positions one word needs to be moved in relation to another word in order to match a phrase specified in a query.

Note: The value of this setting has NO influence on explicit phrase search.

query.phrase.querySlop¶

Type

Integer

TS Path

plugin.tx_solr.search.query.phrase.querySlop

Since

8.0

Default

0

See

"qs" parameter https://lucene.apache.org/solr/guide/6_6/the-dismax-query-parser.html#TheDisMaxQueryParser-Theqs_QueryPhraseSlop_Parameter

This parameter defines the "phrase slop" value, which represents the number of positions one word needs to be moved in relation to another word in order to match a phrase specified in a explicit phrase search query. Note: On explicit("double quoted" phrase) phrase search Apache Solr searches in "qf" queryFields

Note: The value of this setting has no influence on implicit phrase search.

On explicit phrase search the Solr searches in qf (plugin.tx_solr.search.query.queryFields) defined fields.

query.bigramPhrase¶

Type

Boolean

TS Path

plugin.tx_solr.search.query.bigramPhrase

Since

8.0

Default

0

See

"pf2", "ps2" https://lucene.apache.org/solr/guide/6_6/the-extended-dismax-query-parser.html#TheExtendedDisMaxQueryParser-Thepf2Parameter

This parameter enables the bigram phrase search feature from Apache Solr. Setting is to "0" (default) does not change behaviour from Apache Solr if user searches for three and more words. Enabling bigram phrase search feature influences the scores of documents with phrase occurrences.

query.bigramPhrase.fields¶

Type

String

TS Path

plugin.tx_solr.search.query.bigramPhrase.fields

Since

8.0

Default

content^10.0, title^10.0, tagsH1^10.0, tagsH2H3^10.0, tagsH4H5H6^10.0, tagsInline^10.0, description^10.0, abstract^10.0, subtitle^10.0, navtitle^10.0

See

"pf2" parameter https://lucene.apache.org/solr/guide/6_6/the-extended-dismax-query-parser.html#TheExtendedDisMaxQueryParser-Thepf2Parameter

This parameter defines what fields should be used to search in the given sentence(three+ words). Matched documents will be boosted according to fields boost value. Fields are defined as a comma separated list and same way as queryFields.

Note: The value of this setting has NO influence on explicit phrase search.

query.bigramPhrase.slop¶

Type

Integer

TS Path

plugin.tx_solr.search.query.bigramPhrase.slop

Since

8.0

Default

0

See

"ps2" parameter https://lucene.apache.org/solr/guide/6_6/the-extended-dismax-query-parser.html#TheExtendedDisMaxQueryParser-Theps2Parameter

This parameter defines the "bigram phrase slop" value, which represents the number of positions one word needs to be moved in relation to another word in order to match a phrase specified in a query.

Note: The value of this setting has NO influence on explicit phrase search.

query.trigramPhrase¶

Type

Boolean

TS Path

plugin.tx_solr.search.query.trigramPhrase

Since

8.0

Default

0

See

"pf3", "ps3" https://lucene.apache.org/solr/guide/6_6/the-extended-dismax-query-parser.html#TheExtendedDisMaxQueryParser-Thepf3Parameter

This parameter enables the phrase search feature from Apache Solr. Setting is to "0" (default) does not change behaviour from Apache Solr if user searches for two and more words. Enabling phrase search feature influences the scores of documents with phrase occurrences.

query.trigramPhrase.fields¶

Type

String

TS Path

plugin.tx_solr.search.query.trigramPhrase.fields

Since

8.0

Default

content^10.0, title^10.0, tagsH1^10.0, tagsH2H3^10.0, tagsH4H5H6^10.0, tagsInline^10.0, description^10.0, abstract^10.0, subtitle^10.0, navtitle^10.0

See

"pf3" parameter https://lucene.apache.org/solr/guide/6_6/the-extended-dismax-query-parser.html#TheExtendedDisMaxQueryParser-Thepf3Parameter

This parameter defines what fields should be used to search in the given phrase. Matched documents will be boosted according to fields boost value. Fields are defined as a comma separated list and same way as queryFields.

Note: The value of this setting has NO influence on explicit phrase search.

query.trigramPhrase.slop¶

Type

Integer

TS Path

plugin.tx_solr.search.query.trigramPhrase.slop

Since

8.0

Default

0

See

"ps3" parameter https://lucene.apache.org/solr/guide/6_6/the-extended-dismax-query-parser.html#TheExtendedDisMaxQueryParser-Theps3Parameter

This parameter defines the "trigram phrase slop" value, which represents the number of positions one word needs to be moved in relation to another word in order to match a phrase specified in a query.

Note: The value of this setting has NO influence on explicit phrase search.

results¶

results.resultsHighlighting¶

Type

Boolean

TS Path

plugin.tx_solr.search.results.resultsHighlighting

Since

1.0

Default

0

See

Apache Solr Wiki / FastVectorHighlighter

En-/disables search term highlighting on the results page.

Note: The FastVectorHighlighter is used by default (Since 4.0) if fragmentSize is set to at least 18 (this is required by the FastVectorHighlighter to work).

results.resultsHighlighting.highlightFields¶

Type

String

TS Path

plugin.tx_solr.search.results.resultsHighlighting.highlightFields

Since

1.0

Default

content

A comma-separated list of fields to highlight.

Note: The highlighting in solr (based on FastVectorHighlighter requires a field datatype with termVectors=on, termPositions=on and termOffsets=on which is the case for the content field). If you add other fields here, make sure that you are using a datatype where this is configured.

results.resultsHighlighting.fragmentSize¶

Type

Integer

TS Path

plugin.tx_solr.search.results.resultsHighlighting.fragmentSize

Since

1.0

Default

200

The size, in characters, of fragments to consider for highlighting. "0" indicates that the whole field value should be used (no fragmenting).

results.resultsHighlighting.fragmentSeparator¶

Type

String

TS Path

plugin.tx_solr.search.results.resultsHighlighting.fragmentSeparator

Since

3.0

Default

[...]

When highlighting is activated Solr highlights the fields configured in highlightFields and can return multiple fragments of fragmentSize around the highlighted search word. These fragments are used as teasers in the results list. fragmentSeparator allows to configure the glue string between those fragments.

results.resultsHighlighting.wrap¶

Type

String

TS Path

plugin.tx_solr.search.results.resultsHighlighting.wrap

Since

1.0

Default

<span class="results-highlight">|</span>

The wrap for search terms to highlight.

results.siteHighlighting¶

Type

Boolean

TS Path

plugin.tx_solr.search.results.siteHighlighting

Since

2.0

Default

0

Activates TYPO3's highlighting of search words on the actual pages. The words a user searched for will be wrapped with a span and CSS class csc-sword Highlighting can be styled using the CSS class csc-sword, you need to add the style definition yourself for the complete site.

results.resultsPerPage¶

Type

Integer

TS Path

plugin.tx_solr.search.results.resultsPerPage

Since

1.0

Default

{$plugin.tx_solr.search.results.resultsPerPage}

Sets the number of shown results per page.

results.resultsPerPageSwitchOptions¶

Type

String

TS Path

plugin.tx_solr.search.results.resultsPerPageSwitchOptions

Since

1.0

Default

10, 25, 50

Defines the shown options of possible results per page.

results.maxPaginatorLinks¶

Type

Integer

TS Path

plugin.tx_solr.search.results.maxPaginatorLinks

Since

11.5

Default

0

Sets the number of shown page links in the paginator.

results.showDocumentScoreAnalysis¶

Type

Boolean

TS Path

plugin.tx_solr.search.results.showDocumentScoreAnalysis

Since

2.5-dkd

Default

0

Options

0,1

If enabled, the analysis and display of the score analysis for logged in backend users will be initialized.

spellchecking¶

spellchecking¶

Type

Boolean

TS Path

plugin.tx_solr.search.spellchecking

Since

1.0

Default

0

Set plugin.tx_solr.search.spellchecking = 1 to enable spellchecking / did you mean.

spellchecking.searchUsingSpellCheckerSuggestion¶

Type

Boolean

TS Path

plugin.tx_solr.search.spellchecking.searchUsingSpellCheckerSuggestion

Since

4.0

Default

0

This setting can be used to trigger a new search automatically when the previous search had no results but suggestions from the spellchecking. In this case the user can directly see the results of the best correction option.

lastSearches¶

lastSearches¶

Type

Boolean

TS Path

plugin.tx_solr.search.lastSearches

Since

1.3-dkd

Default

0

Set plugin.tx_solr.search.lastSearches = 1 to display a list of the last searches.

lastSearches.limit¶

Type

Integer

TS Path

plugin.tx_solr.search.lastSearches.limit

Since

1.3-dkd

Default

10

Defines the number of last searches, that should get minded.

lastSearches.mode¶

Type

String

TS Path

plugin.tx_solr.search.lastSearches.mode

Since

1.3-dkd

Default

user

Options

user, global

If mode is user, keywords will get stored into the session. If mode is global keywords will get stored into the database.

frequentSearches¶

frequentSearches¶

Type

Boolean

TS Path

plugin.tx_solr.search.frequentSearches

Since

1.3-dkd, 2.8

Default

0

Set plugin.tx_solr.search.frequentSearches = 1 to display a list of the frequent / common searches.

frequentSearches.useLowercaseKeywords¶

Type

Boolean

TS Path

plugin.tx_solr.search.frequentSearches.useLowercaseKeywords

Since

2.9

Default

0

When enabled, keywords are written to the statistics table in lower case.

frequentSearches.minSize¶

Type

Integer

TS Path

plugin.tx_solr.search.frequentSearches.minSize

Since

1.3-dkd, 2.8

Default

14

The difference between frequentSearches.maxSize and frequentSearches.minSize is used for calculating the current step.

frequentSearches.maxSize¶

Type

Integer

TS Path

plugin.tx_solr.search.frequentSearches.maxSize

Since

1.3-dkd, 2.8

Default

32

The difference between frequentSearches.maxSize and frequentSearches.minSize is used for calculating the current step.

frequentSearches.limit¶

Type

Integer

TS Path

plugin.tx_solr.search.frequentSearches.limit

Since

1.3-dkd, 2.8

Default

20

Defines the maximum size of the list by frequentSearches.select.

frequentSearches.select¶

Type

cObject

TS Path

plugin.tx_solr.search.frequentSearches.select

Since

1.3-dkd, 2.8

Defines a database connection for retrieving statistics.

sorting¶

sorting¶

Type

Boolean

TS Path

plugin.tx_solr.search.sorting

Since

1.0

Default

0

Set plugin.tx_solr.search.sorting = 1 to allow sorting of results.

sorting.defaultOrder¶

Type

String

TS Path

plugin.tx_solr.search.sorting.defaultOrder

Since

1.0

Default

asc

Options

asc, desc

Sets the default sort order for all sort options.

sorting.options¶

This is a list of sorting options. Each option has a field and label to be used. By default the options title, type, author, and created are configured, plus the virtual relevancy field which is used for sorting by default.

Example:

plugin.tx_solr.search {
    sorting {
        options {
            relevance {
                field = relevance
                label = Relevance
            }

            title {
                field = sortTitle
                label = Title
            }
        }
    }
}

Note: As mentioned before relevance is a virtual field that is used to reset the sorting. Sorting by relevance means to have the order provided by the scoring from solr. That the reason why sorting descending on relevance is not possible.

sorting.options.[optionName].label¶

Type

String / stdWrap

TS Path

plugin.tx_solr.search.sorting.options.[optionName].label

Since

1.0

Defines the name of the option's label. Supports stdWrap.

sorting.options.[optionName].field¶

Type

String / stdWrap

TS Path

plugin.tx_solr.search.sorting.options.[optionName].field

Since

1.0

Defines the option's field. Supports stdWrap.

sorting.options.[optionName].defaultOrder¶

Type

String

TS Path

plugin.tx_solr.search.sorting.options.[optionName].defaultOrder

Since

2.2

Default

asc

Options

asc, desc

Sets the default sort order for a particular sort option.

faceting¶

faceting¶

Type

Boolean

TS Path

plugin.tx_solr.search.faceting

Since

1.0

Default

0

Set plugin.tx_solr.search.faceting = 1 to enable faceting.

faceting.minimumCount¶

Type

Integer

TS Path

plugin.tx_solr.search.faceting.minimumCount

Since

1.0

Default

1

See

Apache Solr Wiki / Faceting mincount Parameter

This indicates the minimum counts for facet fields should be included in the response.

faceting.sortBy¶

Type

String

TS Path

plugin.tx_solr.search.faceting.sortBy

Since

1.0

Default

count

Options

count, index, 1, 0, true, false, alpha (1.2, 2.0), lex (1.2, 2.0)

See

Apache Solr Wiki / Faceting sortParameter Parameter

Defines how facet options are sorted, by default they are sorted by count of results, highest on top. count, 1, true are aliases for each other.

Facet options can also be sorted alphabetically (lexicographic by indexed term) by setting the option to index. index, 0, false, alpha (from version 1.2 and 2.0), and lex (from version 1.2 and 2.0) are aliases for index.

faceting.limit¶

Type

Integer

TS Path

plugin.tx_solr.search.faceting.limit

Since

1.0

Default

10

Number of options to display per facet. If more options are returned by Solr, they are hidden and can be expanded by clicking a "show more" link. This feature uses a small javascript function to collapse/expand the additional options.

faceting.facetLimit¶

Type

Integer

TS Path

plugin.tx_solr.search.faceting.facetLimit

Since

6.0

Default

100

Number of options of a facet returned from solr.

faceting.keepAllFacetsOnSelection¶

Type

Boolean

TS Path

plugin.tx_solr.search.faceting.keepAllFacetsOnSelection

Since

2.2

Default

0

Options

0, 1

When enabled selecting an option from a facet will not reduce the number of options available in other facets.

faceting.countAllFacetsForSelection¶

Type

Boolean

TS Path

plugin.tx_solr.search.faceting.countAllFacetsForSelection

Since

8.0

Default

0

Options

0, 1

When `keepAllFacetsOnSelection` is active the count of a facet do not get reduced. You can use `countAllFacetsForSelection` to achieve that.

The following example shows how to keep all options of all facets by keeping the real document count, even when it has zero options:

` plugin.tx_solr.search.faceting.keepAllFacetsOnSelection = 1 plugin.tx_solr.search.faceting.countAllFacetsForSelection = 1 plugin.tx_solr.search.faceting.minimumCount = 0 `

faceting.showAllLink.wrap¶

Type

String

TS Path

plugin.tx_solr.search.faceting.showAllLink.wrap

Since

1.0

Default

<li>|</li>

Defines the output of the "Show more" link, that is rendered if there are more facets given than set by faceting.limit.

faceting.showEmptyFacets¶

Type

Boolean

TS Path

plugin.tx_solr.search.faceting.showEmptyFacets

Since

1.3

Default

0

Options

0, 1

By setting this option to 1, you will allow rendering of empty facets. Usually, if a facet does not offer any options to filter a resultset of documents, the facet header will not be shown. Using this option allows the header still to be rendered when no filter options are provided.

faceting.urlParameterStyle¶

Type

Option/String (index or assoc)

TS Path

plugin.tx_solr.search.faceting.urlParameterStyle

Since

11.1

Default

index

Note

On assoc, the setting faceting.urlParameterSort will be enabled and can not be disabled.

Allows to change the url style of facets. This can be legacy index or more modern associative style.

Index style: tx_solr[filter][0]=type:pages Associative style: tx_solr[filter][type:pages]=1

faceting.urlParameterSort¶

Type

Boolean

TS Path

plugin.tx_solr.search.faceting.urlParameterSort

Since

11.1

Default

0

Note

On faceting.urlParameterStyle = assoc, this setting can not be disabled.

Allows to enable sorting of url parameters, so the single state of facets is associated with same url, no matter in which order the facets were selected

faceting.facetLinkUrlParameters¶

Type

String

TS Path

plugin.tx_solr.search.faceting.facetLinkUrlParameters

Since

2.8

Allows to add URL GET parameters to the links build in facets.

faceting.facetLinkUrlParameters.useForFacetResetLinkUrl¶

Type

Boolean

TS Path

plugin.tx_solr.search.faceting.facetLinkUrlParameters.useForFacetResetLinkUrl

Since

2.8

Allows to prevent adding the URL parameters to the facets reset link by setting the option to 0.

faceting.facets¶

Type

Array

TS Path

plugin.tx_solr.search.faceting.facets

Since

1.0

Default

type

See

Apache Solr Wiki / Faceting Overview

Defines which fields you want to use for faceting. It's a list of facet configurations.

plugin.tx_solr.search.faceting.facets {
  type {
    field = type
    label = Content Type
  }

  category {
    field = category_stringM
    label = Category
  }
}

faceting.facets.[facetName] - single facet configuration¶

You can add new facets by simply adding a new facet configuration in TypoScript. [facetName] represents the facet's name and acts as a configuration "container" for a single facet. All configuration options for a facet are defined within that "container".

A facet will use the values of a configured index field to offer these values as filter options to your site's visitors. You need to make sure that the facet field's type allows to sort the field's value; like string, int, and other primitive types.

To configure a facet you only need to provide the label and field configuration options, all other configuration options are optional.

faceting.facets.[facetName].additionalExcludeTags¶

Type

String

TS Path

plugin.tx_solr.search.faceting.facets.[facetName].additionalExcludeTags

Since

9.0

Required

no

The settings keepAllOptionsOnSelection` and keepAllFacetsOnSelection` are used internally to build exclude tags for facets in order to exclude the filters from the facet counts. This helps to keep the counts of a facet as expected by the user, in some usecases (Read also: http://yonik.com/multi-select-faceting/).

With the setting additionalExcludeTags` you can add tags of factes that should be excluded from the counts as well.

Note: This setting is only available for option facets by now.

faceting.facets.[facetName].addFieldAsTag¶

Type

Boolean

TS Path

plugin.tx_solr.search.faceting.facets.[facetName].addFieldAsTag

Since

9.0

Required

no

Default

false

When you want to add fields as `additionalExcludeTags` for a facet a tag for this facet needs to exist. You can use this setting to force the creation of a tag for this facet in the solr query.

faceting.facets.[facetName].field¶

Type

String

TS Path

plugin.tx_solr.search.faceting.facets.[facetName].field

Since

1.0

Required

yes

Which field to use to create the facet.

faceting.facets.[facetName].label¶

Type

String

TS Path

plugin.tx_solr.search.faceting.facets.[facetName].label

Since

1.0

Required

yes

Used as a headline or title to describe the options of a facet. Used in flex forms of plugin for filter labels. Can be translated with LLL: and consumed and translated in Partial/Facets/* with f:translate ViewHelper.

faceting.facets.[facetName].excludeValues¶

Type

String

TS Path

plugin.tx_solr.search.faceting.facets.[facetName].excludeValues

Since

7.0

Required

no

Defines a comma separated list of options that are excluded (The value needs to match the value in solr)

Important: This setting only makes sence for option based facets (option, query, hierarchy)

faceting.facets.[facetName].facetLimit¶

Type

Integer

TS Path

plugin.tx_solr.search.faceting.facets.[facetName].facetLimit

Since

8.0

Default

-1

Hard limit of options returned by solr.

Note: This is only available for options facets.

faceting.facets.[facetName].metrics¶

Type

Array

TS Path

plugin.tx_solr.search.faceting.facets.[facetName].metrics

Since

8.0

Default

empty

Metrics can be use to collect and enhance facet options with statistical data of the faceted documents. They can be used to render useful information in the context of an facet option.

Example:

plugin.tx_solr.search.faceting.facets {
  category {
    field = field
    label = Category
    metrics {
        downloads = sum(downloads_intS)
    }
  }
}

The example above will make the metric "downloads" available for all category options. In this case it will be the sum of all downloads of this category item. In the frontend you can render this metric with "<facetoptions.>.metrics.downloads" and use it for example to show it instead of the normal option count.

faceting.facets.[facetName].partialName¶

Type

String

TS Path

plugin.tx_solr.search.faceting.facets.[facetName].partialName

Since

7.0

Required

no

By convention a facet is rendered by it's default partial that is located in "Resources/Private/Partials/Facets/<Type>.html".

If you want to render a single facet with another, none conventional partial, your can configure it with "partialName = MyFacetPartial".

faceting.facets.[facetName].keepAllOptionsOnSelection¶

Type

Boolean

TS Path

plugin.tx_solr.search.faceting.facets.[facetName].keepAllOptionsOnSelection

Since

1.2, 2.0

Default

0

Options

0, 1

Normally, when clicking any option link of a facet this would result in only that one option being displayed afterwards. By setting this option to one, you can prevent this. All options will still be displayed.

This is useful if you want to allow the user to select more than one option from a single facet.

faceting.facets.[facetName].operator¶

Type

String

TS Path

plugin.tx_solr.search.faceting.facets.[facetName].operator

Since

1.2, 2.0

Default

AND

Options

OR, AND

When configuring a facet to allow selection of multiple options, you can use this option to decide whether multiple selected options should be combined using AND or OR.

faceting.facets.[facetName].sortBy¶

Type

String

TS Path

plugin.tx_solr.search.faceting.facets.[facetName].sortBy

Since

1.2

Default
Options

alpha (aliases: index, lex)

Sets how a single facet's options are sorted, by default they are sorted by number of results, highest on top. Facet options can also be sorted alphabetically by setting the option to alpha.

Note: Since 9.0.0 it is possible to sort a facet by a function. This can be done be defining a metric and use that metric in the sortBy configuration. As sorting name you then need to use by convention "metrics_<metricName>"

Example:

pid {
    label = Content Type
    field = pid
    metrics {
       newest = max(created)
    }
    sortBy = metrics_newest desc
}

faceting.facets.[facetName].manualSortOrder¶

Type

String

TS Path

plugin.tx_solr.search.faceting.facets.[facetName].manualSortOrder

Since

2.2

By default facet options are sorted by the amount of results they will return when applied. This option allows to manually adjust the order of the facet's options. The sorting is defined as a comma-separated list of options to re-order. Options listed will be moved to the top in the order defined, all other options will remain in their original order.

Example - We have a category facet like this:

News Category
+ Politics (256)
+ Sports (212)
+ Economy (185)
+ Culture (179)
+ Health (132)
+ Automobile (99)
+ Travel (51)

Using faceting.facets.[facetName].manualSortOrder = Travel, Health will result in the following order of options:

News Category
+ Travel (51)
+ Health (132)
+ Politics (256)
+ Sports (212)
+ Economy (185)
+ Culture (179)
+ Automobile (99)

faceting.facets.[facetName].manualSortOrderDelimiter¶

Type

String

TS Path

plugin.tx_solr.search.faceting.facets.[facetName].manualSortOrderDelimiter

Since

11.5

Default

,

Define an alternative delimiter instead of the default comma (,) for the manualSortOrder option. This is especially useful if the , is part of a facet option value.

faceting.facets.[facetName].minimumCount¶

Type

Integer

TS Path

plugin.tx_solr.search.faceting.facets.[facetName].minumumCount

Since

8.0

Default

1

Set's the minimumCount for a single facet. This can be usefull e.g. to set the minimumCount of a single facet to 0, to have the options available even when there is result available.

Note: This setting is only available for facets that are using the json faceting API of solr. By now this is only available for the options facets.

faceting.facets.[facetName].reverseOrder¶

Type

Boolean

TS Path

plugin.tx_solr.search.faceting.facets.[facetName].reverseOrder

Since

3.0

Default

0

Options

0, 1

Reverses the order of facet options.

faceting.facets.[facetName].showEvenWhenEmpty¶

Type

Boolean

TS Path

plugin.tx_solr.search.faceting.facets.[facetName].showEvenWhenEmpty

Since

2.0

Default

0

Options

0, 1

Allows you to display a facet even if it does not offer any options (is empty) and although you have set plugin.tx_solr.search.faceting.showEmptyFacets = 0.

faceting.facets.[facetName].includeInAvailableFacets¶

Type

Boolean

TS Path

plugin.tx_solr.search.faceting.facets.[facetName].includeInAvailableFacets

Since

1.3

Default

1

Options

0, 1

By setting this option to 0, you can prevent rendering of a given facet within the list of available facets.

This is useful if you render the facet somewhere eles on the page using the facet view helper and don't want the facet to be rendered twice.

faceting.facets.[facetName].includeInUsedFacets¶

Type

Boolean

TS Path

plugin.tx_solr.search.faceting.facets.[facetName].includeInUsedFacets

Since

2.0

Default

1

Options

0, 1

By setting this option to 0, you can prevent rendering of a given facet within the list of used facets.

faceting.facets.[facetName].type¶

Type

String

TS Path

plugin.tx_solr.search.faceting.facets.[facetName].type

Since

2.0

Defines the type of the facet. By default all facets will render their facet options as a list. PHP Classes can be registered to add new types. Using this setting will allow you to use such a type and then have the facet's options rendered and processed by the registered PHP class.

faceting.facets.[facetName].[type]¶

Type

Array

TS Path

plugin.tx_solr.search.faceting.facets.[facetName].[type]

Since

2.0

When setting a special type for a facet you can set further options for this type using this array.

Example (numericRange facet displayed as a slider):

plugin.tx_solr.search.faceting.facets.size {
     field = size_intS
     label = Size

     type = numericRange
     numericRange {
         start = 0
         end = 100
         gap = 1
    }
}

faceting.facets.[facetName].requirements.[requirementName]¶

Type

Array

TS Path

plugin.tx_solr.search.faceting.facets.[facetName].requirements.[requirementName]

Since

2.2

Allows to define requirements for a facet to be rendered. These requirements are dependencies on values of other facets being selected by the user. You can define multiple requirements for each facet. If multiple requirements are defined, all must be met before the facet is rendered.

Each requirement has a name so you can easily recognize what the requirement is about. The requirement is then defined by the name of another facet and a list of comma-separated values. At least one of the defined values must be selected by the user to meet the requirement.

There are two magic values for the requirement's values definition:

  • __any: will mark the requirement as met if the user selects any of the required facet's options

  • __none: marks the requirement as met if none of the required facet's options is selected. As soon as any of the required facet's options is selected the requirement will not be met and thus the facet will not be rendered

Example of a category facet showing only when the user selects the news type facet option:

plugin.tx_solr {
    search {
        faceting {
            facets {
                type {
                    label = Content Type
                    field = type
                }

                category {
                    label = Category
                    field = category_stringS
                    requirements {
                        typeIsNews {
                          # typeIsNews is the name of the requirement, c
                          # choose any so you can easily  recognize what it does
                          facet = type
                          # The name of the facet as defined above
                          values = news
                          # The value of the type facet option as
                          # it is stored in the Solr index
                        }
                    }
                }
            }
        }
    }
}

faceting.facets.[facetName].renderingInstruction¶

Type

cObject

TS Path

plugin.tx_solr.search.faceting.facets.[facetName].renderingInstruction

Since

1.0

Overwrites how single facet options are rendered using TypoScript cObjects.

Example: (taken from issue #5920)

plugin.tx_solr {
    search {
        faceting {
            facets {
                type {
                    renderingInstruction = CASE
                    renderingInstruction {
                        key.field = optionValue

                        pages = TEXT
                        pages.value = Pages
                        pages.lang.de = Seiten

                        tx_solr_file = TEXT
                        tx_solr_file.value = Files
                        tx_solr_file.lang.de = Dateien

                        tt_news = TEXT
                        tt_news.value = News
                        tt_news.lang.de = Nachrichten
                    }
                }

                language {
                    renderingInstruction = CASE
                    renderingInstruction {
                        key.field = optionValue

                        0 = TEXT
                        0.value = English
                        0.lang.de = Englisch

                        1 = TEXT
                        1.value = German
                        1.lang.de = Deutsch
                    }
                }
            }
        }
    }
}

EXT:solr provides the following renderingInstructions that you can use in your project:

FormatDate:

This rendering instruction can be used in combination with a date field or an integer field that hold a timestamp. You can use this rendering instruction to format the facet value on rendering. A common usecase for this is, when the datatype in solr needs to be sortable (date or int) but you need to render the date as readable date option in the frontend:

plugin.tx_solr.search.faceting.facets {
    created {
        field = created
        label = Created
        sortBy = alpha
        reverseOrder = 1
        renderingInstruction = TEXT
        renderingInstruction {
           field = optionValue
           postUserFunc = ApacheSolrForTypo3\Solr\Domain\Search\ResultSet\Facets\RenderingInstructions\FormatDate->format
        }
    }
}

elevation¶

elevation¶

Type

Boolean

TS Path

plugin.tx_solr.search.elevation

Since

3.0

Default

0

Set plugin.tx_solr.search.elevation = 1 to enable content elevation in search results.

elevation.forceElevation¶

Type

Boolean

TS Path

plugin.tx_solr.search.elevation.forceElevation

Since

3.0

Default

1

Forces content elevation to be active.

elevation.markElevatedResults¶

Type

Boolean

TS Path

plugin.tx_solr.search.elevation.markElevatedResults

Since

3.0

Default

1

If enabled, elevated results are marked with CSS class "results-elevated".

variants¶

By using variants you can shrink down multiple documents with the same value in one field into one document and make similar documents available in the variants property. By default the field variantId is used as Solr collapsing criteria. This can be used e.g. as one approach of deduplication to group similar documents into on "root" SearchResult.

To use the different variants of the documents you can access "document.variants" to access the expanded documents.

This can be used for example for de-duplication to list variants of the same document below a certain document.

Note: Internally this is implemented with Solr field collapsing

Type

Boolean

TS Path

plugin.tx_solr.search.variants

Since

6.0

Default

0

Set plugin.tx_solr.search.variants = 1 to enable the variants in search results.

variants.expand¶

Used to expand the document variants to the document.variants property.

Type

Boolean

TS Path

plugin.tx_solr.search.variants.expand

Since

6.0

Default

1

variants.variantField¶

Used to expand the document variants to the document.variants property.

Note:: The field must be a numeric field or a string field! Not a text field!

Type

String

TS Path

plugin.tx_solr.search.variants.variantField

Since

6.0

Default

variantId

variants.limit¶

Limit of expanded documents.

Though this setting limits the returned variants, you still can get the number of existing variants, it's set in "document.variantsNumFound" (since EXT:solr 10)

Type

Integer

TS Path

plugin.tx_solr.search.variants.limit

Since

6.0

Default

10

  • Previous
  • Next
  • Home
  • Contact
  • Issues
  • Repository

Last updated: Mar 31, 2023 09:46

Last rendered: Mar 31, 2023 12:04

  • TYPO3 Theme 4.7.9
  • DRC v3.0.dev30
© Copyright since 2009 by dkd & contributors
  • Legal Notice
  • Privacy Policy
  • Code of Conduct