google-shopping-merchant-order_tracking-v1beta 0.a → 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (27) hide show
  1. checksums.yaml +4 -4
  2. data/.yardopts +12 -0
  3. data/AUTHENTICATION.md +122 -0
  4. data/README.md +154 -8
  5. data/lib/google/shopping/merchant/order_tracking/v1beta/order_tracking_signals_service/client.rb +467 -0
  6. data/lib/google/shopping/merchant/order_tracking/v1beta/order_tracking_signals_service/credentials.rb +49 -0
  7. data/lib/google/shopping/merchant/order_tracking/v1beta/order_tracking_signals_service/paths.rb +49 -0
  8. data/lib/google/shopping/merchant/order_tracking/v1beta/order_tracking_signals_service/rest/client.rb +434 -0
  9. data/lib/google/shopping/merchant/order_tracking/v1beta/order_tracking_signals_service/rest/service_stub.rb +145 -0
  10. data/lib/google/shopping/merchant/order_tracking/v1beta/order_tracking_signals_service/rest.rb +54 -0
  11. data/lib/google/shopping/merchant/order_tracking/v1beta/order_tracking_signals_service.rb +57 -0
  12. data/lib/google/shopping/merchant/order_tracking/v1beta/rest.rb +39 -0
  13. data/lib/google/shopping/merchant/order_tracking/v1beta/version.rb +7 -2
  14. data/lib/google/shopping/merchant/order_tracking/v1beta.rb +47 -0
  15. data/lib/google/shopping/merchant/ordertracking/v1beta/order_tracking_signals_pb.rb +58 -0
  16. data/lib/google/shopping/merchant/ordertracking/v1beta/order_tracking_signals_services_pb.rb +47 -0
  17. data/lib/google-shopping-merchant-order_tracking-v1beta.rb +21 -0
  18. data/proto_docs/README.md +4 -0
  19. data/proto_docs/google/api/client.rb +473 -0
  20. data/proto_docs/google/api/field_behavior.rb +85 -0
  21. data/proto_docs/google/api/launch_stage.rb +71 -0
  22. data/proto_docs/google/api/resource.rb +227 -0
  23. data/proto_docs/google/protobuf/duration.rb +98 -0
  24. data/proto_docs/google/shopping/merchant/ordertracking/v1beta/order_tracking_signals.rb +211 -0
  25. data/proto_docs/google/shopping/type/types.rb +210 -0
  26. data/proto_docs/google/type/datetime.rb +103 -0
  27. metadata +92 -10
@@ -0,0 +1,227 @@
1
+ # frozen_string_literal: true
2
+
3
+ # Copyright 2025 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
+ # A simple descriptor of a resource type.
23
+ #
24
+ # ResourceDescriptor annotates a resource message (either by means of a
25
+ # protobuf annotation or use in the service config), and associates the
26
+ # resource's schema, the resource type, and the pattern of the resource name.
27
+ #
28
+ # Example:
29
+ #
30
+ # message Topic {
31
+ # // Indicates this message defines a resource schema.
32
+ # // Declares the resource type in the format of {service}/{kind}.
33
+ # // For Kubernetes resources, the format is {api group}/{kind}.
34
+ # option (google.api.resource) = {
35
+ # type: "pubsub.googleapis.com/Topic"
36
+ # pattern: "projects/{project}/topics/{topic}"
37
+ # };
38
+ # }
39
+ #
40
+ # The ResourceDescriptor Yaml config will look like:
41
+ #
42
+ # resources:
43
+ # - type: "pubsub.googleapis.com/Topic"
44
+ # pattern: "projects/{project}/topics/{topic}"
45
+ #
46
+ # Sometimes, resources have multiple patterns, typically because they can
47
+ # live under multiple parents.
48
+ #
49
+ # Example:
50
+ #
51
+ # message LogEntry {
52
+ # option (google.api.resource) = {
53
+ # type: "logging.googleapis.com/LogEntry"
54
+ # pattern: "projects/{project}/logs/{log}"
55
+ # pattern: "folders/{folder}/logs/{log}"
56
+ # pattern: "organizations/{organization}/logs/{log}"
57
+ # pattern: "billingAccounts/{billing_account}/logs/{log}"
58
+ # };
59
+ # }
60
+ #
61
+ # The ResourceDescriptor Yaml config will look like:
62
+ #
63
+ # resources:
64
+ # - type: 'logging.googleapis.com/LogEntry'
65
+ # pattern: "projects/{project}/logs/{log}"
66
+ # pattern: "folders/{folder}/logs/{log}"
67
+ # pattern: "organizations/{organization}/logs/{log}"
68
+ # pattern: "billingAccounts/{billing_account}/logs/{log}"
69
+ # @!attribute [rw] type
70
+ # @return [::String]
71
+ # The resource type. It must be in the format of
72
+ # \\{service_name}/\\{resource_type_kind}. The `resource_type_kind` must be
73
+ # singular and must not include version numbers.
74
+ #
75
+ # Example: `storage.googleapis.com/Bucket`
76
+ #
77
+ # The value of the resource_type_kind must follow the regular expression
78
+ # /[A-Za-z][a-zA-Z0-9]+/. It should start with an upper case character and
79
+ # should use PascalCase (UpperCamelCase). The maximum number of
80
+ # characters allowed for the `resource_type_kind` is 100.
81
+ # @!attribute [rw] pattern
82
+ # @return [::Array<::String>]
83
+ # Optional. The relative resource name pattern associated with this resource
84
+ # type. The DNS prefix of the full resource name shouldn't be specified here.
85
+ #
86
+ # The path pattern must follow the syntax, which aligns with HTTP binding
87
+ # syntax:
88
+ #
89
+ # Template = Segment { "/" Segment } ;
90
+ # Segment = LITERAL | Variable ;
91
+ # Variable = "{" LITERAL "}" ;
92
+ #
93
+ # Examples:
94
+ #
95
+ # - "projects/\\{project}/topics/\\{topic}"
96
+ # - "projects/\\{project}/knowledgeBases/\\{knowledge_base}"
97
+ #
98
+ # The components in braces correspond to the IDs for each resource in the
99
+ # hierarchy. It is expected that, if multiple patterns are provided,
100
+ # the same component name (e.g. "project") refers to IDs of the same
101
+ # type of resource.
102
+ # @!attribute [rw] name_field
103
+ # @return [::String]
104
+ # Optional. The field on the resource that designates the resource name
105
+ # field. If omitted, this is assumed to be "name".
106
+ # @!attribute [rw] history
107
+ # @return [::Google::Api::ResourceDescriptor::History]
108
+ # Optional. The historical or future-looking state of the resource pattern.
109
+ #
110
+ # Example:
111
+ #
112
+ # // The InspectTemplate message originally only supported resource
113
+ # // names with organization, and project was added later.
114
+ # message InspectTemplate {
115
+ # option (google.api.resource) = {
116
+ # type: "dlp.googleapis.com/InspectTemplate"
117
+ # pattern:
118
+ # "organizations/{organization}/inspectTemplates/{inspect_template}"
119
+ # pattern: "projects/{project}/inspectTemplates/{inspect_template}"
120
+ # history: ORIGINALLY_SINGLE_PATTERN
121
+ # };
122
+ # }
123
+ # @!attribute [rw] plural
124
+ # @return [::String]
125
+ # The plural name used in the resource name and permission names, such as
126
+ # 'projects' for the resource name of 'projects/\\{project}' and the permission
127
+ # name of 'cloudresourcemanager.googleapis.com/projects.get'. One exception
128
+ # to this is for Nested Collections that have stuttering names, as defined
129
+ # in [AIP-122](https://google.aip.dev/122#nested-collections), where the
130
+ # collection ID in the resource name pattern does not necessarily directly
131
+ # match the `plural` value.
132
+ #
133
+ # It is the same concept of the `plural` field in k8s CRD spec
134
+ # https://kubernetes.io/docs/tasks/access-kubernetes-api/custom-resources/custom-resource-definitions/
135
+ #
136
+ # Note: The plural form is required even for singleton resources. See
137
+ # https://aip.dev/156
138
+ # @!attribute [rw] singular
139
+ # @return [::String]
140
+ # The same concept of the `singular` field in k8s CRD spec
141
+ # https://kubernetes.io/docs/tasks/access-kubernetes-api/custom-resources/custom-resource-definitions/
142
+ # Such as "project" for the `resourcemanager.googleapis.com/Project` type.
143
+ # @!attribute [rw] style
144
+ # @return [::Array<::Google::Api::ResourceDescriptor::Style>]
145
+ # Style flag(s) for this resource.
146
+ # These indicate that a resource is expected to conform to a given
147
+ # style. See the specific style flags for additional information.
148
+ class ResourceDescriptor
149
+ include ::Google::Protobuf::MessageExts
150
+ extend ::Google::Protobuf::MessageExts::ClassMethods
151
+
152
+ # A description of the historical or future-looking state of the
153
+ # resource pattern.
154
+ module History
155
+ # The "unset" value.
156
+ HISTORY_UNSPECIFIED = 0
157
+
158
+ # The resource originally had one pattern and launched as such, and
159
+ # additional patterns were added later.
160
+ ORIGINALLY_SINGLE_PATTERN = 1
161
+
162
+ # The resource has one pattern, but the API owner expects to add more
163
+ # later. (This is the inverse of ORIGINALLY_SINGLE_PATTERN, and prevents
164
+ # that from being necessary once there are multiple patterns.)
165
+ FUTURE_MULTI_PATTERN = 2
166
+ end
167
+
168
+ # A flag representing a specific style that a resource claims to conform to.
169
+ module Style
170
+ # The unspecified value. Do not use.
171
+ STYLE_UNSPECIFIED = 0
172
+
173
+ # This resource is intended to be "declarative-friendly".
174
+ #
175
+ # Declarative-friendly resources must be more strictly consistent, and
176
+ # setting this to true communicates to tools that this resource should
177
+ # adhere to declarative-friendly expectations.
178
+ #
179
+ # Note: This is used by the API linter (linter.aip.dev) to enable
180
+ # additional checks.
181
+ DECLARATIVE_FRIENDLY = 1
182
+ end
183
+ end
184
+
185
+ # Defines a proto annotation that describes a string field that refers to
186
+ # an API resource.
187
+ # @!attribute [rw] type
188
+ # @return [::String]
189
+ # The resource type that the annotated field references.
190
+ #
191
+ # Example:
192
+ #
193
+ # message Subscription {
194
+ # string topic = 2 [(google.api.resource_reference) = {
195
+ # type: "pubsub.googleapis.com/Topic"
196
+ # }];
197
+ # }
198
+ #
199
+ # Occasionally, a field may reference an arbitrary resource. In this case,
200
+ # APIs use the special value * in their resource reference.
201
+ #
202
+ # Example:
203
+ #
204
+ # message GetIamPolicyRequest {
205
+ # string resource = 2 [(google.api.resource_reference) = {
206
+ # type: "*"
207
+ # }];
208
+ # }
209
+ # @!attribute [rw] child_type
210
+ # @return [::String]
211
+ # The resource type of a child collection that the annotated field
212
+ # references. This is useful for annotating the `parent` field that
213
+ # doesn't have a fixed resource type.
214
+ #
215
+ # Example:
216
+ #
217
+ # message ListLogEntriesRequest {
218
+ # string parent = 1 [(google.api.resource_reference) = {
219
+ # child_type: "logging.googleapis.com/LogEntry"
220
+ # };
221
+ # }
222
+ class ResourceReference
223
+ include ::Google::Protobuf::MessageExts
224
+ extend ::Google::Protobuf::MessageExts::ClassMethods
225
+ end
226
+ end
227
+ end
@@ -0,0 +1,98 @@
1
+ # frozen_string_literal: true
2
+
3
+ # Copyright 2025 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 Protobuf
22
+ # A Duration represents a signed, fixed-length span of time represented
23
+ # as a count of seconds and fractions of seconds at nanosecond
24
+ # resolution. It is independent of any calendar and concepts like "day"
25
+ # or "month". It is related to Timestamp in that the difference between
26
+ # two Timestamp values is a Duration and it can be added or subtracted
27
+ # from a Timestamp. Range is approximately +-10,000 years.
28
+ #
29
+ # # Examples
30
+ #
31
+ # Example 1: Compute Duration from two Timestamps in pseudo code.
32
+ #
33
+ # Timestamp start = ...;
34
+ # Timestamp end = ...;
35
+ # Duration duration = ...;
36
+ #
37
+ # duration.seconds = end.seconds - start.seconds;
38
+ # duration.nanos = end.nanos - start.nanos;
39
+ #
40
+ # if (duration.seconds < 0 && duration.nanos > 0) {
41
+ # duration.seconds += 1;
42
+ # duration.nanos -= 1000000000;
43
+ # } else if (duration.seconds > 0 && duration.nanos < 0) {
44
+ # duration.seconds -= 1;
45
+ # duration.nanos += 1000000000;
46
+ # }
47
+ #
48
+ # Example 2: Compute Timestamp from Timestamp + Duration in pseudo code.
49
+ #
50
+ # Timestamp start = ...;
51
+ # Duration duration = ...;
52
+ # Timestamp end = ...;
53
+ #
54
+ # end.seconds = start.seconds + duration.seconds;
55
+ # end.nanos = start.nanos + duration.nanos;
56
+ #
57
+ # if (end.nanos < 0) {
58
+ # end.seconds -= 1;
59
+ # end.nanos += 1000000000;
60
+ # } else if (end.nanos >= 1000000000) {
61
+ # end.seconds += 1;
62
+ # end.nanos -= 1000000000;
63
+ # }
64
+ #
65
+ # Example 3: Compute Duration from datetime.timedelta in Python.
66
+ #
67
+ # td = datetime.timedelta(days=3, minutes=10)
68
+ # duration = Duration()
69
+ # duration.FromTimedelta(td)
70
+ #
71
+ # # JSON Mapping
72
+ #
73
+ # In JSON format, the Duration type is encoded as a string rather than an
74
+ # object, where the string ends in the suffix "s" (indicating seconds) and
75
+ # is preceded by the number of seconds, with nanoseconds expressed as
76
+ # fractional seconds. For example, 3 seconds with 0 nanoseconds should be
77
+ # encoded in JSON format as "3s", while 3 seconds and 1 nanosecond should
78
+ # be expressed in JSON format as "3.000000001s", and 3 seconds and 1
79
+ # microsecond should be expressed in JSON format as "3.000001s".
80
+ # @!attribute [rw] seconds
81
+ # @return [::Integer]
82
+ # Signed seconds of the span of time. Must be from -315,576,000,000
83
+ # to +315,576,000,000 inclusive. Note: these bounds are computed from:
84
+ # 60 sec/min * 60 min/hr * 24 hr/day * 365.25 days/year * 10000 years
85
+ # @!attribute [rw] nanos
86
+ # @return [::Integer]
87
+ # Signed fractions of a second at nanosecond resolution of the span
88
+ # of time. Durations less than one second are represented with a 0
89
+ # `seconds` field and a positive or negative `nanos` field. For durations
90
+ # of one second or more, a non-zero value for the `nanos` field must be
91
+ # of the same sign as the `seconds` field. Must be from -999,999,999
92
+ # to +999,999,999 inclusive.
93
+ class Duration
94
+ include ::Google::Protobuf::MessageExts
95
+ extend ::Google::Protobuf::MessageExts::ClassMethods
96
+ end
97
+ end
98
+ end
@@ -0,0 +1,211 @@
1
+ # frozen_string_literal: true
2
+
3
+ # Copyright 2025 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 Shopping
22
+ module Merchant
23
+ module OrderTracking
24
+ module V1beta
25
+ # Signals only can be created but not updated.
26
+ # Businesses need to call this API only when the order is completely shipped.
27
+ # Creates new order signal.
28
+ # @!attribute [rw] parent
29
+ # @return [::String]
30
+ # Required. The account of the business for which the order signal is
31
+ # created. Format: accounts/\\{account}
32
+ # @!attribute [r] order_tracking_signal_id
33
+ # @return [::String]
34
+ # Output only. The ID that uniquely identifies this order tracking signal.
35
+ # @!attribute [rw] order_tracking_signal
36
+ # @return [::Google::Shopping::Merchant::OrderTracking::V1beta::OrderTrackingSignal]
37
+ # Required. The order signal to be created.
38
+ class CreateOrderTrackingSignalRequest
39
+ include ::Google::Protobuf::MessageExts
40
+ extend ::Google::Protobuf::MessageExts::ClassMethods
41
+ end
42
+
43
+ # Represents a business trade from which signals are extracted, such as
44
+ # shipping.
45
+ # @!attribute [r] order_tracking_signal_id
46
+ # @return [::Integer]
47
+ # Output only. The ID that uniquely identifies this order tracking signal.
48
+ # @!attribute [rw] merchant_id
49
+ # @return [::Integer]
50
+ # Optional. The Google Merchant Center ID of this order tracking signal. This
51
+ # value is optional. If left unset, the caller's Merchant Center ID is used.
52
+ # You must request access in order to provide data on behalf of another
53
+ # business. For more information, see [Submitting Order Tracking
54
+ # Signals](/shopping-content/guides/order-tracking-signals).
55
+ # @!attribute [rw] order_created_time
56
+ # @return [::Google::Type::DateTime]
57
+ # Required. The time when the order was created on the businesses side.
58
+ # Include the year and timezone string, if available.
59
+ # @!attribute [rw] order_id
60
+ # @return [::String]
61
+ # Required. The ID of the order on the businesses side. This field will be
62
+ # hashed in returned OrderTrackingSignal creation response.
63
+ # @!attribute [rw] shipping_info
64
+ # @return [::Array<::Google::Shopping::Merchant::OrderTracking::V1beta::OrderTrackingSignal::ShippingInfo>]
65
+ # Required. The shipping information for the order.
66
+ # @!attribute [rw] line_items
67
+ # @return [::Array<::Google::Shopping::Merchant::OrderTracking::V1beta::OrderTrackingSignal::LineItemDetails>]
68
+ # Required. Information about line items in the order.
69
+ # @!attribute [rw] shipment_line_item_mapping
70
+ # @return [::Array<::Google::Shopping::Merchant::OrderTracking::V1beta::OrderTrackingSignal::ShipmentLineItemMapping>]
71
+ # Optional. The mapping of the line items to the shipment information.
72
+ # @!attribute [rw] customer_shipping_fee
73
+ # @return [::Google::Shopping::Type::Price]
74
+ # Optional. The shipping fee of the order;
75
+ # this value should be set to zero in the case of free shipping.
76
+ # @!attribute [rw] delivery_postal_code
77
+ # @return [::String]
78
+ # Optional. The delivery postal code, as a continuous string without spaces
79
+ # or dashes, for example "95016". This field will be anonymized in returned
80
+ # OrderTrackingSignal creation response.
81
+ # @!attribute [rw] delivery_region_code
82
+ # @return [::String]
83
+ # Optional. The [CLDR territory code]
84
+ # (http://www.unicode.org/repos/cldr/tags/latest/common/main/en.xml) for
85
+ # the shipping destination.
86
+ class OrderTrackingSignal
87
+ include ::Google::Protobuf::MessageExts
88
+ extend ::Google::Protobuf::MessageExts::ClassMethods
89
+
90
+ # The shipping information for the order.
91
+ # @!attribute [rw] shipment_id
92
+ # @return [::String]
93
+ # Required. The shipment ID. This field will be hashed in returned
94
+ # OrderTrackingSignal creation response.
95
+ # @!attribute [rw] tracking_id
96
+ # @return [::String]
97
+ # Optional. The tracking ID of the shipment. This field is required if one
98
+ # of the following fields is absent: earliest_delivery_promise_time,
99
+ # latest_delivery_promise_time, and actual_delivery_time.
100
+ # @!attribute [rw] carrier
101
+ # @return [::String]
102
+ # Optional. The name of the shipping carrier for the delivery. This field
103
+ # is required if one of the following fields is absent:
104
+ # earliest_delivery_promise_time, latest_delivery_promise_time,
105
+ # and actual_delivery_time.
106
+ # @!attribute [rw] carrier_service
107
+ # @return [::String]
108
+ # Optional. The service type for fulfillment, such as GROUND, FIRST_CLASS,
109
+ # etc.
110
+ # @!attribute [rw] shipped_time
111
+ # @return [::Google::Type::DateTime]
112
+ # Optional. The time when the shipment was shipped.
113
+ # Include the year and timezone string, if available.
114
+ # @!attribute [rw] earliest_delivery_promise_time
115
+ # @return [::Google::Type::DateTime]
116
+ # Optional. The earliest delivery promised time.
117
+ # Include the year and timezone string, if available.
118
+ # This field is required, if one of the following fields is absent:
119
+ # tracking_id or carrier_name.
120
+ # @!attribute [rw] latest_delivery_promise_time
121
+ # @return [::Google::Type::DateTime]
122
+ # Optional. The latest delivery promised time.
123
+ # Include the year and timezone string, if available.
124
+ # This field is required, if one of the following fields is absent:
125
+ # tracking_id or carrier_name.
126
+ # @!attribute [rw] actual_delivery_time
127
+ # @return [::Google::Type::DateTime]
128
+ # Optional. The time when the shipment was actually delivered.
129
+ # Include the year and timezone string, if available.
130
+ # This field is required, if one of the following fields is absent:
131
+ # tracking_id or carrier_name.
132
+ # @!attribute [rw] shipping_status
133
+ # @return [::Google::Shopping::Merchant::OrderTracking::V1beta::OrderTrackingSignal::ShippingInfo::ShippingState]
134
+ # Required. The status of the shipment.
135
+ # @!attribute [rw] origin_postal_code
136
+ # @return [::String]
137
+ # Required. The origin postal code, as a continuous string without spaces
138
+ # or dashes, for example "95016". This field will be anonymized in returned
139
+ # OrderTrackingSignal creation response.
140
+ # @!attribute [rw] origin_region_code
141
+ # @return [::String]
142
+ # Required. The [CLDR territory code]
143
+ # (http://www.unicode.org/repos/cldr/tags/latest/common/main/en.xml) for
144
+ # the shipping origin.
145
+ class ShippingInfo
146
+ include ::Google::Protobuf::MessageExts
147
+ extend ::Google::Protobuf::MessageExts::ClassMethods
148
+
149
+ # The current status of the shipments.
150
+ module ShippingState
151
+ # The shipping status is not known to business.
152
+ SHIPPING_STATE_UNSPECIFIED = 0
153
+
154
+ # All items are shipped.
155
+ SHIPPED = 1
156
+
157
+ # The shipment is already delivered.
158
+ DELIVERED = 2
159
+ end
160
+ end
161
+
162
+ # The line items of the order.
163
+ # @!attribute [rw] line_item_id
164
+ # @return [::String]
165
+ # Required. The ID for this line item.
166
+ # @!attribute [rw] product_id
167
+ # @return [::String]
168
+ # Required. The Content API REST ID of the product, in the
169
+ # form channel:contentLanguage:targetCountry:offerId.
170
+ # @!attribute [rw] gtin
171
+ # @return [::String]
172
+ # Optional. The Global Trade Item Number.
173
+ # @!attribute [rw] mpn
174
+ # @return [::String]
175
+ # Optional. The manufacturer part number.
176
+ # @!attribute [rw] product_title
177
+ # @return [::String]
178
+ # Optional. Plain text title of this product.
179
+ # @!attribute [rw] brand
180
+ # @return [::String]
181
+ # Optional. Brand of the product.
182
+ # @!attribute [rw] quantity
183
+ # @return [::Integer]
184
+ # Required. The quantity of the line item in the order.
185
+ class LineItemDetails
186
+ include ::Google::Protobuf::MessageExts
187
+ extend ::Google::Protobuf::MessageExts::ClassMethods
188
+ end
189
+
190
+ # Represents how many items are in the shipment for the given shipment_id
191
+ # and line_item_id.
192
+ # @!attribute [rw] shipment_id
193
+ # @return [::String]
194
+ # Required. The shipment ID. This field will be hashed in returned
195
+ # OrderTrackingSignal creation response.
196
+ # @!attribute [rw] line_item_id
197
+ # @return [::String]
198
+ # Required. The line item ID.
199
+ # @!attribute [rw] quantity
200
+ # @return [::Integer]
201
+ # Required. The line item quantity in the shipment.
202
+ class ShipmentLineItemMapping
203
+ include ::Google::Protobuf::MessageExts
204
+ extend ::Google::Protobuf::MessageExts::ClassMethods
205
+ end
206
+ end
207
+ end
208
+ end
209
+ end
210
+ end
211
+ end