criteo-api-retailmedia-sdk 0.0.250409__py3-none-any.whl → 0.0.250606__py3-none-any.whl

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 (96) hide show
  1. criteo_api_retailmedia_preview/__init__.py +1 -1
  2. criteo_api_retailmedia_preview/api/accounts_api.py +3 -147
  3. criteo_api_retailmedia_preview/api/analytics_api.py +1 -1
  4. criteo_api_retailmedia_preview/api/audience_api.py +1204 -135
  5. criteo_api_retailmedia_preview/api/campaign_api.py +741 -104
  6. criteo_api_retailmedia_preview/api_client.py +1 -1
  7. criteo_api_retailmedia_preview/configuration.py +1 -1
  8. criteo_api_retailmedia_preview/model/account_fees_update_request.py +4 -0
  9. criteo_api_retailmedia_preview/model/async_accounts_report.py +6 -6
  10. criteo_api_retailmedia_preview/model/async_campaigns_report.py +4 -4
  11. criteo_api_retailmedia_preview/model/async_line_items_report.py +4 -4
  12. criteo_api_retailmedia_preview/model/async_offsite_report.py +25 -18
  13. criteo_api_retailmedia_preview/model/brand_id_search_request.py +7 -1
  14. criteo_api_retailmedia_preview/model/brand_id_search_result.py +7 -1
  15. criteo_api_retailmedia_preview/model/categories_search_request_v1.py +270 -0
  16. criteo_api_retailmedia_preview/model/entity_resource_brand_id_search_result.py +8 -1
  17. criteo_api_retailmedia_preview/model/entity_resource_category202204.py +277 -0
  18. criteo_api_retailmedia_preview/model/entity_resource_collection_outcome_brand_id_search_result_paging_offset_limit_metadata.py +8 -1
  19. criteo_api_retailmedia_preview/model/entity_resource_collection_outcome_category202204.py +281 -0
  20. criteo_api_retailmedia_preview/model/entity_resource_collection_outcome_category202204_metadata.py +287 -0
  21. criteo_api_retailmedia_preview/model/entity_resource_of_sponsored_products_line_item.py +270 -0
  22. criteo_api_retailmedia_preview/model/entity_resource_outcome_of_sponsored_products_line_item.py +274 -0
  23. criteo_api_retailmedia_preview/model/{input_keywords.py → flight_leg.py} +39 -17
  24. criteo_api_retailmedia_preview/model/{recommended_keywords_result.py → flight_schedule.py} +9 -13
  25. criteo_api_retailmedia_preview/model/nillable_decimal.py +263 -0
  26. criteo_api_retailmedia_preview/model/page_of_sponsored_products_line_item.py +276 -0
  27. criteo_api_retailmedia_preview/model/paging_offset_limit_metadata.py +7 -1
  28. criteo_api_retailmedia_preview/model/{grant_consent_model.py → recommended_categories_request_v1.py} +14 -21
  29. criteo_api_retailmedia_preview/model/recommended_keywords_request_v1.py +266 -0
  30. criteo_api_retailmedia_preview/model/recommended_keywords_response_v1.py +263 -0
  31. criteo_api_retailmedia_preview/model/{line_item_bid_multipliers_v2_request.py → rm_audience_bulk_create_input_v1.py} +9 -9
  32. criteo_api_retailmedia_preview/model/{grant_consent_input.py → rm_audience_bulk_delete_input_v1.py} +8 -8
  33. criteo_api_retailmedia_preview/model/rm_audience_bulk_update_input_v1.py +269 -0
  34. criteo_api_retailmedia_preview/model/rm_audience_compute_sizes_entity_v1.py +272 -0
  35. criteo_api_retailmedia_preview/model/rm_audience_compute_sizes_entity_v1_resource.py +273 -0
  36. criteo_api_retailmedia_preview/model/rm_audience_compute_sizes_input_v1.py +269 -0
  37. criteo_api_retailmedia_preview/model/rm_audience_create_entity_v1.py +291 -0
  38. criteo_api_retailmedia_preview/model/{grant_consent_model_value_resource.py → rm_audience_create_entity_v1_resource.py} +8 -8
  39. criteo_api_retailmedia_preview/model/rm_audience_delete_entity_v1_resource.py +271 -0
  40. criteo_api_retailmedia_preview/model/{value_resource_outcome_of_recommended_keywords_result.py → rm_audience_entity_v1_list_response.py} +16 -9
  41. criteo_api_retailmedia_preview/model/rm_audience_estimate_size_entity_v1.py +282 -0
  42. criteo_api_retailmedia_preview/model/rm_audience_estimate_size_entity_v1_resource.py +273 -0
  43. criteo_api_retailmedia_preview/model/rm_audience_estimate_size_input_v1.py +269 -0
  44. criteo_api_retailmedia_preview/model/rm_audience_segment_compute_size_entity_v1.py +272 -0
  45. criteo_api_retailmedia_preview/model/rm_audience_segment_compute_size_entity_v1_resource.py +273 -0
  46. criteo_api_retailmedia_preview/model/rm_audience_segment_compute_sizes_input_v1.py +269 -0
  47. criteo_api_retailmedia_preview/model/rm_audience_segment_create_entity_v1.py +6 -0
  48. criteo_api_retailmedia_preview/model/rm_audience_segment_estimate_size_entity_v1.py +282 -0
  49. criteo_api_retailmedia_preview/model/rm_audience_segment_estimate_size_entity_v1_resource.py +273 -0
  50. criteo_api_retailmedia_preview/model/rm_audience_segment_estimate_size_input_v1.py +269 -0
  51. criteo_api_retailmedia_preview/model/rm_audience_segment_size_entity_v1.py +267 -0
  52. criteo_api_retailmedia_preview/model/rm_audience_segment_size_entity_v1_list_response.py +281 -0
  53. criteo_api_retailmedia_preview/model/{resource_of_line_item_bid_multipliers_v2.py → rm_audience_segment_size_entity_v1_resource.py} +11 -11
  54. criteo_api_retailmedia_preview/model/rm_audience_segment_size_estimation_v1.py +267 -0
  55. criteo_api_retailmedia_preview/model/rm_audience_segment_size_estimation_v1_resource.py +273 -0
  56. criteo_api_retailmedia_preview/model/rm_audience_segment_size_estimation_v1_response.py +281 -0
  57. criteo_api_retailmedia_preview/model/rm_audience_segment_update_entity_v1.py +6 -0
  58. criteo_api_retailmedia_preview/model/rm_audience_size_entity_v1.py +267 -0
  59. criteo_api_retailmedia_preview/model/rm_audience_size_entity_v1_list_response.py +281 -0
  60. criteo_api_retailmedia_preview/model/rm_audience_size_entity_v1_resource.py +277 -0
  61. criteo_api_retailmedia_preview/model/rm_audience_size_estimation_v1.py +267 -0
  62. criteo_api_retailmedia_preview/model/rm_audience_size_estimation_v1_resource.py +273 -0
  63. criteo_api_retailmedia_preview/model/{line_item_bid_multipliers_v2_response.py → rm_audience_size_estimation_v1_response.py} +9 -9
  64. criteo_api_retailmedia_preview/model/rm_audience_update_entity_v1.py +279 -0
  65. criteo_api_retailmedia_preview/model/{json_api_body_with_id_of_int64_and_line_item_bid_multipliers_v2_and_line_item_bid_multipliers_v2.py → rm_audience_update_entity_v1_resource.py} +17 -19
  66. criteo_api_retailmedia_preview/model/rm_events_create_v1.py +305 -0
  67. criteo_api_retailmedia_preview/model/rm_events_estimation_v1.py +305 -0
  68. criteo_api_retailmedia_preview/model/rm_events_update_v1.py +307 -0
  69. criteo_api_retailmedia_preview/model/sku_slim_data_preview.py +6 -6
  70. criteo_api_retailmedia_preview/model/sponsored_products_line_item.py +387 -0
  71. criteo_api_retailmedia_preview/model/{json_api_single_response_of_line_item_bid_multipliers_v2.py → sponsored_products_line_item_create_request_model.py} +81 -33
  72. criteo_api_retailmedia_preview/model/{keywords.py → sponsored_products_line_item_update_request_model.py} +82 -44
  73. criteo_api_retailmedia_preview/model/sync_attributed_transactions_report.py +2 -2
  74. criteo_api_retailmedia_preview/model/sync_campaigns_report.py +4 -4
  75. criteo_api_retailmedia_preview/model/sync_line_items_report.py +4 -4
  76. criteo_api_retailmedia_preview/model/value_resource_brand_id_search_request.py +8 -1
  77. criteo_api_retailmedia_preview/model/value_resource_categories_search_request_v1.py +273 -0
  78. criteo_api_retailmedia_preview/model/{value_resource_collection_outcome_private_market_account_fees.py → value_resource_collection_outcome_private_market_account_fees_and_metadata.py} +9 -3
  79. criteo_api_retailmedia_preview/model/value_resource_input_brand_id_search_request.py +8 -1
  80. criteo_api_retailmedia_preview/model/value_resource_input_categories_search_request_v1.py +269 -0
  81. criteo_api_retailmedia_preview/model/value_resource_input_of_sponsored_products_line_item_update_request_model.py +262 -0
  82. criteo_api_retailmedia_preview/model/value_resource_input_recommended_categories_request_v1.py +269 -0
  83. criteo_api_retailmedia_preview/model/value_resource_input_recommended_keywords_request_v1.py +262 -0
  84. criteo_api_retailmedia_preview/model/value_resource_of_sponsored_products_line_item_update_request_model.py +266 -0
  85. criteo_api_retailmedia_preview/model/value_resource_outcome_recommended_keywords_response_v1.py +274 -0
  86. criteo_api_retailmedia_preview/model/value_resource_recommended_categories_request_v1.py +273 -0
  87. criteo_api_retailmedia_preview/model/value_resource_recommended_keywords_request_v1.py +266 -0
  88. criteo_api_retailmedia_preview/model/{value_resource_of_recommended_keywords_result.py → value_resource_recommended_keywords_response_v1.py} +10 -10
  89. criteo_api_retailmedia_preview/models/__init__.py +63 -17
  90. {criteo_api_retailmedia_sdk-0.0.250409.dist-info → criteo_api_retailmedia_sdk-0.0.250606.dist-info}/METADATA +3 -3
  91. {criteo_api_retailmedia_sdk-0.0.250409.dist-info → criteo_api_retailmedia_sdk-0.0.250606.dist-info}/RECORD +93 -47
  92. {criteo_api_retailmedia_sdk-0.0.250409.dist-info → criteo_api_retailmedia_sdk-0.0.250606.dist-info}/WHEEL +1 -1
  93. criteo_api_retailmedia_preview/model/common_error.py +0 -301
  94. criteo_api_retailmedia_preview/model/common_warning.py +0 -301
  95. criteo_api_retailmedia_preview/model/external_line_item_bid_multipliers_v2.py +0 -307
  96. {criteo_api_retailmedia_sdk-0.0.250409.dist-info → criteo_api_retailmedia_sdk-0.0.250606.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,305 @@
1
+ """
2
+ Criteo API
3
+
4
+ Criteo API - RetailMedia # noqa: E501
5
+
6
+ The version of the OpenAPI document: Preview
7
+ Generated by: https://openapi-generator.tech
8
+ """
9
+
10
+
11
+ import re # noqa: F401
12
+ import sys # noqa: F401
13
+
14
+ from criteo_api_retailmedia_preview.model_utils import ( # noqa: F401
15
+ ApiTypeError,
16
+ ModelComposed,
17
+ ModelNormal,
18
+ ModelSimple,
19
+ cached_property,
20
+ change_keys_js_to_python,
21
+ convert_js_args_to_python_args,
22
+ date,
23
+ datetime,
24
+ file_type,
25
+ none_type,
26
+ validate_get_composed_info,
27
+ OpenApiModel
28
+ )
29
+ from criteo_api_retailmedia_preview.exceptions import ApiAttributeError
30
+
31
+
32
+
33
+ class RmEventsEstimationV1(ModelNormal):
34
+ """NOTE: This class is auto generated by OpenAPI Generator.
35
+ Ref: https://openapi-generator.tech
36
+
37
+ Do not edit the class manually.
38
+
39
+ Attributes:
40
+ allowed_values (dict): The key is the tuple path to the attribute
41
+ and the for var_name this is (var_name,). The value is a dict
42
+ with a capitalized key describing the allowed value and an allowed
43
+ value. These dicts store the allowed enum values.
44
+ attribute_map (dict): The key is attribute name
45
+ and the value is json key in definition.
46
+ discriminator_value_class_map (dict): A dict to go from the discriminator
47
+ variable value to the discriminator class name.
48
+ validations (dict): The key is the tuple path to the attribute
49
+ and the for var_name this is (var_name,). The value is a dict
50
+ that stores validations for max_length, min_length, max_items,
51
+ min_items, exclusive_maximum, inclusive_maximum, exclusive_minimum,
52
+ inclusive_minimum, and regex.
53
+ additional_properties_type (tuple): A tuple of classes accepted
54
+ as additional properties values.
55
+ """
56
+
57
+ allowed_values = {
58
+ ('lookback_days',): {
59
+ 'UNKNOWN': "Unknown",
60
+ 'LAST7DAYS': "Last7Days",
61
+ 'LAST14DAYS': "Last14Days",
62
+ 'LAST30DAYS': "Last30Days",
63
+ 'LAST45DAYS': "Last45Days",
64
+ 'LAST60DAYS': "Last60Days",
65
+ 'LAST90DAYS': "Last90Days",
66
+ 'LAST120DAYS': "Last120Days",
67
+ 'LAST150DAYS': "Last150Days",
68
+ 'LAST180DAYS': "Last180Days",
69
+ },
70
+ ('shopper_activity',): {
71
+ 'UNKNOWN': "Unknown",
72
+ 'VIEW': "View",
73
+ 'BUY': "Buy",
74
+ 'ADDTOCART': "AddToCart",
75
+ },
76
+ }
77
+
78
+ validations = {
79
+ ('brand_ids',): {
80
+ },
81
+ ('category_ids',): {
82
+ },
83
+ }
84
+
85
+ @cached_property
86
+ def additional_properties_type():
87
+ """
88
+ This must be a method because a model may have properties that are
89
+ of type self, this must run after the class is loaded
90
+ """
91
+ return (bool, date, datetime, dict, float, int, list, str, none_type,) # noqa: E501
92
+
93
+ _nullable = False
94
+
95
+ @cached_property
96
+ def openapi_types():
97
+ """
98
+ This must be a method because a model may have properties that are
99
+ of type self, this must run after the class is loaded
100
+
101
+ Returns
102
+ openapi_types (dict): The key is attribute name
103
+ and the value is attribute type.
104
+ """
105
+ return {
106
+ 'brand_ids': ([str],), # noqa: E501
107
+ 'category_ids': ([str],), # noqa: E501
108
+ 'lookback_days': (str,), # noqa: E501
109
+ 'max_price': (float,), # noqa: E501
110
+ 'min_price': (float,), # noqa: E501
111
+ 'shopper_activity': (str,), # noqa: E501
112
+ }
113
+
114
+ @cached_property
115
+ def discriminator():
116
+ return None
117
+
118
+
119
+ attribute_map = {
120
+ 'brand_ids': 'brandIds', # noqa: E501
121
+ 'category_ids': 'categoryIds', # noqa: E501
122
+ 'lookback_days': 'lookbackDays', # noqa: E501
123
+ 'max_price': 'maxPrice', # noqa: E501
124
+ 'min_price': 'minPrice', # noqa: E501
125
+ 'shopper_activity': 'shopperActivity', # noqa: E501
126
+ }
127
+
128
+ read_only_vars = {
129
+ }
130
+
131
+ _composed_schemas = {}
132
+
133
+ @classmethod
134
+ @convert_js_args_to_python_args
135
+ def _from_openapi_data(cls, *args, **kwargs): # noqa: E501
136
+ """RmEventsEstimationV1 - a model defined in OpenAPI
137
+
138
+ Keyword Args:
139
+ _check_type (bool): if True, values for parameters in openapi_types
140
+ will be type checked and a TypeError will be
141
+ raised if the wrong type is input.
142
+ Defaults to True
143
+ _path_to_item (tuple/list): This is a list of keys or values to
144
+ drill down to the model in received_data
145
+ when deserializing a response
146
+ _spec_property_naming (bool): True if the variable names in the input data
147
+ are serialized names, as specified in the OpenAPI document.
148
+ False if the variable names in the input data
149
+ are pythonic names, e.g. snake case (default)
150
+ _configuration (Configuration): the instance to use when
151
+ deserializing a file_type parameter.
152
+ If passed, type conversion is attempted
153
+ If omitted no type conversion is done.
154
+ _visited_composed_classes (tuple): This stores a tuple of
155
+ classes that we have traveled through so that
156
+ if we see that class again we will not use its
157
+ discriminator again.
158
+ When traveling through a discriminator, the
159
+ composed schema that is
160
+ is traveled through is added to this set.
161
+ For example if Animal has a discriminator
162
+ petType and we pass in "Dog", and the class Dog
163
+ allOf includes Animal, we move through Animal
164
+ once using the discriminator, and pick Dog.
165
+ Then in Dog, we will make an instance of the
166
+ Animal class but this time we won't travel
167
+ through its discriminator because we passed in
168
+ _visited_composed_classes = (Animal,)
169
+ brand_ids ([str]): [optional] # noqa: E501
170
+ category_ids ([str]): [optional] # noqa: E501
171
+ lookback_days (str): [optional] # noqa: E501
172
+ max_price (float): [optional] # noqa: E501
173
+ min_price (float): [optional] # noqa: E501
174
+ shopper_activity (str): [optional] # noqa: E501
175
+ """
176
+
177
+ _check_type = kwargs.pop('_check_type', True)
178
+ _spec_property_naming = kwargs.pop('_spec_property_naming', True)
179
+ _path_to_item = kwargs.pop('_path_to_item', ())
180
+ _configuration = kwargs.pop('_configuration', None)
181
+ _visited_composed_classes = kwargs.pop('_visited_composed_classes', ())
182
+
183
+ self = super(OpenApiModel, cls).__new__(cls)
184
+
185
+ if args:
186
+ for arg in args:
187
+ if isinstance(arg, dict):
188
+ kwargs.update(arg)
189
+ else:
190
+ raise ApiTypeError(
191
+ "Invalid positional arguments=%s passed to %s. Remove those invalid positional arguments." % (
192
+ args,
193
+ self.__class__.__name__,
194
+ ),
195
+ path_to_item=_path_to_item,
196
+ valid_classes=(self.__class__,),
197
+ )
198
+
199
+ self._data_store = {}
200
+ self._check_type = _check_type
201
+ self._spec_property_naming = _spec_property_naming
202
+ self._path_to_item = _path_to_item
203
+ self._configuration = _configuration
204
+ self._visited_composed_classes = _visited_composed_classes + (self.__class__,)
205
+
206
+ for var_name, var_value in kwargs.items():
207
+ if var_name not in self.attribute_map and \
208
+ self._configuration is not None and \
209
+ self._configuration.discard_unknown_keys and \
210
+ self.additional_properties_type is None:
211
+ # discard variable.
212
+ continue
213
+ setattr(self, var_name, var_value)
214
+ return self
215
+
216
+ required_properties = set([
217
+ '_data_store',
218
+ '_check_type',
219
+ '_spec_property_naming',
220
+ '_path_to_item',
221
+ '_configuration',
222
+ '_visited_composed_classes',
223
+ ])
224
+
225
+ @convert_js_args_to_python_args
226
+ def __init__(self, *args, **kwargs): # noqa: E501
227
+ """RmEventsEstimationV1 - a model defined in OpenAPI
228
+
229
+ Keyword Args:
230
+ _check_type (bool): if True, values for parameters in openapi_types
231
+ will be type checked and a TypeError will be
232
+ raised if the wrong type is input.
233
+ Defaults to True
234
+ _path_to_item (tuple/list): This is a list of keys or values to
235
+ drill down to the model in received_data
236
+ when deserializing a response
237
+ _spec_property_naming (bool): True if the variable names in the input data
238
+ are serialized names, as specified in the OpenAPI document.
239
+ False if the variable names in the input data
240
+ are pythonic names, e.g. snake case (default)
241
+ _configuration (Configuration): the instance to use when
242
+ deserializing a file_type parameter.
243
+ If passed, type conversion is attempted
244
+ If omitted no type conversion is done.
245
+ _visited_composed_classes (tuple): This stores a tuple of
246
+ classes that we have traveled through so that
247
+ if we see that class again we will not use its
248
+ discriminator again.
249
+ When traveling through a discriminator, the
250
+ composed schema that is
251
+ is traveled through is added to this set.
252
+ For example if Animal has a discriminator
253
+ petType and we pass in "Dog", and the class Dog
254
+ allOf includes Animal, we move through Animal
255
+ once using the discriminator, and pick Dog.
256
+ Then in Dog, we will make an instance of the
257
+ Animal class but this time we won't travel
258
+ through its discriminator because we passed in
259
+ _visited_composed_classes = (Animal,)
260
+ brand_ids ([str]): [optional] # noqa: E501
261
+ category_ids ([str]): [optional] # noqa: E501
262
+ lookback_days (str): [optional] # noqa: E501
263
+ max_price (float): [optional] # noqa: E501
264
+ min_price (float): [optional] # noqa: E501
265
+ shopper_activity (str): [optional] # noqa: E501
266
+ """
267
+
268
+ _check_type = kwargs.pop('_check_type', True)
269
+ _spec_property_naming = kwargs.pop('_spec_property_naming', False)
270
+ _path_to_item = kwargs.pop('_path_to_item', ())
271
+ _configuration = kwargs.pop('_configuration', None)
272
+ _visited_composed_classes = kwargs.pop('_visited_composed_classes', ())
273
+
274
+ if args:
275
+ for arg in args:
276
+ if isinstance(arg, dict):
277
+ kwargs.update(arg)
278
+ else:
279
+ raise ApiTypeError(
280
+ "Invalid positional arguments=%s passed to %s. Remove those invalid positional arguments." % (
281
+ args,
282
+ self.__class__.__name__,
283
+ ),
284
+ path_to_item=_path_to_item,
285
+ valid_classes=(self.__class__,),
286
+ )
287
+
288
+ self._data_store = {}
289
+ self._check_type = _check_type
290
+ self._spec_property_naming = _spec_property_naming
291
+ self._path_to_item = _path_to_item
292
+ self._configuration = _configuration
293
+ self._visited_composed_classes = _visited_composed_classes + (self.__class__,)
294
+
295
+ for var_name, var_value in kwargs.items():
296
+ if var_name not in self.attribute_map and \
297
+ self._configuration is not None and \
298
+ self._configuration.discard_unknown_keys and \
299
+ self.additional_properties_type is None:
300
+ # discard variable.
301
+ continue
302
+ setattr(self, var_name, var_value)
303
+ if var_name in self.read_only_vars:
304
+ raise ApiAttributeError(f"`{var_name}` is a read-only attribute. Use `from_openapi_data` to instantiate "
305
+ f"class with read only attributes.")
@@ -0,0 +1,307 @@
1
+ """
2
+ Criteo API
3
+
4
+ Criteo API - RetailMedia # noqa: E501
5
+
6
+ The version of the OpenAPI document: Preview
7
+ Generated by: https://openapi-generator.tech
8
+ """
9
+
10
+
11
+ import re # noqa: F401
12
+ import sys # noqa: F401
13
+
14
+ from criteo_api_retailmedia_preview.model_utils import ( # noqa: F401
15
+ ApiTypeError,
16
+ ModelComposed,
17
+ ModelNormal,
18
+ ModelSimple,
19
+ cached_property,
20
+ change_keys_js_to_python,
21
+ convert_js_args_to_python_args,
22
+ date,
23
+ datetime,
24
+ file_type,
25
+ none_type,
26
+ validate_get_composed_info,
27
+ OpenApiModel
28
+ )
29
+ from criteo_api_retailmedia_preview.exceptions import ApiAttributeError
30
+
31
+
32
+ def lazy_import():
33
+ from criteo_api_retailmedia_preview.model.nillable_decimal import NillableDecimal
34
+ globals()['NillableDecimal'] = NillableDecimal
35
+
36
+
37
+ class RmEventsUpdateV1(ModelNormal):
38
+ """NOTE: This class is auto generated by OpenAPI Generator.
39
+ Ref: https://openapi-generator.tech
40
+
41
+ Do not edit the class manually.
42
+
43
+ Attributes:
44
+ allowed_values (dict): The key is the tuple path to the attribute
45
+ and the for var_name this is (var_name,). The value is a dict
46
+ with a capitalized key describing the allowed value and an allowed
47
+ value. These dicts store the allowed enum values.
48
+ attribute_map (dict): The key is attribute name
49
+ and the value is json key in definition.
50
+ discriminator_value_class_map (dict): A dict to go from the discriminator
51
+ variable value to the discriminator class name.
52
+ validations (dict): The key is the tuple path to the attribute
53
+ and the for var_name this is (var_name,). The value is a dict
54
+ that stores validations for max_length, min_length, max_items,
55
+ min_items, exclusive_maximum, inclusive_maximum, exclusive_minimum,
56
+ inclusive_minimum, and regex.
57
+ additional_properties_type (tuple): A tuple of classes accepted
58
+ as additional properties values.
59
+ """
60
+
61
+ allowed_values = {
62
+ ('lookback_days',): {
63
+ 'UNKNOWN': "Unknown",
64
+ 'LAST7DAYS': "Last7Days",
65
+ 'LAST14DAYS': "Last14Days",
66
+ 'LAST30DAYS': "Last30Days",
67
+ 'LAST45DAYS': "Last45Days",
68
+ 'LAST60DAYS': "Last60Days",
69
+ 'LAST90DAYS': "Last90Days",
70
+ 'LAST120DAYS': "Last120Days",
71
+ 'LAST150DAYS': "Last150Days",
72
+ 'LAST180DAYS': "Last180Days",
73
+ },
74
+ ('shopper_activity',): {
75
+ 'UNKNOWN': "Unknown",
76
+ 'VIEW': "View",
77
+ 'BUY': "Buy",
78
+ 'ADDTOCART': "AddToCart",
79
+ },
80
+ }
81
+
82
+ validations = {
83
+ }
84
+
85
+ @cached_property
86
+ def additional_properties_type():
87
+ """
88
+ This must be a method because a model may have properties that are
89
+ of type self, this must run after the class is loaded
90
+ """
91
+ lazy_import()
92
+ return (bool, date, datetime, dict, float, int, list, str, none_type,) # noqa: E501
93
+
94
+ _nullable = False
95
+
96
+ @cached_property
97
+ def openapi_types():
98
+ """
99
+ This must be a method because a model may have properties that are
100
+ of type self, this must run after the class is loaded
101
+
102
+ Returns
103
+ openapi_types (dict): The key is attribute name
104
+ and the value is attribute type.
105
+ """
106
+ lazy_import()
107
+ return {
108
+ 'brand_ids': ([str],), # noqa: E501
109
+ 'category_ids': ([str],), # noqa: E501
110
+ 'lookback_days': (str,), # noqa: E501
111
+ 'max_price': (NillableDecimal,), # noqa: E501
112
+ 'min_price': (NillableDecimal,), # noqa: E501
113
+ 'shopper_activity': (str,), # noqa: E501
114
+ }
115
+
116
+ @cached_property
117
+ def discriminator():
118
+ return None
119
+
120
+
121
+ attribute_map = {
122
+ 'brand_ids': 'brandIds', # noqa: E501
123
+ 'category_ids': 'categoryIds', # noqa: E501
124
+ 'lookback_days': 'lookbackDays', # noqa: E501
125
+ 'max_price': 'maxPrice', # noqa: E501
126
+ 'min_price': 'minPrice', # noqa: E501
127
+ 'shopper_activity': 'shopperActivity', # noqa: E501
128
+ }
129
+
130
+ read_only_vars = {
131
+ }
132
+
133
+ _composed_schemas = {}
134
+
135
+ @classmethod
136
+ @convert_js_args_to_python_args
137
+ def _from_openapi_data(cls, *args, **kwargs): # noqa: E501
138
+ """RmEventsUpdateV1 - a model defined in OpenAPI
139
+
140
+ Keyword Args:
141
+ _check_type (bool): if True, values for parameters in openapi_types
142
+ will be type checked and a TypeError will be
143
+ raised if the wrong type is input.
144
+ Defaults to True
145
+ _path_to_item (tuple/list): This is a list of keys or values to
146
+ drill down to the model in received_data
147
+ when deserializing a response
148
+ _spec_property_naming (bool): True if the variable names in the input data
149
+ are serialized names, as specified in the OpenAPI document.
150
+ False if the variable names in the input data
151
+ are pythonic names, e.g. snake case (default)
152
+ _configuration (Configuration): the instance to use when
153
+ deserializing a file_type parameter.
154
+ If passed, type conversion is attempted
155
+ If omitted no type conversion is done.
156
+ _visited_composed_classes (tuple): This stores a tuple of
157
+ classes that we have traveled through so that
158
+ if we see that class again we will not use its
159
+ discriminator again.
160
+ When traveling through a discriminator, the
161
+ composed schema that is
162
+ is traveled through is added to this set.
163
+ For example if Animal has a discriminator
164
+ petType and we pass in "Dog", and the class Dog
165
+ allOf includes Animal, we move through Animal
166
+ once using the discriminator, and pick Dog.
167
+ Then in Dog, we will make an instance of the
168
+ Animal class but this time we won't travel
169
+ through its discriminator because we passed in
170
+ _visited_composed_classes = (Animal,)
171
+ brand_ids ([str]): Choose the brands your segment might be interested in. [optional] # noqa: E501
172
+ category_ids ([str]): Choose the categories your segment might be interested in. [optional] # noqa: E501
173
+ lookback_days (str): Number of days of the lookback windows. [optional] # noqa: E501
174
+ max_price (NillableDecimal): [optional] # noqa: E501
175
+ min_price (NillableDecimal): [optional] # noqa: E501
176
+ shopper_activity (str): Types of shopper activity.. [optional] # noqa: E501
177
+ """
178
+
179
+ _check_type = kwargs.pop('_check_type', True)
180
+ _spec_property_naming = kwargs.pop('_spec_property_naming', True)
181
+ _path_to_item = kwargs.pop('_path_to_item', ())
182
+ _configuration = kwargs.pop('_configuration', None)
183
+ _visited_composed_classes = kwargs.pop('_visited_composed_classes', ())
184
+
185
+ self = super(OpenApiModel, cls).__new__(cls)
186
+
187
+ if args:
188
+ for arg in args:
189
+ if isinstance(arg, dict):
190
+ kwargs.update(arg)
191
+ else:
192
+ raise ApiTypeError(
193
+ "Invalid positional arguments=%s passed to %s. Remove those invalid positional arguments." % (
194
+ args,
195
+ self.__class__.__name__,
196
+ ),
197
+ path_to_item=_path_to_item,
198
+ valid_classes=(self.__class__,),
199
+ )
200
+
201
+ self._data_store = {}
202
+ self._check_type = _check_type
203
+ self._spec_property_naming = _spec_property_naming
204
+ self._path_to_item = _path_to_item
205
+ self._configuration = _configuration
206
+ self._visited_composed_classes = _visited_composed_classes + (self.__class__,)
207
+
208
+ for var_name, var_value in kwargs.items():
209
+ if var_name not in self.attribute_map and \
210
+ self._configuration is not None and \
211
+ self._configuration.discard_unknown_keys and \
212
+ self.additional_properties_type is None:
213
+ # discard variable.
214
+ continue
215
+ setattr(self, var_name, var_value)
216
+ return self
217
+
218
+ required_properties = set([
219
+ '_data_store',
220
+ '_check_type',
221
+ '_spec_property_naming',
222
+ '_path_to_item',
223
+ '_configuration',
224
+ '_visited_composed_classes',
225
+ ])
226
+
227
+ @convert_js_args_to_python_args
228
+ def __init__(self, *args, **kwargs): # noqa: E501
229
+ """RmEventsUpdateV1 - a model defined in OpenAPI
230
+
231
+ Keyword Args:
232
+ _check_type (bool): if True, values for parameters in openapi_types
233
+ will be type checked and a TypeError will be
234
+ raised if the wrong type is input.
235
+ Defaults to True
236
+ _path_to_item (tuple/list): This is a list of keys or values to
237
+ drill down to the model in received_data
238
+ when deserializing a response
239
+ _spec_property_naming (bool): True if the variable names in the input data
240
+ are serialized names, as specified in the OpenAPI document.
241
+ False if the variable names in the input data
242
+ are pythonic names, e.g. snake case (default)
243
+ _configuration (Configuration): the instance to use when
244
+ deserializing a file_type parameter.
245
+ If passed, type conversion is attempted
246
+ If omitted no type conversion is done.
247
+ _visited_composed_classes (tuple): This stores a tuple of
248
+ classes that we have traveled through so that
249
+ if we see that class again we will not use its
250
+ discriminator again.
251
+ When traveling through a discriminator, the
252
+ composed schema that is
253
+ is traveled through is added to this set.
254
+ For example if Animal has a discriminator
255
+ petType and we pass in "Dog", and the class Dog
256
+ allOf includes Animal, we move through Animal
257
+ once using the discriminator, and pick Dog.
258
+ Then in Dog, we will make an instance of the
259
+ Animal class but this time we won't travel
260
+ through its discriminator because we passed in
261
+ _visited_composed_classes = (Animal,)
262
+ brand_ids ([str]): Choose the brands your segment might be interested in. [optional] # noqa: E501
263
+ category_ids ([str]): Choose the categories your segment might be interested in. [optional] # noqa: E501
264
+ lookback_days (str): Number of days of the lookback windows. [optional] # noqa: E501
265
+ max_price (NillableDecimal): [optional] # noqa: E501
266
+ min_price (NillableDecimal): [optional] # noqa: E501
267
+ shopper_activity (str): Types of shopper activity.. [optional] # noqa: E501
268
+ """
269
+
270
+ _check_type = kwargs.pop('_check_type', True)
271
+ _spec_property_naming = kwargs.pop('_spec_property_naming', False)
272
+ _path_to_item = kwargs.pop('_path_to_item', ())
273
+ _configuration = kwargs.pop('_configuration', None)
274
+ _visited_composed_classes = kwargs.pop('_visited_composed_classes', ())
275
+
276
+ if args:
277
+ for arg in args:
278
+ if isinstance(arg, dict):
279
+ kwargs.update(arg)
280
+ else:
281
+ raise ApiTypeError(
282
+ "Invalid positional arguments=%s passed to %s. Remove those invalid positional arguments." % (
283
+ args,
284
+ self.__class__.__name__,
285
+ ),
286
+ path_to_item=_path_to_item,
287
+ valid_classes=(self.__class__,),
288
+ )
289
+
290
+ self._data_store = {}
291
+ self._check_type = _check_type
292
+ self._spec_property_naming = _spec_property_naming
293
+ self._path_to_item = _path_to_item
294
+ self._configuration = _configuration
295
+ self._visited_composed_classes = _visited_composed_classes + (self.__class__,)
296
+
297
+ for var_name, var_value in kwargs.items():
298
+ if var_name not in self.attribute_map and \
299
+ self._configuration is not None and \
300
+ self._configuration.discard_unknown_keys and \
301
+ self.additional_properties_type is None:
302
+ # discard variable.
303
+ continue
304
+ setattr(self, var_name, var_value)
305
+ if var_name in self.read_only_vars:
306
+ raise ApiAttributeError(f"`{var_name}` is a read-only attribute. Use `from_openapi_data` to instantiate "
307
+ f"class with read only attributes.")
@@ -105,9 +105,9 @@ class SkuSlimDataPreview(ModelNormal):
105
105
  'updated_at': (datetime,), # noqa: E501
106
106
  'category': (str,), # noqa: E501
107
107
  'global_category_id': (str,), # noqa: E501
108
- 'gtin': (str,), # noqa: E501
108
+ 'gtin': (str, none_type,), # noqa: E501
109
109
  'image_url': (str,), # noqa: E501
110
- 'mpn': (str,), # noqa: E501
110
+ 'mpn': (str, none_type,), # noqa: E501
111
111
  'name': (str,), # noqa: E501
112
112
  'retailer_brand_id': (str,), # noqa: E501
113
113
  'retailer_brand_name': (str,), # noqa: E501
@@ -186,9 +186,9 @@ class SkuSlimDataPreview(ModelNormal):
186
186
  _visited_composed_classes = (Animal,)
187
187
  category (str): The full category breadcrumb in the retailers catalog.. [optional] # noqa: E501
188
188
  global_category_id (str): The global category Id.. [optional] # noqa: E501
189
- gtin (str): A GTIN identifier for the product if available. Covers variations such as EANs and UPCs.. [optional] # noqa: E501
189
+ gtin (str, none_type): A GTIN identifier for the product if available. Covers variations such as EANs and UPCs.. [optional] # noqa: E501
190
190
  image_url (str): An http image resource provided by the retailer.. [optional] # noqa: E501
191
- mpn (str): The MPN for the product if available.. [optional] # noqa: E501
191
+ mpn (str, none_type): The MPN for the product if available.. [optional] # noqa: E501
192
192
  name (str): A short product name.. [optional] # noqa: E501
193
193
  retailer_brand_id (str): The retailer brand id associated to the product.. [optional] # noqa: E501
194
194
  retailer_brand_name (str): The name of the retailer brand.. [optional] # noqa: E501
@@ -293,9 +293,9 @@ class SkuSlimDataPreview(ModelNormal):
293
293
  _visited_composed_classes = (Animal,)
294
294
  category (str): The full category breadcrumb in the retailers catalog.. [optional] # noqa: E501
295
295
  global_category_id (str): The global category Id.. [optional] # noqa: E501
296
- gtin (str): A GTIN identifier for the product if available. Covers variations such as EANs and UPCs.. [optional] # noqa: E501
296
+ gtin (str, none_type): A GTIN identifier for the product if available. Covers variations such as EANs and UPCs.. [optional] # noqa: E501
297
297
  image_url (str): An http image resource provided by the retailer.. [optional] # noqa: E501
298
- mpn (str): The MPN for the product if available.. [optional] # noqa: E501
298
+ mpn (str, none_type): The MPN for the product if available.. [optional] # noqa: E501
299
299
  name (str): A short product name.. [optional] # noqa: E501
300
300
  retailer_brand_id (str): The retailer brand id associated to the product.. [optional] # noqa: E501
301
301
  retailer_brand_name (str): The name of the retailer brand.. [optional] # noqa: E501