circle-developer-controlled-wallets 0.1.0b1__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 circle-developer-controlled-wallets might be problematic. Click here for more details.

Files changed (95) hide show
  1. circle/__init__.py +0 -0
  2. circle/web3/__init__.py +0 -0
  3. circle/web3/developer_controlled_wallets/__init__.py +108 -0
  4. circle/web3/developer_controlled_wallets/api/__init__.py +9 -0
  5. circle/web3/developer_controlled_wallets/api/signing_api.py +356 -0
  6. circle/web3/developer_controlled_wallets/api/token_lookup_api.py +198 -0
  7. circle/web3/developer_controlled_wallets/api/transactions_api.py +1527 -0
  8. circle/web3/developer_controlled_wallets/api/wallet_sets_api.py +691 -0
  9. circle/web3/developer_controlled_wallets/api/wallets_api.py +1118 -0
  10. circle/web3/developer_controlled_wallets/api_client.py +789 -0
  11. circle/web3/developer_controlled_wallets/api_response.py +25 -0
  12. circle/web3/developer_controlled_wallets/configuration.py +455 -0
  13. circle/web3/developer_controlled_wallets/exceptions.py +162 -0
  14. circle/web3/developer_controlled_wallets/models/__init__.py +87 -0
  15. circle/web3/developer_controlled_wallets/models/abi_parameters_inner.py +168 -0
  16. circle/web3/developer_controlled_wallets/models/accelerate_transaction_for_developer_request.py +85 -0
  17. circle/web3/developer_controlled_wallets/models/accelerate_transaction_for_developer_response.py +83 -0
  18. circle/web3/developer_controlled_wallets/models/account_type.py +36 -0
  19. circle/web3/developer_controlled_wallets/models/balance.py +91 -0
  20. circle/web3/developer_controlled_wallets/models/blockchain.py +40 -0
  21. circle/web3/developer_controlled_wallets/models/cancel_transaction_for_developer_request.py +85 -0
  22. circle/web3/developer_controlled_wallets/models/cancel_transaction_for_developer_response.py +86 -0
  23. circle/web3/developer_controlled_wallets/models/create_contract_execution_transaction_for_developer_request.py +118 -0
  24. circle/web3/developer_controlled_wallets/models/create_contract_execution_transaction_for_developer_response.py +86 -0
  25. circle/web3/developer_controlled_wallets/models/create_developer_transaction_accelerate200_response.py +87 -0
  26. circle/web3/developer_controlled_wallets/models/create_developer_transaction_cancel200_response.py +87 -0
  27. circle/web3/developer_controlled_wallets/models/create_developer_transaction_contract_execution200_response.py +87 -0
  28. circle/web3/developer_controlled_wallets/models/create_developer_transaction_transfer200_response.py +87 -0
  29. circle/web3/developer_controlled_wallets/models/create_developer_wallet200_response.py +87 -0
  30. circle/web3/developer_controlled_wallets/models/create_developer_wallet_request.py +105 -0
  31. circle/web3/developer_controlled_wallets/models/create_developer_wallet_response.py +91 -0
  32. circle/web3/developer_controlled_wallets/models/create_developer_wallet_set_request.py +87 -0
  33. circle/web3/developer_controlled_wallets/models/create_developer_wallet_set_response.py +87 -0
  34. circle/web3/developer_controlled_wallets/models/create_transfer_estimate_fee200_response.py +87 -0
  35. circle/web3/developer_controlled_wallets/models/create_transfer_transaction_for_developer_request.py +112 -0
  36. circle/web3/developer_controlled_wallets/models/create_transfer_transaction_for_developer_response.py +86 -0
  37. circle/web3/developer_controlled_wallets/models/create_validate_address200_response.py +87 -0
  38. circle/web3/developer_controlled_wallets/models/create_wallet_set200_response.py +87 -0
  39. circle/web3/developer_controlled_wallets/models/custody_type.py +36 -0
  40. circle/web3/developer_controlled_wallets/models/error.py +85 -0
  41. circle/web3/developer_controlled_wallets/models/estimate_contract_execution_transaction_fee_request.py +106 -0
  42. circle/web3/developer_controlled_wallets/models/estimate_transaction_fee_response.py +103 -0
  43. circle/web3/developer_controlled_wallets/models/estimate_transfer_transaction_fee_request.py +97 -0
  44. circle/web3/developer_controlled_wallets/models/estimated_transaction_fee.py +91 -0
  45. circle/web3/developer_controlled_wallets/models/ext_get_all_wallets_response.py +91 -0
  46. circle/web3/developer_controlled_wallets/models/ext_get_wallet_by_id_response.py +87 -0
  47. circle/web3/developer_controlled_wallets/models/ext_update_wallet_metadata_request.py +85 -0
  48. circle/web3/developer_controlled_wallets/models/ext_wallet_response.py +87 -0
  49. circle/web3/developer_controlled_wallets/models/ext_wallet_response_wallet.py +111 -0
  50. circle/web3/developer_controlled_wallets/models/fee_level.py +37 -0
  51. circle/web3/developer_controlled_wallets/models/get_balances_response.py +91 -0
  52. circle/web3/developer_controlled_wallets/models/get_nfts_response.py +91 -0
  53. circle/web3/developer_controlled_wallets/models/get_token_by_id_response.py +87 -0
  54. circle/web3/developer_controlled_wallets/models/get_token_id200_response.py +87 -0
  55. circle/web3/developer_controlled_wallets/models/get_transaction200_response.py +87 -0
  56. circle/web3/developer_controlled_wallets/models/get_transaction_by_id_response.py +87 -0
  57. circle/web3/developer_controlled_wallets/models/get_transactions_response.py +91 -0
  58. circle/web3/developer_controlled_wallets/models/get_wallet200_response.py +87 -0
  59. circle/web3/developer_controlled_wallets/models/get_wallet_set200_response.py +87 -0
  60. circle/web3/developer_controlled_wallets/models/get_wallet_set_by_id_response.py +87 -0
  61. circle/web3/developer_controlled_wallets/models/get_wallet_sets_response.py +91 -0
  62. circle/web3/developer_controlled_wallets/models/list_transactions200_response.py +87 -0
  63. circle/web3/developer_controlled_wallets/models/list_wallet_ballance200_response.py +87 -0
  64. circle/web3/developer_controlled_wallets/models/list_wallet_nfts200_response.py +87 -0
  65. circle/web3/developer_controlled_wallets/models/list_wallet_sets200_response.py +87 -0
  66. circle/web3/developer_controlled_wallets/models/list_wallets200_response.py +87 -0
  67. circle/web3/developer_controlled_wallets/models/nft.py +95 -0
  68. circle/web3/developer_controlled_wallets/models/operation.py +37 -0
  69. circle/web3/developer_controlled_wallets/models/sign_developer_message200_response.py +87 -0
  70. circle/web3/developer_controlled_wallets/models/sign_developer_typed_data200_response.py +87 -0
  71. circle/web3/developer_controlled_wallets/models/sign_message_for_developer_request.py +91 -0
  72. circle/web3/developer_controlled_wallets/models/sign_message_for_developer_response.py +83 -0
  73. circle/web3/developer_controlled_wallets/models/sign_typed_data_for_developer_request.py +89 -0
  74. circle/web3/developer_controlled_wallets/models/sign_typed_data_for_developer_response.py +83 -0
  75. circle/web3/developer_controlled_wallets/models/token_response.py +103 -0
  76. circle/web3/developer_controlled_wallets/models/token_standard.py +37 -0
  77. circle/web3/developer_controlled_wallets/models/transaction.py +159 -0
  78. circle/web3/developer_controlled_wallets/models/transaction_state.py +43 -0
  79. circle/web3/developer_controlled_wallets/models/transaction_type.py +36 -0
  80. circle/web3/developer_controlled_wallets/models/update_wallet200_response.py +87 -0
  81. circle/web3/developer_controlled_wallets/models/update_wallet_set200_response.py +87 -0
  82. circle/web3/developer_controlled_wallets/models/update_wallet_set_metadata_request.py +83 -0
  83. circle/web3/developer_controlled_wallets/models/update_wallet_set_metadata_response.py +87 -0
  84. circle/web3/developer_controlled_wallets/models/validate_address_request.py +86 -0
  85. circle/web3/developer_controlled_wallets/models/validate_address_response.py +83 -0
  86. circle/web3/developer_controlled_wallets/models/wallet_metadata.py +85 -0
  87. circle/web3/developer_controlled_wallets/models/wallet_response.py +111 -0
  88. circle/web3/developer_controlled_wallets/models/wallet_set_response.py +94 -0
  89. circle/web3/developer_controlled_wallets/models/wallet_state.py +36 -0
  90. circle/web3/developer_controlled_wallets/py.typed +0 -0
  91. circle/web3/developer_controlled_wallets/rest.py +299 -0
  92. circle_developer_controlled_wallets-0.1.0b1.dist-info/METADATA +112 -0
  93. circle_developer_controlled_wallets-0.1.0b1.dist-info/RECORD +95 -0
  94. circle_developer_controlled_wallets-0.1.0b1.dist-info/WHEEL +5 -0
  95. circle_developer_controlled_wallets-0.1.0b1.dist-info/top_level.txt +1 -0
@@ -0,0 +1,25 @@
1
+ """API response object."""
2
+
3
+ from __future__ import annotations
4
+ from typing import Any, Dict, Optional
5
+ from pydantic import Field, StrictInt, StrictStr
6
+
7
+ class ApiResponse:
8
+ """
9
+ API response object
10
+ """
11
+
12
+ status_code: Optional[StrictInt] = Field(None, description="HTTP status code")
13
+ headers: Optional[Dict[StrictStr, StrictStr]] = Field(None, description="HTTP headers")
14
+ data: Optional[Any] = Field(None, description="Deserialized data given the data type")
15
+ raw_data: Optional[Any] = Field(None, description="Raw data (HTTP response body)")
16
+
17
+ def __init__(self,
18
+ status_code=None,
19
+ headers=None,
20
+ data=None,
21
+ raw_data=None):
22
+ self.status_code = status_code
23
+ self.headers = headers
24
+ self.data = data
25
+ self.raw_data = raw_data
@@ -0,0 +1,455 @@
1
+ # coding: utf-8
2
+
3
+ """
4
+ The version of the OpenAPI document: 1.0
5
+ Generated by OpenAPI Generator (https://openapi-generator.tech)
6
+
7
+ Do not edit the class manually.
8
+ """ # noqa: E501
9
+
10
+
11
+ import copy
12
+ import logging
13
+ import multiprocessing
14
+ import sys
15
+ import urllib3
16
+
17
+ import http.client as httplib
18
+ from circle.web3.developer_controlled_wallets.exceptions import ApiValueError
19
+
20
+ JSON_SCHEMA_VALIDATION_KEYWORDS = {
21
+ 'multipleOf', 'maximum', 'exclusiveMaximum',
22
+ 'minimum', 'exclusiveMinimum', 'maxLength',
23
+ 'minLength', 'pattern', 'maxItems', 'minItems'
24
+ }
25
+
26
+ class Configuration(object):
27
+ """This class contains various settings of the API client.
28
+
29
+ :param host: Base url.
30
+ :param api_key: Dict to store API key(s).
31
+ Each entry in the dict specifies an API key.
32
+ The dict key is the name of the security scheme in the OAS specification.
33
+ The dict value is the API key secret.
34
+ :param api_key_prefix: Dict to store API prefix (e.g. Bearer).
35
+ The dict key is the name of the security scheme in the OAS specification.
36
+ The dict value is an API key prefix when generating the auth data.
37
+ :param username: Username for HTTP basic authentication.
38
+ :param password: Password for HTTP basic authentication.
39
+ :param access_token: Access token.
40
+ :param entity_secret: Entity secret.
41
+ :param public_key: Public Key.
42
+ :param server_index: Index to servers configuration.
43
+ :param server_variables: Mapping with string values to replace variables in
44
+ templated server configuration. The validation of enums is performed for
45
+ variables with defined enum values before.
46
+ :param server_operation_index: Mapping from operation ID to an index to server
47
+ configuration.
48
+ :param server_operation_variables: Mapping from operation ID to a mapping with
49
+ string values to replace variables in templated server configuration.
50
+ The validation of enums is performed for variables with defined enum values before.
51
+ :param ssl_ca_cert: str - the path to a file of concatenated CA certificates
52
+ in PEM format.
53
+
54
+ :Example:
55
+ """
56
+
57
+ _default = None
58
+
59
+ def __init__(self, host=None,
60
+ api_key=None, api_key_prefix=None,
61
+ username=None, password=None,
62
+ access_token=None,
63
+ entity_secret=None,
64
+ public_key=None,
65
+ server_index=None, server_variables=None,
66
+ server_operation_index=None, server_operation_variables=None,
67
+ ssl_ca_cert=None,
68
+ ):
69
+ """Constructor
70
+ """
71
+ self._base_path = "https://api.circle.com/v1/w3s" if host is None else host
72
+ """Default Base url
73
+ """
74
+ self.server_index = 0 if server_index is None and host is None else server_index
75
+ self.server_operation_index = server_operation_index or {}
76
+ """Default server index
77
+ """
78
+ self.server_variables = server_variables or {}
79
+ self.server_operation_variables = server_operation_variables or {}
80
+ """Default server variables
81
+ """
82
+ self.temp_folder_path = None
83
+ """Temp file folder for downloading files
84
+ """
85
+ # Authentication Settings
86
+ self.api_key = {}
87
+ if api_key:
88
+ self.api_key = api_key
89
+ """dict to store API key(s)
90
+ """
91
+ self.api_key_prefix = {}
92
+ if api_key_prefix:
93
+ self.api_key_prefix = api_key_prefix
94
+ """dict to store API prefix (e.g. Bearer)
95
+ """
96
+ self.refresh_api_key_hook = None
97
+ """function hook to refresh API key if expired
98
+ """
99
+ self.username = username
100
+ """Username for HTTP basic authentication
101
+ """
102
+ self.password = password
103
+ """Password for HTTP basic authentication
104
+ """
105
+ self.access_token = access_token
106
+ """Access token
107
+ """
108
+ self.entity_secret = entity_secret
109
+ """Entity Secret
110
+ """
111
+ self.public_key = public_key
112
+ """Public Key
113
+ """
114
+ self.logger = {}
115
+ """Logging Settings
116
+ """
117
+ self.logger["package_logger"] = logging.getLogger("circle.web3.developer_controlled_wallets")
118
+ self.logger["urllib3_logger"] = logging.getLogger("urllib3")
119
+ self.logger_format = '%(asctime)s %(levelname)s %(message)s'
120
+ """Log format
121
+ """
122
+ self.logger_stream_handler = None
123
+ """Log stream handler
124
+ """
125
+ self.logger_file_handler = None
126
+ """Log file handler
127
+ """
128
+ self.logger_file = None
129
+ """Debug file location
130
+ """
131
+ self.debug = False
132
+ """Debug switch
133
+ """
134
+
135
+ self.verify_ssl = True
136
+ """SSL/TLS verification
137
+ Set this to false to skip verifying SSL certificate when calling API
138
+ from https server.
139
+ """
140
+ self.ssl_ca_cert = ssl_ca_cert
141
+ """Set this to customize the certificate file to verify the peer.
142
+ """
143
+ self.cert_file = None
144
+ """client certificate file
145
+ """
146
+ self.key_file = None
147
+ """client key file
148
+ """
149
+ self.assert_hostname = None
150
+ """Set this to True/False to enable/disable SSL hostname verification.
151
+ """
152
+ self.tls_server_name = None
153
+ """SSL/TLS Server Name Indication (SNI)
154
+ Set this to the SNI value expected by the server.
155
+ """
156
+
157
+ self.connection_pool_maxsize = multiprocessing.cpu_count() * 5
158
+ """urllib3 connection pool's maximum number of connections saved
159
+ per pool. urllib3 uses 1 connection as default value, but this is
160
+ not the best value when you are making a lot of possibly parallel
161
+ requests to the same host, which is often the case here.
162
+ cpu_count * 5 is used as default value to increase performance.
163
+ """
164
+
165
+ self.proxy = None
166
+ """Proxy URL
167
+ """
168
+ self.proxy_headers = None
169
+ """Proxy headers
170
+ """
171
+ self.safe_chars_for_path_param = ''
172
+ """Safe chars for path_param
173
+ """
174
+ self.retries = None
175
+ """Adding retries to override urllib3 default value 3
176
+ """
177
+ # Enable client side validation
178
+ self.client_side_validation = True
179
+
180
+ self.socket_options = None
181
+ """Options to pass down to the underlying urllib3 socket
182
+ """
183
+
184
+ self.datetime_format = "%Y-%m-%dT%H:%M:%S.%f%z"
185
+ """datetime format
186
+ """
187
+
188
+ self.date_format = "%Y-%m-%d"
189
+ """date format
190
+ """
191
+
192
+ def __deepcopy__(self, memo):
193
+ cls = self.__class__
194
+ result = cls.__new__(cls)
195
+ memo[id(self)] = result
196
+ for k, v in self.__dict__.items():
197
+ if k not in ('logger', 'logger_file_handler'):
198
+ setattr(result, k, copy.deepcopy(v, memo))
199
+ # shallow copy of loggers
200
+ result.logger = copy.copy(self.logger)
201
+ # use setters to configure loggers
202
+ result.logger_file = self.logger_file
203
+ result.debug = self.debug
204
+ return result
205
+
206
+ def __setattr__(self, name, value):
207
+ object.__setattr__(self, name, value)
208
+
209
+ @classmethod
210
+ def set_default(cls, default):
211
+ """Set default instance of configuration.
212
+
213
+ It stores default configuration, which can be
214
+ returned by get_default_copy method.
215
+
216
+ :param default: object of Configuration
217
+ """
218
+ cls._default = default
219
+
220
+ @classmethod
221
+ def get_default_copy(cls):
222
+ """Deprecated. Please use `get_default` instead.
223
+
224
+ Deprecated. Please use `get_default` instead.
225
+
226
+ :return: The configuration object.
227
+ """
228
+ return cls.get_default()
229
+
230
+ @classmethod
231
+ def get_default(cls):
232
+ """Return the default configuration.
233
+
234
+ This method returns newly created, based on default constructor,
235
+ object of Configuration class or returns a copy of default
236
+ configuration.
237
+
238
+ :return: The configuration object.
239
+ """
240
+ if cls._default is None:
241
+ cls._default = Configuration()
242
+ return cls._default
243
+
244
+ @property
245
+ def logger_file(self):
246
+ """The logger file.
247
+
248
+ If the logger_file is None, then add stream handler and remove file
249
+ handler. Otherwise, add file handler and remove stream handler.
250
+
251
+ :param value: The logger_file path.
252
+ :type: str
253
+ """
254
+ return self.__logger_file
255
+
256
+ @logger_file.setter
257
+ def logger_file(self, value):
258
+ """The logger file.
259
+
260
+ If the logger_file is None, then add stream handler and remove file
261
+ handler. Otherwise, add file handler and remove stream handler.
262
+
263
+ :param value: The logger_file path.
264
+ :type: str
265
+ """
266
+ self.__logger_file = value
267
+ if self.__logger_file:
268
+ # If set logging file,
269
+ # then add file handler and remove stream handler.
270
+ self.logger_file_handler = logging.FileHandler(self.__logger_file)
271
+ self.logger_file_handler.setFormatter(self.logger_formatter)
272
+ for _, logger in self.logger.items():
273
+ logger.addHandler(self.logger_file_handler)
274
+
275
+ @property
276
+ def debug(self):
277
+ """Debug status
278
+
279
+ :param value: The debug status, True or False.
280
+ :type: bool
281
+ """
282
+ return self.__debug
283
+
284
+ @debug.setter
285
+ def debug(self, value):
286
+ """Debug status
287
+
288
+ :param value: The debug status, True or False.
289
+ :type: bool
290
+ """
291
+ self.__debug = value
292
+ if self.__debug:
293
+ # if debug status is True, turn on debug logging
294
+ for _, logger in self.logger.items():
295
+ logger.setLevel(logging.DEBUG)
296
+ # turn on httplib debug
297
+ httplib.HTTPConnection.debuglevel = 1
298
+ else:
299
+ # if debug status is False, turn off debug logging,
300
+ # setting log level to default `logging.WARNING`
301
+ for _, logger in self.logger.items():
302
+ logger.setLevel(logging.WARNING)
303
+ # turn off httplib debug
304
+ httplib.HTTPConnection.debuglevel = 0
305
+
306
+ @property
307
+ def logger_format(self):
308
+ """The logger format.
309
+
310
+ The logger_formatter will be updated when sets logger_format.
311
+
312
+ :param value: The format string.
313
+ :type: str
314
+ """
315
+ return self.__logger_format
316
+
317
+ @logger_format.setter
318
+ def logger_format(self, value):
319
+ """The logger format.
320
+
321
+ The logger_formatter will be updated when sets logger_format.
322
+
323
+ :param value: The format string.
324
+ :type: str
325
+ """
326
+ self.__logger_format = value
327
+ self.logger_formatter = logging.Formatter(self.__logger_format)
328
+
329
+ def get_api_key_with_prefix(self, identifier, alias=None):
330
+ """Gets API key (with prefix if set).
331
+
332
+ :param identifier: The identifier of apiKey.
333
+ :param alias: The alternative identifier of apiKey.
334
+ :return: The token for api key authentication.
335
+ """
336
+ if self.refresh_api_key_hook is not None:
337
+ self.refresh_api_key_hook(self)
338
+ key = self.api_key.get(identifier, self.api_key.get(alias) if alias is not None else None)
339
+ if key:
340
+ prefix = self.api_key_prefix.get(identifier)
341
+ if prefix:
342
+ return "%s %s" % (prefix, key)
343
+ else:
344
+ return key
345
+
346
+ def get_basic_auth_token(self):
347
+ """Gets HTTP basic authentication header (string).
348
+
349
+ :return: The token for basic HTTP authentication.
350
+ """
351
+ username = ""
352
+ if self.username is not None:
353
+ username = self.username
354
+ password = ""
355
+ if self.password is not None:
356
+ password = self.password
357
+ return urllib3.util.make_headers(
358
+ basic_auth=username + ':' + password
359
+ ).get('authorization')
360
+
361
+ def auth_settings(self):
362
+ """Gets Auth Settings dict for api client.
363
+
364
+ :return: The Auth Settings information dict.
365
+ """
366
+ auth = {}
367
+ if self.access_token is not None:
368
+ auth['BearerAuth'] = {
369
+ 'type': 'bearer',
370
+ 'in': 'header',
371
+ 'format': 'PREFIX:ID:SECRET',
372
+ 'key': 'Authorization',
373
+ 'value': 'Bearer ' + self.access_token
374
+ }
375
+ return auth
376
+
377
+ def to_debug_report(self):
378
+ """Gets the essential information for debugging.
379
+
380
+ :return: The report for debugging.
381
+ """
382
+ return "Python SDK Debug Report:\n"\
383
+ "OS: {env}\n"\
384
+ "Python Version: {pyversion}\n"\
385
+ "Version of the API: 1.0\n"\
386
+ "SDK Package Version: 0.1.0b1".\
387
+ format(env=sys.platform, pyversion=sys.version)
388
+
389
+ def get_host_settings(self):
390
+ """Gets an array of host settings
391
+
392
+ :return: An array of host settings
393
+ """
394
+ return [
395
+ {
396
+ 'url': "https://api.circle.com/v1/w3s",
397
+ 'description': "No description provided",
398
+ }
399
+ ]
400
+
401
+ def get_host_from_settings(self, index, variables=None, servers=None):
402
+ """Gets host URL based on the index and variables
403
+ :param index: array index of the host settings
404
+ :param variables: hash of variable and the corresponding value
405
+ :param servers: an array of host settings or None
406
+ :return: URL based on host settings
407
+ """
408
+ if index is None:
409
+ return self._base_path
410
+
411
+ variables = {} if variables is None else variables
412
+ servers = self.get_host_settings() if servers is None else servers
413
+
414
+ try:
415
+ server = servers[index]
416
+ except IndexError:
417
+ raise ValueError(
418
+ "Invalid index {0} when selecting the host settings. "
419
+ "Must be less than {1}".format(index, len(servers)))
420
+
421
+ url = server['url']
422
+
423
+ # go through variables and replace placeholders
424
+ for variable_name, variable in server.get('variables', {}).items():
425
+ used_value = variables.get(
426
+ variable_name, variable['default_value'])
427
+
428
+ if 'enum_values' in variable \
429
+ and used_value not in variable['enum_values']:
430
+ raise ValueError(
431
+ "The variable `{0}` in the host URL has invalid value "
432
+ "{1}. Must be {2}.".format(
433
+ variable_name, variables[variable_name],
434
+ variable['enum_values']))
435
+
436
+ url = url.replace("{" + variable_name + "}", used_value)
437
+
438
+ return url
439
+
440
+ @property
441
+ def host(self):
442
+ """Return generated host."""
443
+ return self.get_host_from_settings(self.server_index, variables=self.server_variables)
444
+
445
+ @host.setter
446
+ def host(self, value):
447
+ """Fix base path."""
448
+ self._base_path = value
449
+ self.server_index = None
450
+
451
+ def get_public_key(self):
452
+ return self.public_key
453
+
454
+ def set_public_key(self, key):
455
+ self.public_key = key
@@ -0,0 +1,162 @@
1
+ # coding: utf-8
2
+
3
+ """
4
+ The version of the OpenAPI document: 1.0
5
+ Generated by OpenAPI Generator (https://openapi-generator.tech)
6
+
7
+ Do not edit the class manually.
8
+ """ # noqa: E501
9
+
10
+
11
+ class OpenApiException(Exception):
12
+ """The base exception class for all OpenAPIExceptions"""
13
+
14
+
15
+ class ApiTypeError(OpenApiException, TypeError):
16
+ def __init__(self, msg, path_to_item=None, valid_classes=None,
17
+ key_type=None):
18
+ """ Raises an exception for TypeErrors
19
+
20
+ Args:
21
+ msg (str): the exception message
22
+
23
+ Keyword Args:
24
+ path_to_item (list): a list of keys an indices to get to the
25
+ current_item
26
+ None if unset
27
+ valid_classes (tuple): the primitive classes that current item
28
+ should be an instance of
29
+ None if unset
30
+ key_type (bool): False if our value is a value in a dict
31
+ True if it is a key in a dict
32
+ False if our item is an item in a list
33
+ None if unset
34
+ """
35
+ self.path_to_item = path_to_item
36
+ self.valid_classes = valid_classes
37
+ self.key_type = key_type
38
+ full_msg = msg
39
+ if path_to_item:
40
+ full_msg = "{0} at {1}".format(msg, render_path(path_to_item))
41
+ super(ApiTypeError, self).__init__(full_msg)
42
+
43
+
44
+ class ApiValueError(OpenApiException, ValueError):
45
+ def __init__(self, msg, path_to_item=None):
46
+ """
47
+ Args:
48
+ msg (str): the exception message
49
+
50
+ Keyword Args:
51
+ path_to_item (list) the path to the exception in the
52
+ received_data dict. None if unset
53
+ """
54
+
55
+ self.path_to_item = path_to_item
56
+ full_msg = msg
57
+ if path_to_item:
58
+ full_msg = "{0} at {1}".format(msg, render_path(path_to_item))
59
+ super(ApiValueError, self).__init__(full_msg)
60
+
61
+
62
+ class ApiAttributeError(OpenApiException, AttributeError):
63
+ def __init__(self, msg, path_to_item=None):
64
+ """
65
+ Raised when an attribute reference or assignment fails.
66
+
67
+ Args:
68
+ msg (str): the exception message
69
+
70
+ Keyword Args:
71
+ path_to_item (None/list) the path to the exception in the
72
+ received_data dict
73
+ """
74
+ self.path_to_item = path_to_item
75
+ full_msg = msg
76
+ if path_to_item:
77
+ full_msg = "{0} at {1}".format(msg, render_path(path_to_item))
78
+ super(ApiAttributeError, self).__init__(full_msg)
79
+
80
+
81
+ class ApiKeyError(OpenApiException, KeyError):
82
+ def __init__(self, msg, path_to_item=None):
83
+ """
84
+ Args:
85
+ msg (str): the exception message
86
+
87
+ Keyword Args:
88
+ path_to_item (None/list) the path to the exception in the
89
+ received_data dict
90
+ """
91
+ self.path_to_item = path_to_item
92
+ full_msg = msg
93
+ if path_to_item:
94
+ full_msg = "{0} at {1}".format(msg, render_path(path_to_item))
95
+ super(ApiKeyError, self).__init__(full_msg)
96
+
97
+
98
+ class ApiException(OpenApiException):
99
+
100
+ def __init__(self, status=None, reason=None, http_resp=None):
101
+ if http_resp:
102
+ self.status = http_resp.status
103
+ self.reason = http_resp.reason
104
+ self.body = http_resp.data
105
+ self.headers = http_resp.getheaders()
106
+ else:
107
+ self.status = status
108
+ self.reason = reason
109
+ self.body = None
110
+ self.headers = None
111
+
112
+ def __str__(self):
113
+ """Custom error messages for exception"""
114
+ error_message = "({0})\n"\
115
+ "Reason: {1}\n".format(self.status, self.reason)
116
+ if self.headers:
117
+ error_message += "HTTP response headers: {0}\n".format(
118
+ self.headers)
119
+
120
+ if self.body:
121
+ error_message += "HTTP response body: {0}\n".format(self.body)
122
+
123
+ return error_message
124
+
125
+ class BadRequestException(ApiException):
126
+
127
+ def __init__(self, status=None, reason=None, http_resp=None):
128
+ super(BadRequestException, self).__init__(status, reason, http_resp)
129
+
130
+ class NotFoundException(ApiException):
131
+
132
+ def __init__(self, status=None, reason=None, http_resp=None):
133
+ super(NotFoundException, self).__init__(status, reason, http_resp)
134
+
135
+
136
+ class UnauthorizedException(ApiException):
137
+
138
+ def __init__(self, status=None, reason=None, http_resp=None):
139
+ super(UnauthorizedException, self).__init__(status, reason, http_resp)
140
+
141
+
142
+ class ForbiddenException(ApiException):
143
+
144
+ def __init__(self, status=None, reason=None, http_resp=None):
145
+ super(ForbiddenException, self).__init__(status, reason, http_resp)
146
+
147
+
148
+ class ServiceException(ApiException):
149
+
150
+ def __init__(self, status=None, reason=None, http_resp=None):
151
+ super(ServiceException, self).__init__(status, reason, http_resp)
152
+
153
+
154
+ def render_path(path_to_item):
155
+ """Returns a string representation of a path"""
156
+ result = ""
157
+ for pth in path_to_item:
158
+ if isinstance(pth, int):
159
+ result += "[{0}]".format(pth)
160
+ else:
161
+ result += "['{0}']".format(pth)
162
+ return result