compass_api_sdk 0.0.1__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 compass_api_sdk might be problematic. Click here for more details.
- compass_api_sdk/__init__.py +17 -0
- compass_api_sdk/_hooks/__init__.py +5 -0
- compass_api_sdk/_hooks/registration.py +13 -0
- compass_api_sdk/_hooks/sdkhooks.py +76 -0
- compass_api_sdk/_hooks/types.py +106 -0
- compass_api_sdk/_version.py +15 -0
- compass_api_sdk/aave_v3.py +1903 -0
- compass_api_sdk/aerodrome_slipstream.py +1875 -0
- compass_api_sdk/basesdk.py +362 -0
- compass_api_sdk/errors/__init__.py +7 -0
- compass_api_sdk/errors/apierror.py +22 -0
- compass_api_sdk/errors/httpvalidationerror.py +21 -0
- compass_api_sdk/httpclient.py +136 -0
- compass_api_sdk/models/__init__.py +777 -0
- compass_api_sdk/models/aave_liquidity_changeop.py +108 -0
- compass_api_sdk/models/aave_token_priceop.py +98 -0
- compass_api_sdk/models/aave_user_position_per_tokenop.py +104 -0
- compass_api_sdk/models/aave_user_position_summaryop.py +35 -0
- compass_api_sdk/models/aaveborrowrequest.py +105 -0
- compass_api_sdk/models/aaveliquiditychangeresponse.py +26 -0
- compass_api_sdk/models/aaverepayrequest.py +105 -0
- compass_api_sdk/models/aavesupplyrequest.py +93 -0
- compass_api_sdk/models/aavetokenpriceresponse.py +15 -0
- compass_api_sdk/models/aaveuserpositionpertokenresponse.py +73 -0
- compass_api_sdk/models/aaveuserpositionsummaryresponse.py +50 -0
- compass_api_sdk/models/aavewithdrawrequest.py +58 -0
- compass_api_sdk/models/aerodrome_slipstream_liquidity_provision_positionsop.py +35 -0
- compass_api_sdk/models/aerodrome_slipstream_pool_priceop.py +173 -0
- compass_api_sdk/models/aerodromelppositionsresponse.py +21 -0
- compass_api_sdk/models/aerodromeposition.py +70 -0
- compass_api_sdk/models/aerodromeslipstreambuyexactlyrequest.py +92 -0
- compass_api_sdk/models/aerodromeslipstreamincreaseliquidityprovisionrequest.py +109 -0
- compass_api_sdk/models/aerodromeslipstreammintliquidityprovisionrequest.py +186 -0
- compass_api_sdk/models/aerodromeslipstreampoolpriceresponse.py +57 -0
- compass_api_sdk/models/aerodromeslipstreamsellexactlyrequest.py +96 -0
- compass_api_sdk/models/aerodromeslipstreamwithdrawliquidityprovisionrequest.py +50 -0
- compass_api_sdk/models/allowanceinforesponse.py +48 -0
- compass_api_sdk/models/balanceinforesponse.py +43 -0
- compass_api_sdk/models/chain.py +12 -0
- compass_api_sdk/models/chaininfo.py +53 -0
- compass_api_sdk/models/compass_api_backend_models_morpho_read_response_get_markets_asset.py +22 -0
- compass_api_sdk/models/compass_api_backend_models_morpho_read_response_get_vaults_asset.py +23 -0
- compass_api_sdk/models/ensnameinforesponse.py +24 -0
- compass_api_sdk/models/feeenum.py +16 -0
- compass_api_sdk/models/generic_allowanceop.py +121 -0
- compass_api_sdk/models/generic_balanceop.py +104 -0
- compass_api_sdk/models/generic_ensop.py +35 -0
- compass_api_sdk/models/generic_portfolioop.py +35 -0
- compass_api_sdk/models/generic_price_usdop.py +98 -0
- compass_api_sdk/models/generic_supported_tokensop.py +29 -0
- compass_api_sdk/models/generic_visualize_portfolioop.py +35 -0
- compass_api_sdk/models/image.py +15 -0
- compass_api_sdk/models/increaseallowancerequest.py +77 -0
- compass_api_sdk/models/interestratemode.py +14 -0
- compass_api_sdk/models/marketstate.py +35 -0
- compass_api_sdk/models/morpho_market_positionop.py +39 -0
- compass_api_sdk/models/morpho_marketsop.py +78 -0
- compass_api_sdk/models/morpho_vault_positionop.py +39 -0
- compass_api_sdk/models/morpho_vaultsop.py +72 -0
- compass_api_sdk/models/morphoborrowrequest.py +91 -0
- compass_api_sdk/models/morphocheckmarketpositionresponse.py +23 -0
- compass_api_sdk/models/morphocheckvaultpositionresponse.py +20 -0
- compass_api_sdk/models/morphodepositrequest.py +86 -0
- compass_api_sdk/models/morphogetmarketsresponse.py +17 -0
- compass_api_sdk/models/morphogetvaultsresponse.py +17 -0
- compass_api_sdk/models/morphomarket.py +80 -0
- compass_api_sdk/models/morphorepayrequest.py +79 -0
- compass_api_sdk/models/morphosetvaultallowancerequest.py +44 -0
- compass_api_sdk/models/morphosupplycollateralrequest.py +91 -0
- compass_api_sdk/models/morphovault.py +47 -0
- compass_api_sdk/models/morphowithdrawcollateralrequest.py +91 -0
- compass_api_sdk/models/morphowithdrawrequest.py +74 -0
- compass_api_sdk/models/portfolio.py +22 -0
- compass_api_sdk/models/priceresponse.py +15 -0
- compass_api_sdk/models/security.py +24 -0
- compass_api_sdk/models/token_addressop.py +98 -0
- compass_api_sdk/models/token_balanceop.py +49 -0
- compass_api_sdk/models/token_enum.py +57 -0
- compass_api_sdk/models/token_priceop.py +97 -0
- compass_api_sdk/models/tokenaddressresponse.py +15 -0
- compass_api_sdk/models/tokenbalance.py +49 -0
- compass_api_sdk/models/tokenbalanceresponse.py +44 -0
- compass_api_sdk/models/tokeninfo.py +17 -0
- compass_api_sdk/models/tokenpriceresponse.py +15 -0
- compass_api_sdk/models/tokentransferrequest.py +66 -0
- compass_api_sdk/models/transfererc20request.py +62 -0
- compass_api_sdk/models/transferethrequest.py +46 -0
- compass_api_sdk/models/uniswap_liquidity_provision_in_rangeop.py +34 -0
- compass_api_sdk/models/uniswap_liquidity_provision_positionsop.py +35 -0
- compass_api_sdk/models/uniswap_pool_priceop.py +193 -0
- compass_api_sdk/models/uniswap_quote_buy_exactlyop.py +209 -0
- compass_api_sdk/models/uniswap_quote_sell_exactlyop.py +209 -0
- compass_api_sdk/models/uniswapbuyexactlyrequest.py +104 -0
- compass_api_sdk/models/uniswapbuyquoteinforesponse.py +20 -0
- compass_api_sdk/models/uniswapcheckinrangeresponse.py +15 -0
- compass_api_sdk/models/uniswapincreaseliquidityprovisionrequest.py +99 -0
- compass_api_sdk/models/uniswaplppositionsinforesponse.py +24 -0
- compass_api_sdk/models/uniswapmintliquidityprovisionrequest.py +185 -0
- compass_api_sdk/models/uniswappoolpriceresponse.py +47 -0
- compass_api_sdk/models/uniswappositionssolidityresponse.py +46 -0
- compass_api_sdk/models/uniswapsellexactlyrequest.py +104 -0
- compass_api_sdk/models/uniswapsellquoteinforesponse.py +20 -0
- compass_api_sdk/models/uniswapwithdrawliquidityprovisionrequest.py +51 -0
- compass_api_sdk/models/unsignedtransaction.py +58 -0
- compass_api_sdk/models/unwrapwethrequest.py +41 -0
- compass_api_sdk/models/validationerror.py +26 -0
- compass_api_sdk/models/vaultstate.py +32 -0
- compass_api_sdk/models/weeklyapys.py +23 -0
- compass_api_sdk/models/wrapethrequest.py +41 -0
- compass_api_sdk/morpho.py +2577 -0
- compass_api_sdk/py.typed +1 -0
- compass_api_sdk/sdk.py +155 -0
- compass_api_sdk/sdkconfiguration.py +56 -0
- compass_api_sdk/token_sdk.py +861 -0
- compass_api_sdk/types/__init__.py +21 -0
- compass_api_sdk/types/basemodel.py +39 -0
- compass_api_sdk/uniswap_v3.py +2551 -0
- compass_api_sdk/universal.py +2625 -0
- compass_api_sdk/utils/__init__.py +100 -0
- compass_api_sdk/utils/annotations.py +55 -0
- compass_api_sdk/utils/datetimes.py +23 -0
- compass_api_sdk/utils/enums.py +74 -0
- compass_api_sdk/utils/eventstreaming.py +238 -0
- compass_api_sdk/utils/forms.py +202 -0
- compass_api_sdk/utils/headers.py +136 -0
- compass_api_sdk/utils/logger.py +22 -0
- compass_api_sdk/utils/metadata.py +118 -0
- compass_api_sdk/utils/queryparams.py +205 -0
- compass_api_sdk/utils/requestbodies.py +66 -0
- compass_api_sdk/utils/retries.py +217 -0
- compass_api_sdk/utils/security.py +174 -0
- compass_api_sdk/utils/serializers.py +248 -0
- compass_api_sdk/utils/url.py +155 -0
- compass_api_sdk/utils/values.py +137 -0
- compass_api_sdk-0.0.1.dist-info/METADATA +534 -0
- compass_api_sdk-0.0.1.dist-info/RECORD +137 -0
- compass_api_sdk-0.0.1.dist-info/WHEEL +4 -0
|
@@ -0,0 +1,155 @@
|
|
|
1
|
+
"""Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
|
|
2
|
+
|
|
3
|
+
from decimal import Decimal
|
|
4
|
+
from typing import (
|
|
5
|
+
Any,
|
|
6
|
+
Dict,
|
|
7
|
+
get_type_hints,
|
|
8
|
+
List,
|
|
9
|
+
Optional,
|
|
10
|
+
Union,
|
|
11
|
+
get_args,
|
|
12
|
+
get_origin,
|
|
13
|
+
)
|
|
14
|
+
from pydantic import BaseModel
|
|
15
|
+
from pydantic.fields import FieldInfo
|
|
16
|
+
|
|
17
|
+
from .metadata import (
|
|
18
|
+
PathParamMetadata,
|
|
19
|
+
find_field_metadata,
|
|
20
|
+
)
|
|
21
|
+
from .values import (
|
|
22
|
+
_get_serialized_params,
|
|
23
|
+
_is_set,
|
|
24
|
+
_populate_from_globals,
|
|
25
|
+
_val_to_string,
|
|
26
|
+
)
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+
def generate_url(
|
|
30
|
+
server_url: str,
|
|
31
|
+
path: str,
|
|
32
|
+
path_params: Any,
|
|
33
|
+
gbls: Optional[Any] = None,
|
|
34
|
+
) -> str:
|
|
35
|
+
path_param_values: Dict[str, str] = {}
|
|
36
|
+
|
|
37
|
+
globals_already_populated = _populate_path_params(
|
|
38
|
+
path_params, gbls, path_param_values, []
|
|
39
|
+
)
|
|
40
|
+
if _is_set(gbls):
|
|
41
|
+
_populate_path_params(gbls, None, path_param_values, globals_already_populated)
|
|
42
|
+
|
|
43
|
+
for key, value in path_param_values.items():
|
|
44
|
+
path = path.replace("{" + key + "}", value, 1)
|
|
45
|
+
|
|
46
|
+
return remove_suffix(server_url, "/") + path
|
|
47
|
+
|
|
48
|
+
|
|
49
|
+
def _populate_path_params(
|
|
50
|
+
path_params: Any,
|
|
51
|
+
gbls: Any,
|
|
52
|
+
path_param_values: Dict[str, str],
|
|
53
|
+
skip_fields: List[str],
|
|
54
|
+
) -> List[str]:
|
|
55
|
+
globals_already_populated: List[str] = []
|
|
56
|
+
|
|
57
|
+
if not isinstance(path_params, BaseModel):
|
|
58
|
+
return globals_already_populated
|
|
59
|
+
|
|
60
|
+
path_param_fields: Dict[str, FieldInfo] = path_params.__class__.model_fields
|
|
61
|
+
path_param_field_types = get_type_hints(path_params.__class__)
|
|
62
|
+
for name in path_param_fields:
|
|
63
|
+
if name in skip_fields:
|
|
64
|
+
continue
|
|
65
|
+
|
|
66
|
+
field = path_param_fields[name]
|
|
67
|
+
|
|
68
|
+
param_metadata = find_field_metadata(field, PathParamMetadata)
|
|
69
|
+
if param_metadata is None:
|
|
70
|
+
continue
|
|
71
|
+
|
|
72
|
+
param = getattr(path_params, name) if _is_set(path_params) else None
|
|
73
|
+
param, global_found = _populate_from_globals(
|
|
74
|
+
name, param, PathParamMetadata, gbls
|
|
75
|
+
)
|
|
76
|
+
if global_found:
|
|
77
|
+
globals_already_populated.append(name)
|
|
78
|
+
|
|
79
|
+
if not _is_set(param):
|
|
80
|
+
continue
|
|
81
|
+
|
|
82
|
+
f_name = field.alias if field.alias is not None else name
|
|
83
|
+
serialization = param_metadata.serialization
|
|
84
|
+
if serialization is not None:
|
|
85
|
+
serialized_params = _get_serialized_params(
|
|
86
|
+
param_metadata, f_name, param, path_param_field_types[name]
|
|
87
|
+
)
|
|
88
|
+
for key, value in serialized_params.items():
|
|
89
|
+
path_param_values[key] = value
|
|
90
|
+
else:
|
|
91
|
+
pp_vals: List[str] = []
|
|
92
|
+
if param_metadata.style == "simple":
|
|
93
|
+
if isinstance(param, List):
|
|
94
|
+
for pp_val in param:
|
|
95
|
+
if not _is_set(pp_val):
|
|
96
|
+
continue
|
|
97
|
+
pp_vals.append(_val_to_string(pp_val))
|
|
98
|
+
path_param_values[f_name] = ",".join(pp_vals)
|
|
99
|
+
elif isinstance(param, Dict):
|
|
100
|
+
for pp_key in param:
|
|
101
|
+
if not _is_set(param[pp_key]):
|
|
102
|
+
continue
|
|
103
|
+
if param_metadata.explode:
|
|
104
|
+
pp_vals.append(f"{pp_key}={_val_to_string(param[pp_key])}")
|
|
105
|
+
else:
|
|
106
|
+
pp_vals.append(f"{pp_key},{_val_to_string(param[pp_key])}")
|
|
107
|
+
path_param_values[f_name] = ",".join(pp_vals)
|
|
108
|
+
elif not isinstance(param, (str, int, float, complex, bool, Decimal)):
|
|
109
|
+
param_fields: Dict[str, FieldInfo] = param.__class__.model_fields
|
|
110
|
+
for name in param_fields:
|
|
111
|
+
param_field = param_fields[name]
|
|
112
|
+
|
|
113
|
+
param_value_metadata = find_field_metadata(
|
|
114
|
+
param_field, PathParamMetadata
|
|
115
|
+
)
|
|
116
|
+
if param_value_metadata is None:
|
|
117
|
+
continue
|
|
118
|
+
|
|
119
|
+
param_name = (
|
|
120
|
+
param_field.alias if param_field.alias is not None else name
|
|
121
|
+
)
|
|
122
|
+
|
|
123
|
+
param_field_val = getattr(param, name)
|
|
124
|
+
if not _is_set(param_field_val):
|
|
125
|
+
continue
|
|
126
|
+
if param_metadata.explode:
|
|
127
|
+
pp_vals.append(
|
|
128
|
+
f"{param_name}={_val_to_string(param_field_val)}"
|
|
129
|
+
)
|
|
130
|
+
else:
|
|
131
|
+
pp_vals.append(
|
|
132
|
+
f"{param_name},{_val_to_string(param_field_val)}"
|
|
133
|
+
)
|
|
134
|
+
path_param_values[f_name] = ",".join(pp_vals)
|
|
135
|
+
elif _is_set(param):
|
|
136
|
+
path_param_values[f_name] = _val_to_string(param)
|
|
137
|
+
|
|
138
|
+
return globals_already_populated
|
|
139
|
+
|
|
140
|
+
|
|
141
|
+
def is_optional(field):
|
|
142
|
+
return get_origin(field) is Union and type(None) in get_args(field)
|
|
143
|
+
|
|
144
|
+
|
|
145
|
+
def template_url(url_with_params: str, params: Dict[str, str]) -> str:
|
|
146
|
+
for key, value in params.items():
|
|
147
|
+
url_with_params = url_with_params.replace("{" + key + "}", value)
|
|
148
|
+
|
|
149
|
+
return url_with_params
|
|
150
|
+
|
|
151
|
+
|
|
152
|
+
def remove_suffix(input_string, suffix):
|
|
153
|
+
if suffix and input_string.endswith(suffix):
|
|
154
|
+
return input_string[: -len(suffix)]
|
|
155
|
+
return input_string
|
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
"""Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
|
|
2
|
+
|
|
3
|
+
from datetime import datetime
|
|
4
|
+
from enum import Enum
|
|
5
|
+
from email.message import Message
|
|
6
|
+
from functools import partial
|
|
7
|
+
import os
|
|
8
|
+
from typing import Any, Callable, Dict, List, Optional, Tuple, TypeVar, Union, cast
|
|
9
|
+
|
|
10
|
+
from httpx import Response
|
|
11
|
+
from pydantic import BaseModel
|
|
12
|
+
from pydantic.fields import FieldInfo
|
|
13
|
+
|
|
14
|
+
from ..types.basemodel import Unset
|
|
15
|
+
|
|
16
|
+
from .serializers import marshal_json
|
|
17
|
+
|
|
18
|
+
from .metadata import ParamMetadata, find_field_metadata
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
def match_content_type(content_type: str, pattern: str) -> bool:
|
|
22
|
+
if pattern in (content_type, "*", "*/*"):
|
|
23
|
+
return True
|
|
24
|
+
|
|
25
|
+
msg = Message()
|
|
26
|
+
msg["content-type"] = content_type
|
|
27
|
+
media_type = msg.get_content_type()
|
|
28
|
+
|
|
29
|
+
if media_type == pattern:
|
|
30
|
+
return True
|
|
31
|
+
|
|
32
|
+
parts = media_type.split("/")
|
|
33
|
+
if len(parts) == 2:
|
|
34
|
+
if pattern in (f"{parts[0]}/*", f"*/{parts[1]}"):
|
|
35
|
+
return True
|
|
36
|
+
|
|
37
|
+
return False
|
|
38
|
+
|
|
39
|
+
|
|
40
|
+
def match_status_codes(status_codes: List[str], status_code: int) -> bool:
|
|
41
|
+
if "default" in status_codes:
|
|
42
|
+
return True
|
|
43
|
+
|
|
44
|
+
for code in status_codes:
|
|
45
|
+
if code == str(status_code):
|
|
46
|
+
return True
|
|
47
|
+
|
|
48
|
+
if code.endswith("XX") and code.startswith(str(status_code)[:1]):
|
|
49
|
+
return True
|
|
50
|
+
return False
|
|
51
|
+
|
|
52
|
+
|
|
53
|
+
T = TypeVar("T")
|
|
54
|
+
|
|
55
|
+
def cast_partial(typ):
|
|
56
|
+
return partial(cast, typ)
|
|
57
|
+
|
|
58
|
+
def get_global_from_env(
|
|
59
|
+
value: Optional[T], env_key: str, type_cast: Callable[[str], T]
|
|
60
|
+
) -> Optional[T]:
|
|
61
|
+
if value is not None:
|
|
62
|
+
return value
|
|
63
|
+
env_value = os.getenv(env_key)
|
|
64
|
+
if env_value is not None:
|
|
65
|
+
try:
|
|
66
|
+
return type_cast(env_value)
|
|
67
|
+
except ValueError:
|
|
68
|
+
pass
|
|
69
|
+
return None
|
|
70
|
+
|
|
71
|
+
|
|
72
|
+
def match_response(
|
|
73
|
+
response: Response, code: Union[str, List[str]], content_type: str
|
|
74
|
+
) -> bool:
|
|
75
|
+
codes = code if isinstance(code, list) else [code]
|
|
76
|
+
return match_status_codes(codes, response.status_code) and match_content_type(
|
|
77
|
+
response.headers.get("content-type", "application/octet-stream"), content_type
|
|
78
|
+
)
|
|
79
|
+
|
|
80
|
+
|
|
81
|
+
def _populate_from_globals(
|
|
82
|
+
param_name: str, value: Any, param_metadata_type: type, gbls: Any
|
|
83
|
+
) -> Tuple[Any, bool]:
|
|
84
|
+
if gbls is None:
|
|
85
|
+
return value, False
|
|
86
|
+
|
|
87
|
+
if not isinstance(gbls, BaseModel):
|
|
88
|
+
raise TypeError("globals must be a pydantic model")
|
|
89
|
+
|
|
90
|
+
global_fields: Dict[str, FieldInfo] = gbls.__class__.model_fields
|
|
91
|
+
found = False
|
|
92
|
+
for name in global_fields:
|
|
93
|
+
field = global_fields[name]
|
|
94
|
+
if name is not param_name:
|
|
95
|
+
continue
|
|
96
|
+
|
|
97
|
+
found = True
|
|
98
|
+
|
|
99
|
+
if value is not None:
|
|
100
|
+
return value, True
|
|
101
|
+
|
|
102
|
+
global_value = getattr(gbls, name)
|
|
103
|
+
|
|
104
|
+
param_metadata = find_field_metadata(field, param_metadata_type)
|
|
105
|
+
if param_metadata is None:
|
|
106
|
+
return value, True
|
|
107
|
+
|
|
108
|
+
return global_value, True
|
|
109
|
+
|
|
110
|
+
return value, found
|
|
111
|
+
|
|
112
|
+
|
|
113
|
+
def _val_to_string(val) -> str:
|
|
114
|
+
if isinstance(val, bool):
|
|
115
|
+
return str(val).lower()
|
|
116
|
+
if isinstance(val, datetime):
|
|
117
|
+
return str(val.isoformat().replace("+00:00", "Z"))
|
|
118
|
+
if isinstance(val, Enum):
|
|
119
|
+
return str(val.value)
|
|
120
|
+
|
|
121
|
+
return str(val)
|
|
122
|
+
|
|
123
|
+
|
|
124
|
+
def _get_serialized_params(
|
|
125
|
+
metadata: ParamMetadata, field_name: str, obj: Any, typ: type
|
|
126
|
+
) -> Dict[str, str]:
|
|
127
|
+
params: Dict[str, str] = {}
|
|
128
|
+
|
|
129
|
+
serialization = metadata.serialization
|
|
130
|
+
if serialization == "json":
|
|
131
|
+
params[field_name] = marshal_json(obj, typ)
|
|
132
|
+
|
|
133
|
+
return params
|
|
134
|
+
|
|
135
|
+
|
|
136
|
+
def _is_set(value: Any) -> bool:
|
|
137
|
+
return value is not None and not isinstance(value, Unset)
|