- Resource: Control
- Methods
Resource: Control
Defines a conditioned behavior to employ during serving. Must be attached to a ServingConfig to be considered at serving time. Permitted actions dependent on SolutionType.
| JSON representation | 
|---|
| { "name": string, "displayName": string, "associatedServingConfigIds": [ string ], "solutionType": enum ( | 
| Fields | |
|---|---|
| name | 
 Immutable. Fully qualified name  | 
| displayName | 
 Required. Human readable name. The identifier used in UI views. Must be UTF-8 encoded string. Length limit is 128 characters. Otherwise an INVALID ARGUMENT error is thrown. | 
| associatedServingConfigIds[] | 
 Output only. List of all  | 
| solutionType | 
 Required. Immutable. What solution the control belongs to. Must be compatible with vertical of resource. Otherwise an INVALID ARGUMENT error is thrown. | 
| useCases[] | 
 Specifies the use case for the control. Affects what condition fields can be set. Only applies to  | 
| conditions[] | 
 Determines when the associated action will trigger. Omit to always apply the action. Currently only a single condition may be specified. Otherwise an INVALID ARGUMENT error is thrown. | 
| Union field  Required.  | |
| boostAction | 
 Defines a boost-type control | 
| filterAction | 
 Defines a filter-type control Currently not supported by Recommendation | 
| redirectAction | 
 Defines a redirect-type control. | 
| synonymsAction | 
 Treats a group of terms as synonyms of one another. | 
| promoteAction | 
 Promote certain links based on predefined trigger queries. | 
BoostAction
Adjusts order of products in returned list.
| JSON representation | 
|---|
| { "boost": number, "filter": string, "dataStore": string, // Union field | 
| Fields | |
|---|---|
| boost | 
 Strength of the boost, which should be in [-1, 1]. Negative boost means demotion. Default is 0.0 (No-op). | 
| filter | 
 Required. Specifies which products to apply the boost to. If no filter is provided all products will be boosted (No-op). Syntax documentation: https://cloud.google.com/retail/docs/filter-and-order Maximum length is 5000 characters. Otherwise an INVALID ARGUMENT error is thrown. | 
| dataStore | 
 Required. Specifies which data store's documents can be boosted by this control. Full data store name e.g. projects/123/locations/global/collections/default_collection/dataStores/default_data_store | 
| Union field boost_spec. Constant value boost or custom ranking based boost specifications.boost_speccan be only one of the following: | |
| fixedBoost | 
 Optional. Strength of the boost, which should be in [-1, 1]. Negative boost means demotion. Default is 0.0 (No-op). | 
| interpolationBoostSpec | 
 Optional. Complex specification for custom ranking based on customer defined attribute value. | 
InterpolationBoostSpec
Specification for custom ranking based on customer specified attribute value. It provides more controls for customized ranking than the simple (condition, boost) combination above.
| JSON representation | 
|---|
| { "fieldName": string, "attributeType": enum ( | 
| Fields | |
|---|---|
| fieldName | 
 Optional. The name of the field whose value will be used to determine the boost amount. | 
| attributeType | 
 Optional. The attribute type to be used to determine the boost amount. The attribute value can be derived from the field value of the specified fieldName. In the case of numerical it is straightforward i.e. attributeValue = numerical_field_value. In the case of freshness however, attributeValue = (time.now() - datetime_field_value). | 
| interpolationType | 
 Optional. The interpolation type to be applied to connect the control points listed below. | 
| controlPoints[] | 
 Optional. The control points used to define the curve. The monotonic function (defined through the interpolationType above) passes through the control points listed here. | 
AttributeType
The attribute(or function) for which the custom ranking is to be applied.
| Enums | |
|---|---|
| ATTRIBUTE_TYPE_UNSPECIFIED | Unspecified AttributeType. | 
| NUMERICAL | The value of the numerical field will be used to dynamically update the boost amount. In this case, the attributeValue (the x value) of the control point will be the actual value of the numerical field for which the boostAmount is specified. | 
| FRESHNESS | For the freshness use case the attribute value will be the duration between the current time and the date in the datetime field specified. The value must be formatted as an XSD dayTimeDurationvalue (a restricted subset of an ISO 8601 duration value). The pattern for this is:[nD][T[nH][nM][nS]]. For example,5D,3DT12H30M,T24H. | 
InterpolationType
The interpolation type to be applied. Default will be linear (Piecewise Linear).
| Enums | |
|---|---|
| INTERPOLATION_TYPE_UNSPECIFIED | Interpolation type is unspecified. In this case, it defaults to Linear. | 
| LINEAR | Piecewise linear interpolation will be applied. | 
ControlPoint
The control points used to define the curve. The curve defined through these control points can only be monotonically increasing or decreasing(constant values are acceptable).
| JSON representation | 
|---|
| { "attributeValue": string, "boostAmount": number } | 
| Fields | |
|---|---|
| attributeValue | 
 Optional. Can be one of: 1. The numerical field value. 2. The duration spec for freshness: The value must be formatted as an XSD  | 
| boostAmount | 
 Optional. The value between -1 to 1 by which to boost the score if the attributeValue evaluates to the value specified above. | 
FilterAction
Specified which products may be included in results. Uses same filter as boost.
| JSON representation | 
|---|
| { "filter": string, "dataStore": string } | 
| Fields | |
|---|---|
| filter | 
 Required. A filter to apply on the matching condition results. Required Syntax documentation: https://cloud.google.com/retail/docs/filter-and-order Maximum length is 5000 characters. Otherwise an INVALID ARGUMENT error is thrown. | 
| dataStore | 
 Required. Specifies which data store's documents can be filtered by this control. Full data store name e.g. projects/123/locations/global/collections/default_collection/dataStores/default_data_store | 
RedirectAction
Redirects a shopper to the provided URI.
| JSON representation | 
|---|
| { "redirectUri": string } | 
| Fields | |
|---|---|
| redirectUri | 
 Required. The URI to which the shopper will be redirected. Required. URI must have length equal or less than 2000 characters. Otherwise an INVALID ARGUMENT error is thrown. | 
SynonymsAction
Creates a set of terms that will act as synonyms of one another.
Example: "happy" will also be considered as "glad", "glad" will also be considered as "happy".
| JSON representation | 
|---|
| { "synonyms": [ string ] } | 
| Fields | |
|---|---|
| synonyms[] | 
 Defines a set of synonyms. Can specify up to 100 synonyms. Must specify at least 2 synonyms. Otherwise an INVALID ARGUMENT error is thrown. | 
PromoteAction
Promote certain links based on some trigger queries.
Example: Promote shoe store link when searching for shoe keyword. The link can be outside of associated data store.
| JSON representation | 
|---|
| {
  "dataStore": string,
  "searchLinkPromotion": {
    object ( | 
| Fields | |
|---|---|
| dataStore | 
 Required. Data store with which this promotion is attached to. | 
| searchLinkPromotion | 
 Required. Promotion attached to this action. | 
SearchLinkPromotion
Promotion proto includes uri and other helping information to display the promotion.
| JSON representation | 
|---|
| { "title": string, "uri": string, "document": string, "imageUri": string, "description": string, "enabled": boolean } | 
| Fields | |
|---|---|
| title | 
 Required. The title of the promotion. Maximum length: 160 characters. | 
| uri | 
 Optional. The URL for the page the user wants to promote. Must be set for site search. For other verticals, this is optional. | 
| document | 
 Optional. The  | 
| imageUri | 
 Optional. The promotion thumbnail image url. | 
| description | 
 Optional. The Promotion description. Maximum length: 200 characters. | 
| enabled | 
 Optional. The enabled promotion will be returned for any serving configs associated with the parent of the control this promotion is attached to. This flag is used for basic site search only. | 
SearchUseCase
Defines a further subdivision of SolutionType. Specifically applies to SOLUTION_TYPE_SEARCH.
| Enums | |
|---|---|
| SEARCH_USE_CASE_UNSPECIFIED | Value used when unset. Will not occur in CSS. | 
| SEARCH_USE_CASE_SEARCH | Search use case. Expects the traffic has a non-empty query. | 
| SEARCH_USE_CASE_BROWSE | Browse use case. Expects the traffic has an empty query. | 
Condition
Defines circumstances to be checked before allowing a behavior
| JSON representation | 
|---|
| { "queryTerms": [ { object ( | 
| Fields | |
|---|---|
| queryTerms[] | 
 Search only A list of terms to match the query on. Cannot be set when  Maximum of 10 query terms. | 
| activeTimeRange[] | 
 Range of time(s) specifying when condition is active. Maximum of 10 time ranges. | 
| queryRegex | 
 Optional. Query regex to match the whole search query. Cannot be set when  | 
QueryTerm
Matcher for search request query
| JSON representation | 
|---|
| { "value": string, "fullMatch": boolean } | 
| Fields | |
|---|---|
| value | 
 The specific query value to match against Must be lowercase, must be UTF-8. Can have at most 3 space separated terms if fullMatch is true. Cannot be an empty string. Maximum length of 5000 characters. | 
| fullMatch | 
 Whether the search query needs to exactly match the query term. | 
TimeRange
Used for time-dependent conditions.
| JSON representation | 
|---|
| { "startTime": string, "endTime": string } | 
| Fields | |
|---|---|
| startTime | 
 Start of time range. Range is inclusive. Uses RFC 3339, where generated output will always be Z-normalized and use 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples:  | 
| endTime | 
 End of time range. Range is inclusive. Must be in the future. Uses RFC 3339, where generated output will always be Z-normalized and use 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples:  | 
| Methods | |
|---|---|
| 
 | Creates a Control. | 
| 
 | Deletes a Control. | 
| 
 | Gets a Control. | 
| 
 | Lists all Controls by their parent DataStore. | 
| 
 | Updates a Control. |