criteo-api-retailmedia-sdk 0.0.240808__py3-none-any.whl → 0.0.241029__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 (60) hide show
  1. criteo_api_retailmedia_preview/__init__.py +1 -1
  2. criteo_api_retailmedia_preview/api/accounts_api.py +148 -0
  3. criteo_api_retailmedia_preview/api/analytics_api.py +3 -3
  4. criteo_api_retailmedia_preview/api/audience_api.py +89 -232
  5. criteo_api_retailmedia_preview/api/campaign_api.py +0 -564
  6. criteo_api_retailmedia_preview/api/on_site_recommendation_api.py +186 -0
  7. criteo_api_retailmedia_preview/api_client.py +1 -1
  8. criteo_api_retailmedia_preview/apis/__init__.py +1 -0
  9. criteo_api_retailmedia_preview/configuration.py +1 -1
  10. criteo_api_retailmedia_preview/model/bot_message.py +277 -0
  11. criteo_api_retailmedia_preview/model/botmessage.py +329 -0
  12. criteo_api_retailmedia_preview/model/{rm_legacy_audience_get_entity_v2_list_response.py → entity_resource_collection_outcome_of_retail_media_account.py} +8 -8
  13. criteo_api_retailmedia_preview/model/{rm_legacy_audience_get_entity_v1_resource.py → entity_resource_of_retail_media_account.py} +9 -18
  14. criteo_api_retailmedia_preview/model/external_account.py +4 -0
  15. criteo_api_retailmedia_preview/model/{rm_legacy_audience_get_entity_v2.py → external_retail_media_account.py} +54 -32
  16. criteo_api_retailmedia_preview/model/{value_resource_input_of_line_item_budget_overrides.py → http_validation_error.py} +17 -10
  17. criteo_api_retailmedia_preview/model/inbot_discussion.py +272 -0
  18. criteo_api_retailmedia_preview/model/{rm_legacy_segment_customer_list.py → inbot_discussion_body_model.py} +17 -17
  19. criteo_api_retailmedia_preview/model/{rm_legacy_audience_user_behavior_details_v2.py → inbot_discussion_data_instance_model.py} +17 -17
  20. criteo_api_retailmedia_preview/model/{value_resource_input_of_campaign_budget_overrides.py → location_inner.py} +10 -13
  21. criteo_api_retailmedia_preview/model/message.py +273 -0
  22. criteo_api_retailmedia_preview/model/message_body_model.py +275 -0
  23. criteo_api_retailmedia_preview/model/{value_resource_of_line_item_budget_overrides.py → message_data_instance_model.py} +27 -14
  24. criteo_api_retailmedia_preview/model/message_error.py +275 -0
  25. criteo_api_retailmedia_preview/model/product.py +4 -0
  26. criteo_api_retailmedia_preview/model/{rm_legacy_segment_user_behavior_v1.py → product_recommendation.py} +46 -47
  27. criteo_api_retailmedia_preview/model/report_detail_warning.py +285 -0
  28. criteo_api_retailmedia_preview/model/report_detail_warnings.py +281 -0
  29. criteo_api_retailmedia_preview/model/report_ok_response.py +16 -2
  30. criteo_api_retailmedia_preview/model/retail_media_account.py +6 -2
  31. criteo_api_retailmedia_preview/model/retail_media_seller_account_creation.py +6 -2
  32. criteo_api_retailmedia_preview/model/rm_algebra_node_v1.py +275 -0
  33. criteo_api_retailmedia_preview/model/rm_audience_entity_v1.py +307 -0
  34. criteo_api_retailmedia_preview/model/{rm_legacy_audience_get_entity_v2_resource.py → rm_audience_entity_v1_resource.py} +8 -8
  35. criteo_api_retailmedia_preview/model/{rm_legacy_audience_get_entity_v1_list_response.py → rm_audience_entity_v1_rm_audience_search_metadata_v1_list_response.py} +14 -8
  36. criteo_api_retailmedia_preview/model/rm_audience_search_entity_v1.py +271 -0
  37. criteo_api_retailmedia_preview/model/{value_resource_of_campaign_budget_overrides.py → rm_audience_search_entity_v1_resource.py} +16 -9
  38. criteo_api_retailmedia_preview/model/rm_audience_search_input_v1.py +269 -0
  39. criteo_api_retailmedia_preview/model/rm_audience_search_metadata_v1.py +271 -0
  40. criteo_api_retailmedia_preview/model/rm_audience_segment_create_entity_v1.py +17 -9
  41. criteo_api_retailmedia_preview/model/rm_audience_segment_entity_v1.py +7 -7
  42. criteo_api_retailmedia_preview/model/rm_audience_segment_search_entity_v1.py +1 -1
  43. criteo_api_retailmedia_preview/model/rm_contact_list_v1.py +5 -5
  44. criteo_api_retailmedia_preview/model/{rm_user_behavior_v1.py → rm_events_v1.py} +3 -3
  45. criteo_api_retailmedia_preview/model/validation_error.py +287 -0
  46. criteo_api_retailmedia_preview/models/__init__.py +27 -23
  47. {criteo_api_retailmedia_sdk-0.0.240808.dist-info → criteo_api_retailmedia_sdk-0.0.241029.dist-info}/METADATA +3 -3
  48. {criteo_api_retailmedia_sdk-0.0.240808.dist-info → criteo_api_retailmedia_sdk-0.0.241029.dist-info}/RECORD +50 -45
  49. {criteo_api_retailmedia_sdk-0.0.240808.dist-info → criteo_api_retailmedia_sdk-0.0.241029.dist-info}/WHEEL +1 -1
  50. criteo_api_retailmedia_preview/model/campaign_budget_overrides.py +0 -276
  51. criteo_api_retailmedia_preview/model/campaign_daily_budget_override.py +0 -283
  52. criteo_api_retailmedia_preview/model/campaign_monthly_budget_override.py +0 -283
  53. criteo_api_retailmedia_preview/model/daily_line_item_budget_override.py +0 -281
  54. criteo_api_retailmedia_preview/model/line_item_budget_overrides.py +0 -276
  55. criteo_api_retailmedia_preview/model/monthly_line_item_budeget_override.py +0 -283
  56. criteo_api_retailmedia_preview/model/rm_legacy_audience_get_entity_v1.py +0 -291
  57. criteo_api_retailmedia_preview/model/rm_legacy_segment_user_behavior_v2.py +0 -311
  58. criteo_api_retailmedia_preview/model/value_resource_outcome_of_campaign_budget_overrides.py +0 -274
  59. criteo_api_retailmedia_preview/model/value_resource_outcome_of_line_item_budget_overrides.py +0 -274
  60. {criteo_api_retailmedia_sdk-0.0.240808.dist-info → criteo_api_retailmedia_sdk-0.0.241029.dist-info}/top_level.txt +0 -0
@@ -30,11 +30,11 @@ from criteo_api_retailmedia_preview.exceptions import ApiAttributeError
30
30
 
31
31
 
32
32
  def lazy_import():
33
- from criteo_api_retailmedia_preview.model.rm_legacy_segment_user_behavior_v2 import RmLegacySegmentUserBehaviorV2
34
- globals()['RmLegacySegmentUserBehaviorV2'] = RmLegacySegmentUserBehaviorV2
33
+ from criteo_api_retailmedia_preview.model.inbot_discussion import InbotDiscussion
34
+ globals()['InbotDiscussion'] = InbotDiscussion
35
35
 
36
36
 
37
- class RmLegacyAudienceUserBehaviorDetailsV2(ModelNormal):
37
+ class InbotDiscussionDataInstanceModel(ModelNormal):
38
38
  """NOTE: This class is auto generated by OpenAPI Generator.
39
39
  Ref: https://openapi-generator.tech
40
40
 
@@ -87,8 +87,8 @@ class RmLegacyAudienceUserBehaviorDetailsV2(ModelNormal):
87
87
  """
88
88
  lazy_import()
89
89
  return {
90
- 'inclusive_segment': (RmLegacySegmentUserBehaviorV2,), # noqa: E501
91
- 'exclusive_segment': (RmLegacySegmentUserBehaviorV2,), # noqa: E501
90
+ 'attributes': (InbotDiscussion,), # noqa: E501
91
+ 'type': (str, none_type,), # noqa: E501
92
92
  }
93
93
 
94
94
  @cached_property
@@ -97,8 +97,8 @@ class RmLegacyAudienceUserBehaviorDetailsV2(ModelNormal):
97
97
 
98
98
 
99
99
  attribute_map = {
100
- 'inclusive_segment': 'inclusiveSegment', # noqa: E501
101
- 'exclusive_segment': 'exclusiveSegment', # noqa: E501
100
+ 'attributes': 'attributes', # noqa: E501
101
+ 'type': 'type', # noqa: E501
102
102
  }
103
103
 
104
104
  read_only_vars = {
@@ -108,11 +108,11 @@ class RmLegacyAudienceUserBehaviorDetailsV2(ModelNormal):
108
108
 
109
109
  @classmethod
110
110
  @convert_js_args_to_python_args
111
- def _from_openapi_data(cls, inclusive_segment, *args, **kwargs): # noqa: E501
112
- """RmLegacyAudienceUserBehaviorDetailsV2 - a model defined in OpenAPI
111
+ def _from_openapi_data(cls, attributes, *args, **kwargs): # noqa: E501
112
+ """InbotDiscussionDataInstanceModel - a model defined in OpenAPI
113
113
 
114
114
  Args:
115
- inclusive_segment (RmLegacySegmentUserBehaviorV2):
115
+ attributes (InbotDiscussion):
116
116
 
117
117
  Keyword Args:
118
118
  _check_type (bool): if True, values for parameters in openapi_types
@@ -145,7 +145,7 @@ class RmLegacyAudienceUserBehaviorDetailsV2(ModelNormal):
145
145
  Animal class but this time we won't travel
146
146
  through its discriminator because we passed in
147
147
  _visited_composed_classes = (Animal,)
148
- exclusive_segment (RmLegacySegmentUserBehaviorV2): [optional] # noqa: E501
148
+ type (str, none_type): [optional] if omitted the server will use the default value of "InbotDiscussion" # noqa: E501
149
149
  """
150
150
 
151
151
  _check_type = kwargs.pop('_check_type', True)
@@ -177,7 +177,7 @@ class RmLegacyAudienceUserBehaviorDetailsV2(ModelNormal):
177
177
  self._configuration = _configuration
178
178
  self._visited_composed_classes = _visited_composed_classes + (self.__class__,)
179
179
 
180
- self.inclusive_segment = inclusive_segment
180
+ self.attributes = attributes
181
181
  for var_name, var_value in kwargs.items():
182
182
  if var_name not in self.attribute_map and \
183
183
  self._configuration is not None and \
@@ -198,11 +198,11 @@ class RmLegacyAudienceUserBehaviorDetailsV2(ModelNormal):
198
198
  ])
199
199
 
200
200
  @convert_js_args_to_python_args
201
- def __init__(self, inclusive_segment, *args, **kwargs): # noqa: E501
202
- """RmLegacyAudienceUserBehaviorDetailsV2 - a model defined in OpenAPI
201
+ def __init__(self, attributes, *args, **kwargs): # noqa: E501
202
+ """InbotDiscussionDataInstanceModel - a model defined in OpenAPI
203
203
 
204
204
  Args:
205
- inclusive_segment (RmLegacySegmentUserBehaviorV2):
205
+ attributes (InbotDiscussion):
206
206
 
207
207
  Keyword Args:
208
208
  _check_type (bool): if True, values for parameters in openapi_types
@@ -235,7 +235,7 @@ class RmLegacyAudienceUserBehaviorDetailsV2(ModelNormal):
235
235
  Animal class but this time we won't travel
236
236
  through its discriminator because we passed in
237
237
  _visited_composed_classes = (Animal,)
238
- exclusive_segment (RmLegacySegmentUserBehaviorV2): [optional] # noqa: E501
238
+ type (str, none_type): [optional] if omitted the server will use the default value of "InbotDiscussion" # noqa: E501
239
239
  """
240
240
 
241
241
  _check_type = kwargs.pop('_check_type', True)
@@ -265,7 +265,7 @@ class RmLegacyAudienceUserBehaviorDetailsV2(ModelNormal):
265
265
  self._configuration = _configuration
266
266
  self._visited_composed_classes = _visited_composed_classes + (self.__class__,)
267
267
 
268
- self.inclusive_segment = inclusive_segment
268
+ self.attributes = attributes
269
269
  for var_name, var_value in kwargs.items():
270
270
  if var_name not in self.attribute_map and \
271
271
  self._configuration is not None and \
@@ -29,12 +29,8 @@ from criteo_api_retailmedia_preview.model_utils import ( # noqa: F401
29
29
  from criteo_api_retailmedia_preview.exceptions import ApiAttributeError
30
30
 
31
31
 
32
- def lazy_import():
33
- from criteo_api_retailmedia_preview.model.value_resource_of_campaign_budget_overrides import ValueResourceOfCampaignBudgetOverrides
34
- globals()['ValueResourceOfCampaignBudgetOverrides'] = ValueResourceOfCampaignBudgetOverrides
35
32
 
36
-
37
- class ValueResourceInputOfCampaignBudgetOverrides(ModelNormal):
33
+ class LocationInner(ModelNormal):
38
34
  """NOTE: This class is auto generated by OpenAPI Generator.
39
35
  Ref: https://openapi-generator.tech
40
36
 
@@ -64,7 +60,13 @@ class ValueResourceInputOfCampaignBudgetOverrides(ModelNormal):
64
60
  validations = {
65
61
  }
66
62
 
67
- additional_properties_type = None
63
+ @cached_property
64
+ def additional_properties_type():
65
+ """
66
+ This must be a method because a model may have properties that are
67
+ of type self, this must run after the class is loaded
68
+ """
69
+ return (bool, date, datetime, dict, float, int, list, str, none_type,) # noqa: E501
68
70
 
69
71
  _nullable = False
70
72
 
@@ -78,9 +80,7 @@ class ValueResourceInputOfCampaignBudgetOverrides(ModelNormal):
78
80
  openapi_types (dict): The key is attribute name
79
81
  and the value is attribute type.
80
82
  """
81
- lazy_import()
82
83
  return {
83
- 'data': (ValueResourceOfCampaignBudgetOverrides,), # noqa: E501
84
84
  }
85
85
 
86
86
  @cached_property
@@ -89,7 +89,6 @@ class ValueResourceInputOfCampaignBudgetOverrides(ModelNormal):
89
89
 
90
90
 
91
91
  attribute_map = {
92
- 'data': 'data', # noqa: E501
93
92
  }
94
93
 
95
94
  read_only_vars = {
@@ -100,7 +99,7 @@ class ValueResourceInputOfCampaignBudgetOverrides(ModelNormal):
100
99
  @classmethod
101
100
  @convert_js_args_to_python_args
102
101
  def _from_openapi_data(cls, *args, **kwargs): # noqa: E501
103
- """ValueResourceInputOfCampaignBudgetOverrides - a model defined in OpenAPI
102
+ """LocationInner - a model defined in OpenAPI
104
103
 
105
104
  Keyword Args:
106
105
  _check_type (bool): if True, values for parameters in openapi_types
@@ -133,7 +132,6 @@ class ValueResourceInputOfCampaignBudgetOverrides(ModelNormal):
133
132
  Animal class but this time we won't travel
134
133
  through its discriminator because we passed in
135
134
  _visited_composed_classes = (Animal,)
136
- data (ValueResourceOfCampaignBudgetOverrides): [optional] # noqa: E501
137
135
  """
138
136
 
139
137
  _check_type = kwargs.pop('_check_type', True)
@@ -186,7 +184,7 @@ class ValueResourceInputOfCampaignBudgetOverrides(ModelNormal):
186
184
 
187
185
  @convert_js_args_to_python_args
188
186
  def __init__(self, *args, **kwargs): # noqa: E501
189
- """ValueResourceInputOfCampaignBudgetOverrides - a model defined in OpenAPI
187
+ """LocationInner - a model defined in OpenAPI
190
188
 
191
189
  Keyword Args:
192
190
  _check_type (bool): if True, values for parameters in openapi_types
@@ -219,7 +217,6 @@ class ValueResourceInputOfCampaignBudgetOverrides(ModelNormal):
219
217
  Animal class but this time we won't travel
220
218
  through its discriminator because we passed in
221
219
  _visited_composed_classes = (Animal,)
222
- data (ValueResourceOfCampaignBudgetOverrides): [optional] # noqa: E501
223
220
  """
224
221
 
225
222
  _check_type = kwargs.pop('_check_type', True)
@@ -0,0 +1,273 @@
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.botmessage import Botmessage
34
+ globals()['Botmessage'] = Botmessage
35
+
36
+
37
+ class Message(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
+ @cached_property
68
+ def additional_properties_type():
69
+ """
70
+ This must be a method because a model may have properties that are
71
+ of type self, this must run after the class is loaded
72
+ """
73
+ lazy_import()
74
+ return (bool, date, datetime, dict, float, int, list, str, none_type,) # noqa: E501
75
+
76
+ _nullable = False
77
+
78
+ @cached_property
79
+ def openapi_types():
80
+ """
81
+ This must be a method because a model may have properties that are
82
+ of type self, this must run after the class is loaded
83
+
84
+ Returns
85
+ openapi_types (dict): The key is attribute name
86
+ and the value is attribute type.
87
+ """
88
+ lazy_import()
89
+ return {
90
+ 'user_message': (str, none_type,), # noqa: E501
91
+ 'bot_message': (Botmessage,), # noqa: E501
92
+ }
93
+
94
+ @cached_property
95
+ def discriminator():
96
+ return None
97
+
98
+
99
+ attribute_map = {
100
+ 'user_message': 'userMessage', # noqa: E501
101
+ 'bot_message': 'botMessage', # noqa: E501
102
+ }
103
+
104
+ read_only_vars = {
105
+ }
106
+
107
+ _composed_schemas = {}
108
+
109
+ @classmethod
110
+ @convert_js_args_to_python_args
111
+ def _from_openapi_data(cls, *args, **kwargs): # noqa: E501
112
+ """Message - a model defined in OpenAPI
113
+
114
+ Keyword Args:
115
+ _check_type (bool): if True, values for parameters in openapi_types
116
+ will be type checked and a TypeError will be
117
+ raised if the wrong type is input.
118
+ Defaults to True
119
+ _path_to_item (tuple/list): This is a list of keys or values to
120
+ drill down to the model in received_data
121
+ when deserializing a response
122
+ _spec_property_naming (bool): True if the variable names in the input data
123
+ are serialized names, as specified in the OpenAPI document.
124
+ False if the variable names in the input data
125
+ are pythonic names, e.g. snake case (default)
126
+ _configuration (Configuration): the instance to use when
127
+ deserializing a file_type parameter.
128
+ If passed, type conversion is attempted
129
+ If omitted no type conversion is done.
130
+ _visited_composed_classes (tuple): This stores a tuple of
131
+ classes that we have traveled through so that
132
+ if we see that class again we will not use its
133
+ discriminator again.
134
+ When traveling through a discriminator, the
135
+ composed schema that is
136
+ is traveled through is added to this set.
137
+ For example if Animal has a discriminator
138
+ petType and we pass in "Dog", and the class Dog
139
+ allOf includes Animal, we move through Animal
140
+ once using the discriminator, and pick Dog.
141
+ Then in Dog, we will make an instance of the
142
+ Animal class but this time we won't travel
143
+ through its discriminator because we passed in
144
+ _visited_composed_classes = (Animal,)
145
+ user_message (str, none_type): user prompt. [optional] # noqa: E501
146
+ bot_message (Botmessage): [optional] # noqa: E501
147
+ """
148
+
149
+ _check_type = kwargs.pop('_check_type', True)
150
+ _spec_property_naming = kwargs.pop('_spec_property_naming', True)
151
+ _path_to_item = kwargs.pop('_path_to_item', ())
152
+ _configuration = kwargs.pop('_configuration', None)
153
+ _visited_composed_classes = kwargs.pop('_visited_composed_classes', ())
154
+
155
+ self = super(OpenApiModel, cls).__new__(cls)
156
+
157
+ if args:
158
+ for arg in args:
159
+ if isinstance(arg, dict):
160
+ kwargs.update(arg)
161
+ else:
162
+ raise ApiTypeError(
163
+ "Invalid positional arguments=%s passed to %s. Remove those invalid positional arguments." % (
164
+ args,
165
+ self.__class__.__name__,
166
+ ),
167
+ path_to_item=_path_to_item,
168
+ valid_classes=(self.__class__,),
169
+ )
170
+
171
+ self._data_store = {}
172
+ self._check_type = _check_type
173
+ self._spec_property_naming = _spec_property_naming
174
+ self._path_to_item = _path_to_item
175
+ self._configuration = _configuration
176
+ self._visited_composed_classes = _visited_composed_classes + (self.__class__,)
177
+
178
+ for var_name, var_value in kwargs.items():
179
+ if var_name not in self.attribute_map and \
180
+ self._configuration is not None and \
181
+ self._configuration.discard_unknown_keys and \
182
+ self.additional_properties_type is None:
183
+ # discard variable.
184
+ continue
185
+ setattr(self, var_name, var_value)
186
+ return self
187
+
188
+ required_properties = set([
189
+ '_data_store',
190
+ '_check_type',
191
+ '_spec_property_naming',
192
+ '_path_to_item',
193
+ '_configuration',
194
+ '_visited_composed_classes',
195
+ ])
196
+
197
+ @convert_js_args_to_python_args
198
+ def __init__(self, *args, **kwargs): # noqa: E501
199
+ """Message - a model defined in OpenAPI
200
+
201
+ Keyword Args:
202
+ _check_type (bool): if True, values for parameters in openapi_types
203
+ will be type checked and a TypeError will be
204
+ raised if the wrong type is input.
205
+ Defaults to True
206
+ _path_to_item (tuple/list): This is a list of keys or values to
207
+ drill down to the model in received_data
208
+ when deserializing a response
209
+ _spec_property_naming (bool): True if the variable names in the input data
210
+ are serialized names, as specified in the OpenAPI document.
211
+ False if the variable names in the input data
212
+ are pythonic names, e.g. snake case (default)
213
+ _configuration (Configuration): the instance to use when
214
+ deserializing a file_type parameter.
215
+ If passed, type conversion is attempted
216
+ If omitted no type conversion is done.
217
+ _visited_composed_classes (tuple): This stores a tuple of
218
+ classes that we have traveled through so that
219
+ if we see that class again we will not use its
220
+ discriminator again.
221
+ When traveling through a discriminator, the
222
+ composed schema that is
223
+ is traveled through is added to this set.
224
+ For example if Animal has a discriminator
225
+ petType and we pass in "Dog", and the class Dog
226
+ allOf includes Animal, we move through Animal
227
+ once using the discriminator, and pick Dog.
228
+ Then in Dog, we will make an instance of the
229
+ Animal class but this time we won't travel
230
+ through its discriminator because we passed in
231
+ _visited_composed_classes = (Animal,)
232
+ user_message (str, none_type): user prompt. [optional] # noqa: E501
233
+ bot_message (Botmessage): [optional] # noqa: E501
234
+ """
235
+
236
+ _check_type = kwargs.pop('_check_type', True)
237
+ _spec_property_naming = kwargs.pop('_spec_property_naming', False)
238
+ _path_to_item = kwargs.pop('_path_to_item', ())
239
+ _configuration = kwargs.pop('_configuration', None)
240
+ _visited_composed_classes = kwargs.pop('_visited_composed_classes', ())
241
+
242
+ if args:
243
+ for arg in args:
244
+ if isinstance(arg, dict):
245
+ kwargs.update(arg)
246
+ else:
247
+ raise ApiTypeError(
248
+ "Invalid positional arguments=%s passed to %s. Remove those invalid positional arguments." % (
249
+ args,
250
+ self.__class__.__name__,
251
+ ),
252
+ path_to_item=_path_to_item,
253
+ valid_classes=(self.__class__,),
254
+ )
255
+
256
+ self._data_store = {}
257
+ self._check_type = _check_type
258
+ self._spec_property_naming = _spec_property_naming
259
+ self._path_to_item = _path_to_item
260
+ self._configuration = _configuration
261
+ self._visited_composed_classes = _visited_composed_classes + (self.__class__,)
262
+
263
+ for var_name, var_value in kwargs.items():
264
+ if var_name not in self.attribute_map and \
265
+ self._configuration is not None and \
266
+ self._configuration.discard_unknown_keys and \
267
+ self.additional_properties_type is None:
268
+ # discard variable.
269
+ continue
270
+ setattr(self, var_name, var_value)
271
+ if var_name in self.read_only_vars:
272
+ raise ApiAttributeError(f"`{var_name}` is a read-only attribute. Use `from_openapi_data` to instantiate "
273
+ f"class with read only attributes.")