crypticorn 2.5.1__py3-none-any.whl → 2.5.2__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.
- crypticorn/common/__init__.py +1 -0
- crypticorn/common/enums.py +3 -1
- crypticorn/common/errors.py +40 -4
- crypticorn/common/mixins.py +1 -0
- crypticorn/common/status_router.py +42 -0
- crypticorn/common/utils.py +5 -12
- crypticorn/klines/client/__init__.py +0 -5
- crypticorn/klines/client/api/change_in_timeframe_api.py +8 -9
- crypticorn/klines/client/api/ohlcv_data_api.py +7 -8
- crypticorn/klines/client/api/symbols_api.py +7 -8
- crypticorn/klines/client/models/__init__.py +0 -5
- crypticorn/klines/client/models/exception_detail.py +3 -6
- crypticorn/klines/client/models/search_symbol.py +4 -3
- crypticorn/klines/client/models/udf_config.py +1 -2
- crypticorn/metrics/client/__init__.py +1 -6
- crypticorn/metrics/client/api/exchanges_api.py +29 -31
- crypticorn/metrics/client/api/indicators_api.py +15 -16
- crypticorn/metrics/client/api/logs_api.py +1 -1
- crypticorn/metrics/client/api/marketcap_api.py +15 -16
- crypticorn/metrics/client/api/markets_api.py +15 -16
- crypticorn/metrics/client/api/status_api.py +1 -1
- crypticorn/metrics/client/api/tokens_api.py +1 -1
- crypticorn/metrics/client/api_client.py +1 -1
- crypticorn/metrics/client/configuration.py +3 -5
- crypticorn/metrics/client/exceptions.py +1 -1
- crypticorn/metrics/client/models/__init__.py +1 -6
- crypticorn/metrics/client/models/exception_detail.py +4 -7
- crypticorn/metrics/client/models/severity.py +1 -1
- crypticorn/metrics/client/models/time_interval.py +1 -1
- crypticorn/metrics/client/models/trading_status.py +1 -1
- crypticorn/metrics/client/rest.py +1 -1
- crypticorn/trade/client/__init__.py +1 -2
- crypticorn/trade/client/api/exchanges_api.py +6 -6
- crypticorn/trade/client/api/trading_actions_api.py +16 -15
- crypticorn/trade/client/configuration.py +2 -2
- crypticorn/trade/client/models/__init__.py +1 -2
- crypticorn/trade/client/models/action_model.py +1 -2
- crypticorn/trade/client/models/exchange_key_model.py +2 -11
- crypticorn/trade/client/models/futures_trading_action.py +1 -2
- crypticorn/trade/client/models/order_model.py +4 -14
- crypticorn/trade/client/models/spot_trading_action.py +1 -2
- crypticorn/trade/client/models/strategy_exchange_info.py +2 -3
- crypticorn/trade/client/models/strategy_model_input.py +1 -2
- crypticorn/trade/client/models/strategy_model_output.py +1 -2
- crypticorn/trade/client/models/tpsl.py +3 -1
- {crypticorn-2.5.1.dist-info → crypticorn-2.5.2.dist-info}/METADATA +1 -1
- {crypticorn-2.5.1.dist-info → crypticorn-2.5.2.dist-info}/RECORD +50 -127
- crypticorn/klines/client/api/health_check_api.py +0 -265
- crypticorn/klines/client/models/api_error_identifier.py +0 -108
- crypticorn/klines/client/models/api_error_level.py +0 -37
- crypticorn/klines/client/models/api_error_type.py +0 -37
- crypticorn/klines/client/models/base_response_health_check_response.py +0 -114
- crypticorn/klines/client/models/base_response_list_change_in_timeframe_response.py +0 -123
- crypticorn/klines/client/models/base_response_list_funding_rate_response.py +0 -118
- crypticorn/klines/client/models/base_response_list_str.py +0 -106
- crypticorn/klines/client/models/base_response_ohlcv_response.py +0 -114
- crypticorn/klines/client/models/change_in_timeframe_response.py +0 -86
- crypticorn/klines/client/models/error_response.py +0 -109
- crypticorn/klines/client/models/exchange.py +0 -91
- crypticorn/klines/client/models/funding_rate_response.py +0 -92
- crypticorn/klines/client/models/health_check_response.py +0 -91
- crypticorn/klines/client/models/history_error_response.py +0 -89
- crypticorn/klines/client/models/history_no_data_response.py +0 -99
- crypticorn/klines/client/models/history_success_response.py +0 -99
- crypticorn/klines/client/models/http_validation_error.py +0 -99
- crypticorn/klines/client/models/internal_exchange.py +0 -39
- crypticorn/klines/client/models/market.py +0 -35
- crypticorn/klines/client/models/market_type.py +0 -35
- crypticorn/klines/client/models/ohlcv_response.py +0 -105
- crypticorn/klines/client/models/response_get_history_udf_history_get.py +0 -198
- crypticorn/klines/client/models/response_get_udf_history.py +0 -198
- crypticorn/klines/client/models/search_symbol_response.py +0 -104
- crypticorn/klines/client/models/symbol_group_response.py +0 -83
- crypticorn/klines/client/models/symbol_info_response.py +0 -131
- crypticorn/klines/client/models/udf_config_response.py +0 -160
- crypticorn/klines/client/models/validation_error.py +0 -105
- crypticorn/klines/client/models/validation_error_loc_inner.py +0 -159
- crypticorn/metrics/client/api/health_check_api.py +0 -265
- crypticorn/metrics/client/models/api_error_identifier.py +0 -108
- crypticorn/metrics/client/models/api_error_level.py +0 -37
- crypticorn/metrics/client/models/api_error_type.py +0 -37
- crypticorn/metrics/client/models/base_response_dict.py +0 -106
- crypticorn/metrics/client/models/base_response_health_check_response.py +0 -114
- crypticorn/metrics/client/models/base_response_list_dict.py +0 -106
- crypticorn/metrics/client/models/base_response_list_exchange_mapping.py +0 -118
- crypticorn/metrics/client/models/base_response_list_str.py +0 -106
- crypticorn/metrics/client/models/error_response.py +0 -109
- crypticorn/metrics/client/models/exchange_mapping.py +0 -134
- crypticorn/metrics/client/models/health_check_response.py +0 -91
- crypticorn/metrics/client/models/http_validation_error.py +0 -99
- crypticorn/metrics/client/models/internal_exchange.py +0 -39
- crypticorn/metrics/client/models/market.py +0 -35
- crypticorn/metrics/client/models/market_type.py +0 -35
- crypticorn/metrics/client/models/validation_error.py +0 -105
- crypticorn/metrics/client/models/validation_error_loc_inner.py +0 -159
- crypticorn/pay/client/models/api_status_res.py +0 -83
- crypticorn/pay/client/models/body_create_now_invoice.py +0 -98
- crypticorn/pay/client/models/body_create_product.py +0 -98
- crypticorn/pay/client/models/body_get_products.py +0 -87
- crypticorn/pay/client/models/body_handle_now_webhook.py +0 -98
- crypticorn/pay/client/models/body_update_product.py +0 -98
- crypticorn/pay/client/models/combined_payment_history.py +0 -101
- crypticorn/pay/client/models/create_invoice_req.py +0 -188
- crypticorn/pay/client/models/create_invoice_res.py +0 -188
- crypticorn/pay/client/models/currency.py +0 -165
- crypticorn/pay/client/models/estimate_price_req.py +0 -91
- crypticorn/pay/client/models/estimate_price_res.py +0 -102
- crypticorn/pay/client/models/get_currencies_res.py +0 -99
- crypticorn/pay/client/models/get_payment_status_res.py +0 -222
- crypticorn/pay/client/models/get_payments_list_res.py +0 -109
- crypticorn/pay/client/models/min_amount_req.py +0 -124
- crypticorn/pay/client/models/min_amount_res.py +0 -105
- crypticorn/pay/client/models/now_fee_structure.py +0 -104
- crypticorn/pay/client/models/now_payment_model.py +0 -124
- crypticorn/pay/client/models/now_payment_status.py +0 -42
- crypticorn/pay/client/models/now_webhook_payload.py +0 -181
- crypticorn/pay/client/models/partial_product_update_model.py +0 -150
- crypticorn/pay/client/models/product.py +0 -87
- crypticorn/pay/client/models/product_model.py +0 -128
- crypticorn/pay/client/models/product_subs_model.py +0 -108
- crypticorn/pay/client/models/product_update_model.py +0 -150
- crypticorn/pay/client/models/unified_payment_model.py +0 -112
- crypticorn/trade/client/models/api_key_model.py +0 -156
- crypticorn/trade/client/models/exchange.py +0 -35
- crypticorn/trade/client/models/market_type.py +0 -35
- {crypticorn-2.5.1.dist-info → crypticorn-2.5.2.dist-info}/WHEEL +0 -0
- {crypticorn-2.5.1.dist-info → crypticorn-2.5.2.dist-info}/entry_points.txt +0 -0
- {crypticorn-2.5.1.dist-info → crypticorn-2.5.2.dist-info}/top_level.txt +0 -0
@@ -1,265 +0,0 @@
|
|
1
|
-
# coding: utf-8
|
2
|
-
|
3
|
-
"""
|
4
|
-
Marketcap Service API
|
5
|
-
|
6
|
-
API for retrieving historical marketcap data, available exchanges, and indicators. ## Features - Historical marketcap data - OHLCV data with marketcap - Technical indicators (KER, SMA) - Exchange and symbol mappings - Error logs
|
7
|
-
|
8
|
-
The version of the OpenAPI document: 1.0.0
|
9
|
-
Generated by OpenAPI Generator (https://openapi-generator.tech)
|
10
|
-
|
11
|
-
Do not edit the class manually.
|
12
|
-
""" # noqa: E501
|
13
|
-
|
14
|
-
import warnings
|
15
|
-
from pydantic import validate_call, Field, StrictFloat, StrictStr, StrictInt
|
16
|
-
from typing import Any, Dict, List, Optional, Tuple, Union
|
17
|
-
from typing_extensions import Annotated
|
18
|
-
|
19
|
-
from crypticorn.metrics.client.models.base_response_health_check_response import (
|
20
|
-
BaseResponseHealthCheckResponse,
|
21
|
-
)
|
22
|
-
|
23
|
-
from crypticorn.metrics.client.api_client import ApiClient, RequestSerialized
|
24
|
-
from crypticorn.metrics.client.api_response import ApiResponse
|
25
|
-
from crypticorn.metrics.client.rest import RESTResponseType
|
26
|
-
|
27
|
-
|
28
|
-
class HealthCheckApi:
|
29
|
-
"""NOTE: This class is auto generated by OpenAPI Generator
|
30
|
-
Ref: https://openapi-generator.tech
|
31
|
-
|
32
|
-
Do not edit the class manually.
|
33
|
-
"""
|
34
|
-
|
35
|
-
def __init__(self, api_client=None) -> None:
|
36
|
-
if api_client is None:
|
37
|
-
api_client = ApiClient.get_default()
|
38
|
-
self.api_client = api_client
|
39
|
-
|
40
|
-
@validate_call
|
41
|
-
async def health_check(
|
42
|
-
self,
|
43
|
-
_request_timeout: Union[
|
44
|
-
None,
|
45
|
-
Annotated[StrictFloat, Field(gt=0)],
|
46
|
-
Tuple[
|
47
|
-
Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)]
|
48
|
-
],
|
49
|
-
] = None,
|
50
|
-
_request_auth: Optional[Dict[StrictStr, Any]] = None,
|
51
|
-
_content_type: Optional[StrictStr] = None,
|
52
|
-
_headers: Optional[Dict[StrictStr, Any]] = None,
|
53
|
-
_host_index: Annotated[StrictInt, Field(ge=0, le=0)] = 0,
|
54
|
-
) -> BaseResponseHealthCheckResponse:
|
55
|
-
"""Read Root
|
56
|
-
|
57
|
-
Health check endpoint to verify if the API is running.
|
58
|
-
|
59
|
-
:param _request_timeout: timeout setting for this request. If one
|
60
|
-
number provided, it will be total request
|
61
|
-
timeout. It can also be a pair (tuple) of
|
62
|
-
(connection, read) timeouts.
|
63
|
-
:type _request_timeout: int, tuple(int, int), optional
|
64
|
-
:param _request_auth: set to override the auth_settings for an a single
|
65
|
-
request; this effectively ignores the
|
66
|
-
authentication in the spec for a single request.
|
67
|
-
:type _request_auth: dict, optional
|
68
|
-
:param _content_type: force content-type for the request.
|
69
|
-
:type _content_type: str, Optional
|
70
|
-
:param _headers: set to override the headers for a single
|
71
|
-
request; this effectively ignores the headers
|
72
|
-
in the spec for a single request.
|
73
|
-
:type _headers: dict, optional
|
74
|
-
:param _host_index: set to override the host_index for a single
|
75
|
-
request; this effectively ignores the host_index
|
76
|
-
in the spec for a single request.
|
77
|
-
:type _host_index: int, optional
|
78
|
-
:return: Returns the result object.
|
79
|
-
""" # noqa: E501
|
80
|
-
|
81
|
-
_param = self._health_check_serialize(
|
82
|
-
_request_auth=_request_auth,
|
83
|
-
_content_type=_content_type,
|
84
|
-
_headers=_headers,
|
85
|
-
_host_index=_host_index,
|
86
|
-
)
|
87
|
-
|
88
|
-
_response_types_map: Dict[str, Optional[str]] = {
|
89
|
-
"200": "BaseResponseHealthCheckResponse",
|
90
|
-
}
|
91
|
-
response_data = await self.api_client.call_api(
|
92
|
-
*_param, _request_timeout=_request_timeout
|
93
|
-
)
|
94
|
-
await response_data.read()
|
95
|
-
return self.api_client.response_deserialize(
|
96
|
-
response_data=response_data,
|
97
|
-
response_types_map=_response_types_map,
|
98
|
-
).data
|
99
|
-
|
100
|
-
@validate_call
|
101
|
-
async def health_check_with_http_info(
|
102
|
-
self,
|
103
|
-
_request_timeout: Union[
|
104
|
-
None,
|
105
|
-
Annotated[StrictFloat, Field(gt=0)],
|
106
|
-
Tuple[
|
107
|
-
Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)]
|
108
|
-
],
|
109
|
-
] = None,
|
110
|
-
_request_auth: Optional[Dict[StrictStr, Any]] = None,
|
111
|
-
_content_type: Optional[StrictStr] = None,
|
112
|
-
_headers: Optional[Dict[StrictStr, Any]] = None,
|
113
|
-
_host_index: Annotated[StrictInt, Field(ge=0, le=0)] = 0,
|
114
|
-
) -> ApiResponse[BaseResponseHealthCheckResponse]:
|
115
|
-
"""Read Root
|
116
|
-
|
117
|
-
Health check endpoint to verify if the API is running.
|
118
|
-
|
119
|
-
:param _request_timeout: timeout setting for this request. If one
|
120
|
-
number provided, it will be total request
|
121
|
-
timeout. It can also be a pair (tuple) of
|
122
|
-
(connection, read) timeouts.
|
123
|
-
:type _request_timeout: int, tuple(int, int), optional
|
124
|
-
:param _request_auth: set to override the auth_settings for an a single
|
125
|
-
request; this effectively ignores the
|
126
|
-
authentication in the spec for a single request.
|
127
|
-
:type _request_auth: dict, optional
|
128
|
-
:param _content_type: force content-type for the request.
|
129
|
-
:type _content_type: str, Optional
|
130
|
-
:param _headers: set to override the headers for a single
|
131
|
-
request; this effectively ignores the headers
|
132
|
-
in the spec for a single request.
|
133
|
-
:type _headers: dict, optional
|
134
|
-
:param _host_index: set to override the host_index for a single
|
135
|
-
request; this effectively ignores the host_index
|
136
|
-
in the spec for a single request.
|
137
|
-
:type _host_index: int, optional
|
138
|
-
:return: Returns the result object.
|
139
|
-
""" # noqa: E501
|
140
|
-
|
141
|
-
_param = self._health_check_serialize(
|
142
|
-
_request_auth=_request_auth,
|
143
|
-
_content_type=_content_type,
|
144
|
-
_headers=_headers,
|
145
|
-
_host_index=_host_index,
|
146
|
-
)
|
147
|
-
|
148
|
-
_response_types_map: Dict[str, Optional[str]] = {
|
149
|
-
"200": "BaseResponseHealthCheckResponse",
|
150
|
-
}
|
151
|
-
response_data = await self.api_client.call_api(
|
152
|
-
*_param, _request_timeout=_request_timeout
|
153
|
-
)
|
154
|
-
await response_data.read()
|
155
|
-
return self.api_client.response_deserialize(
|
156
|
-
response_data=response_data,
|
157
|
-
response_types_map=_response_types_map,
|
158
|
-
)
|
159
|
-
|
160
|
-
@validate_call
|
161
|
-
async def health_check_without_preload_content(
|
162
|
-
self,
|
163
|
-
_request_timeout: Union[
|
164
|
-
None,
|
165
|
-
Annotated[StrictFloat, Field(gt=0)],
|
166
|
-
Tuple[
|
167
|
-
Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)]
|
168
|
-
],
|
169
|
-
] = None,
|
170
|
-
_request_auth: Optional[Dict[StrictStr, Any]] = None,
|
171
|
-
_content_type: Optional[StrictStr] = None,
|
172
|
-
_headers: Optional[Dict[StrictStr, Any]] = None,
|
173
|
-
_host_index: Annotated[StrictInt, Field(ge=0, le=0)] = 0,
|
174
|
-
) -> RESTResponseType:
|
175
|
-
"""Read Root
|
176
|
-
|
177
|
-
Health check endpoint to verify if the API is running.
|
178
|
-
|
179
|
-
:param _request_timeout: timeout setting for this request. If one
|
180
|
-
number provided, it will be total request
|
181
|
-
timeout. It can also be a pair (tuple) of
|
182
|
-
(connection, read) timeouts.
|
183
|
-
:type _request_timeout: int, tuple(int, int), optional
|
184
|
-
:param _request_auth: set to override the auth_settings for an a single
|
185
|
-
request; this effectively ignores the
|
186
|
-
authentication in the spec for a single request.
|
187
|
-
:type _request_auth: dict, optional
|
188
|
-
:param _content_type: force content-type for the request.
|
189
|
-
:type _content_type: str, Optional
|
190
|
-
:param _headers: set to override the headers for a single
|
191
|
-
request; this effectively ignores the headers
|
192
|
-
in the spec for a single request.
|
193
|
-
:type _headers: dict, optional
|
194
|
-
:param _host_index: set to override the host_index for a single
|
195
|
-
request; this effectively ignores the host_index
|
196
|
-
in the spec for a single request.
|
197
|
-
:type _host_index: int, optional
|
198
|
-
:return: Returns the result object.
|
199
|
-
""" # noqa: E501
|
200
|
-
|
201
|
-
_param = self._health_check_serialize(
|
202
|
-
_request_auth=_request_auth,
|
203
|
-
_content_type=_content_type,
|
204
|
-
_headers=_headers,
|
205
|
-
_host_index=_host_index,
|
206
|
-
)
|
207
|
-
|
208
|
-
_response_types_map: Dict[str, Optional[str]] = {
|
209
|
-
"200": "BaseResponseHealthCheckResponse",
|
210
|
-
}
|
211
|
-
response_data = await self.api_client.call_api(
|
212
|
-
*_param, _request_timeout=_request_timeout
|
213
|
-
)
|
214
|
-
return response_data.response
|
215
|
-
|
216
|
-
def _health_check_serialize(
|
217
|
-
self,
|
218
|
-
_request_auth,
|
219
|
-
_content_type,
|
220
|
-
_headers,
|
221
|
-
_host_index,
|
222
|
-
) -> RequestSerialized:
|
223
|
-
|
224
|
-
_host = None
|
225
|
-
|
226
|
-
_collection_formats: Dict[str, str] = {}
|
227
|
-
|
228
|
-
_path_params: Dict[str, str] = {}
|
229
|
-
_query_params: List[Tuple[str, str]] = []
|
230
|
-
_header_params: Dict[str, Optional[str]] = _headers or {}
|
231
|
-
_form_params: List[Tuple[str, str]] = []
|
232
|
-
_files: Dict[
|
233
|
-
str, Union[str, bytes, List[str], List[bytes], List[Tuple[str, bytes]]]
|
234
|
-
] = {}
|
235
|
-
_body_params: Optional[bytes] = None
|
236
|
-
|
237
|
-
# process the path parameters
|
238
|
-
# process the query parameters
|
239
|
-
# process the header parameters
|
240
|
-
# process the form parameters
|
241
|
-
# process the body parameter
|
242
|
-
|
243
|
-
# set the HTTP header `Accept`
|
244
|
-
if "Accept" not in _header_params:
|
245
|
-
_header_params["Accept"] = self.api_client.select_header_accept(
|
246
|
-
["application/json"]
|
247
|
-
)
|
248
|
-
|
249
|
-
# authentication setting
|
250
|
-
_auth_settings: List[str] = []
|
251
|
-
|
252
|
-
return self.api_client.param_serialize(
|
253
|
-
method="GET",
|
254
|
-
resource_path="/",
|
255
|
-
path_params=_path_params,
|
256
|
-
query_params=_query_params,
|
257
|
-
header_params=_header_params,
|
258
|
-
body=_body_params,
|
259
|
-
post_params=_form_params,
|
260
|
-
files=_files,
|
261
|
-
auth_settings=_auth_settings,
|
262
|
-
collection_formats=_collection_formats,
|
263
|
-
_host=_host,
|
264
|
-
_request_auth=_request_auth,
|
265
|
-
)
|
@@ -1,108 +0,0 @@
|
|
1
|
-
# coding: utf-8
|
2
|
-
|
3
|
-
"""
|
4
|
-
Marketcap Service API
|
5
|
-
|
6
|
-
No description provided (generated by Openapi Generator https://github.com/openapitools/openapi-generator)
|
7
|
-
|
8
|
-
The version of the OpenAPI document: 1.0.0
|
9
|
-
Generated by OpenAPI Generator (https://openapi-generator.tech)
|
10
|
-
|
11
|
-
Do not edit the class manually.
|
12
|
-
""" # noqa: E501
|
13
|
-
|
14
|
-
|
15
|
-
from __future__ import annotations
|
16
|
-
import json
|
17
|
-
from enum import Enum
|
18
|
-
from typing_extensions import Self
|
19
|
-
|
20
|
-
|
21
|
-
class ApiErrorIdentifier(str, Enum):
|
22
|
-
"""
|
23
|
-
API error identifiers
|
24
|
-
"""
|
25
|
-
|
26
|
-
"""
|
27
|
-
allowed enum values
|
28
|
-
"""
|
29
|
-
ALLOCATION_BELOW_CURRENT_EXPOSURE = "allocation_below_current_exposure"
|
30
|
-
ALLOCATION_BELOW_MIN_AMOUNT = "allocation_below_min_amount"
|
31
|
-
ALPHANUMERIC_CHARACTERS_ONLY = "alphanumeric_characters_only"
|
32
|
-
BLACK_SWAN = "black_swan"
|
33
|
-
BOT_ALREADY_DELETED = "bot_already_deleted"
|
34
|
-
BOT_DISABLED = "bot_disabled"
|
35
|
-
BOT_STOPPING_COMPLETED = "bot_stopping_completed"
|
36
|
-
CLIENT_ORDER_ID_ALREADY_EXISTS = "client_order_id_already_exists"
|
37
|
-
INVALID_CONTENT_TYPE = "invalid_content_type"
|
38
|
-
DELETE_BOT_ERROR = "delete_bot_error"
|
39
|
-
EXCHANGE_INVALID_SIGNATURE = "exchange_invalid_signature"
|
40
|
-
EXCHANGE_INVALID_TIMESTAMP = "exchange_invalid_timestamp"
|
41
|
-
EXCHANGE_IP_ADDRESS_IS_NOT_AUTHORIZED = "exchange_ip_address_is_not_authorized"
|
42
|
-
EXCHANGE_KEY_ALREADY_EXISTS = "exchange_key_already_exists"
|
43
|
-
EXCHANGE_KEY_IN_USE = "exchange_key_in_use"
|
44
|
-
EXCHANGE_SYSTEM_UNDER_MAINTENANCE = "exchange_system_under_maintenance"
|
45
|
-
EXCHANGE_RATE_LIMIT_EXCEEDED = "exchange_rate_limit_exceeded"
|
46
|
-
INSUFFICIENT_PERMISSIONS_SPOT_AND_FUTURES_REQUIRED = (
|
47
|
-
"insufficient_permissions_spot_and_futures_required"
|
48
|
-
)
|
49
|
-
EXCHANGE_SERVICE_TEMPORARILY_UNAVAILABLE = (
|
50
|
-
"exchange_service_temporarily_unavailable"
|
51
|
-
)
|
52
|
-
EXCHANGE_SYSTEM_IS_BUSY = "exchange_system_is_busy"
|
53
|
-
EXCHANGE_SYSTEM_CONFIGURATION_ERROR = "exchange_system_configuration_error"
|
54
|
-
EXCHANGE_INTERNAL_SYSTEM_ERROR = "exchange_internal_system_error"
|
55
|
-
EXCHANGE_USER_ACCOUNT_IS_FROZEN = "exchange_user_account_is_frozen"
|
56
|
-
FORBIDDEN = "forbidden"
|
57
|
-
HEDGE_MODE_NOT_ACTIVE = "hedge_mode_not_active"
|
58
|
-
HTTP_REQUEST_ERROR = "http_request_error"
|
59
|
-
INSUFFICIENT_BALANCE = "insufficient_balance"
|
60
|
-
INSUFFICIENT_MARGIN = "insufficient_margin"
|
61
|
-
INSUFFICIENT_SCOPES = "insufficient_scopes"
|
62
|
-
INVALID_API_KEY = "invalid_api_key"
|
63
|
-
INVALID_BEARER = "invalid_bearer"
|
64
|
-
INVALID_DATA = "invalid_data"
|
65
|
-
INVALID_DATA_RESPONSE = "invalid_data_response"
|
66
|
-
INVALID_EXCHANGE_KEY = "invalid_exchange_key"
|
67
|
-
INVALID_MARGIN_MODE = "invalid_margin_mode"
|
68
|
-
INVALID_PARAMETER_PROVIDED = "invalid_parameter_provided"
|
69
|
-
JWT_EXPIRED = "jwt_expired"
|
70
|
-
LEVERAGE_LIMIT_EXCEEDED = "leverage_limit_exceeded"
|
71
|
-
ORDER_VIOLATES_LIQUIDATION_PRICE_CONSTRAINTS = (
|
72
|
-
"order_violates_liquidation_price_constraints"
|
73
|
-
)
|
74
|
-
NO_CREDENTIALS = "no_credentials"
|
75
|
-
NOW_API_DOWN = "now_api_down"
|
76
|
-
OBJECT_NOT_FOUND = "object_not_found"
|
77
|
-
OBJECT_ALREADY_EXISTS = "object_already_exists"
|
78
|
-
ORDER_IS_ALREADY_FILLED = "order_is_already_filled"
|
79
|
-
ORDER_IS_BEING_PROCESSED = "order_is_being_processed"
|
80
|
-
ORDER_QUANTITY_LIMIT_EXCEEDED = "order_quantity_limit_exceeded"
|
81
|
-
ORDER_DOES_NOT_EXIST = "order_does_not_exist"
|
82
|
-
ORDER_PRICE_IS_INVALID = "order_price_is_invalid"
|
83
|
-
ORDER_SIZE_TOO_LARGE = "order_size_too_large"
|
84
|
-
ORDER_SIZE_TOO_SMALL = "order_size_too_small"
|
85
|
-
POSITION_LIMIT_EXCEEDED = "position_limit_exceeded"
|
86
|
-
POSITION_DOES_NOT_EXIST = "position_does_not_exist"
|
87
|
-
POSITION_OPENING_TEMPORARILY_SUSPENDED = "position_opening_temporarily_suspended"
|
88
|
-
POST_ONLY_ORDER_WOULD_IMMEDIATELY_MATCH = "post_only_order_would_immediately_match"
|
89
|
-
REQUEST_SCOPE_LIMIT_EXCEEDED = "request_scope_limit_exceeded"
|
90
|
-
RISK_LIMIT_EXCEEDED = "risk_limit_exceeded"
|
91
|
-
RPC_TIMEOUT = "rpc_timeout"
|
92
|
-
SYSTEM_SETTLEMENT_IN_PROCESS = "system_settlement_in_process"
|
93
|
-
STRATEGY_DISABLED = "strategy_disabled"
|
94
|
-
STRATEGY_LEVERAGE_MISMATCH = "strategy_leverage_mismatch"
|
95
|
-
STRATEGY_NOT_SUPPORTING_EXCHANGE = "strategy_not_supporting_exchange"
|
96
|
-
SUCCESS = "success"
|
97
|
-
SYMBOL_DOES_NOT_EXIST = "symbol_does_not_exist"
|
98
|
-
TRADING_ACTION_EXPIRED = "trading_action_expired"
|
99
|
-
TRADING_ACTION_SKIPPED = "trading_action_skipped"
|
100
|
-
TRADING_HAS_BEEN_LOCKED = "trading_has_been_locked"
|
101
|
-
TRADING_IS_SUSPENDED = "trading_is_suspended"
|
102
|
-
UNKNOWN_ERROR_OCCURRED = "unknown_error_occurred"
|
103
|
-
REQUESTED_RESOURCE_NOT_FOUND = "requested_resource_not_found"
|
104
|
-
|
105
|
-
@classmethod
|
106
|
-
def from_json(cls, json_str: str) -> Self:
|
107
|
-
"""Create an instance of ApiErrorIdentifier from a JSON string"""
|
108
|
-
return cls(json.loads(json_str))
|
@@ -1,37 +0,0 @@
|
|
1
|
-
# coding: utf-8
|
2
|
-
|
3
|
-
"""
|
4
|
-
Marketcap Service API
|
5
|
-
|
6
|
-
No description provided (generated by Openapi Generator https://github.com/openapitools/openapi-generator)
|
7
|
-
|
8
|
-
The version of the OpenAPI document: 1.0.0
|
9
|
-
Generated by OpenAPI Generator (https://openapi-generator.tech)
|
10
|
-
|
11
|
-
Do not edit the class manually.
|
12
|
-
""" # noqa: E501
|
13
|
-
|
14
|
-
|
15
|
-
from __future__ import annotations
|
16
|
-
import json
|
17
|
-
from enum import Enum
|
18
|
-
from typing_extensions import Self
|
19
|
-
|
20
|
-
|
21
|
-
class ApiErrorLevel(str, Enum):
|
22
|
-
"""
|
23
|
-
API error levels
|
24
|
-
"""
|
25
|
-
|
26
|
-
"""
|
27
|
-
allowed enum values
|
28
|
-
"""
|
29
|
-
ERROR = "error"
|
30
|
-
INFO = "info"
|
31
|
-
SUCCESS = "success"
|
32
|
-
WARNING = "warning"
|
33
|
-
|
34
|
-
@classmethod
|
35
|
-
def from_json(cls, json_str: str) -> Self:
|
36
|
-
"""Create an instance of ApiErrorLevel from a JSON string"""
|
37
|
-
return cls(json.loads(json_str))
|
@@ -1,37 +0,0 @@
|
|
1
|
-
# coding: utf-8
|
2
|
-
|
3
|
-
"""
|
4
|
-
Marketcap Service API
|
5
|
-
|
6
|
-
No description provided (generated by Openapi Generator https://github.com/openapitools/openapi-generator)
|
7
|
-
|
8
|
-
The version of the OpenAPI document: 1.0.0
|
9
|
-
Generated by OpenAPI Generator (https://openapi-generator.tech)
|
10
|
-
|
11
|
-
Do not edit the class manually.
|
12
|
-
""" # noqa: E501
|
13
|
-
|
14
|
-
|
15
|
-
from __future__ import annotations
|
16
|
-
import json
|
17
|
-
from enum import Enum
|
18
|
-
from typing_extensions import Self
|
19
|
-
|
20
|
-
|
21
|
-
class ApiErrorType(str, Enum):
|
22
|
-
"""
|
23
|
-
Type of API error
|
24
|
-
"""
|
25
|
-
|
26
|
-
"""
|
27
|
-
allowed enum values
|
28
|
-
"""
|
29
|
-
USER_ERROR = "user error"
|
30
|
-
EXCHANGE_ERROR = "exchange error"
|
31
|
-
SERVER_ERROR = "server error"
|
32
|
-
NO_ERROR = "no error"
|
33
|
-
|
34
|
-
@classmethod
|
35
|
-
def from_json(cls, json_str: str) -> Self:
|
36
|
-
"""Create an instance of ApiErrorType from a JSON string"""
|
37
|
-
return cls(json.loads(json_str))
|
@@ -1,106 +0,0 @@
|
|
1
|
-
# coding: utf-8
|
2
|
-
|
3
|
-
"""
|
4
|
-
Marketcap Service API
|
5
|
-
|
6
|
-
API for retrieving historical marketcap data, available exchanges, and indicators. ## Features - Historical marketcap data - OHLCV data with marketcap - Technical indicators (KER, SMA) - Exchange and symbol mappings - Error logs
|
7
|
-
|
8
|
-
The version of the OpenAPI document: 1.0.0
|
9
|
-
Generated by OpenAPI Generator (https://openapi-generator.tech)
|
10
|
-
|
11
|
-
Do not edit the class manually.
|
12
|
-
""" # noqa: E501
|
13
|
-
|
14
|
-
|
15
|
-
from __future__ import annotations
|
16
|
-
import pprint
|
17
|
-
import re # noqa: F401
|
18
|
-
import json
|
19
|
-
|
20
|
-
from datetime import datetime
|
21
|
-
from pydantic import BaseModel, ConfigDict, StrictBool, StrictStr
|
22
|
-
from typing import Any, ClassVar, Dict, List, Optional
|
23
|
-
from typing import Optional, Set
|
24
|
-
from typing_extensions import Self
|
25
|
-
|
26
|
-
|
27
|
-
class BaseResponseDict(BaseModel):
|
28
|
-
"""
|
29
|
-
BaseResponseDict
|
30
|
-
""" # noqa: E501
|
31
|
-
|
32
|
-
success: Optional[StrictBool] = True
|
33
|
-
message: Optional[StrictStr] = None
|
34
|
-
data: Optional[Dict[str, Any]] = None
|
35
|
-
timestamp: Optional[datetime] = None
|
36
|
-
__properties: ClassVar[List[str]] = ["success", "message", "data", "timestamp"]
|
37
|
-
|
38
|
-
model_config = ConfigDict(
|
39
|
-
populate_by_name=True,
|
40
|
-
validate_assignment=True,
|
41
|
-
protected_namespaces=(),
|
42
|
-
)
|
43
|
-
|
44
|
-
def to_str(self) -> str:
|
45
|
-
"""Returns the string representation of the model using alias"""
|
46
|
-
return pprint.pformat(self.model_dump(by_alias=True))
|
47
|
-
|
48
|
-
def to_json(self) -> str:
|
49
|
-
"""Returns the JSON representation of the model using alias"""
|
50
|
-
# TODO: pydantic v2: use .model_dump_json(by_alias=True, exclude_unset=True) instead
|
51
|
-
return json.dumps(self.to_dict())
|
52
|
-
|
53
|
-
@classmethod
|
54
|
-
def from_json(cls, json_str: str) -> Optional[Self]:
|
55
|
-
"""Create an instance of BaseResponseDict from a JSON string"""
|
56
|
-
return cls.from_dict(json.loads(json_str))
|
57
|
-
|
58
|
-
def to_dict(self) -> Dict[str, Any]:
|
59
|
-
"""Return the dictionary representation of the model using alias.
|
60
|
-
|
61
|
-
This has the following differences from calling pydantic's
|
62
|
-
`self.model_dump(by_alias=True)`:
|
63
|
-
|
64
|
-
* `None` is only added to the output dict for nullable fields that
|
65
|
-
were set at model initialization. Other fields with value `None`
|
66
|
-
are ignored.
|
67
|
-
"""
|
68
|
-
excluded_fields: Set[str] = set([])
|
69
|
-
|
70
|
-
_dict = self.model_dump(
|
71
|
-
by_alias=True,
|
72
|
-
exclude=excluded_fields,
|
73
|
-
exclude_none=True,
|
74
|
-
)
|
75
|
-
# set to None if message (nullable) is None
|
76
|
-
# and model_fields_set contains the field
|
77
|
-
if self.message is None and "message" in self.model_fields_set:
|
78
|
-
_dict["message"] = None
|
79
|
-
|
80
|
-
# set to None if data (nullable) is None
|
81
|
-
# and model_fields_set contains the field
|
82
|
-
if self.data is None and "data" in self.model_fields_set:
|
83
|
-
_dict["data"] = None
|
84
|
-
|
85
|
-
return _dict
|
86
|
-
|
87
|
-
@classmethod
|
88
|
-
def from_dict(cls, obj: Optional[Dict[str, Any]]) -> Optional[Self]:
|
89
|
-
"""Create an instance of BaseResponseDict from a dict"""
|
90
|
-
if obj is None:
|
91
|
-
return None
|
92
|
-
|
93
|
-
if not isinstance(obj, dict):
|
94
|
-
return cls.model_validate(obj)
|
95
|
-
|
96
|
-
_obj = cls.model_validate(
|
97
|
-
{
|
98
|
-
"success": (
|
99
|
-
obj.get("success") if obj.get("success") is not None else True
|
100
|
-
),
|
101
|
-
"message": obj.get("message"),
|
102
|
-
"data": obj.get("data"),
|
103
|
-
"timestamp": obj.get("timestamp"),
|
104
|
-
}
|
105
|
-
)
|
106
|
-
return _obj
|
@@ -1,114 +0,0 @@
|
|
1
|
-
# coding: utf-8
|
2
|
-
|
3
|
-
"""
|
4
|
-
Marketcap Service API
|
5
|
-
|
6
|
-
API for retrieving historical marketcap data, available exchanges, and indicators. ## Features - Historical marketcap data - OHLCV data with marketcap - Technical indicators (KER, SMA) - Exchange and symbol mappings - Error logs
|
7
|
-
|
8
|
-
The version of the OpenAPI document: 1.0.0
|
9
|
-
Generated by OpenAPI Generator (https://openapi-generator.tech)
|
10
|
-
|
11
|
-
Do not edit the class manually.
|
12
|
-
""" # noqa: E501
|
13
|
-
|
14
|
-
|
15
|
-
from __future__ import annotations
|
16
|
-
import pprint
|
17
|
-
import re # noqa: F401
|
18
|
-
import json
|
19
|
-
|
20
|
-
from datetime import datetime
|
21
|
-
from pydantic import BaseModel, ConfigDict, StrictBool, StrictStr
|
22
|
-
from typing import Any, ClassVar, Dict, List, Optional
|
23
|
-
from crypticorn.metrics.client.models.health_check_response import HealthCheckResponse
|
24
|
-
from typing import Optional, Set
|
25
|
-
from typing_extensions import Self
|
26
|
-
|
27
|
-
|
28
|
-
class BaseResponseHealthCheckResponse(BaseModel):
|
29
|
-
"""
|
30
|
-
BaseResponseHealthCheckResponse
|
31
|
-
""" # noqa: E501
|
32
|
-
|
33
|
-
success: Optional[StrictBool] = True
|
34
|
-
message: Optional[StrictStr] = None
|
35
|
-
data: Optional[HealthCheckResponse] = None
|
36
|
-
timestamp: Optional[datetime] = None
|
37
|
-
__properties: ClassVar[List[str]] = ["success", "message", "data", "timestamp"]
|
38
|
-
|
39
|
-
model_config = ConfigDict(
|
40
|
-
populate_by_name=True,
|
41
|
-
validate_assignment=True,
|
42
|
-
protected_namespaces=(),
|
43
|
-
)
|
44
|
-
|
45
|
-
def to_str(self) -> str:
|
46
|
-
"""Returns the string representation of the model using alias"""
|
47
|
-
return pprint.pformat(self.model_dump(by_alias=True))
|
48
|
-
|
49
|
-
def to_json(self) -> str:
|
50
|
-
"""Returns the JSON representation of the model using alias"""
|
51
|
-
# TODO: pydantic v2: use .model_dump_json(by_alias=True, exclude_unset=True) instead
|
52
|
-
return json.dumps(self.to_dict())
|
53
|
-
|
54
|
-
@classmethod
|
55
|
-
def from_json(cls, json_str: str) -> Optional[Self]:
|
56
|
-
"""Create an instance of BaseResponseHealthCheckResponse from a JSON string"""
|
57
|
-
return cls.from_dict(json.loads(json_str))
|
58
|
-
|
59
|
-
def to_dict(self) -> Dict[str, Any]:
|
60
|
-
"""Return the dictionary representation of the model using alias.
|
61
|
-
|
62
|
-
This has the following differences from calling pydantic's
|
63
|
-
`self.model_dump(by_alias=True)`:
|
64
|
-
|
65
|
-
* `None` is only added to the output dict for nullable fields that
|
66
|
-
were set at model initialization. Other fields with value `None`
|
67
|
-
are ignored.
|
68
|
-
"""
|
69
|
-
excluded_fields: Set[str] = set([])
|
70
|
-
|
71
|
-
_dict = self.model_dump(
|
72
|
-
by_alias=True,
|
73
|
-
exclude=excluded_fields,
|
74
|
-
exclude_none=True,
|
75
|
-
)
|
76
|
-
# override the default output from pydantic by calling `to_dict()` of data
|
77
|
-
if self.data:
|
78
|
-
_dict["data"] = self.data.to_dict()
|
79
|
-
# set to None if message (nullable) is None
|
80
|
-
# and model_fields_set contains the field
|
81
|
-
if self.message is None and "message" in self.model_fields_set:
|
82
|
-
_dict["message"] = None
|
83
|
-
|
84
|
-
# set to None if data (nullable) is None
|
85
|
-
# and model_fields_set contains the field
|
86
|
-
if self.data is None and "data" in self.model_fields_set:
|
87
|
-
_dict["data"] = None
|
88
|
-
|
89
|
-
return _dict
|
90
|
-
|
91
|
-
@classmethod
|
92
|
-
def from_dict(cls, obj: Optional[Dict[str, Any]]) -> Optional[Self]:
|
93
|
-
"""Create an instance of BaseResponseHealthCheckResponse from a dict"""
|
94
|
-
if obj is None:
|
95
|
-
return None
|
96
|
-
|
97
|
-
if not isinstance(obj, dict):
|
98
|
-
return cls.model_validate(obj)
|
99
|
-
|
100
|
-
_obj = cls.model_validate(
|
101
|
-
{
|
102
|
-
"success": (
|
103
|
-
obj.get("success") if obj.get("success") is not None else True
|
104
|
-
),
|
105
|
-
"message": obj.get("message"),
|
106
|
-
"data": (
|
107
|
-
HealthCheckResponse.from_dict(obj["data"])
|
108
|
-
if obj.get("data") is not None
|
109
|
-
else None
|
110
|
-
),
|
111
|
-
"timestamp": obj.get("timestamp"),
|
112
|
-
}
|
113
|
-
)
|
114
|
-
return _obj
|