google-cloud-retail-v2 0.10.0 → 0.12.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (61) hide show
  1. checksums.yaml +4 -4
  2. data/AUTHENTICATION.md +1 -1
  3. data/README.md +1 -1
  4. data/lib/google/cloud/retail/v2/catalog_pb.rb +69 -0
  5. data/lib/google/cloud/retail/v2/catalog_service/client.rb +718 -0
  6. data/lib/google/cloud/retail/v2/catalog_service/paths.rb +38 -0
  7. data/lib/google/cloud/retail/v2/catalog_service.rb +1 -1
  8. data/lib/google/cloud/retail/v2/catalog_service_pb.rb +34 -0
  9. data/lib/google/cloud/retail/v2/catalog_service_services_pb.rb +38 -0
  10. data/lib/google/cloud/retail/v2/common_pb.rb +86 -0
  11. data/lib/google/cloud/retail/v2/completion_service/client.rb +11 -8
  12. data/lib/google/cloud/retail/v2/completion_service.rb +2 -2
  13. data/lib/google/cloud/retail/v2/completion_service_services_pb.rb +3 -3
  14. data/lib/google/cloud/retail/v2/control_pb.rb +33 -0
  15. data/lib/google/cloud/retail/v2/control_service/client.rb +807 -0
  16. data/lib/google/cloud/retail/v2/control_service/credentials.rb +51 -0
  17. data/lib/google/cloud/retail/v2/control_service/paths.rb +73 -0
  18. data/lib/google/cloud/retail/v2/control_service.rb +49 -0
  19. data/lib/google/cloud/retail/v2/control_service_pb.rb +57 -0
  20. data/lib/google/cloud/retail/v2/control_service_services_pb.rb +65 -0
  21. data/lib/google/cloud/retail/v2/prediction_service/client.rb +7 -8
  22. data/lib/google/cloud/retail/v2/prediction_service.rb +1 -1
  23. data/lib/google/cloud/retail/v2/product_pb.rb +1 -0
  24. data/lib/google/cloud/retail/v2/product_service/client.rb +65 -25
  25. data/lib/google/cloud/retail/v2/product_service.rb +1 -1
  26. data/lib/google/cloud/retail/v2/product_service_services_pb.rb +58 -13
  27. data/lib/google/cloud/retail/v2/search_service/client.rb +16 -5
  28. data/lib/google/cloud/retail/v2/search_service.rb +2 -2
  29. data/lib/google/cloud/retail/v2/search_service_pb.rb +1 -0
  30. data/lib/google/cloud/retail/v2/search_service_services_pb.rb +2 -2
  31. data/lib/google/cloud/retail/v2/serving_config_pb.rb +51 -0
  32. data/lib/google/cloud/retail/v2/serving_config_service/client.rb +998 -0
  33. data/lib/google/cloud/retail/v2/serving_config_service/credentials.rb +51 -0
  34. data/lib/google/cloud/retail/v2/serving_config_service/paths.rb +73 -0
  35. data/lib/google/cloud/retail/v2/serving_config_service.rb +49 -0
  36. data/lib/google/cloud/retail/v2/serving_config_service_pb.rb +66 -0
  37. data/lib/google/cloud/retail/v2/serving_config_service_services_pb.rb +74 -0
  38. data/lib/google/cloud/retail/v2/user_event_service/client.rb +27 -14
  39. data/lib/google/cloud/retail/v2/user_event_service.rb +1 -1
  40. data/lib/google/cloud/retail/v2/user_event_service_pb.rb +5 -0
  41. data/lib/google/cloud/retail/v2/user_event_service_services_pb.rb +10 -10
  42. data/lib/google/cloud/retail/v2/version.rb +1 -1
  43. data/lib/google/cloud/retail/v2.rb +4 -2
  44. data/proto_docs/google/api/client.rb +318 -0
  45. data/proto_docs/google/api/launch_stage.rb +71 -0
  46. data/proto_docs/google/cloud/retail/v2/catalog.rb +271 -0
  47. data/proto_docs/google/cloud/retail/v2/catalog_service.rb +133 -0
  48. data/proto_docs/google/cloud/retail/v2/common.rb +316 -4
  49. data/proto_docs/google/cloud/retail/v2/completion_service.rb +6 -3
  50. data/proto_docs/google/cloud/retail/v2/control.rb +75 -0
  51. data/proto_docs/google/cloud/retail/v2/control_service.rb +122 -0
  52. data/proto_docs/google/cloud/retail/v2/import_config.rb +20 -35
  53. data/proto_docs/google/cloud/retail/v2/prediction_service.rb +7 -8
  54. data/proto_docs/google/cloud/retail/v2/product.rb +33 -5
  55. data/proto_docs/google/cloud/retail/v2/search_service.rb +44 -10
  56. data/proto_docs/google/cloud/retail/v2/serving_config.rb +255 -0
  57. data/proto_docs/google/cloud/retail/v2/serving_config_service.rb +143 -0
  58. data/proto_docs/google/cloud/retail/v2/user_event.rb +1 -1
  59. data/proto_docs/google/cloud/retail/v2/user_event_service.rb +24 -8
  60. data/proto_docs/google/rpc/status.rb +4 -2
  61. metadata +24 -4
@@ -0,0 +1,318 @@
1
+ # frozen_string_literal: true
2
+
3
+ # Copyright 2022 Google LLC
4
+ #
5
+ # Licensed under the Apache License, Version 2.0 (the "License");
6
+ # you may not use this file except in compliance with the License.
7
+ # You may obtain a copy of the License at
8
+ #
9
+ # https://www.apache.org/licenses/LICENSE-2.0
10
+ #
11
+ # Unless required by applicable law or agreed to in writing, software
12
+ # distributed under the License is distributed on an "AS IS" BASIS,
13
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ # See the License for the specific language governing permissions and
15
+ # limitations under the License.
16
+
17
+ # Auto-generated by gapic-generator-ruby. DO NOT EDIT!
18
+
19
+
20
+ module Google
21
+ module Api
22
+ # Required information for every language.
23
+ # @!attribute [rw] reference_docs_uri
24
+ # @return [::String]
25
+ # Link to automatically generated reference documentation. Example:
26
+ # https://cloud.google.com/nodejs/docs/reference/asset/latest
27
+ # @!attribute [rw] destinations
28
+ # @return [::Array<::Google::Api::ClientLibraryDestination>]
29
+ # The destination where API teams want this client library to be published.
30
+ class CommonLanguageSettings
31
+ include ::Google::Protobuf::MessageExts
32
+ extend ::Google::Protobuf::MessageExts::ClassMethods
33
+ end
34
+
35
+ # Details about how and where to publish client libraries.
36
+ # @!attribute [rw] version
37
+ # @return [::String]
38
+ # Version of the API to apply these settings to.
39
+ # @!attribute [rw] launch_stage
40
+ # @return [::Google::Api::LaunchStage]
41
+ # Launch stage of this version of the API.
42
+ # @!attribute [rw] rest_numeric_enums
43
+ # @return [::Boolean]
44
+ # When using transport=rest, the client request will encode enums as
45
+ # numbers rather than strings.
46
+ # @!attribute [rw] java_settings
47
+ # @return [::Google::Api::JavaSettings]
48
+ # Settings for legacy Java features, supported in the Service YAML.
49
+ # @!attribute [rw] cpp_settings
50
+ # @return [::Google::Api::CppSettings]
51
+ # Settings for C++ client libraries.
52
+ # @!attribute [rw] php_settings
53
+ # @return [::Google::Api::PhpSettings]
54
+ # Settings for PHP client libraries.
55
+ # @!attribute [rw] python_settings
56
+ # @return [::Google::Api::PythonSettings]
57
+ # Settings for Python client libraries.
58
+ # @!attribute [rw] node_settings
59
+ # @return [::Google::Api::NodeSettings]
60
+ # Settings for Node client libraries.
61
+ # @!attribute [rw] dotnet_settings
62
+ # @return [::Google::Api::DotnetSettings]
63
+ # Settings for .NET client libraries.
64
+ # @!attribute [rw] ruby_settings
65
+ # @return [::Google::Api::RubySettings]
66
+ # Settings for Ruby client libraries.
67
+ # @!attribute [rw] go_settings
68
+ # @return [::Google::Api::GoSettings]
69
+ # Settings for Go client libraries.
70
+ class ClientLibrarySettings
71
+ include ::Google::Protobuf::MessageExts
72
+ extend ::Google::Protobuf::MessageExts::ClassMethods
73
+ end
74
+
75
+ # This message configures the settings for publishing [Google Cloud Client
76
+ # libraries](https://cloud.google.com/apis/docs/cloud-client-libraries)
77
+ # generated from the service config.
78
+ # @!attribute [rw] method_settings
79
+ # @return [::Array<::Google::Api::MethodSettings>]
80
+ # A list of API method settings, e.g. the behavior for methods that use the
81
+ # long-running operation pattern.
82
+ # @!attribute [rw] new_issue_uri
83
+ # @return [::String]
84
+ # Link to a place that API users can report issues. Example:
85
+ # https://issuetracker.google.com/issues/new?component=190865&template=1161103
86
+ # @!attribute [rw] documentation_uri
87
+ # @return [::String]
88
+ # Link to product home page. Example:
89
+ # https://cloud.google.com/asset-inventory/docs/overview
90
+ # @!attribute [rw] api_short_name
91
+ # @return [::String]
92
+ # Used as a tracking tag when collecting data about the APIs developer
93
+ # relations artifacts like docs, packages delivered to package managers,
94
+ # etc. Example: "speech".
95
+ # @!attribute [rw] github_label
96
+ # @return [::String]
97
+ # GitHub label to apply to issues and pull requests opened for this API.
98
+ # @!attribute [rw] codeowner_github_teams
99
+ # @return [::Array<::String>]
100
+ # GitHub teams to be added to CODEOWNERS in the directory in GitHub
101
+ # containing source code for the client libraries for this API.
102
+ # @!attribute [rw] doc_tag_prefix
103
+ # @return [::String]
104
+ # A prefix used in sample code when demarking regions to be included in
105
+ # documentation.
106
+ # @!attribute [rw] organization
107
+ # @return [::Google::Api::ClientLibraryOrganization]
108
+ # For whom the client library is being published.
109
+ # @!attribute [rw] library_settings
110
+ # @return [::Array<::Google::Api::ClientLibrarySettings>]
111
+ # Client library settings. If the same version string appears multiple
112
+ # times in this list, then the last one wins. Settings from earlier
113
+ # settings with the same version string are discarded.
114
+ class Publishing
115
+ include ::Google::Protobuf::MessageExts
116
+ extend ::Google::Protobuf::MessageExts::ClassMethods
117
+ end
118
+
119
+ # Settings for Java client libraries.
120
+ # @!attribute [rw] library_package
121
+ # @return [::String]
122
+ # The package name to use in Java. Clobbers the java_package option
123
+ # set in the protobuf. This should be used **only** by APIs
124
+ # who have already set the language_settings.java.package_name" field
125
+ # in gapic.yaml. API teams should use the protobuf java_package option
126
+ # where possible.
127
+ #
128
+ # Example of a YAML configuration::
129
+ #
130
+ # publishing:
131
+ # java_settings:
132
+ # library_package: com.google.cloud.pubsub.v1
133
+ # @!attribute [rw] service_class_names
134
+ # @return [::Google::Protobuf::Map{::String => ::String}]
135
+ # Configure the Java class name to use instead of the service's for its
136
+ # corresponding generated GAPIC client. Keys are fully-qualified
137
+ # service names as they appear in the protobuf (including the full
138
+ # the language_settings.java.interface_names" field in gapic.yaml. API
139
+ # teams should otherwise use the service name as it appears in the
140
+ # protobuf.
141
+ #
142
+ # Example of a YAML configuration::
143
+ #
144
+ # publishing:
145
+ # java_settings:
146
+ # service_class_names:
147
+ # - google.pubsub.v1.Publisher: TopicAdmin
148
+ # - google.pubsub.v1.Subscriber: SubscriptionAdmin
149
+ # @!attribute [rw] common
150
+ # @return [::Google::Api::CommonLanguageSettings]
151
+ # Some settings.
152
+ class JavaSettings
153
+ include ::Google::Protobuf::MessageExts
154
+ extend ::Google::Protobuf::MessageExts::ClassMethods
155
+
156
+ # @!attribute [rw] key
157
+ # @return [::String]
158
+ # @!attribute [rw] value
159
+ # @return [::String]
160
+ class ServiceClassNamesEntry
161
+ include ::Google::Protobuf::MessageExts
162
+ extend ::Google::Protobuf::MessageExts::ClassMethods
163
+ end
164
+ end
165
+
166
+ # Settings for C++ client libraries.
167
+ # @!attribute [rw] common
168
+ # @return [::Google::Api::CommonLanguageSettings]
169
+ # Some settings.
170
+ class CppSettings
171
+ include ::Google::Protobuf::MessageExts
172
+ extend ::Google::Protobuf::MessageExts::ClassMethods
173
+ end
174
+
175
+ # Settings for Php client libraries.
176
+ # @!attribute [rw] common
177
+ # @return [::Google::Api::CommonLanguageSettings]
178
+ # Some settings.
179
+ class PhpSettings
180
+ include ::Google::Protobuf::MessageExts
181
+ extend ::Google::Protobuf::MessageExts::ClassMethods
182
+ end
183
+
184
+ # Settings for Python client libraries.
185
+ # @!attribute [rw] common
186
+ # @return [::Google::Api::CommonLanguageSettings]
187
+ # Some settings.
188
+ class PythonSettings
189
+ include ::Google::Protobuf::MessageExts
190
+ extend ::Google::Protobuf::MessageExts::ClassMethods
191
+ end
192
+
193
+ # Settings for Node client libraries.
194
+ # @!attribute [rw] common
195
+ # @return [::Google::Api::CommonLanguageSettings]
196
+ # Some settings.
197
+ class NodeSettings
198
+ include ::Google::Protobuf::MessageExts
199
+ extend ::Google::Protobuf::MessageExts::ClassMethods
200
+ end
201
+
202
+ # Settings for Dotnet client libraries.
203
+ # @!attribute [rw] common
204
+ # @return [::Google::Api::CommonLanguageSettings]
205
+ # Some settings.
206
+ class DotnetSettings
207
+ include ::Google::Protobuf::MessageExts
208
+ extend ::Google::Protobuf::MessageExts::ClassMethods
209
+ end
210
+
211
+ # Settings for Ruby client libraries.
212
+ # @!attribute [rw] common
213
+ # @return [::Google::Api::CommonLanguageSettings]
214
+ # Some settings.
215
+ class RubySettings
216
+ include ::Google::Protobuf::MessageExts
217
+ extend ::Google::Protobuf::MessageExts::ClassMethods
218
+ end
219
+
220
+ # Settings for Go client libraries.
221
+ # @!attribute [rw] common
222
+ # @return [::Google::Api::CommonLanguageSettings]
223
+ # Some settings.
224
+ class GoSettings
225
+ include ::Google::Protobuf::MessageExts
226
+ extend ::Google::Protobuf::MessageExts::ClassMethods
227
+ end
228
+
229
+ # Describes the generator configuration for a method.
230
+ # @!attribute [rw] selector
231
+ # @return [::String]
232
+ # The fully qualified name of the method, for which the options below apply.
233
+ # This is used to find the method to apply the options.
234
+ # @!attribute [rw] long_running
235
+ # @return [::Google::Api::MethodSettings::LongRunning]
236
+ # Describes settings to use for long-running operations when generating
237
+ # API methods for RPCs. Complements RPCs that use the annotations in
238
+ # google/longrunning/operations.proto.
239
+ #
240
+ # Example of a YAML configuration::
241
+ #
242
+ # publishing:
243
+ # method_behavior:
244
+ # - selector: CreateAdDomain
245
+ # long_running:
246
+ # initial_poll_delay:
247
+ # seconds: 60 # 1 minute
248
+ # poll_delay_multiplier: 1.5
249
+ # max_poll_delay:
250
+ # seconds: 360 # 6 minutes
251
+ # total_poll_timeout:
252
+ # seconds: 54000 # 90 minutes
253
+ class MethodSettings
254
+ include ::Google::Protobuf::MessageExts
255
+ extend ::Google::Protobuf::MessageExts::ClassMethods
256
+
257
+ # Describes settings to use when generating API methods that use the
258
+ # long-running operation pattern.
259
+ # All default values below are from those used in the client library
260
+ # generators (e.g.
261
+ # [Java](https://github.com/googleapis/gapic-generator-java/blob/04c2faa191a9b5a10b92392fe8482279c4404803/src/main/java/com/google/api/generator/gapic/composer/common/RetrySettingsComposer.java)).
262
+ # @!attribute [rw] initial_poll_delay
263
+ # @return [::Google::Protobuf::Duration]
264
+ # Initial delay after which the first poll request will be made.
265
+ # Default value: 5 seconds.
266
+ # @!attribute [rw] poll_delay_multiplier
267
+ # @return [::Float]
268
+ # Multiplier to gradually increase delay between subsequent polls until it
269
+ # reaches max_poll_delay.
270
+ # Default value: 1.5.
271
+ # @!attribute [rw] max_poll_delay
272
+ # @return [::Google::Protobuf::Duration]
273
+ # Maximum time between two subsequent poll requests.
274
+ # Default value: 45 seconds.
275
+ # @!attribute [rw] total_poll_timeout
276
+ # @return [::Google::Protobuf::Duration]
277
+ # Total polling timeout.
278
+ # Default value: 5 minutes.
279
+ class LongRunning
280
+ include ::Google::Protobuf::MessageExts
281
+ extend ::Google::Protobuf::MessageExts::ClassMethods
282
+ end
283
+ end
284
+
285
+ # The organization for which the client libraries are being published.
286
+ # Affects the url where generated docs are published, etc.
287
+ module ClientLibraryOrganization
288
+ # Not useful.
289
+ CLIENT_LIBRARY_ORGANIZATION_UNSPECIFIED = 0
290
+
291
+ # Google Cloud Platform Org.
292
+ CLOUD = 1
293
+
294
+ # Ads (Advertising) Org.
295
+ ADS = 2
296
+
297
+ # Photos Org.
298
+ PHOTOS = 3
299
+
300
+ # Street View Org.
301
+ STREET_VIEW = 4
302
+ end
303
+
304
+ # To where should client libraries be published?
305
+ module ClientLibraryDestination
306
+ # Client libraries will neither be generated nor published to package
307
+ # managers.
308
+ CLIENT_LIBRARY_DESTINATION_UNSPECIFIED = 0
309
+
310
+ # Generate the client library in a repo under github.com/googleapis,
311
+ # but don't publish it to package managers.
312
+ GITHUB = 10
313
+
314
+ # Publish the library to package managers like nuget.org and npmjs.com.
315
+ PACKAGE_MANAGER = 20
316
+ end
317
+ end
318
+ end
@@ -0,0 +1,71 @@
1
+ # frozen_string_literal: true
2
+
3
+ # Copyright 2022 Google LLC
4
+ #
5
+ # Licensed under the Apache License, Version 2.0 (the "License");
6
+ # you may not use this file except in compliance with the License.
7
+ # You may obtain a copy of the License at
8
+ #
9
+ # https://www.apache.org/licenses/LICENSE-2.0
10
+ #
11
+ # Unless required by applicable law or agreed to in writing, software
12
+ # distributed under the License is distributed on an "AS IS" BASIS,
13
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ # See the License for the specific language governing permissions and
15
+ # limitations under the License.
16
+
17
+ # Auto-generated by gapic-generator-ruby. DO NOT EDIT!
18
+
19
+
20
+ module Google
21
+ module Api
22
+ # The launch stage as defined by [Google Cloud Platform
23
+ # Launch Stages](https://cloud.google.com/terms/launch-stages).
24
+ module LaunchStage
25
+ # Do not use this default value.
26
+ LAUNCH_STAGE_UNSPECIFIED = 0
27
+
28
+ # The feature is not yet implemented. Users can not use it.
29
+ UNIMPLEMENTED = 6
30
+
31
+ # Prelaunch features are hidden from users and are only visible internally.
32
+ PRELAUNCH = 7
33
+
34
+ # Early Access features are limited to a closed group of testers. To use
35
+ # these features, you must sign up in advance and sign a Trusted Tester
36
+ # agreement (which includes confidentiality provisions). These features may
37
+ # be unstable, changed in backward-incompatible ways, and are not
38
+ # guaranteed to be released.
39
+ EARLY_ACCESS = 1
40
+
41
+ # Alpha is a limited availability test for releases before they are cleared
42
+ # for widespread use. By Alpha, all significant design issues are resolved
43
+ # and we are in the process of verifying functionality. Alpha customers
44
+ # need to apply for access, agree to applicable terms, and have their
45
+ # projects allowlisted. Alpha releases don't have to be feature complete,
46
+ # no SLAs are provided, and there are no technical support obligations, but
47
+ # they will be far enough along that customers can actually use them in
48
+ # test environments or for limited-use tests -- just like they would in
49
+ # normal production cases.
50
+ ALPHA = 2
51
+
52
+ # Beta is the point at which we are ready to open a release for any
53
+ # customer to use. There are no SLA or technical support obligations in a
54
+ # Beta release. Products will be complete from a feature perspective, but
55
+ # may have some open outstanding issues. Beta releases are suitable for
56
+ # limited production use cases.
57
+ BETA = 3
58
+
59
+ # GA features are open to all developers and are considered stable and
60
+ # fully qualified for production use.
61
+ GA = 4
62
+
63
+ # Deprecated features are scheduled to be shut down and removed. For more
64
+ # information, see the "Deprecation Policy" section of our [Terms of
65
+ # Service](https://cloud.google.com/terms/)
66
+ # and the [Google Cloud Platform Subject to the Deprecation
67
+ # Policy](https://cloud.google.com/terms/deprecation) documentation.
68
+ DEPRECATED = 5
69
+ end
70
+ end
71
+ end
@@ -78,6 +78,277 @@ module Google
78
78
  extend ::Google::Protobuf::MessageExts::ClassMethods
79
79
  end
80
80
 
81
+ # Catalog level attribute config for an attribute. For example, if customers
82
+ # want to enable/disable facet for a specific attribute.
83
+ # @!attribute [rw] key
84
+ # @return [::String]
85
+ # Required. Attribute name.
86
+ # For example: `color`, `brands`, `attributes.custom_attribute`, such as
87
+ # `attributes.xyz`.
88
+ # To be indexable, the attribute name can contain only alpha-numeric
89
+ # characters and underscores. For example, an attribute named
90
+ # `attributes.abc_xyz` can be indexed, but an attribute named
91
+ # `attributes.abc-xyz` cannot be indexed.
92
+ # @!attribute [r] in_use
93
+ # @return [::Boolean]
94
+ # Output only. Indicates whether this attribute has been used by any
95
+ # products. `True` if at least one {::Google::Cloud::Retail::V2::Product Product}
96
+ # is using this attribute in
97
+ # {::Google::Cloud::Retail::V2::Product#attributes Product.attributes}. Otherwise,
98
+ # this field is `False`.
99
+ #
100
+ # {::Google::Cloud::Retail::V2::CatalogAttribute CatalogAttribute} can be
101
+ # pre-loaded by using
102
+ # {::Google::Cloud::Retail::V2::CatalogService::Client#add_catalog_attribute CatalogService.AddCatalogAttribute},
103
+ # [CatalogService.ImportCatalogAttributes][], or
104
+ # {::Google::Cloud::Retail::V2::CatalogService::Client#update_attributes_config CatalogService.UpdateAttributesConfig}
105
+ # APIs. This field is `False` for pre-loaded
106
+ # {::Google::Cloud::Retail::V2::CatalogAttribute CatalogAttribute}s.
107
+ #
108
+ # Only pre-loaded [catalog
109
+ # attributes][google.cloud.retail.v2.CatalogAttribute] that are neither in
110
+ # use by products nor predefined can be deleted. [Catalog
111
+ # attributes][google.cloud.retail.v2.CatalogAttribute] that are
112
+ # either in use by products or are predefined attributes cannot be deleted;
113
+ # however, their configuration properties will reset to default values upon
114
+ # removal request.
115
+ #
116
+ # After catalog changes, it takes about 10 minutes for this field to update.
117
+ # @!attribute [r] type
118
+ # @return [::Google::Cloud::Retail::V2::CatalogAttribute::AttributeType]
119
+ # Output only. The type of this attribute. This is derived from the attribute
120
+ # in {::Google::Cloud::Retail::V2::Product#attributes Product.attributes}.
121
+ # @!attribute [rw] indexable_option
122
+ # @return [::Google::Cloud::Retail::V2::CatalogAttribute::IndexableOption]
123
+ # When
124
+ # {::Google::Cloud::Retail::V2::AttributesConfig#attribute_config_level AttributesConfig.attribute_config_level}
125
+ # is CATALOG_LEVEL_ATTRIBUTE_CONFIG, if INDEXABLE_ENABLED attribute values
126
+ # are indexed so that it can be filtered, faceted, or boosted in
127
+ # {::Google::Cloud::Retail::V2::SearchService::Client#search SearchService.Search}.
128
+ #
129
+ # Must be specified, otherwise throws INVALID_FORMAT error.
130
+ # @!attribute [rw] dynamic_facetable_option
131
+ # @return [::Google::Cloud::Retail::V2::CatalogAttribute::DynamicFacetableOption]
132
+ # If DYNAMIC_FACETABLE_ENABLED, attribute values are available for dynamic
133
+ # facet. Could only be DYNAMIC_FACETABLE_DISABLED if
134
+ # {::Google::Cloud::Retail::V2::CatalogAttribute#indexable_option CatalogAttribute.indexable_option}
135
+ # is INDEXABLE_DISABLED. Otherwise, an INVALID_ARGUMENT error is returned.
136
+ #
137
+ # Must be specified, otherwise throws INVALID_FORMAT error.
138
+ # @!attribute [rw] searchable_option
139
+ # @return [::Google::Cloud::Retail::V2::CatalogAttribute::SearchableOption]
140
+ # When
141
+ # {::Google::Cloud::Retail::V2::AttributesConfig#attribute_config_level AttributesConfig.attribute_config_level}
142
+ # is CATALOG_LEVEL_ATTRIBUTE_CONFIG, if SEARCHABLE_ENABLED, attribute values
143
+ # are searchable by text queries in
144
+ # {::Google::Cloud::Retail::V2::SearchService::Client#search SearchService.Search}.
145
+ #
146
+ # If SEARCHABLE_ENABLED but attribute type is numerical, attribute values
147
+ # will not be searchable by text queries in
148
+ # {::Google::Cloud::Retail::V2::SearchService::Client#search SearchService.Search}, as
149
+ # there are no text values associated to numerical attributes.
150
+ #
151
+ # Must be specified, otherwise throws INVALID_FORMAT error.
152
+ # @!attribute [rw] exact_searchable_option
153
+ # @return [::Google::Cloud::Retail::V2::CatalogAttribute::ExactSearchableOption]
154
+ # If EXACT_SEARCHABLE_ENABLED, attribute values will be exact searchable.
155
+ # This property only applies to textual custom attributes and requires
156
+ # indexable set to enabled to enable exact-searchable.
157
+ # @!attribute [rw] retrievable_option
158
+ # @return [::Google::Cloud::Retail::V2::CatalogAttribute::RetrievableOption]
159
+ # If RETRIEVABLE_ENABLED, attribute values are retrievable in the search
160
+ # results.
161
+ class CatalogAttribute
162
+ include ::Google::Protobuf::MessageExts
163
+ extend ::Google::Protobuf::MessageExts::ClassMethods
164
+
165
+ # The type of an attribute.
166
+ module AttributeType
167
+ # The type of the attribute is unknown.
168
+ #
169
+ # Used when type cannot be derived from attribute that is not
170
+ # {::Google::Cloud::Retail::V2::CatalogAttribute#in_use in_use}.
171
+ UNKNOWN = 0
172
+
173
+ # Textual attribute.
174
+ TEXTUAL = 1
175
+
176
+ # Numerical attribute.
177
+ NUMERICAL = 2
178
+ end
179
+
180
+ # The status of the indexable option of a catalog attribute.
181
+ module IndexableOption
182
+ # Value used when unset.
183
+ INDEXABLE_OPTION_UNSPECIFIED = 0
184
+
185
+ # Indexable option enabled for an attribute.
186
+ INDEXABLE_ENABLED = 1
187
+
188
+ # Indexable option disabled for an attribute.
189
+ INDEXABLE_DISABLED = 2
190
+ end
191
+
192
+ # The status of the dynamic facetable option of a catalog attribute.
193
+ module DynamicFacetableOption
194
+ # Value used when unset.
195
+ DYNAMIC_FACETABLE_OPTION_UNSPECIFIED = 0
196
+
197
+ # Dynamic facetable option enabled for an attribute.
198
+ DYNAMIC_FACETABLE_ENABLED = 1
199
+
200
+ # Dynamic facetable option disabled for an attribute.
201
+ DYNAMIC_FACETABLE_DISABLED = 2
202
+ end
203
+
204
+ # The status of the searchable option of a catalog attribute.
205
+ module SearchableOption
206
+ # Value used when unset.
207
+ SEARCHABLE_OPTION_UNSPECIFIED = 0
208
+
209
+ # Searchable option enabled for an attribute.
210
+ SEARCHABLE_ENABLED = 1
211
+
212
+ # Searchable option disabled for an attribute.
213
+ SEARCHABLE_DISABLED = 2
214
+ end
215
+
216
+ # The status of the exact-searchable option of a catalog attribute.
217
+ module ExactSearchableOption
218
+ # Value used when unset. Defaults to
219
+ # {::Google::Cloud::Retail::V2::CatalogAttribute::ExactSearchableOption::EXACT_SEARCHABLE_DISABLED EXACT_SEARCHABLE_DISABLED}.
220
+ EXACT_SEARCHABLE_OPTION_UNSPECIFIED = 0
221
+
222
+ # Exact searchable option enabled for an attribute.
223
+ EXACT_SEARCHABLE_ENABLED = 1
224
+
225
+ # Exact searchable option disabled for an attribute.
226
+ EXACT_SEARCHABLE_DISABLED = 2
227
+ end
228
+
229
+ # The status of the retrievable option of a catalog attribute.
230
+ module RetrievableOption
231
+ # Value used when unset. Defaults to
232
+ # {::Google::Cloud::Retail::V2::CatalogAttribute::RetrievableOption::RETRIEVABLE_DISABLED RETRIEVABLE_DISABLED}.
233
+ RETRIEVABLE_OPTION_UNSPECIFIED = 0
234
+
235
+ # Retrievable option enabled for an attribute.
236
+ RETRIEVABLE_ENABLED = 1
237
+
238
+ # Retrievable option disabled for an attribute.
239
+ RETRIEVABLE_DISABLED = 2
240
+ end
241
+ end
242
+
243
+ # Catalog level attribute config.
244
+ # @!attribute [rw] name
245
+ # @return [::String]
246
+ # Required. Immutable. The fully qualified resource name of the attribute
247
+ # config. Format: `projects/*/locations/*/catalogs/*/attributesConfig`
248
+ # @!attribute [rw] catalog_attributes
249
+ # @return [::Google::Protobuf::Map{::String => ::Google::Cloud::Retail::V2::CatalogAttribute}]
250
+ # Enable attribute(s) config at catalog level.
251
+ # For example, indexable, dynamic_facetable, or searchable for each
252
+ # attribute.
253
+ #
254
+ # The key is catalog attribute's name.
255
+ # For example: `color`, `brands`, `attributes.custom_attribute`, such as
256
+ # `attributes.xyz`.
257
+ #
258
+ # The maximum number of catalog attributes allowed in a request is 1000.
259
+ # @!attribute [r] attribute_config_level
260
+ # @return [::Google::Cloud::Retail::V2::AttributeConfigLevel]
261
+ # Output only. The
262
+ # {::Google::Cloud::Retail::V2::AttributeConfigLevel AttributeConfigLevel} used
263
+ # for this catalog.
264
+ class AttributesConfig
265
+ include ::Google::Protobuf::MessageExts
266
+ extend ::Google::Protobuf::MessageExts::ClassMethods
267
+
268
+ # @!attribute [rw] key
269
+ # @return [::String]
270
+ # @!attribute [rw] value
271
+ # @return [::Google::Cloud::Retail::V2::CatalogAttribute]
272
+ class CatalogAttributesEntry
273
+ include ::Google::Protobuf::MessageExts
274
+ extend ::Google::Protobuf::MessageExts::ClassMethods
275
+ end
276
+ end
277
+
278
+ # Catalog level autocomplete config for customers to customize autocomplete
279
+ # feature's settings.
280
+ # @!attribute [rw] name
281
+ # @return [::String]
282
+ # Required. Immutable. Fully qualified name
283
+ # `projects/*/locations/*/catalogs/*/completionConfig`
284
+ # @!attribute [rw] matching_order
285
+ # @return [::String]
286
+ # Specifies the matching order for autocomplete suggestions, e.g., a query
287
+ # consisting of 'sh' with 'out-of-order' specified would suggest "women's
288
+ # shoes", whereas a query of 'red s' with 'exact-prefix' specified would
289
+ # suggest "red shoes". Currently supported values:
290
+ #
291
+ # * 'out-of-order'
292
+ # * 'exact-prefix'
293
+ #
294
+ # Default value: 'exact-prefix'.
295
+ # @!attribute [rw] max_suggestions
296
+ # @return [::Integer]
297
+ # The maximum number of autocomplete suggestions returned per term. Default
298
+ # value is 20. If left unset or set to 0, then will fallback to default
299
+ # value.
300
+ #
301
+ # Value range is 1 to 20.
302
+ # @!attribute [rw] min_prefix_length
303
+ # @return [::Integer]
304
+ # The minimum number of characters needed to be typed in order to get
305
+ # suggestions. Default value is 2. If left unset or set to 0, then will
306
+ # fallback to default value.
307
+ #
308
+ # Value range is 1 to 20.
309
+ # @!attribute [rw] auto_learning
310
+ # @return [::Boolean]
311
+ # If set to true, the auto learning function is enabled. Auto learning uses
312
+ # user data to generate suggestions using ML techniques. Default value is
313
+ # false. Only after enabling auto learning can users use `cloud-retail`
314
+ # data in
315
+ # {::Google::Cloud::Retail::V2::CompleteQueryRequest CompleteQueryRequest}.
316
+ # @!attribute [r] suggestions_input_config
317
+ # @return [::Google::Cloud::Retail::V2::CompletionDataInputConfig]
318
+ # Output only. The source data for the latest import of the autocomplete
319
+ # suggestion phrases.
320
+ # @!attribute [r] last_suggestions_import_operation
321
+ # @return [::String]
322
+ # Output only. Name of the LRO corresponding to the latest suggestion terms
323
+ # list import.
324
+ #
325
+ # Can use GetOperation API to
326
+ # retrieve the latest state of the Long Running Operation.
327
+ # @!attribute [r] denylist_input_config
328
+ # @return [::Google::Cloud::Retail::V2::CompletionDataInputConfig]
329
+ # Output only. The source data for the latest import of the autocomplete
330
+ # denylist phrases.
331
+ # @!attribute [r] last_denylist_import_operation
332
+ # @return [::String]
333
+ # Output only. Name of the LRO corresponding to the latest denylist import.
334
+ #
335
+ # Can use GetOperation API to
336
+ # retrieve the latest state of the Long Running Operation.
337
+ # @!attribute [r] allowlist_input_config
338
+ # @return [::Google::Cloud::Retail::V2::CompletionDataInputConfig]
339
+ # Output only. The source data for the latest import of the autocomplete
340
+ # allowlist phrases.
341
+ # @!attribute [r] last_allowlist_import_operation
342
+ # @return [::String]
343
+ # Output only. Name of the LRO corresponding to the latest allowlist import.
344
+ #
345
+ # Can use GetOperation API to
346
+ # retrieve the latest state of the Long Running Operation.
347
+ class CompletionConfig
348
+ include ::Google::Protobuf::MessageExts
349
+ extend ::Google::Protobuf::MessageExts::ClassMethods
350
+ end
351
+
81
352
  # The catalog configuration.
82
353
  # @!attribute [rw] name
83
354
  # @return [::String]