criteo-api-retailmedia-sdk 0.0.250915__py3-none-any.whl → 0.0.251014__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.

Potentially problematic release.


This version of criteo-api-retailmedia-sdk might be problematic. Click here for more details.

Files changed (34) hide show
  1. criteo_api_retailmedia_preview/__init__.py +1 -1
  2. criteo_api_retailmedia_preview/api/accounts_api.py +70 -73
  3. criteo_api_retailmedia_preview/api/analytics_api.py +137 -0
  4. criteo_api_retailmedia_preview/api/audience_api.py +12 -12
  5. criteo_api_retailmedia_preview/api/billing_api.py +18 -18
  6. criteo_api_retailmedia_preview/api/campaign_api.py +493 -325
  7. criteo_api_retailmedia_preview/api_client.py +4 -4
  8. criteo_api_retailmedia_preview/configuration.py +1 -1
  9. criteo_api_retailmedia_preview/model/async_fill_rate_report.py +5 -0
  10. criteo_api_retailmedia_preview/model/async_unfilled_placements_report.py +392 -0
  11. criteo_api_retailmedia_preview/model/async_unfilled_placements_report_request.py +269 -0
  12. criteo_api_retailmedia_preview/model/async_unfilled_placements_report_resource.py +273 -0
  13. criteo_api_retailmedia_preview/model/campaign_availability.py +289 -0
  14. criteo_api_retailmedia_preview/model/demand_managed_fee.py +1 -1
  15. criteo_api_retailmedia_preview/model/{value_resource_outcome_account_fees_update_result.py → entity_resource_collection_outcome_of_retailer_result_and_metadata.py} +14 -8
  16. criteo_api_retailmedia_preview/model/entity_resource_of_retailer_result.py +270 -0
  17. criteo_api_retailmedia_preview/model/files_variable_value.py +0 -3
  18. criteo_api_retailmedia_preview/model/managed_service_fee.py +1 -1
  19. criteo_api_retailmedia_preview/model/page_type_combination.py +287 -0
  20. criteo_api_retailmedia_preview/model/private_market_fees.py +6 -14
  21. criteo_api_retailmedia_preview/model/retailer_result.py +266 -0
  22. criteo_api_retailmedia_preview/model/{account_fees_update_result.py → retailer_search_request.py} +8 -12
  23. criteo_api_retailmedia_preview/model/rm_contact_list_create_v1.py +1 -0
  24. criteo_api_retailmedia_preview/model/rm_contact_list_v1.py +1 -0
  25. criteo_api_retailmedia_preview/model/sponsored_products_line_item.py +11 -2
  26. criteo_api_retailmedia_preview/model/sponsored_products_line_item_create_request_model.py +8 -0
  27. criteo_api_retailmedia_preview/model/sponsored_products_line_item_update_request_model.py +34 -28
  28. criteo_api_retailmedia_preview/model/value_resource_input_of_retailer_search_request.py +262 -0
  29. criteo_api_retailmedia_preview/model/{value_resource_account_fees_update_result.py → value_resource_of_retailer_search_request.py} +9 -9
  30. criteo_api_retailmedia_preview/models/__init__.py +11 -3
  31. {criteo_api_retailmedia_sdk-0.0.250915.dist-info → criteo_api_retailmedia_sdk-0.0.251014.dist-info}/METADATA +3 -3
  32. {criteo_api_retailmedia_sdk-0.0.250915.dist-info → criteo_api_retailmedia_sdk-0.0.251014.dist-info}/RECORD +34 -26
  33. {criteo_api_retailmedia_sdk-0.0.250915.dist-info → criteo_api_retailmedia_sdk-0.0.251014.dist-info}/WHEEL +0 -0
  34. {criteo_api_retailmedia_sdk-0.0.250915.dist-info → criteo_api_retailmedia_sdk-0.0.251014.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,287 @@
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 PageTypeCombination(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
+ ('page_environment_type',): {
59
+ 'None': None,
60
+ 'UNKNOWN': "unknown",
61
+ 'WEB': "web",
62
+ 'MOBILE': "mobile",
63
+ 'APP': "app",
64
+ 'LOCKOUT': "lockout",
65
+ 'MIXED': "mixed",
66
+ 'IOS': "ios",
67
+ 'ANDROID': "android",
68
+ },
69
+ ('page_type',): {
70
+ 'None': None,
71
+ 'UNKNOWN': "unknown",
72
+ 'SEARCH': "search",
73
+ 'HOME': "home",
74
+ 'CHECKOUT': "checkout",
75
+ 'CATEGORY': "category",
76
+ 'PRODUCTDETAIL': "productdetail",
77
+ 'CONFIRMATION': "confirmation",
78
+ 'MERCHANDISING': "merchandising",
79
+ 'DEALS': "deals",
80
+ 'FAVORITES': "favorites",
81
+ 'SEARCHBAR': "searchbar",
82
+ 'CATEGORYMENU': "categorymenu",
83
+ },
84
+ }
85
+
86
+ validations = {
87
+ }
88
+
89
+ additional_properties_type = None
90
+
91
+ _nullable = False
92
+
93
+ @cached_property
94
+ def openapi_types():
95
+ """
96
+ This must be a method because a model may have properties that are
97
+ of type self, this must run after the class is loaded
98
+
99
+ Returns
100
+ openapi_types (dict): The key is attribute name
101
+ and the value is attribute type.
102
+ """
103
+ return {
104
+ 'page_environment_type': (str, none_type,), # noqa: E501
105
+ 'page_type': (str, none_type,), # noqa: E501
106
+ }
107
+
108
+ @cached_property
109
+ def discriminator():
110
+ return None
111
+
112
+
113
+ attribute_map = {
114
+ 'page_environment_type': 'pageEnvironmentType', # noqa: E501
115
+ 'page_type': 'pageType', # noqa: E501
116
+ }
117
+
118
+ read_only_vars = {
119
+ }
120
+
121
+ _composed_schemas = {}
122
+
123
+ @classmethod
124
+ @convert_js_args_to_python_args
125
+ def _from_openapi_data(cls, *args, **kwargs): # noqa: E501
126
+ """PageTypeCombination - a model defined in OpenAPI
127
+
128
+ Keyword Args:
129
+ _check_type (bool): if True, values for parameters in openapi_types
130
+ will be type checked and a TypeError will be
131
+ raised if the wrong type is input.
132
+ Defaults to True
133
+ _path_to_item (tuple/list): This is a list of keys or values to
134
+ drill down to the model in received_data
135
+ when deserializing a response
136
+ _spec_property_naming (bool): True if the variable names in the input data
137
+ are serialized names, as specified in the OpenAPI document.
138
+ False if the variable names in the input data
139
+ are pythonic names, e.g. snake case (default)
140
+ _configuration (Configuration): the instance to use when
141
+ deserializing a file_type parameter.
142
+ If passed, type conversion is attempted
143
+ If omitted no type conversion is done.
144
+ _visited_composed_classes (tuple): This stores a tuple of
145
+ classes that we have traveled through so that
146
+ if we see that class again we will not use its
147
+ discriminator again.
148
+ When traveling through a discriminator, the
149
+ composed schema that is
150
+ is traveled through is added to this set.
151
+ For example if Animal has a discriminator
152
+ petType and we pass in "Dog", and the class Dog
153
+ allOf includes Animal, we move through Animal
154
+ once using the discriminator, and pick Dog.
155
+ Then in Dog, we will make an instance of the
156
+ Animal class but this time we won't travel
157
+ through its discriminator because we passed in
158
+ _visited_composed_classes = (Animal,)
159
+ page_environment_type (str, none_type): The page types which are supported for this campaign-buy type combination. [optional] # noqa: E501
160
+ page_type (str, none_type): The page types which are supported for this campaign-buy type combination. [optional] # noqa: E501
161
+ """
162
+
163
+ _check_type = kwargs.pop('_check_type', True)
164
+ _spec_property_naming = kwargs.pop('_spec_property_naming', True)
165
+ _path_to_item = kwargs.pop('_path_to_item', ())
166
+ _configuration = kwargs.pop('_configuration', None)
167
+ _visited_composed_classes = kwargs.pop('_visited_composed_classes', ())
168
+
169
+ self = super(OpenApiModel, cls).__new__(cls)
170
+
171
+ if args:
172
+ for arg in args:
173
+ if isinstance(arg, dict):
174
+ kwargs.update(arg)
175
+ else:
176
+ raise ApiTypeError(
177
+ "Invalid positional arguments=%s passed to %s. Remove those invalid positional arguments." % (
178
+ args,
179
+ self.__class__.__name__,
180
+ ),
181
+ path_to_item=_path_to_item,
182
+ valid_classes=(self.__class__,),
183
+ )
184
+
185
+ self._data_store = {}
186
+ self._check_type = _check_type
187
+ self._spec_property_naming = _spec_property_naming
188
+ self._path_to_item = _path_to_item
189
+ self._configuration = _configuration
190
+ self._visited_composed_classes = _visited_composed_classes + (self.__class__,)
191
+
192
+ for var_name, var_value in kwargs.items():
193
+ if var_name not in self.attribute_map and \
194
+ self._configuration is not None and \
195
+ self._configuration.discard_unknown_keys and \
196
+ self.additional_properties_type is None:
197
+ # discard variable.
198
+ continue
199
+ setattr(self, var_name, var_value)
200
+ return self
201
+
202
+ required_properties = set([
203
+ '_data_store',
204
+ '_check_type',
205
+ '_spec_property_naming',
206
+ '_path_to_item',
207
+ '_configuration',
208
+ '_visited_composed_classes',
209
+ ])
210
+
211
+ @convert_js_args_to_python_args
212
+ def __init__(self, *args, **kwargs): # noqa: E501
213
+ """PageTypeCombination - a model defined in OpenAPI
214
+
215
+ Keyword Args:
216
+ _check_type (bool): if True, values for parameters in openapi_types
217
+ will be type checked and a TypeError will be
218
+ raised if the wrong type is input.
219
+ Defaults to True
220
+ _path_to_item (tuple/list): This is a list of keys or values to
221
+ drill down to the model in received_data
222
+ when deserializing a response
223
+ _spec_property_naming (bool): True if the variable names in the input data
224
+ are serialized names, as specified in the OpenAPI document.
225
+ False if the variable names in the input data
226
+ are pythonic names, e.g. snake case (default)
227
+ _configuration (Configuration): the instance to use when
228
+ deserializing a file_type parameter.
229
+ If passed, type conversion is attempted
230
+ If omitted no type conversion is done.
231
+ _visited_composed_classes (tuple): This stores a tuple of
232
+ classes that we have traveled through so that
233
+ if we see that class again we will not use its
234
+ discriminator again.
235
+ When traveling through a discriminator, the
236
+ composed schema that is
237
+ is traveled through is added to this set.
238
+ For example if Animal has a discriminator
239
+ petType and we pass in "Dog", and the class Dog
240
+ allOf includes Animal, we move through Animal
241
+ once using the discriminator, and pick Dog.
242
+ Then in Dog, we will make an instance of the
243
+ Animal class but this time we won't travel
244
+ through its discriminator because we passed in
245
+ _visited_composed_classes = (Animal,)
246
+ page_environment_type (str, none_type): The page types which are supported for this campaign-buy type combination. [optional] # noqa: E501
247
+ page_type (str, none_type): The page types which are supported for this campaign-buy type combination. [optional] # noqa: E501
248
+ """
249
+
250
+ _check_type = kwargs.pop('_check_type', True)
251
+ _spec_property_naming = kwargs.pop('_spec_property_naming', False)
252
+ _path_to_item = kwargs.pop('_path_to_item', ())
253
+ _configuration = kwargs.pop('_configuration', None)
254
+ _visited_composed_classes = kwargs.pop('_visited_composed_classes', ())
255
+
256
+ if args:
257
+ for arg in args:
258
+ if isinstance(arg, dict):
259
+ kwargs.update(arg)
260
+ else:
261
+ raise ApiTypeError(
262
+ "Invalid positional arguments=%s passed to %s. Remove those invalid positional arguments." % (
263
+ args,
264
+ self.__class__.__name__,
265
+ ),
266
+ path_to_item=_path_to_item,
267
+ valid_classes=(self.__class__,),
268
+ )
269
+
270
+ self._data_store = {}
271
+ self._check_type = _check_type
272
+ self._spec_property_naming = _spec_property_naming
273
+ self._path_to_item = _path_to_item
274
+ self._configuration = _configuration
275
+ self._visited_composed_classes = _visited_composed_classes + (self.__class__,)
276
+
277
+ for var_name, var_value in kwargs.items():
278
+ if var_name not in self.attribute_map and \
279
+ self._configuration is not None and \
280
+ self._configuration.discard_unknown_keys and \
281
+ self.additional_properties_type is None:
282
+ # discard variable.
283
+ continue
284
+ setattr(self, var_name, var_value)
285
+ if var_name in self.read_only_vars:
286
+ raise ApiAttributeError(f"`{var_name}` is a read-only attribute. Use `from_openapi_data` to instantiate "
287
+ f"class with read only attributes.")
@@ -103,13 +103,9 @@ class PrivateMarketFees(ModelNormal):
103
103
 
104
104
  @classmethod
105
105
  @convert_js_args_to_python_args
106
- def _from_openapi_data(cls, demand_managed, managed_service, *args, **kwargs): # noqa: E501
106
+ def _from_openapi_data(cls, *args, **kwargs): # noqa: E501
107
107
  """PrivateMarketFees - a model defined in OpenAPI
108
108
 
109
- Args:
110
- demand_managed (DemandManagedFee):
111
- managed_service (ManagedServiceFee):
112
-
113
109
  Keyword Args:
114
110
  _check_type (bool): if True, values for parameters in openapi_types
115
111
  will be type checked and a TypeError will be
@@ -141,6 +137,8 @@ class PrivateMarketFees(ModelNormal):
141
137
  Animal class but this time we won't travel
142
138
  through its discriminator because we passed in
143
139
  _visited_composed_classes = (Animal,)
140
+ demand_managed (DemandManagedFee): [optional] # noqa: E501
141
+ managed_service (ManagedServiceFee): [optional] # noqa: E501
144
142
  """
145
143
 
146
144
  _check_type = kwargs.pop('_check_type', True)
@@ -172,8 +170,6 @@ class PrivateMarketFees(ModelNormal):
172
170
  self._configuration = _configuration
173
171
  self._visited_composed_classes = _visited_composed_classes + (self.__class__,)
174
172
 
175
- self.demand_managed = demand_managed
176
- self.managed_service = managed_service
177
173
  for var_name, var_value in kwargs.items():
178
174
  if var_name not in self.attribute_map and \
179
175
  self._configuration is not None and \
@@ -194,13 +190,9 @@ class PrivateMarketFees(ModelNormal):
194
190
  ])
195
191
 
196
192
  @convert_js_args_to_python_args
197
- def __init__(self, demand_managed, managed_service, *args, **kwargs): # noqa: E501
193
+ def __init__(self, *args, **kwargs): # noqa: E501
198
194
  """PrivateMarketFees - a model defined in OpenAPI
199
195
 
200
- Args:
201
- demand_managed (DemandManagedFee):
202
- managed_service (ManagedServiceFee):
203
-
204
196
  Keyword Args:
205
197
  _check_type (bool): if True, values for parameters in openapi_types
206
198
  will be type checked and a TypeError will be
@@ -232,6 +224,8 @@ class PrivateMarketFees(ModelNormal):
232
224
  Animal class but this time we won't travel
233
225
  through its discriminator because we passed in
234
226
  _visited_composed_classes = (Animal,)
227
+ demand_managed (DemandManagedFee): [optional] # noqa: E501
228
+ managed_service (ManagedServiceFee): [optional] # noqa: E501
235
229
  """
236
230
 
237
231
  _check_type = kwargs.pop('_check_type', True)
@@ -261,8 +255,6 @@ class PrivateMarketFees(ModelNormal):
261
255
  self._configuration = _configuration
262
256
  self._visited_composed_classes = _visited_composed_classes + (self.__class__,)
263
257
 
264
- self.demand_managed = demand_managed
265
- self.managed_service = managed_service
266
258
  for var_name, var_value in kwargs.items():
267
259
  if var_name not in self.attribute_map and \
268
260
  self._configuration is not None and \
@@ -0,0 +1,266 @@
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.campaign_availability import CampaignAvailability
34
+ globals()['CampaignAvailability'] = CampaignAvailability
35
+
36
+
37
+ class RetailerResult(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
+ }
63
+
64
+ validations = {
65
+ }
66
+
67
+ additional_properties_type = None
68
+
69
+ _nullable = True
70
+
71
+ @cached_property
72
+ def openapi_types():
73
+ """
74
+ This must be a method because a model may have properties that are
75
+ of type self, this must run after the class is loaded
76
+
77
+ Returns
78
+ openapi_types (dict): The key is attribute name
79
+ and the value is attribute type.
80
+ """
81
+ lazy_import()
82
+ return {
83
+ 'campaign_availabilities': ([CampaignAvailability], none_type,), # noqa: E501
84
+ 'name': (str, none_type,), # noqa: E501
85
+ }
86
+
87
+ @cached_property
88
+ def discriminator():
89
+ return None
90
+
91
+
92
+ attribute_map = {
93
+ 'campaign_availabilities': 'campaignAvailabilities', # noqa: E501
94
+ 'name': 'name', # noqa: E501
95
+ }
96
+
97
+ read_only_vars = {
98
+ }
99
+
100
+ _composed_schemas = {}
101
+
102
+ @classmethod
103
+ @convert_js_args_to_python_args
104
+ def _from_openapi_data(cls, *args, **kwargs): # noqa: E501
105
+ """RetailerResult - a model defined in OpenAPI
106
+
107
+ Keyword Args:
108
+ _check_type (bool): if True, values for parameters in openapi_types
109
+ will be type checked and a TypeError will be
110
+ raised if the wrong type is input.
111
+ Defaults to True
112
+ _path_to_item (tuple/list): This is a list of keys or values to
113
+ drill down to the model in received_data
114
+ when deserializing a response
115
+ _spec_property_naming (bool): True if the variable names in the input data
116
+ are serialized names, as specified in the OpenAPI document.
117
+ False if the variable names in the input data
118
+ are pythonic names, e.g. snake case (default)
119
+ _configuration (Configuration): the instance to use when
120
+ deserializing a file_type parameter.
121
+ If passed, type conversion is attempted
122
+ If omitted no type conversion is done.
123
+ _visited_composed_classes (tuple): This stores a tuple of
124
+ classes that we have traveled through so that
125
+ if we see that class again we will not use its
126
+ discriminator again.
127
+ When traveling through a discriminator, the
128
+ composed schema that is
129
+ is traveled through is added to this set.
130
+ For example if Animal has a discriminator
131
+ petType and we pass in "Dog", and the class Dog
132
+ allOf includes Animal, we move through Animal
133
+ once using the discriminator, and pick Dog.
134
+ Then in Dog, we will make an instance of the
135
+ Animal class but this time we won't travel
136
+ through its discriminator because we passed in
137
+ _visited_composed_classes = (Animal,)
138
+ campaign_availabilities ([CampaignAvailability], none_type): A list of campaign availabilities for the retailer, each of which shows the availability of a specific campaign type and buy type combination. [optional] # noqa: E501
139
+ name (str, none_type): Name of the retailer. [optional] # noqa: E501
140
+ """
141
+
142
+ _check_type = kwargs.pop('_check_type', True)
143
+ _spec_property_naming = kwargs.pop('_spec_property_naming', True)
144
+ _path_to_item = kwargs.pop('_path_to_item', ())
145
+ _configuration = kwargs.pop('_configuration', None)
146
+ _visited_composed_classes = kwargs.pop('_visited_composed_classes', ())
147
+
148
+ self = super(OpenApiModel, cls).__new__(cls)
149
+
150
+ if args:
151
+ for arg in args:
152
+ if isinstance(arg, dict):
153
+ kwargs.update(arg)
154
+ else:
155
+ raise ApiTypeError(
156
+ "Invalid positional arguments=%s passed to %s. Remove those invalid positional arguments." % (
157
+ args,
158
+ self.__class__.__name__,
159
+ ),
160
+ path_to_item=_path_to_item,
161
+ valid_classes=(self.__class__,),
162
+ )
163
+
164
+ self._data_store = {}
165
+ self._check_type = _check_type
166
+ self._spec_property_naming = _spec_property_naming
167
+ self._path_to_item = _path_to_item
168
+ self._configuration = _configuration
169
+ self._visited_composed_classes = _visited_composed_classes + (self.__class__,)
170
+
171
+ for var_name, var_value in kwargs.items():
172
+ if var_name not in self.attribute_map and \
173
+ self._configuration is not None and \
174
+ self._configuration.discard_unknown_keys and \
175
+ self.additional_properties_type is None:
176
+ # discard variable.
177
+ continue
178
+ setattr(self, var_name, var_value)
179
+ return self
180
+
181
+ required_properties = set([
182
+ '_data_store',
183
+ '_check_type',
184
+ '_spec_property_naming',
185
+ '_path_to_item',
186
+ '_configuration',
187
+ '_visited_composed_classes',
188
+ ])
189
+
190
+ @convert_js_args_to_python_args
191
+ def __init__(self, *args, **kwargs): # noqa: E501
192
+ """RetailerResult - a model defined in OpenAPI
193
+
194
+ Keyword Args:
195
+ _check_type (bool): if True, values for parameters in openapi_types
196
+ will be type checked and a TypeError will be
197
+ raised if the wrong type is input.
198
+ Defaults to True
199
+ _path_to_item (tuple/list): This is a list of keys or values to
200
+ drill down to the model in received_data
201
+ when deserializing a response
202
+ _spec_property_naming (bool): True if the variable names in the input data
203
+ are serialized names, as specified in the OpenAPI document.
204
+ False if the variable names in the input data
205
+ are pythonic names, e.g. snake case (default)
206
+ _configuration (Configuration): the instance to use when
207
+ deserializing a file_type parameter.
208
+ If passed, type conversion is attempted
209
+ If omitted no type conversion is done.
210
+ _visited_composed_classes (tuple): This stores a tuple of
211
+ classes that we have traveled through so that
212
+ if we see that class again we will not use its
213
+ discriminator again.
214
+ When traveling through a discriminator, the
215
+ composed schema that is
216
+ is traveled through is added to this set.
217
+ For example if Animal has a discriminator
218
+ petType and we pass in "Dog", and the class Dog
219
+ allOf includes Animal, we move through Animal
220
+ once using the discriminator, and pick Dog.
221
+ Then in Dog, we will make an instance of the
222
+ Animal class but this time we won't travel
223
+ through its discriminator because we passed in
224
+ _visited_composed_classes = (Animal,)
225
+ campaign_availabilities ([CampaignAvailability], none_type): A list of campaign availabilities for the retailer, each of which shows the availability of a specific campaign type and buy type combination. [optional] # noqa: E501
226
+ name (str, none_type): Name of the retailer. [optional] # noqa: E501
227
+ """
228
+
229
+ _check_type = kwargs.pop('_check_type', True)
230
+ _spec_property_naming = kwargs.pop('_spec_property_naming', False)
231
+ _path_to_item = kwargs.pop('_path_to_item', ())
232
+ _configuration = kwargs.pop('_configuration', None)
233
+ _visited_composed_classes = kwargs.pop('_visited_composed_classes', ())
234
+
235
+ if args:
236
+ for arg in args:
237
+ if isinstance(arg, dict):
238
+ kwargs.update(arg)
239
+ else:
240
+ raise ApiTypeError(
241
+ "Invalid positional arguments=%s passed to %s. Remove those invalid positional arguments." % (
242
+ args,
243
+ self.__class__.__name__,
244
+ ),
245
+ path_to_item=_path_to_item,
246
+ valid_classes=(self.__class__,),
247
+ )
248
+
249
+ self._data_store = {}
250
+ self._check_type = _check_type
251
+ self._spec_property_naming = _spec_property_naming
252
+ self._path_to_item = _path_to_item
253
+ self._configuration = _configuration
254
+ self._visited_composed_classes = _visited_composed_classes + (self.__class__,)
255
+
256
+ for var_name, var_value in kwargs.items():
257
+ if var_name not in self.attribute_map and \
258
+ self._configuration is not None and \
259
+ self._configuration.discard_unknown_keys and \
260
+ self.additional_properties_type is None:
261
+ # discard variable.
262
+ continue
263
+ setattr(self, var_name, var_value)
264
+ if var_name in self.read_only_vars:
265
+ raise ApiAttributeError(f"`{var_name}` is a read-only attribute. Use `from_openapi_data` to instantiate "
266
+ f"class with read only attributes.")