Full text search criterion.
The string provided in this criterion is matched as a full text query against all indexed content objects in the storage layer.
Normalization and querying capabilities might depend on the system configuration or the used search engine and might differ. To find about supported querying capabilities you can use SearchService::supports() method.
If supported, advanced full text query has the following semantics:
- If multiple words are specified an OR query is performed.
- Boolean operators are supported: AND (&&), OR (||), NOT (!).
- Required/prohibit operators are supported: +, -.
- Grouping is supported through parentheses.
- Phrases are supported using double quotes.
- Simple wild cards are supported. If an asterisk (*) is used at the end or beginning of a word this is translated into a wild card query. Thus "fo*" would match "foo" and "foobar", for example.
- Advanced language analysis (like stemming, synonym expansion and stop word removal) might be applied to the words provided in the query.
If advanced full text query is not supported, basic query format will be available:
- If multiple words are specified an AND query is performed. OR queries are not supported.
- Simple wild cards are supported. If an asterisk () is used at the end or beginning of a word this is translated into a wild card query. Thus "fo" would match "foo" and "foobar", for example.
- Simple stop word removal might be applied to the words provided in the query.
Properties¶
                 $boost
            ¶
        $boost
            ¶
    
        Boost for certain fields.
|  |  | 
Array of boosts to apply for certain fields – the array should look like this:
 array(
     'title' => 2,
     …
 )
    
                 $fuzziness
            ¶
        $fuzziness
            ¶
    
        Fuzziness of the fulltext search.
|  |  | 
Value between 0. (fuzzy) and 1. (sharp).
                 $operator
            ¶
        $operator
            ¶
    
        The operator used by the Criterion.
|  |  | 
                 $target
            ¶
        $target
            ¶
    
        The target used by the criteria (field, metadata...).
|  |  | 
                 $value
            ¶
        $value
            ¶
    
        The value(s) matched by the criteria.
|  |  | 
                 $valueData
            ¶
        $valueData
            ¶
    
        Additional value data, required by some criteria, MapLocationDistance for instance.
|  |  | 
                 $customFields
            ¶
        $customFields
            ¶
    
        Custom field definitions to query instead of default field.
|  |  | 
Methods¶
                 __construct()
            ¶
__construct()
            ¶
    
        Creates a Criterion.
|  |  | 
Parameters
| Name | Type | Default value | Description | 
|---|---|---|---|
| $value | string|null | - | - | 
| $properties | array<string|int, mixed> | [] | - | 
                 getCustomField()
            ¶
getCustomField()
            ¶
    
        Return custom field.
|  |  | 
If no custom field is set, return null
Parameters
| Name | Type | Default value | Description | 
|---|---|---|---|
| $type | string | - | - | 
| $field | string | - | - | 
Return values
string|null
                 getSpecifications()
            ¶
getSpecifications()
            ¶
    
        Criterion description function.
|  |  | 
Returns the combination of the Criterion's supported operator/value, as an array of Specifications objects
- Specifications::$operator is a supported Operator constant.
- Specifications::$valueFormat is the type of input value this operator requires, either array (Specifications::FORMAT_ARRAY) or single (Specifications::FORMAT_SINGLE).
- Specifications::$valueTypes are bitwise flags of types the operator will accept (Specifications::TYPE_BOOLEAN, Specifications::TYPE_INTEGER, and/or Specifications::TYPE_STRING).
- Specifications::$valueCount is an integer saying how many values are expected.
// IN and EQ are supported
return [
    // The EQ operator expects a single value, either as an integer or a string
    new Specifications(
        Operator::EQ,
        Specifications::FORMAT_SINGLE,
        Specifications::TYPE_INTEGER | Specifications::TYPE_STRING
    ),
    // The IN operator expects an array of values, of either integers or strings
    new Specifications(
        Operator::IN,
        Specifications::FORMAT_ARRAY,
        Specifications::TYPE_INTEGER | Specifications::TYPE_STRING
    )
]
Return values
array<int, Specifications>
                 setCustomField()
            ¶
setCustomField()
            ¶
    
        Set a custom field to query.
|  |  | 
Set a custom field to query for a defined field in a defined type.
Parameters
| Name | Type | Default value | Description | 
|---|---|---|---|
| $type | string | - | - | 
| $field | string | - | - | 
| $customField | string | - | - |