fds.sdk.ProposalGenerationEngine 0.1.0__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 (141) hide show
  1. fds/__init__.py +0 -0
  2. fds/sdk/ProposalGenerationEngine/__init__.py +28 -0
  3. fds/sdk/ProposalGenerationEngine/api/__init__.py +3 -0
  4. fds/sdk/ProposalGenerationEngine/api/ex_post_api.py +1451 -0
  5. fds/sdk/ProposalGenerationEngine/api/lookup_api.py +333 -0
  6. fds/sdk/ProposalGenerationEngine/api_client.py +939 -0
  7. fds/sdk/ProposalGenerationEngine/apis/__init__.py +18 -0
  8. fds/sdk/ProposalGenerationEngine/configuration.py +500 -0
  9. fds/sdk/ProposalGenerationEngine/exceptions.py +160 -0
  10. fds/sdk/ProposalGenerationEngine/model/__init__.py +5 -0
  11. fds/sdk/ProposalGenerationEngine/model/array.py +279 -0
  12. fds/sdk/ProposalGenerationEngine/model/backfill_data.py +264 -0
  13. fds/sdk/ProposalGenerationEngine/model/base_settings.py +264 -0
  14. fds/sdk/ProposalGenerationEngine/model/boxplot.py +266 -0
  15. fds/sdk/ProposalGenerationEngine/model/boxplot_boxplot_summary.py +284 -0
  16. fds/sdk/ProposalGenerationEngine/model/cl_pair.py +252 -0
  17. fds/sdk/ProposalGenerationEngine/model/correlation_matrix.py +260 -0
  18. fds/sdk/ProposalGenerationEngine/model/correlation_stats.py +268 -0
  19. fds/sdk/ProposalGenerationEngine/model/dated_correlation_stats.py +268 -0
  20. fds/sdk/ProposalGenerationEngine/model/dated_correlation_stats_per_time_window.py +262 -0
  21. fds/sdk/ProposalGenerationEngine/model/dated_node_stats.py +262 -0
  22. fds/sdk/ProposalGenerationEngine/model/drawdown.py +268 -0
  23. fds/sdk/ProposalGenerationEngine/model/drawdown_stats.py +290 -0
  24. fds/sdk/ProposalGenerationEngine/model/entity.py +256 -0
  25. fds/sdk/ProposalGenerationEngine/model/entity_stats.py +292 -0
  26. fds/sdk/ProposalGenerationEngine/model/error.py +274 -0
  27. fds/sdk/ProposalGenerationEngine/model/errors.py +262 -0
  28. fds/sdk/ProposalGenerationEngine/model/ex_post_period_stats.py +333 -0
  29. fds/sdk/ProposalGenerationEngine/model/ex_post_period_stats_all_of.py +262 -0
  30. fds/sdk/ProposalGenerationEngine/model/ex_post_portfolio.py +343 -0
  31. fds/sdk/ProposalGenerationEngine/model/ex_post_portfolio_all_of.py +268 -0
  32. fds/sdk/ProposalGenerationEngine/model/ex_post_portfolio_investment.py +329 -0
  33. fds/sdk/ProposalGenerationEngine/model/ex_post_portfolio_investment_all_of.py +266 -0
  34. fds/sdk/ProposalGenerationEngine/model/ex_post_portfolio_investment_response.py +357 -0
  35. fds/sdk/ProposalGenerationEngine/model/ex_post_portfolio_investment_response_all_of.py +284 -0
  36. fds/sdk/ProposalGenerationEngine/model/ex_post_portfolio_investment_series_response.py +353 -0
  37. fds/sdk/ProposalGenerationEngine/model/ex_post_portfolio_investment_series_response_all_of.py +280 -0
  38. fds/sdk/ProposalGenerationEngine/model/ex_post_rolling_settings.py +338 -0
  39. fds/sdk/ProposalGenerationEngine/model/ex_post_rolling_settings_all_of.py +280 -0
  40. fds/sdk/ProposalGenerationEngine/model/ex_post_series.py +268 -0
  41. fds/sdk/ProposalGenerationEngine/model/ex_post_series_data.py +280 -0
  42. fds/sdk/ProposalGenerationEngine/model/ex_post_series_response.py +268 -0
  43. fds/sdk/ProposalGenerationEngine/model/ex_post_series_response_data.py +272 -0
  44. fds/sdk/ProposalGenerationEngine/model/ex_post_series_response_meta.py +262 -0
  45. fds/sdk/ProposalGenerationEngine/model/ex_post_series_rolling.py +268 -0
  46. fds/sdk/ProposalGenerationEngine/model/ex_post_series_rolling_data.py +278 -0
  47. fds/sdk/ProposalGenerationEngine/model/ex_post_series_rolling_response.py +274 -0
  48. fds/sdk/ProposalGenerationEngine/model/ex_post_series_rolling_response_data.py +262 -0
  49. fds/sdk/ProposalGenerationEngine/model/ex_post_series_rolling_response_meta.py +262 -0
  50. fds/sdk/ProposalGenerationEngine/model/ex_post_series_rolling_settings.py +341 -0
  51. fds/sdk/ProposalGenerationEngine/model/ex_post_series_settings.py +353 -0
  52. fds/sdk/ProposalGenerationEngine/model/ex_post_series_settings_all_of.py +267 -0
  53. fds/sdk/ProposalGenerationEngine/model/ex_post_settings.py +355 -0
  54. fds/sdk/ProposalGenerationEngine/model/ex_post_settings_all_of.py +262 -0
  55. fds/sdk/ProposalGenerationEngine/model/ex_post_stats.py +268 -0
  56. fds/sdk/ProposalGenerationEngine/model/ex_post_stats_correlations.py +268 -0
  57. fds/sdk/ProposalGenerationEngine/model/ex_post_stats_correlations_data.py +280 -0
  58. fds/sdk/ProposalGenerationEngine/model/ex_post_stats_correlations_response.py +274 -0
  59. fds/sdk/ProposalGenerationEngine/model/ex_post_stats_correlations_response_meta.py +262 -0
  60. fds/sdk/ProposalGenerationEngine/model/ex_post_stats_correlations_settings.py +346 -0
  61. fds/sdk/ProposalGenerationEngine/model/ex_post_stats_correlations_settings_all_of.py +275 -0
  62. fds/sdk/ProposalGenerationEngine/model/ex_post_stats_data.py +280 -0
  63. fds/sdk/ProposalGenerationEngine/model/ex_post_stats_factor_exposure.py +268 -0
  64. fds/sdk/ProposalGenerationEngine/model/ex_post_stats_factor_exposure_data.py +280 -0
  65. fds/sdk/ProposalGenerationEngine/model/ex_post_stats_factor_exposure_response.py +274 -0
  66. fds/sdk/ProposalGenerationEngine/model/ex_post_stats_factor_exposure_response_meta.py +262 -0
  67. fds/sdk/ProposalGenerationEngine/model/ex_post_stats_factor_exposure_settings.py +338 -0
  68. fds/sdk/ProposalGenerationEngine/model/ex_post_stats_factor_exposure_settings_all_of.py +267 -0
  69. fds/sdk/ProposalGenerationEngine/model/ex_post_stats_response.py +268 -0
  70. fds/sdk/ProposalGenerationEngine/model/ex_post_stats_response_data.py +272 -0
  71. fds/sdk/ProposalGenerationEngine/model/ex_post_stats_response_meta.py +262 -0
  72. fds/sdk/ProposalGenerationEngine/model/ex_post_stats_rolling.py +268 -0
  73. fds/sdk/ProposalGenerationEngine/model/ex_post_stats_rolling_data.py +280 -0
  74. fds/sdk/ProposalGenerationEngine/model/ex_post_stats_rolling_response.py +274 -0
  75. fds/sdk/ProposalGenerationEngine/model/ex_post_stats_rolling_response_data.py +262 -0
  76. fds/sdk/ProposalGenerationEngine/model/ex_post_stats_rolling_response_meta.py +262 -0
  77. fds/sdk/ProposalGenerationEngine/model/ex_post_stats_rolling_settings.py +339 -0
  78. fds/sdk/ProposalGenerationEngine/model/ex_post_stats_rolling_settings_all_of.py +262 -0
  79. fds/sdk/ProposalGenerationEngine/model/ex_post_stats_settings.py +360 -0
  80. fds/sdk/ProposalGenerationEngine/model/ex_post_stats_settings_all_of.py +256 -0
  81. fds/sdk/ProposalGenerationEngine/model/exposure.py +282 -0
  82. fds/sdk/ProposalGenerationEngine/model/investment.py +343 -0
  83. fds/sdk/ProposalGenerationEngine/model/investment_all_of.py +280 -0
  84. fds/sdk/ProposalGenerationEngine/model/key_value_pair.py +260 -0
  85. fds/sdk/ProposalGenerationEngine/model/level.py +256 -0
  86. fds/sdk/ProposalGenerationEngine/model/paged_securities.py +276 -0
  87. fds/sdk/ProposalGenerationEngine/model/paged_securities_meta.py +262 -0
  88. fds/sdk/ProposalGenerationEngine/model/paged_securities_meta_pagination.py +260 -0
  89. fds/sdk/ProposalGenerationEngine/model/performance_stats.py +264 -0
  90. fds/sdk/ProposalGenerationEngine/model/period.py +260 -0
  91. fds/sdk/ProposalGenerationEngine/model/period_correlation_stats.py +333 -0
  92. fds/sdk/ProposalGenerationEngine/model/period_correlation_stats_all_of.py +262 -0
  93. fds/sdk/ProposalGenerationEngine/model/period_info.py +268 -0
  94. fds/sdk/ProposalGenerationEngine/model/period_series.py +333 -0
  95. fds/sdk/ProposalGenerationEngine/model/period_series_all_of.py +262 -0
  96. fds/sdk/ProposalGenerationEngine/model/periods.py +262 -0
  97. fds/sdk/ProposalGenerationEngine/model/portfolio.py +331 -0
  98. fds/sdk/ProposalGenerationEngine/model/portfolio_all_of.py +266 -0
  99. fds/sdk/ProposalGenerationEngine/model/portfolio_correlation_matrix.py +260 -0
  100. fds/sdk/ProposalGenerationEngine/model/portfolio_entity.py +266 -0
  101. fds/sdk/ProposalGenerationEngine/model/portfolio_entity_details.py +256 -0
  102. fds/sdk/ProposalGenerationEngine/model/portfolio_investment.py +268 -0
  103. fds/sdk/ProposalGenerationEngine/model/portfolio_with_ex_post_series.py +333 -0
  104. fds/sdk/ProposalGenerationEngine/model/portfolio_with_ex_post_series_all_of.py +268 -0
  105. fds/sdk/ProposalGenerationEngine/model/portfolio_with_ex_post_stats.py +337 -0
  106. fds/sdk/ProposalGenerationEngine/model/portfolio_with_ex_post_stats_all_of.py +272 -0
  107. fds/sdk/ProposalGenerationEngine/model/portfolio_with_rolling_series.py +327 -0
  108. fds/sdk/ProposalGenerationEngine/model/portfolio_with_rolling_series_all_of.py +262 -0
  109. fds/sdk/ProposalGenerationEngine/model/portfolio_with_rolling_stats.py +327 -0
  110. fds/sdk/ProposalGenerationEngine/model/portfolio_with_rolling_stats_all_of.py +262 -0
  111. fds/sdk/ProposalGenerationEngine/model/rebalancing.py +270 -0
  112. fds/sdk/ProposalGenerationEngine/model/relative_risk_stats.py +280 -0
  113. fds/sdk/ProposalGenerationEngine/model/return_stats.py +264 -0
  114. fds/sdk/ProposalGenerationEngine/model/risk_node_stats.py +304 -0
  115. fds/sdk/ProposalGenerationEngine/model/risk_stats.py +290 -0
  116. fds/sdk/ProposalGenerationEngine/model/rolling_series.py +262 -0
  117. fds/sdk/ProposalGenerationEngine/model/rolling_series_per_time_window.py +266 -0
  118. fds/sdk/ProposalGenerationEngine/model/rolling_series_per_time_window_returns.py +266 -0
  119. fds/sdk/ProposalGenerationEngine/model/rolling_stats.py +262 -0
  120. fds/sdk/ProposalGenerationEngine/model/rolling_stats_per_time_window.py +262 -0
  121. fds/sdk/ProposalGenerationEngine/model/rolling_stats_per_time_window_rolling.py +256 -0
  122. fds/sdk/ProposalGenerationEngine/model/serie_stats.py +282 -0
  123. fds/sdk/ProposalGenerationEngine/model/series_stats.py +266 -0
  124. fds/sdk/ProposalGenerationEngine/model/settings.py +338 -0
  125. fds/sdk/ProposalGenerationEngine/model/settings_all_of.py +269 -0
  126. fds/sdk/ProposalGenerationEngine/model/stats.py +311 -0
  127. fds/sdk/ProposalGenerationEngine/model/time_window.py +256 -0
  128. fds/sdk/ProposalGenerationEngine/model/time_window_series.py +262 -0
  129. fds/sdk/ProposalGenerationEngine/model/time_window_stats.py +268 -0
  130. fds/sdk/ProposalGenerationEngine/model/time_window_stats_generic.py +256 -0
  131. fds/sdk/ProposalGenerationEngine/model/transaction_rule.py +334 -0
  132. fds/sdk/ProposalGenerationEngine/model/ui_value_object.py +264 -0
  133. fds/sdk/ProposalGenerationEngine/model_utils.py +2062 -0
  134. fds/sdk/ProposalGenerationEngine/models/__init__.py +133 -0
  135. fds/sdk/ProposalGenerationEngine/rest.py +347 -0
  136. fds/sdk/__init__.py +0 -0
  137. fds_sdk_proposalgenerationengine-0.1.0.dist-info/METADATA +456 -0
  138. fds_sdk_proposalgenerationengine-0.1.0.dist-info/RECORD +141 -0
  139. fds_sdk_proposalgenerationengine-0.1.0.dist-info/WHEEL +5 -0
  140. fds_sdk_proposalgenerationengine-0.1.0.dist-info/licenses/LICENSE +202 -0
  141. fds_sdk_proposalgenerationengine-0.1.0.dist-info/top_level.txt +1 -0
@@ -0,0 +1,939 @@
1
+ """
2
+ Proposal Generation Engine API
3
+
4
+ Documentation on all available end points in the Proposal Generation API # noqa: E501
5
+
6
+ The version of the OpenAPI document: 0.0.1
7
+ Contact: api@factset.com
8
+ Generated by: https://openapi-generator.tech
9
+ """
10
+
11
+
12
+ import json
13
+ import platform
14
+ import atexit
15
+ import mimetypes
16
+ from multiprocessing.pool import ThreadPool
17
+ import io
18
+ import os
19
+ import re
20
+ import typing
21
+ from typing import Tuple, Dict, Any, Callable, Optional
22
+ from urllib.parse import quote
23
+ from urllib3.fields import RequestField
24
+
25
+
26
+ from fds.sdk.ProposalGenerationEngine import rest
27
+ from fds.sdk.ProposalGenerationEngine.configuration import Configuration
28
+ from fds.sdk.ProposalGenerationEngine.exceptions import ApiTypeError, ApiValueError, ApiException
29
+ from fds.sdk.ProposalGenerationEngine.model_utils import (
30
+ ModelNormal,
31
+ ModelSimple,
32
+ ModelComposed,
33
+ check_allowed_values,
34
+ check_validations,
35
+ date,
36
+ datetime,
37
+ deserialize_file,
38
+ file_type,
39
+ model_to_dict,
40
+ none_type,
41
+ validate_and_convert_types,
42
+ get_full_classname
43
+ )
44
+
45
+ ResponseType = Tuple[Any]
46
+ """
47
+ Types to serialize the API response into.
48
+ A tuple containing:
49
+ * valid classes
50
+ * a list containing valid classes (for list schemas)
51
+ * a dict containing a tuple of valid classes as the value
52
+
53
+ Example values:
54
+ - (str,)
55
+ - (Pet,)
56
+ - (float, none_type)
57
+ - ([int, none_type],)
58
+ - ({str: (bool, str, int, float, date, datetime, str, none_type)},)
59
+ """
60
+
61
+ HttpStatusCode = int
62
+ ResponseTypeByStatusCode = Dict[HttpStatusCode, Optional[ResponseType]]
63
+ """
64
+ Map specifying return types per HTTP status code.
65
+
66
+ Examples value:
67
+ - { 200: (ModelA,), 201: (None,) }
68
+ """
69
+
70
+ ResponseWrapper = Callable[[HttpStatusCode, Any], Any]
71
+ ResponseTypeWithWrapper = Tuple[ResponseTypeByStatusCode, Optional[ResponseWrapper]]
72
+
73
+
74
+ class ApiClient(object):
75
+ """Generic API client for OpenAPI client library builds.
76
+
77
+ OpenAPI generic API client. This client handles the client-
78
+ server communication, and is invariant across implementations. Specifics of
79
+ the methods and models for each application are generated from the OpenAPI
80
+ templates.
81
+
82
+ NOTE: This class is auto generated by OpenAPI Generator.
83
+ Ref: https://openapi-generator.tech
84
+ Do not edit the class manually.
85
+
86
+ :param configuration: .Configuration object for this client
87
+ :param header_name: a header to pass when making calls to the API.
88
+ :param header_value: a header value to pass when making calls to
89
+ the API.
90
+ :param cookie: a cookie to include in the header when making calls
91
+ to the API
92
+ :param pool_threads: The number of threads to use for async requests
93
+ to the API. More threads means more concurrent API requests.
94
+ """
95
+
96
+ _pool = None
97
+
98
+ def __init__(self, configuration=None, header_name=None, header_value=None,
99
+ cookie=None, pool_threads=1):
100
+ if configuration is None:
101
+ configuration = Configuration.get_default_copy()
102
+ else:
103
+ if not isinstance(configuration, Configuration):
104
+ input_config_class_name = get_full_classname(type(configuration))
105
+ expected_config_class_name = get_full_classname(Configuration)
106
+ raise ApiTypeError(
107
+ f"Configuration must be an instance of {expected_config_class_name} but got {input_config_class_name}"
108
+ )
109
+
110
+ self.configuration = configuration
111
+ self.pool_threads = pool_threads
112
+
113
+ self.rest_client = rest.RESTClientObject(configuration)
114
+ self.default_headers = {}
115
+ if header_name is not None:
116
+ self.default_headers[header_name] = header_value
117
+ self.cookie = cookie
118
+ # Set default User-Agent.
119
+ self.user_agent = f'fds-sdk/python/ProposalGenerationEngine/0.1.0 ({platform.system()}, Python {platform.python_version()})'
120
+
121
+ def __enter__(self):
122
+ return self
123
+
124
+ def __exit__(self, exc_type, exc_value, traceback):
125
+ self.close()
126
+
127
+ def close(self):
128
+ if self._pool:
129
+ self._pool.close()
130
+ self._pool.join()
131
+ self._pool = None
132
+ if hasattr(atexit, 'unregister'):
133
+ atexit.unregister(self.close)
134
+
135
+ @property
136
+ def pool(self):
137
+ """Create thread pool on first request
138
+ avoids instantiating unused threadpool for blocking clients.
139
+ """
140
+ if self._pool is None:
141
+ atexit.register(self.close)
142
+ self._pool = ThreadPool(self.pool_threads)
143
+ return self._pool
144
+
145
+ @property
146
+ def user_agent(self):
147
+ """User agent for this API client"""
148
+ return self.default_headers['User-Agent']
149
+
150
+ @user_agent.setter
151
+ def user_agent(self, value):
152
+ self.default_headers['User-Agent'] = value
153
+
154
+ def set_default_header(self, header_name, header_value):
155
+ self.default_headers[header_name] = header_value
156
+
157
+ def __call_api(
158
+ self,
159
+ resource_path: str,
160
+ method: str,
161
+ path_params: typing.Optional[typing.Dict[str, typing.Any]] = None,
162
+ query_params: typing.Optional[typing.List[typing.Tuple[str, typing.Any]]] = None,
163
+ header_params: typing.Optional[typing.Dict[str, typing.Any]] = None,
164
+ body: typing.Optional[typing.Any] = None,
165
+ post_params: typing.Optional[typing.List[typing.Tuple[str, typing.Any]]] = None,
166
+ files: typing.Optional[typing.Dict[str, typing.List[io.IOBase]]] = None,
167
+ response_type: typing.Optional[ResponseTypeWithWrapper] = None,
168
+ auth_settings: typing.Optional[typing.List[str]] = None,
169
+ _return_http_data_only: typing.Optional[bool] = None,
170
+ collection_formats: typing.Optional[typing.Dict[str, str]] = None,
171
+ _preload_content: bool = True,
172
+ _request_timeout: typing.Optional[typing.Union[int, float, typing.Tuple]] = None,
173
+ _host: typing.Optional[str] = None,
174
+ _check_type: typing.Optional[bool] = None,
175
+ _content_type: typing.Optional[str] = None
176
+ ):
177
+
178
+ config = self.configuration
179
+
180
+ # header parameters
181
+ header_params = header_params or {}
182
+ header_params.update(self.default_headers)
183
+ if self.cookie:
184
+ header_params['Cookie'] = self.cookie
185
+ if header_params:
186
+ header_params = self.sanitize_for_serialization(header_params)
187
+ header_params = dict(self.parameters_to_tuples(header_params,
188
+ collection_formats))
189
+
190
+ # path parameters
191
+ if path_params:
192
+ path_params = self.sanitize_for_serialization(path_params)
193
+ path_params = self.parameters_to_tuples(path_params,
194
+ collection_formats)
195
+ for k, v in path_params:
196
+ # specified safe chars, encode everything
197
+ resource_path = resource_path.replace(
198
+ '{%s}' % k,
199
+ quote(str(v), safe=config.safe_chars_for_path_param)
200
+ )
201
+
202
+ # query parameters
203
+ if query_params:
204
+ query_params = self.sanitize_for_serialization(query_params)
205
+ query_params = self.parameters_to_tuples(query_params,
206
+ collection_formats)
207
+
208
+ # post parameters
209
+ if post_params or files:
210
+ post_params = post_params if post_params else []
211
+ post_params = self.sanitize_for_serialization(post_params)
212
+ post_params = self.parameters_to_tuples(post_params,
213
+ collection_formats)
214
+ post_params.extend(self.files_parameters(files))
215
+ if header_params['Content-Type'].startswith("multipart"):
216
+ post_params = self.parameters_to_multipart(post_params, dict)
217
+
218
+ # body
219
+ if body:
220
+ body = self.sanitize_for_serialization(body)
221
+
222
+ # auth setting
223
+ self.update_params_for_auth(header_params, query_params,
224
+ auth_settings, resource_path, method, body)
225
+
226
+ # request url
227
+ if _host is None:
228
+ url = self.configuration.host + resource_path
229
+ else:
230
+ # use server/host defined in path or operation instead
231
+ url = _host + resource_path
232
+
233
+ try:
234
+ # perform request and return response
235
+ response_data = self.request(
236
+ method, url, query_params=query_params, headers=header_params,
237
+ post_params=post_params, body=body,
238
+ _preload_content=_preload_content,
239
+ _request_timeout=_request_timeout)
240
+ except ApiException as e:
241
+ e.body = e.body.decode('utf-8')
242
+ raise e
243
+
244
+ self.last_response = response_data
245
+
246
+ return_data = response_data
247
+
248
+ if not _preload_content:
249
+ return (return_data)
250
+
251
+ # deserialize response data with response code to type serialization mapping
252
+ if response_type is not None:
253
+ (status_code_map, response_wrapper) = response_type
254
+ else:
255
+ status_code_map = {}
256
+ response_wrapper = None
257
+
258
+ if response_data.status in status_code_map:
259
+ response_type = status_code_map[response_data.status]
260
+
261
+ if response_type != (file_type,):
262
+ encoding = "utf-8"
263
+ content_type = response_data.getheader('content-type')
264
+ if content_type is not None:
265
+ match = re.search(r"charset=([a-zA-Z\-\d]+)[\s;]?", content_type)
266
+ if match:
267
+ encoding = match.group(1)
268
+ response_data.data = response_data.data.decode(encoding)
269
+
270
+ return_data = self.deserialize(
271
+ response_data,
272
+ response_type,
273
+ _check_type
274
+ )
275
+
276
+ else:
277
+ return_data = None
278
+
279
+ if response_wrapper is not None:
280
+ return_data = response_wrapper(response_data.status, return_data)
281
+
282
+ if _return_http_data_only:
283
+ return return_data
284
+ else:
285
+ return return_data, response_data.status, response_data.getheaders()
286
+
287
+ def parameters_to_multipart(self, params, collection_types):
288
+ """Get parameters as list of tuples, formatting as json if value is collection_types
289
+
290
+ :param params: Parameters as list of two-tuples
291
+ :type params: list
292
+ :param collection_types: Parameter collection types
293
+ :type collection_types: Type(typing.Any)
294
+ :return: Parameters as list of tuple or urllib3.fields.RequestField
295
+ """
296
+ new_params = []
297
+ if collection_types is None:
298
+ collection_types = dict
299
+ for k, v in params.items() if isinstance(params, dict) else params: # noqa: E501
300
+ if isinstance(v, collection_types): # v is instance of collection_type, formatting as application/json
301
+ v = json.dumps(v, ensure_ascii=False).encode("utf-8")
302
+ field = RequestField(k, v)
303
+ field.make_multipart(content_type="application/json; charset=utf-8")
304
+ new_params.append(field)
305
+ else:
306
+ new_params.append((k, v))
307
+ return new_params
308
+
309
+ @classmethod
310
+ def sanitize_for_serialization(cls, obj):
311
+ """Prepares data for transmission before it is sent with the rest client
312
+ If obj is None, return None.
313
+ If obj is str, int, long, float, bool, return directly.
314
+ If obj is datetime.datetime, datetime.date
315
+ convert to string in iso8601 format.
316
+ If obj is list, sanitize each element in the list.
317
+ If obj is dict, return the dict.
318
+ If obj is OpenAPI model, return the properties dict.
319
+ If obj is io.IOBase, return the bytes
320
+ :param obj: The data to serialize.
321
+ :type obj: Any
322
+ :raises ApiValueError: Unable to prepare type {} for serialization.
323
+ :return: The serialized form of data.
324
+ """
325
+ if isinstance(obj, (ModelNormal, ModelComposed)):
326
+ return {
327
+ key: cls.sanitize_for_serialization(val) for key, val in model_to_dict(obj, serialize=True).items()
328
+ }
329
+ elif isinstance(obj, io.IOBase):
330
+ return cls.get_file_data_and_close_file(obj)
331
+ elif isinstance(obj, (str, int, float, none_type, bool)):
332
+ return obj
333
+ elif isinstance(obj, (datetime, date)):
334
+ return obj.isoformat()
335
+ elif isinstance(obj, ModelSimple):
336
+ return cls.sanitize_for_serialization(obj.value)
337
+ elif isinstance(obj, (list, tuple)):
338
+ return [cls.sanitize_for_serialization(item) for item in obj]
339
+ if isinstance(obj, dict):
340
+ return {key: cls.sanitize_for_serialization(val) for key, val in obj.items()}
341
+ raise ApiValueError('Unable to prepare type {} for serialization'.format(obj.__class__.__name__))
342
+
343
+ def deserialize(self, response, response_type, _check_type):
344
+ """Deserializes response into an object.
345
+
346
+ :param response: RESTResponse object to be deserialized.
347
+ :type response: Any
348
+ :param response_type: For the response, a tuple containing:
349
+ valid classes
350
+ a list containing valid classes (for list schemas)
351
+ a dict containing a tuple of valid classes as the value
352
+ Example values:
353
+ (str,)
354
+ (Pet,)
355
+ (float, none_type)
356
+ ([int, none_type],)
357
+ ({str: (bool, str, int, float, date, datetime, str, none_type)},)
358
+ :type response_type: Any
359
+ :raises ValueError: Unable to prepare type {} for serialization
360
+ :param _check_type: boolean, whether to check the types of the data
361
+ received from the server
362
+ :type _check_type: bool
363
+
364
+ :return: deserialized object.
365
+ """
366
+ # handle file downloading
367
+ # save response body into a tmp file and return the instance
368
+ if response_type == (file_type,):
369
+ content_disposition = response.getheader("Content-Disposition")
370
+ return deserialize_file(response.data, self.configuration,
371
+ content_disposition=content_disposition)
372
+
373
+ # fetch data from response object
374
+ try:
375
+ received_data = json.loads(response.data)
376
+ except ValueError:
377
+ received_data = response.data
378
+
379
+ # store our data under the key of 'received_data' so users have some
380
+ # context if they are deserializing a string and the data type is wrong
381
+ deserialized_data = validate_and_convert_types(
382
+ received_data,
383
+ response_type,
384
+ ['received_data'],
385
+ True,
386
+ _check_type,
387
+ configuration=self.configuration
388
+ )
389
+ return deserialized_data
390
+
391
+ def call_api(
392
+ self,
393
+ resource_path: str,
394
+ method: str,
395
+ path_params: typing.Optional[typing.Dict[str, typing.Any]] = None,
396
+ query_params: typing.Optional[typing.List[typing.Tuple[str, typing.Any]]] = None,
397
+ header_params: typing.Optional[typing.Dict[str, typing.Any]] = None,
398
+ body: typing.Optional[typing.Any] = None,
399
+ post_params: typing.Optional[typing.List[typing.Tuple[str, typing.Any]]] = None,
400
+ files: typing.Optional[typing.Dict[str, typing.List[io.IOBase]]] = None,
401
+ response_type: typing.Optional[ResponseTypeWithWrapper] = None,
402
+ auth_settings: typing.Optional[typing.List[str]] = None,
403
+ async_req: typing.Optional[bool] = None,
404
+ _return_http_data_only: typing.Optional[bool] = None,
405
+ collection_formats: typing.Optional[typing.Dict[str, str]] = None,
406
+ _preload_content: bool = True,
407
+ _request_timeout: typing.Optional[typing.Union[int, float, typing.Tuple]] = None,
408
+ _host: typing.Optional[str] = None,
409
+ _check_type: typing.Optional[bool] = None
410
+ ):
411
+ """Makes the HTTP request (synchronous) and returns deserialized data.
412
+
413
+ To make an async_req request, set the async_req parameter.
414
+
415
+ :param resource_path: Path to method endpoint.
416
+ :type resource_path: str
417
+ :param method: Method to call.
418
+ :type method: str
419
+ :param path_params: Path parameters in the url.
420
+ :param query_params: Query parameters in the url.
421
+ :param header_params: Header parameters to be
422
+ placed in the request header.
423
+ :param body: Request body.
424
+ :param post_params: Request post form parameters,
425
+ for `application/x-www-form-urlencoded`, `multipart/form-data`.
426
+ :type post_params: dict
427
+ :param auth_settings: Auth Settings names for the request.
428
+ :type auth_settings: list
429
+ :param response_type: Determines the type of the deserialized response.
430
+ A tuple containing a map of response types per status code and an optional wrapper function.
431
+ Example values:
432
+ ({200: ModelA, 201: None, 202: ModelB}, None)
433
+ ({200: ModelA, 201: None, 202: ModelB}, MyWrapper)
434
+ :type response_type: ResponseTypeWithWrapper, optional
435
+ :raises ApiValueError: Unable to prepare type.
436
+ :param files: key -> field name, value -> a list of open file
437
+ objects for `multipart/form-data`.
438
+ :type files: dict
439
+ :param async_req: execute request asynchronously
440
+ :type async_req: bool, optional
441
+ :param _return_http_data_only: response data without head status code
442
+ and headers
443
+ :type _return_http_data_only: bool, optional
444
+ :param collection_formats: dict of collection formats for path, query,
445
+ header, and post parameters.
446
+ :type collection_formats: dict, optional
447
+ :param _preload_content: if False, the urllib3.HTTPResponse object will
448
+ be returned without reading/decoding response
449
+ data. Default is True.
450
+ :type _preload_content: bool, optional
451
+ :param _request_timeout: timeout setting for this request. If one
452
+ number provided, it will be total request
453
+ timeout. It can also be a pair (tuple) of
454
+ (connection, read) timeouts.
455
+ :param _host: host
456
+ :type _host: str, optional
457
+ :param _check_type: boolean describing if the data back from the server
458
+ should have its type checked.
459
+ :type _check_type: bool, optional
460
+ :return:
461
+ If async_req parameter is True,
462
+ the request will be called asynchronously.
463
+ The method will return the request thread.
464
+ If parameter async_req is False or missing,
465
+ then the method will return the response directly.
466
+ """
467
+ if not async_req:
468
+ return self.__call_api(resource_path, method,
469
+ path_params, query_params, header_params,
470
+ body, post_params, files,
471
+ response_type, auth_settings,
472
+ _return_http_data_only, collection_formats,
473
+ _preload_content, _request_timeout, _host,
474
+ _check_type)
475
+
476
+ return self.pool.apply_async(self.__call_api, (resource_path,
477
+ method, path_params,
478
+ query_params,
479
+ header_params, body,
480
+ post_params, files,
481
+ response_type,
482
+ auth_settings,
483
+ _return_http_data_only,
484
+ collection_formats,
485
+ _preload_content,
486
+ _request_timeout,
487
+ _host, _check_type))
488
+
489
+ def request(self, method, url, query_params=None, headers=None,
490
+ post_params=None, body=None, _preload_content=True,
491
+ _request_timeout=None):
492
+ """Makes the HTTP request using RESTClient."""
493
+ if method == "GET":
494
+ return self.rest_client.GET(url,
495
+ query_params=query_params,
496
+ _preload_content=_preload_content,
497
+ _request_timeout=_request_timeout,
498
+ headers=headers)
499
+ elif method == "HEAD":
500
+ return self.rest_client.HEAD(url,
501
+ query_params=query_params,
502
+ _preload_content=_preload_content,
503
+ _request_timeout=_request_timeout,
504
+ headers=headers)
505
+ elif method == "OPTIONS":
506
+ return self.rest_client.OPTIONS(url,
507
+ query_params=query_params,
508
+ headers=headers,
509
+ post_params=post_params,
510
+ _preload_content=_preload_content,
511
+ _request_timeout=_request_timeout,
512
+ body=body)
513
+ elif method == "POST":
514
+ return self.rest_client.POST(url,
515
+ query_params=query_params,
516
+ headers=headers,
517
+ post_params=post_params,
518
+ _preload_content=_preload_content,
519
+ _request_timeout=_request_timeout,
520
+ body=body)
521
+ elif method == "PUT":
522
+ return self.rest_client.PUT(url,
523
+ query_params=query_params,
524
+ headers=headers,
525
+ post_params=post_params,
526
+ _preload_content=_preload_content,
527
+ _request_timeout=_request_timeout,
528
+ body=body)
529
+ elif method == "PATCH":
530
+ return self.rest_client.PATCH(url,
531
+ query_params=query_params,
532
+ headers=headers,
533
+ post_params=post_params,
534
+ _preload_content=_preload_content,
535
+ _request_timeout=_request_timeout,
536
+ body=body)
537
+ elif method == "DELETE":
538
+ return self.rest_client.DELETE(url,
539
+ query_params=query_params,
540
+ headers=headers,
541
+ _preload_content=_preload_content,
542
+ _request_timeout=_request_timeout,
543
+ body=body)
544
+ else:
545
+ raise ApiValueError(
546
+ "http method must be `GET`, `HEAD`, `OPTIONS`,"
547
+ " `POST`, `PATCH`, `PUT` or `DELETE`."
548
+ )
549
+
550
+ def parameters_to_tuples(self, params, collection_formats):
551
+ """Get parameters as list of tuples, formatting collections.
552
+
553
+ :param params: Parameters as dict or list of two-tuples
554
+ :type params: dict, list
555
+ :param collection_formats: Parameter collection formats
556
+ :type collection_formats: dict
557
+ :return: Parameters as list of tuples, collections formatted
558
+ """
559
+ new_params = []
560
+ if collection_formats is None:
561
+ collection_formats = {}
562
+ for k, v in params.items() if isinstance(params, dict) else params: # noqa: E501
563
+ if k in collection_formats:
564
+ collection_format = collection_formats[k]
565
+ if collection_format == 'multi':
566
+ new_params.extend((k, value) for value in v)
567
+ else:
568
+ if collection_format == 'ssv':
569
+ delimiter = ' '
570
+ elif collection_format == 'tsv':
571
+ delimiter = '\t'
572
+ elif collection_format == 'pipes':
573
+ delimiter = '|'
574
+ else: # csv is the default
575
+ delimiter = ','
576
+ new_params.append(
577
+ (k, delimiter.join(str(value) for value in v)))
578
+ else:
579
+ new_params.append((k, v))
580
+ return new_params
581
+
582
+ @staticmethod
583
+ def get_file_data_and_close_file(file_instance: io.IOBase) -> bytes:
584
+ file_data = file_instance.read()
585
+ file_instance.close()
586
+ return file_data
587
+
588
+ def files_parameters(self, files: typing.Optional[typing.Dict[str, typing.List[io.IOBase]]] = None):
589
+ """Builds form parameters.
590
+
591
+ :param files: None or a dict with key=param_name and
592
+ value is a list of open file objects
593
+ :type files: dict, None
594
+ :raises ApiValueError: Cannot read a closed file. The passed in file_type.
595
+ :return: List of tuples of form parameters with file data
596
+ """
597
+ if files is None:
598
+ return []
599
+
600
+ params = []
601
+ for param_name, file_instances in files.items():
602
+ if file_instances is None:
603
+ # if the file field is nullable, skip None values
604
+ continue
605
+ for file_instance in file_instances:
606
+ if file_instance is None:
607
+ # if the file field is nullable, skip None values
608
+ continue
609
+ if file_instance.closed is True:
610
+ raise ApiValueError(
611
+ "Cannot read a closed file. The passed in file_type "
612
+ "for %s must be open." % param_name
613
+ )
614
+ filename = os.path.basename(file_instance.name)
615
+ filedata = self.get_file_data_and_close_file(file_instance)
616
+ mimetype = (mimetypes.guess_type(filename)[0] or
617
+ 'application/octet-stream')
618
+ params.append(
619
+ tuple([param_name, tuple([filename, filedata, mimetype])]))
620
+
621
+ return params
622
+
623
+ def select_header_accept(self, accepts):
624
+ """Returns `Accept` based on an array of accepts provided.
625
+
626
+ :param accepts: List of headers.
627
+ :type accepts: list
628
+ :return: Accept (e.g. application/json).
629
+ """
630
+ if not accepts:
631
+ return
632
+
633
+ accepts = [x.lower() for x in accepts]
634
+
635
+ if 'application/json' in accepts:
636
+ return 'application/json'
637
+ else:
638
+ return ', '.join(accepts)
639
+
640
+ def select_header_content_type(self, content_types, method=None, body=None):
641
+ """Returns `Content-Type` based on an array of content_types provided.
642
+
643
+ :param content_types: List of content-types.
644
+ :type content_types: list
645
+ :param method: http method (e.g. POST, PATCH).
646
+ :type method: str
647
+ :param body: http body to send.
648
+ :return: Content-Type (e.g. application/json).
649
+ """
650
+ if not content_types:
651
+ return 'application/json'
652
+
653
+ content_types = [x.lower() for x in content_types]
654
+
655
+ if (method == 'PATCH' and
656
+ 'application/json-patch+json' in content_types and
657
+ isinstance(body, list)):
658
+ return 'application/json-patch+json'
659
+
660
+ if 'application/json' in content_types or '*/*' in content_types:
661
+ return 'application/json'
662
+ else:
663
+ return content_types[0]
664
+
665
+ def update_params_for_auth(self, headers, queries, auth_settings,
666
+ resource_path, method, body):
667
+ """Updates header and query params based on authentication setting.
668
+
669
+ :param headers: Header parameters dict to be updated.
670
+ :type headers: dict
671
+ :param queries: Query parameters tuple list to be updated.
672
+ :type queries: list
673
+ :param auth_settings: Authentication setting identifiers list.
674
+ type auth_settings: list
675
+ :param resource_path: A string representation of the HTTP request resource path.
676
+ :type resource_path: str
677
+ :param method: A string representation of the HTTP request method.
678
+ :type method: str
679
+ :param body: A object representing the body of the HTTP request.
680
+ The object type is the return value of _encoder.default().
681
+ """
682
+ if not auth_settings:
683
+ return
684
+
685
+ auth_settings_dict = self.configuration.auth_settings()
686
+
687
+ for auth in auth_settings:
688
+ auth_setting = auth_settings_dict.get(auth)
689
+ if auth_setting:
690
+ if auth_setting['in'] == 'cookie':
691
+ headers['Cookie'] = auth_setting['value']
692
+ elif auth_setting['in'] == 'header':
693
+ if auth_setting['type'] != 'http-signature':
694
+ headers[auth_setting['key']] = auth_setting['value']
695
+ elif auth_setting['in'] == 'query':
696
+ queries.append((auth_setting['key'], auth_setting['value']))
697
+ else:
698
+ raise ApiValueError(
699
+ 'Authentication token must be in `query` or `header`'
700
+ )
701
+
702
+
703
+ class Endpoint(object):
704
+ def __init__(self, settings=None, params_map=None, root_map=None,
705
+ headers_map=None, api_client=None, callable=None):
706
+ """Creates an endpoint
707
+
708
+ Args:
709
+ settings (dict): see below key value pairs
710
+ 'response_type' (ResponseTypeWithWrapper/None): response type map and wrapper function
711
+ 'auth' (list): a list of auth type keys
712
+ 'endpoint_path' (str): the endpoint path
713
+ 'operation_id' (str): endpoint string identifier
714
+ 'http_method' (str): POST/PUT/PATCH/GET etc
715
+ 'servers' (list): list of str servers that this endpoint is at
716
+ params_map (dict): see below key value pairs
717
+ 'all' (list): list of str endpoint parameter names
718
+ 'required' (list): list of required parameter names
719
+ 'nullable' (list): list of nullable parameter names
720
+ 'enum' (list): list of parameters with enum values
721
+ 'validation' (list): list of parameters with validations
722
+ root_map
723
+ 'validations' (dict): the dict mapping endpoint parameter tuple
724
+ paths to their validation dictionaries
725
+ 'allowed_values' (dict): the dict mapping endpoint parameter
726
+ tuple paths to their allowed_values (enum) dictionaries
727
+ 'openapi_types' (dict): param_name to openapi type
728
+ 'attribute_map' (dict): param_name to camelCase name
729
+ 'location_map' (dict): param_name to 'body', 'file', 'form',
730
+ 'header', 'path', 'query'
731
+ 'collection_format_map' (dict): param_name to `csv` etc.
732
+ headers_map (dict): see below key value pairs
733
+ 'accept' (list): list of Accept header strings
734
+ 'content_type' (list): list of Content-Type header strings
735
+ api_client (ApiClient) api client instance
736
+ callable (function): the function which is invoked when the
737
+ Endpoint is called
738
+ """
739
+ self.settings = settings
740
+ self.params_map = params_map
741
+ self.params_map['all'].extend([
742
+ 'async_req',
743
+ '_host_index',
744
+ '_preload_content',
745
+ '_request_timeout',
746
+ '_return_http_data_only',
747
+ '_check_input_type',
748
+ '_check_return_type',
749
+ '_content_type',
750
+ '_spec_property_naming'
751
+ ])
752
+ self.params_map['nullable'].extend(['_request_timeout'])
753
+ self.validations = root_map['validations']
754
+ self.allowed_values = root_map['allowed_values']
755
+ self.openapi_types = root_map['openapi_types']
756
+ extra_types = {
757
+ 'async_req': (bool,),
758
+ '_host_index': (none_type, int),
759
+ '_preload_content': (bool,),
760
+ '_request_timeout': (none_type, float, (float,), [float], int, (int,), [int]),
761
+ '_return_http_data_only': (bool,),
762
+ '_check_input_type': (bool,),
763
+ '_check_return_type': (bool,),
764
+ '_spec_property_naming': (bool,),
765
+ '_content_type': (none_type, str)
766
+ }
767
+ self.openapi_types.update(extra_types)
768
+ self.attribute_map = root_map['attribute_map']
769
+ self.location_map = root_map['location_map']
770
+ self.collection_format_map = root_map['collection_format_map']
771
+ self.headers_map = headers_map
772
+ self.api_client = api_client
773
+ self.callable = callable
774
+
775
+ def __validate_inputs(self, kwargs):
776
+ for param in self.params_map['enum']:
777
+ if param in kwargs:
778
+ check_allowed_values(
779
+ self.allowed_values,
780
+ (param,),
781
+ kwargs[param]
782
+ )
783
+
784
+ for param in self.params_map['validation']:
785
+ if param in kwargs:
786
+ check_validations(
787
+ self.validations,
788
+ (param,),
789
+ kwargs[param],
790
+ configuration=self.api_client.configuration
791
+ )
792
+
793
+ if kwargs['_check_input_type'] is False:
794
+ return
795
+
796
+ for key, value in kwargs.items():
797
+ fixed_val = validate_and_convert_types(
798
+ value,
799
+ self.openapi_types[key],
800
+ [key],
801
+ kwargs['_spec_property_naming'],
802
+ kwargs['_check_input_type'],
803
+ configuration=self.api_client.configuration
804
+ )
805
+ kwargs[key] = fixed_val
806
+
807
+ def __gather_params(self, kwargs):
808
+ params = {
809
+ 'body': None,
810
+ 'collection_format': {},
811
+ 'file': {},
812
+ 'form': [],
813
+ 'header': {},
814
+ 'path': {},
815
+ 'query': []
816
+ }
817
+
818
+ for param_name, param_value in kwargs.items():
819
+ param_location = self.location_map.get(param_name)
820
+ if param_location is None:
821
+ continue
822
+ if param_location:
823
+ if param_location == 'body':
824
+ params['body'] = param_value
825
+ continue
826
+ base_name = self.attribute_map[param_name]
827
+ if (param_location == 'form' and
828
+ self.openapi_types[param_name] == (file_type,)):
829
+ params['file'][base_name] = [param_value]
830
+ elif (param_location == 'form' and
831
+ self.openapi_types[param_name] == ([file_type],)):
832
+ # param_value is already a list
833
+ params['file'][base_name] = param_value
834
+ elif param_location in {'form', 'query'}:
835
+ param_value_full = (base_name, param_value)
836
+ params[param_location].append(param_value_full)
837
+ if param_location not in {'form', 'query'}:
838
+ params[param_location][base_name] = param_value
839
+ collection_format = self.collection_format_map.get(param_name)
840
+ if collection_format:
841
+ params['collection_format'][base_name] = collection_format
842
+
843
+ return params
844
+
845
+ def __call__(self, *args, **kwargs):
846
+ """ This method is invoked when endpoints are called
847
+ Example:
848
+
849
+ api_instance = ExPostApi()
850
+ api_instance.calculate_ex_post_correlations_stats # this is an instance of the class Endpoint
851
+ api_instance.calculate_ex_post_correlations_stats() # this invokes api_instance.calculate_ex_post_correlations_stats.__call__()
852
+ which then invokes the callable functions stored in that endpoint at
853
+ api_instance.calculate_ex_post_correlations_stats.callable or self.callable in this class
854
+
855
+ """
856
+ return self.callable(self, *args, **kwargs)
857
+
858
+ def call_with_http_info(self, **kwargs):
859
+
860
+ try:
861
+ index = self.api_client.configuration.server_operation_index.get(
862
+ self.settings['operation_id'], self.api_client.configuration.server_index
863
+ ) if kwargs['_host_index'] is None else kwargs['_host_index']
864
+ server_variables = self.api_client.configuration.server_operation_variables.get(
865
+ self.settings['operation_id'], self.api_client.configuration.server_variables
866
+ )
867
+ _host = self.api_client.configuration.get_host_from_settings(
868
+ index, variables=server_variables, servers=self.settings['servers']
869
+ )
870
+ except IndexError:
871
+ if self.settings['servers']:
872
+ raise ApiValueError(
873
+ "Invalid host index. Must be 0 <= index < %s" %
874
+ len(self.settings['servers'])
875
+ )
876
+ _host = None
877
+
878
+ for key, value in kwargs.items():
879
+ if key not in self.params_map['all']:
880
+ raise ApiTypeError(
881
+ "Got an unexpected parameter '%s'"
882
+ " to method `%s`" %
883
+ (key, self.settings['operation_id'])
884
+ )
885
+ # only throw this nullable ApiValueError if _check_input_type
886
+ # is False, if _check_input_type==True we catch this case
887
+ # in self.__validate_inputs
888
+ if (key not in self.params_map['nullable'] and value is None
889
+ and kwargs['_check_input_type'] is False):
890
+ raise ApiValueError(
891
+ "Value may not be None for non-nullable parameter `%s`"
892
+ " when calling `%s`" %
893
+ (key, self.settings['operation_id'])
894
+ )
895
+
896
+ for key in self.params_map['required']:
897
+ if key not in kwargs.keys():
898
+ raise ApiValueError(
899
+ "Missing the required parameter `%s` when calling "
900
+ "`%s`" % (key, self.settings['operation_id'])
901
+ )
902
+
903
+ self.__validate_inputs(kwargs)
904
+
905
+ params = self.__gather_params(kwargs)
906
+
907
+ accept_headers_list = self.headers_map['accept']
908
+ if accept_headers_list:
909
+ params['header']['Accept'] = self.api_client.select_header_accept(
910
+ accept_headers_list)
911
+
912
+ if kwargs.get('_content_type'):
913
+ params['header']['Content-Type'] = kwargs['_content_type']
914
+ else:
915
+ content_type_headers_list = self.headers_map['content_type']
916
+ if content_type_headers_list:
917
+ if params['body'] != "":
918
+ header_list = self.api_client.select_header_content_type(
919
+ content_type_headers_list, self.settings['http_method'],
920
+ params['body'])
921
+ params['header']['Content-Type'] = header_list
922
+
923
+ return self.api_client.call_api(
924
+ self.settings['endpoint_path'], self.settings['http_method'],
925
+ params['path'],
926
+ params['query'],
927
+ params['header'],
928
+ body=params['body'],
929
+ post_params=params['form'],
930
+ files=params['file'],
931
+ response_type=self.settings['response_type'],
932
+ auth_settings=self.settings['auth'],
933
+ async_req=kwargs['async_req'],
934
+ _check_type=kwargs['_check_return_type'],
935
+ _return_http_data_only=kwargs['_return_http_data_only'],
936
+ _preload_content=kwargs['_preload_content'],
937
+ _request_timeout=kwargs['_request_timeout'],
938
+ _host=_host,
939
+ collection_formats=params['collection_format'])