2016-12-15 17:59:13 +01:00
.. highlight :: typoscript
.. _configuration:
Configuration
=============
The extension offers the following configuration options through TypoScript. If you overwrite them
through `setup` make sure to keep them in the `module` area as they will be accessed from backend
mode of TYPO3. Do so by placing the following line at the end::
module.tx_searchcore < plugin.tx_searchcore
.. todo ::
We will use references inside the extension to make the above unnecessary in the future.
2016-12-16 12:55:23 +01:00
The structure is following TYPO3 Extbase conventions. All settings are placed inside of::
2016-12-15 17:59:13 +01:00
plugin.tx_searchcore.settings
2017-01-26 14:37:17 +01:00
Here is the example default configuration that's provided through static include:
.. literalinclude :: ../../Configuration/TypoScript/constants.txt
:language: typoscript
:linenos:
:caption: Static TypoScript Constants
2016-12-15 17:59:13 +01:00
.. literalinclude :: ../../Configuration/TypoScript/setup.txt
:language: typoscript
:linenos:
:caption: Static TypoScript Setup
.. _configuration_options:
Options
-------
2016-12-20 10:04:44 +01:00
The following section contains the different options, e.g. for :ref: `connections` and
:ref:`indexer`: ``plugin.tx_searchcore.settings.connection`` or
2017-06-27 16:51:33 +02:00
`` plugin.tx_searchcore.settings.indexing `` .
2016-12-16 12:55:23 +01:00
2016-12-15 17:59:13 +01:00
.. _configuration_options_connection:
2016-12-20 10:04:44 +01:00
connections
^^^^^^^^^^^
2016-12-15 17:59:13 +01:00
2016-12-20 10:04:44 +01:00
Holds settings regarding the different possible connections for search services like Elasticsearch
or Solr.
2016-12-15 17:59:13 +01:00
Configured as::
plugin {
tx_searchcore {
settings {
2016-12-20 10:04:44 +01:00
connections {
connectionName {
// the settings
}
2016-12-15 17:59:13 +01:00
}
}
}
}
2016-12-20 10:04:44 +01:00
Where `` connectionName `` is one of the available :ref: `connections` .
The following settings are available. For each setting its documented which connection consumes it.
2016-12-15 17:59:13 +01:00
.. _host:
`` host ``
""""""""
Used by: :ref: `Elasticsearch` .
2016-12-16 12:55:23 +01:00
The host, e.g. `` localhost `` or an IP where the search service is reachable from TYPO3
2016-12-15 17:59:13 +01:00
installation.
Example::
2016-12-20 10:04:44 +01:00
plugin.tx_searchcore.settings.connections.elasticsearch.host = localhost
2016-12-15 17:59:13 +01:00
.. _port:
`` port ``
""""""""
Used by: :ref: `Elasticsearch` .
2016-12-16 12:55:23 +01:00
The port where search service is reachable. E.g. default `` 9200 `` for Elasticsearch.
2016-12-15 17:59:13 +01:00
Example::
2016-12-20 10:04:44 +01:00
plugin.tx_searchcore.settings.connections.elasticsearch.port = 9200
2016-12-15 17:59:13 +01:00
.. _configuration_options_index:
2017-07-06 16:17:30 +02:00
Indexing
^^^^^^^^
2016-12-15 17:59:13 +01:00
2016-12-20 10:04:44 +01:00
Holds settings regarding the indexing, e.g. of TYPO3 records, to search services.
2016-12-15 17:59:13 +01:00
Configured as::
plugin {
tx_searchcore {
settings {
2017-06-27 16:51:33 +02:00
indexing {
identifier {
2017-07-06 16:17:30 +02:00
indexer = FullyQualifiedClassname
2016-12-20 10:04:44 +01:00
// the settings
}
2016-12-15 17:59:13 +01:00
}
}
}
}
2017-06-27 16:51:33 +02:00
Where `` identifier `` is up to you, but should match table names to make :ref: `TcaIndexer` work.
2016-12-20 10:04:44 +01:00
The following settings are available. For each setting its documented which indexer consumes it.
2016-12-15 17:59:13 +01:00
.. _rootLineBlacklist:
`` rootLineBlacklist ``
"""""""""""""""""""""
2017-07-13 13:58:16 +02:00
Used by: :ref: `TcaIndexer` , :ref: `PagesIndexer` .
2016-12-15 17:59:13 +01:00
Defines a blacklist of page uids. Records below any of these pages, or subpages, are not
indexed. This allows you to define areas that should not be indexed.
The page attribute *No Search* is also taken into account to prevent indexing records from only one
page without recursion.
2017-01-26 14:37:17 +01:00
Contains a comma separated list of page uids. Spaces are trimmed.
2016-12-15 17:59:13 +01:00
Example::
2017-06-27 16:51:33 +02:00
plugin.tx_searchcore.settings.indexing.<identifier>.rootLineBlacklist = 3, 10, 100
2016-12-15 17:59:13 +01:00
Also it's possible to define some behaviour for the different document types. In context of TYPO3
tables are used as document types 1:1. It's possible to configure different tables. The following
options are available:
.. _additionalWhereClause:
`` additionalWhereClause ``
"""""""""""""""""""""""""
2017-07-13 13:58:16 +02:00
Used by: :ref: `TcaIndexer` , :ref: `PagesIndexer` .
2016-12-15 17:59:13 +01:00
Add additional SQL to where clauses to determine indexable records from the table. This way you
can exclude specific records like `` tt_content `` records with specific `` CType `` values or
something else. E.g. you can add a new field to the table to exclude records from indexing.
Example::
2017-06-27 16:51:33 +02:00
plugin.tx_searchcore.settings.indexing.<identifier>.additionalWhereClause = tt_content.CType NOT IN ('gridelements_pi1', 'list', 'div', 'menu')
2016-12-15 17:59:13 +01:00
.. attention ::
Make sure to prefix all fields with the corresponding table name. The selection from
database will contain joins and can lead to SQL errors if a field exists in multiple tables.
2017-07-06 16:17:30 +02:00
2017-07-13 13:58:16 +02:00
.. _abstractFields:
`` abstractFields ``
"""""""""""""""""""""""""
Used by: :ref: `PagesIndexer` .
Define which field should be used to provide the auto generated field "search_abstract".
The fields have to exist in the record to be indexed. Therefore fields like `` content `` are also
possible.
Example::
# As last fallback we use the content of the page
plugin.tx_searchcore.settings.indexing.<identifier>.abstractFields := addToList(content)
Default::
abstract, description, bodytext
2017-07-06 16:17:30 +02:00
.. _mapping:
`` mapping ``
"""""""""""
Used by: Elasticsearch connection while indexing.
Define mapping for Elasticsearch, have a look at the official docs: https://www.elastic.co/guide/en/elasticsearch/reference/5.2/mapping.html
You are able to define the mapping for each property / columns.
Example::
plugin.tx_searchcore.settings.indexing.tt_content.mapping {
CType {
type = keyword
}
}
The above example will define the `` CType `` field of `` tt_content `` as `` type: keyword `` . This
makes building a facet possible.
2017-07-25 09:52:17 +02:00
.. _index:
`` index ``
"""""""""
Used by: Elasticsearch connection while indexing.
Define index for Elasticsearch, have a look at the official docs: https://www.elastic.co/guide/en/elasticsearch/reference/5.2/indices-create-index.html
Example::
plugin.tx_searchcore.settings.indexing.tt_content.index {
analysis {
analyzer {
ngram4 {
type = custom
tokenizer = ngram4
2017-07-25 15:00:25 +02:00
char_filter = html_strip
filter = lowercase, asciifolding
2017-07-25 09:52:17 +02:00
}
}
tokenizer {
ngram4 {
type = ngram
min_gram = 4
max_gram = 4
}
}
}
}
2017-07-25 15:00:25 +02:00
`` char_filter `` and `` filter `` are a comma separated list of options.
2017-07-06 16:17:30 +02:00
.. _configuration_options_search:
Searching
^^^^^^^^^
2017-07-18 10:44:39 +02:00
.. _size:
`` size ``
""""""""
Used by: Elasticsearch connection while building search query.
Defined how many search results should be fetched to be available in search result.
Example::
plugin.tx_searchcore.settings.searching.size = 50
Default if not configured is 10.
2017-07-06 16:17:30 +02:00
.. _facets:
`` facets ``
"""""""""""
Used by: Elasticsearch connection while building search query.
Define aggregations for Elasticsearch, have a look at the official docs: https://www.elastic.co/guide/en/elasticsearch/reference/5.2/search-aggregations-bucket-terms-aggregation.html
Currently only the term facet is provided.
Example::
plugin.tx_searchcore.settings.searching.facets {
contentTypes {
field = CType
}
}
The above example will provide a facet with options for all found `` CType `` results together
with a count.
2017-07-25 09:52:17 +02:00
2017-09-15 21:35:52 +02:00
.. _filter:
`` filter ``
"""""""""""
Used by: While building search request.
Define filter that should be set for all requests.
Example::
plugin.tx_searchcore.settings.searching.filter {
property = value
}
For Elasticsearch the fields have to be filterable, e.g. need a mapping as `` keyword `` .
2017-07-25 09:52:17 +02:00
.. _minimumShouldMatch:
`` minimumShouldMatch ``
""""""""""""""""""""""
Used by: Elasticsearch connection while building search query.
Define the minimum match for Elasticsearch, have a look at the official docs: https://www.elastic.co/guide/en/elasticsearch/reference/5.2/query-dsl-minimum-should-match.html
Example::
plugin.tx_searchcore.settings.searching.minimumShouldMatch = 50%
2017-07-27 14:48:43 +02:00
2017-07-25 15:38:40 +02:00
.. _boost:
`` boost ``
"""""""""
Used by: Elasticsearch connection while building search query.
Define fields that should boost the score for results.
Example::
plugin.tx_searchcore.settings.searching.boost {
search_title = 3
search_abstract = 1.5
}
For further information take a look at
https://www.elastic.co/guide/en/elasticsearch/guide/2.x/_boosting_query_clauses.html
2017-07-27 14:20:37 +02:00
.. _fieldValueFactor:
`` fieldValueFactor ``
""""""""""""""""""""
Used by: Elasticsearch connection while building search query.
Define a field to use as a factor for scoring. The configuration is passed through to elastic
search `` field_value_factor `` , see: https://www.elastic.co/guide/en/elasticsearch/reference/5.2/query-dsl-function-score-query.html#function-field-value-factor
Example::
plugin.tx_searchcore.settings.searching.field_value_factor {
field = rootlineLevel
modifier = reciprocal
factor = 2
missing = 1
}
2017-09-15 22:26:52 +02:00
.. _mode:
`` mode ``
""""""""
Used by: Controller while preparing action.
Define to switch from search to filter mode.
Example::
plugin.tx_searchcore.settings.searching {
mode = filter
}
Only `` filter `` is allowed as value. Will submit an empty query to switch to filter mode.