coinex-api 0.0.23__py3-none-any.whl → 0.0.25__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.
- coinex/ccxt/__init__.py +2 -3
- coinex/ccxt/async_support/__init__.py +2 -3
- coinex/ccxt/async_support/base/exchange.py +2 -2
- coinex/ccxt/async_support/coinex.py +3 -1
- coinex/ccxt/base/exchange.py +109 -23
- coinex/ccxt/coinex.py +3 -1
- coinex/ccxt/pro/__init__.py +2 -3
- {coinex_api-0.0.23.dist-info → coinex_api-0.0.25.dist-info}/METADATA +7 -3
- {coinex_api-0.0.23.dist-info → coinex_api-0.0.25.dist-info}/RECORD +10 -10
- {coinex_api-0.0.23.dist-info → coinex_api-0.0.25.dist-info}/WHEEL +0 -0
coinex/ccxt/__init__.py
CHANGED
@@ -26,7 +26,7 @@ sys.modules['ccxt'] = ccxt_module
|
|
26
26
|
|
27
27
|
# ----------------------------------------------------------------------------
|
28
28
|
|
29
|
-
__version__ = '4.4.
|
29
|
+
__version__ = '4.4.78'
|
30
30
|
|
31
31
|
# ----------------------------------------------------------------------------
|
32
32
|
|
@@ -87,10 +87,9 @@ from ccxt.base.errors import CancelPending # noqa: F4
|
|
87
87
|
from ccxt.base.errors import UnsubscribeError # noqa: F401
|
88
88
|
from ccxt.base.errors import error_hierarchy # noqa: F401
|
89
89
|
|
90
|
-
from ccxt.bitfinex1 import bitfinex1 # noqa: F401
|
91
90
|
from ccxt.coinex import coinex # noqa: F401
|
92
91
|
|
93
|
-
exchanges = [ '
|
92
|
+
exchanges = [ 'coinex',]
|
94
93
|
|
95
94
|
base = [
|
96
95
|
'Exchange',
|
@@ -8,7 +8,7 @@ sys.modules['ccxt'] = ccxt_module
|
|
8
8
|
|
9
9
|
# -----------------------------------------------------------------------------
|
10
10
|
|
11
|
-
__version__ = '4.4.
|
11
|
+
__version__ = '4.4.78'
|
12
12
|
|
13
13
|
# -----------------------------------------------------------------------------
|
14
14
|
|
@@ -67,10 +67,9 @@ from ccxt.base.errors import UnsubscribeError # noqa: F4
|
|
67
67
|
from ccxt.base.errors import error_hierarchy # noqa: F401
|
68
68
|
|
69
69
|
|
70
|
-
from ccxt.async_support.bitfinex1 import bitfinex1 # noqa: F401
|
71
70
|
from ccxt.async_support.coinex import coinex # noqa: F401
|
72
71
|
|
73
|
-
exchanges = [ '
|
72
|
+
exchanges = [ 'coinex',]
|
74
73
|
|
75
74
|
base = [
|
76
75
|
'Exchange',
|
@@ -2,7 +2,7 @@
|
|
2
2
|
|
3
3
|
# -----------------------------------------------------------------------------
|
4
4
|
|
5
|
-
__version__ = '4.4.
|
5
|
+
__version__ = '4.4.78'
|
6
6
|
|
7
7
|
# -----------------------------------------------------------------------------
|
8
8
|
|
@@ -154,7 +154,7 @@ class Exchange(BaseExchange):
|
|
154
154
|
proxyUrl = self.check_proxy_url_settings(url, method, headers, body)
|
155
155
|
if proxyUrl is not None:
|
156
156
|
request_headers.update({'Origin': self.origin})
|
157
|
-
url = proxyUrl + url
|
157
|
+
url = proxyUrl + self.url_encoder_for_proxy_url(url)
|
158
158
|
# proxy agents
|
159
159
|
final_proxy = None # set default
|
160
160
|
proxy_session = None
|
@@ -763,6 +763,8 @@ class coinex(Exchange, ImplicitAPI):
|
|
763
763
|
for j in range(0, len(chains)):
|
764
764
|
chain = chains[j]
|
765
765
|
networkId = self.safe_string(chain, 'chain')
|
766
|
+
if networkId is None:
|
767
|
+
continue
|
766
768
|
precisionString = self.parse_precision(self.safe_string(chain, 'withdrawal_precision'))
|
767
769
|
feeString = self.safe_string(chain, 'withdrawal_fee')
|
768
770
|
minNetworkDepositString = self.safe_string(chain, 'min_deposit_amount')
|
@@ -3857,7 +3859,7 @@ class coinex(Exchange, ImplicitAPI):
|
|
3857
3859
|
data = self.safe_list(response, 'data', [])
|
3858
3860
|
return self.parse_trades(data, market, since, limit)
|
3859
3861
|
|
3860
|
-
async def fetch_positions(self, symbols: Strings = None, params={}):
|
3862
|
+
async def fetch_positions(self, symbols: Strings = None, params={}) -> List[Position]:
|
3861
3863
|
"""
|
3862
3864
|
fetch all open positions
|
3863
3865
|
|
coinex/ccxt/base/exchange.py
CHANGED
@@ -4,7 +4,7 @@
|
|
4
4
|
|
5
5
|
# -----------------------------------------------------------------------------
|
6
6
|
|
7
|
-
__version__ = '4.4.
|
7
|
+
__version__ = '4.4.78'
|
8
8
|
|
9
9
|
# -----------------------------------------------------------------------------
|
10
10
|
|
@@ -67,6 +67,10 @@ from ccxt.static_dependencies.starknet.hash.address import compute_address
|
|
67
67
|
from ccxt.static_dependencies.starknet.hash.selector import get_selector_from_name
|
68
68
|
from ccxt.static_dependencies.starknet.hash.utils import message_signature, private_to_stark_key
|
69
69
|
from ccxt.static_dependencies.starknet.utils.typed_data import TypedData as TypedDataDataclass
|
70
|
+
try:
|
71
|
+
import apexpro.zklink_sdk as zklink_sdk
|
72
|
+
except ImportError:
|
73
|
+
zklink_sdk = None
|
70
74
|
|
71
75
|
# -----------------------------------------------------------------------------
|
72
76
|
|
@@ -509,7 +513,7 @@ class Exchange(object):
|
|
509
513
|
proxyUrl = self.check_proxy_url_settings(url, method, headers, body)
|
510
514
|
if proxyUrl is not None:
|
511
515
|
request_headers.update({'Origin': self.origin})
|
512
|
-
url = proxyUrl + url
|
516
|
+
url = proxyUrl + self.url_encoder_for_proxy_url(url)
|
513
517
|
# proxy agents
|
514
518
|
proxies = None # set default
|
515
519
|
httpProxy, httpsProxy, socksProxy = self.check_proxy_settings(url, method, headers, body)
|
@@ -1755,6 +1759,69 @@ class Exchange(object):
|
|
1755
1759
|
def binary_length(self, binary):
|
1756
1760
|
return len(binary)
|
1757
1761
|
|
1762
|
+
def get_zk_contract_signature_obj(self, seeds: str, params={}):
|
1763
|
+
if zklink_sdk is None:
|
1764
|
+
raise Exception('zklink_sdk is not installed, please do pip3 install apexomni-arm or apexomni-x86-mac or apexomni-x86-windows-linux')
|
1765
|
+
|
1766
|
+
slotId = self.safe_string(params, 'slotId')
|
1767
|
+
nonceInt = int(self.remove0x_prefix(self.hash(self.encode(slotId), 'sha256', 'hex')), 16)
|
1768
|
+
|
1769
|
+
maxUint64 = 18446744073709551615
|
1770
|
+
maxUint32 = 4294967295
|
1771
|
+
|
1772
|
+
slotId = (nonceInt % maxUint64) / maxUint32
|
1773
|
+
nonce = nonceInt % maxUint32
|
1774
|
+
accountId = int(self.safe_string(params, 'accountId'), 10) % maxUint32
|
1775
|
+
|
1776
|
+
priceStr = (Decimal(self.safe_string(params, 'price')) * Decimal(10) ** Decimal('18')).quantize(Decimal(0), rounding='ROUND_DOWN')
|
1777
|
+
sizeStr = (Decimal(self.safe_string(params, 'size')) * Decimal(10) ** Decimal('18')).quantize(Decimal(0), rounding='ROUND_DOWN')
|
1778
|
+
|
1779
|
+
takerFeeRateStr = (Decimal(self.safe_string(params, 'takerFeeRate')) * Decimal(10000)).quantize(Decimal(0), rounding='ROUND_UP')
|
1780
|
+
makerFeeRateStr = (Decimal(self.safe_string(params, 'makerFeeRate')) * Decimal(10000)).quantize(Decimal(0), rounding='ROUND_UP')
|
1781
|
+
|
1782
|
+
builder = zklink_sdk.ContractBuilder(
|
1783
|
+
int(accountId), int(0), int(slotId), int(nonce), int(self.safe_number(params, 'pairId')),
|
1784
|
+
sizeStr.__str__(), priceStr.__str__(), self.safe_string(params, 'direction') == "BUY",
|
1785
|
+
int(takerFeeRateStr), int(makerFeeRateStr), False)
|
1786
|
+
|
1787
|
+
|
1788
|
+
tx = zklink_sdk.Contract(builder)
|
1789
|
+
seedsByte = bytes.fromhex(seeds.removeprefix('0x'))
|
1790
|
+
signerSeed = zklink_sdk.ZkLinkSigner().new_from_seed(seedsByte)
|
1791
|
+
auth_data = signerSeed.sign_musig(tx.get_bytes())
|
1792
|
+
signature = auth_data.signature
|
1793
|
+
return signature
|
1794
|
+
|
1795
|
+
def get_zk_transfer_signature_obj(self, seeds: str, params={}):
|
1796
|
+
if zklink_sdk is None:
|
1797
|
+
raise Exception('zklink_sdk is not installed, please do pip3 install apexomni-arm or apexomni-x86-mac or apexomni-x86-windows-linux')
|
1798
|
+
|
1799
|
+
nonce = self.safe_string(params, 'nonce', '0')
|
1800
|
+
if self.safe_bool(params, 'isContract'):
|
1801
|
+
formattedUint32 = '4294967295'
|
1802
|
+
formattedNonce = int(self.remove0x_prefix(self.hash(self.encode(nonce), 'sha256', 'hex')), 16)
|
1803
|
+
nonce = Precise.string_mod(str(formattedNonce), formattedUint32)
|
1804
|
+
|
1805
|
+
tx_builder = zklink_sdk.TransferBuilder(
|
1806
|
+
int(self.safe_number(params, 'zkAccountId', 0)),
|
1807
|
+
self.safe_string(params, 'receiverAddress'),
|
1808
|
+
int(self.safe_number(params, 'subAccountId', 0)),
|
1809
|
+
int(self.safe_number(params, 'receiverSubAccountId', 0)),
|
1810
|
+
int(self.safe_number(params, 'tokenId', 0)),
|
1811
|
+
self.safe_string(params, 'amount', '0'),
|
1812
|
+
self.safe_string(params, 'fee', '0'),
|
1813
|
+
self.parse_to_int(nonce),
|
1814
|
+
int(self.safe_number(params, 'timestampSeconds', 0))
|
1815
|
+
)
|
1816
|
+
|
1817
|
+
tx = zklink_sdk.Transfer(tx_builder)
|
1818
|
+
seedsByte = bytes.fromhex(seeds.removeprefix('0x'))
|
1819
|
+
signerSeed = zklink_sdk.ZkLinkSigner().new_from_seed(seedsByte)
|
1820
|
+
auth_data = signerSeed.sign_musig(tx.get_bytes())
|
1821
|
+
signature = auth_data.signature
|
1822
|
+
return signature
|
1823
|
+
|
1824
|
+
|
1758
1825
|
# ########################################################################
|
1759
1826
|
# ########################################################################
|
1760
1827
|
# ########################################################################
|
@@ -2254,6 +2321,12 @@ class Exchange(object):
|
|
2254
2321
|
raise InvalidProxySettings(self.id + ' you have multiple conflicting proxy settings(' + joinedProxyNames + '), please use only one from : proxyUrl, proxy_url, proxyUrlCallback, proxy_url_callback')
|
2255
2322
|
return proxyUrl
|
2256
2323
|
|
2324
|
+
def url_encoder_for_proxy_url(self, targetUrl: str):
|
2325
|
+
# to be overriden
|
2326
|
+
includesQuery = targetUrl.find('?') >= 0
|
2327
|
+
finalUrl = self.encode_uri_component(targetUrl) if includesQuery else targetUrl
|
2328
|
+
return finalUrl
|
2329
|
+
|
2257
2330
|
def check_proxy_settings(self, url: Str = None, method: Str = None, headers=None, body=None):
|
2258
2331
|
usedProxies = []
|
2259
2332
|
httpProxy = None
|
@@ -2913,9 +2986,6 @@ class Exchange(object):
|
|
2913
2986
|
|
2914
2987
|
def safe_currency_structure(self, currency: object):
|
2915
2988
|
# derive data from networks: deposit, withdraw, active, fee, limits, precision
|
2916
|
-
currencyDeposit = self.safe_bool(currency, 'deposit')
|
2917
|
-
currencyWithdraw = self.safe_bool(currency, 'withdraw')
|
2918
|
-
currencyActive = self.safe_bool(currency, 'active')
|
2919
2989
|
networks = self.safe_dict(currency, 'networks', {})
|
2920
2990
|
keys = list(networks.keys())
|
2921
2991
|
length = len(keys)
|
@@ -2924,20 +2994,24 @@ class Exchange(object):
|
|
2924
2994
|
key = keys[i]
|
2925
2995
|
network = networks[key]
|
2926
2996
|
deposit = self.safe_bool(network, 'deposit')
|
2997
|
+
currencyDeposit = self.safe_bool(currency, 'deposit')
|
2927
2998
|
if currencyDeposit is None or deposit:
|
2928
2999
|
currency['deposit'] = deposit
|
2929
3000
|
withdraw = self.safe_bool(network, 'withdraw')
|
3001
|
+
currencyWithdraw = self.safe_bool(currency, 'withdraw')
|
2930
3002
|
if currencyWithdraw is None or withdraw:
|
2931
3003
|
currency['withdraw'] = withdraw
|
2932
|
-
active = self.safe_bool(network, 'active')
|
2933
|
-
if currencyActive is None or active:
|
2934
|
-
currency['active'] = active
|
2935
3004
|
# set network 'active' to False if D or W is disabled
|
2936
|
-
|
3005
|
+
active = self.safe_bool(network, 'active')
|
3006
|
+
if active is None:
|
2937
3007
|
if deposit and withdraw:
|
2938
3008
|
currency['networks'][key]['active'] = True
|
2939
3009
|
elif deposit is not None and withdraw is not None:
|
2940
3010
|
currency['networks'][key]['active'] = False
|
3011
|
+
active = self.safe_bool(network, 'active')
|
3012
|
+
currencyActive = self.safe_bool(currency, 'active')
|
3013
|
+
if currencyActive is None or active:
|
3014
|
+
currency['active'] = active
|
2941
3015
|
# find lowest fee(which is more desired)
|
2942
3016
|
fee = self.safe_string(network, 'fee')
|
2943
3017
|
feeMain = self.safe_string(currency, 'fee')
|
@@ -2946,7 +3020,7 @@ class Exchange(object):
|
|
2946
3020
|
# find lowest precision(which is more desired)
|
2947
3021
|
precision = self.safe_string(network, 'precision')
|
2948
3022
|
precisionMain = self.safe_string(currency, 'precision')
|
2949
|
-
if precisionMain is None or Precise.
|
3023
|
+
if precisionMain is None or Precise.string_gt(precision, precisionMain):
|
2950
3024
|
currency['precision'] = self.parse_number(precision)
|
2951
3025
|
# limits
|
2952
3026
|
limits = self.safe_dict(network, 'limits')
|
@@ -6471,24 +6545,36 @@ class Exchange(object):
|
|
6471
6545
|
return self.sort_by(result, 'id', True)
|
6472
6546
|
return result
|
6473
6547
|
|
6474
|
-
def remove_repeated_elements_from_array(self, input):
|
6548
|
+
def remove_repeated_elements_from_array(self, input, fallbackToTimestamp: bool = True):
|
6549
|
+
uniqueDic = {}
|
6550
|
+
uniqueResult = []
|
6551
|
+
for i in range(0, len(input)):
|
6552
|
+
entry = input[i]
|
6553
|
+
uniqValue = self.safe_string_n(entry, ['id', 'timestamp', 0]) if fallbackToTimestamp else self.safe_string(entry, 'id')
|
6554
|
+
if uniqValue is not None and not (uniqValue in uniqueDic):
|
6555
|
+
uniqueDic[uniqValue] = 1
|
6556
|
+
uniqueResult.append(entry)
|
6557
|
+
valuesLength = len(uniqueResult)
|
6558
|
+
if valuesLength > 0:
|
6559
|
+
return uniqueResult
|
6560
|
+
return input
|
6561
|
+
|
6562
|
+
def remove_repeated_trades_from_array(self, input):
|
6475
6563
|
uniqueResult = {}
|
6476
6564
|
for i in range(0, len(input)):
|
6477
6565
|
entry = input[i]
|
6478
6566
|
id = self.safe_string(entry, 'id')
|
6479
|
-
if id is
|
6480
|
-
|
6481
|
-
|
6482
|
-
|
6483
|
-
|
6484
|
-
|
6485
|
-
|
6486
|
-
|
6567
|
+
if id is None:
|
6568
|
+
price = self.safe_string(entry, 'price')
|
6569
|
+
amount = self.safe_string(entry, 'amount')
|
6570
|
+
timestamp = self.safe_string(entry, 'timestamp')
|
6571
|
+
side = self.safe_string(entry, 'side')
|
6572
|
+
# unique trade identifier
|
6573
|
+
id = 't_' + str(timestamp) + '_' + side + '_' + price + '_' + amount
|
6574
|
+
if id is not None and not (id in uniqueResult):
|
6575
|
+
uniqueResult[id] = entry
|
6487
6576
|
values = list(uniqueResult.values())
|
6488
|
-
|
6489
|
-
if valuesLength > 0:
|
6490
|
-
return values
|
6491
|
-
return input
|
6577
|
+
return values
|
6492
6578
|
|
6493
6579
|
def handle_until_option(self, key: str, request, params, multiplier=1):
|
6494
6580
|
until = self.safe_integer_2(params, 'until', 'till')
|
coinex/ccxt/coinex.py
CHANGED
@@ -762,6 +762,8 @@ class coinex(Exchange, ImplicitAPI):
|
|
762
762
|
for j in range(0, len(chains)):
|
763
763
|
chain = chains[j]
|
764
764
|
networkId = self.safe_string(chain, 'chain')
|
765
|
+
if networkId is None:
|
766
|
+
continue
|
765
767
|
precisionString = self.parse_precision(self.safe_string(chain, 'withdrawal_precision'))
|
766
768
|
feeString = self.safe_string(chain, 'withdrawal_fee')
|
767
769
|
minNetworkDepositString = self.safe_string(chain, 'min_deposit_amount')
|
@@ -3856,7 +3858,7 @@ class coinex(Exchange, ImplicitAPI):
|
|
3856
3858
|
data = self.safe_list(response, 'data', [])
|
3857
3859
|
return self.parse_trades(data, market, since, limit)
|
3858
3860
|
|
3859
|
-
def fetch_positions(self, symbols: Strings = None, params={}):
|
3861
|
+
def fetch_positions(self, symbols: Strings = None, params={}) -> List[Position]:
|
3860
3862
|
"""
|
3861
3863
|
fetch all open positions
|
3862
3864
|
|
coinex/ccxt/pro/__init__.py
CHANGED
@@ -8,7 +8,7 @@ sys.modules['ccxt'] = ccxt_module
|
|
8
8
|
|
9
9
|
# ----------------------------------------------------------------------------
|
10
10
|
|
11
|
-
__version__ = '4.4.
|
11
|
+
__version__ = '4.4.78'
|
12
12
|
|
13
13
|
# ----------------------------------------------------------------------------
|
14
14
|
|
@@ -16,7 +16,6 @@ from ccxt.async_support.base.exchange import Exchange # noqa: F401
|
|
16
16
|
|
17
17
|
# CCXT Pro exchanges (now this is mainly used for importing exchanges in WS tests)
|
18
18
|
|
19
|
-
from ccxt.pro.bitfinex1 import bitfinex1 # noqa: F401
|
20
19
|
from ccxt.pro.coinex import coinex # noqa: F401
|
21
20
|
|
22
|
-
exchanges = [ '
|
21
|
+
exchanges = [ 'coinex',]
|
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.4
|
2
2
|
Name: coinex-api
|
3
|
-
Version: 0.0.
|
3
|
+
Version: 0.0.25
|
4
4
|
Summary: coinex crypto exchange api client
|
5
5
|
Project-URL: Homepage, https://github.com/ccxt/ccxt
|
6
6
|
Project-URL: Issues, https://github.com/ccxt/ccxt
|
@@ -20,8 +20,10 @@ Description-Content-Type: text/markdown
|
|
20
20
|
# coinex-python
|
21
21
|
Python SDK (sync and async) for Coinex cryptocurrency exchange with Rest and WS capabilities.
|
22
22
|
|
23
|
-
You can check the SDK docs here: [SDK](https://docs.ccxt.com/#/exchanges/coinex)
|
24
|
-
You can check Coinex's docs here: [Docs](https://www.google.com/search?q=google+coinex+cryptocurrency+exchange+api+docs)
|
23
|
+
- You can check the SDK docs here: [SDK](https://docs.ccxt.com/#/exchanges/coinex)
|
24
|
+
- You can check Coinex's docs here: [Docs](https://www.google.com/search?q=google+coinex+cryptocurrency+exchange+api+docs)
|
25
|
+
- Github repo: https://github.com/ccxt/coinex-python
|
26
|
+
- Pypi package: https://pypi.org/project/coinex-api
|
25
27
|
|
26
28
|
|
27
29
|
## Installation
|
@@ -44,6 +46,8 @@ def main():
|
|
44
46
|
#
|
45
47
|
# balance = instance.fetch_balance()
|
46
48
|
# order = instance.create_order("BTC/USDC", "limit", "buy", 1, 100000)
|
49
|
+
|
50
|
+
main()
|
47
51
|
```
|
48
52
|
|
49
53
|
### Async
|
@@ -1,11 +1,11 @@
|
|
1
1
|
coinex/__init__.py,sha256=d633U2PpNFHvpDWLb3lItS0ObcBN0E2XgS5QkOEejI8,246
|
2
|
-
coinex/ccxt/__init__.py,sha256=
|
3
|
-
coinex/ccxt/coinex.py,sha256=
|
2
|
+
coinex/ccxt/__init__.py,sha256=N-vxPxFSeHJ1xOJ9qokv2f-VYWCQDHf9qF68_wB5Atg,6048
|
3
|
+
coinex/ccxt/coinex.py,sha256=W_sp6RQvsSuNu9H-V5i6tq9zplNNuyU5rqHlrCZcUqQ,267309
|
4
4
|
coinex/ccxt/abstract/coinex.py,sha256=4TRXtWgONqkm3eSL55Y5T7Q4QxJrnOTuhP0ugsKHAWo,34856
|
5
|
-
coinex/ccxt/async_support/__init__.py,sha256=
|
6
|
-
coinex/ccxt/async_support/coinex.py,sha256=
|
5
|
+
coinex/ccxt/async_support/__init__.py,sha256=_6NpYq6WGg_d7g21oBCQBhfXETN9Su8T-9wjTWpf6OA,4781
|
6
|
+
coinex/ccxt/async_support/coinex.py,sha256=fBPZvrWmUd9uh_aW0wVxv4y6jmRBEbh7iOMR_ujX0aw,268597
|
7
7
|
coinex/ccxt/async_support/base/__init__.py,sha256=aVYSsFi--b4InRs9zDN_wtCpj8odosAB726JdUHavrk,67
|
8
|
-
coinex/ccxt/async_support/base/exchange.py,sha256=
|
8
|
+
coinex/ccxt/async_support/base/exchange.py,sha256=AOQnGV5CUYT2fOCko3E6JqYxa_s8_QxHDdBxbqUUOgU,117255
|
9
9
|
coinex/ccxt/async_support/base/throttler.py,sha256=tvDVcdRUVYi8fZRlEcnqtgzcgB_KMUMRs5Pu8tuU-tU,1847
|
10
10
|
coinex/ccxt/async_support/base/ws/__init__.py,sha256=uockzpLuwntKGZbs5EOWFe-Zg-k6Cj7GhNJLc_RX0so,1791
|
11
11
|
coinex/ccxt/async_support/base/ws/aiohttp_client.py,sha256=Y5HxAVXyyYduj6b6SbbUZETlq3GrVMzrkW1r-TMgpb8,6329
|
@@ -19,10 +19,10 @@ coinex/ccxt/async_support/base/ws/order_book_side.py,sha256=GhnGUt78pJ-AYL_Dq9pr
|
|
19
19
|
coinex/ccxt/base/__init__.py,sha256=eTx1OE3HJjspFUQjGm6LBhaQiMKJnXjkdP-JUXknyQ0,1320
|
20
20
|
coinex/ccxt/base/decimal_to_precision.py,sha256=fgWRBzRTtsf3r2INyS4f7WHlzgjB5YM1ekiwqD21aac,6634
|
21
21
|
coinex/ccxt/base/errors.py,sha256=MvCrL_sAM3de616T6RE0PSxiF2xV6Qqz5b1y1ghidbk,4888
|
22
|
-
coinex/ccxt/base/exchange.py,sha256=
|
22
|
+
coinex/ccxt/base/exchange.py,sha256=R0StVeXIxmXvA73by-Gqx70tT7wbJMNuenrVXgoe0Dk,326255
|
23
23
|
coinex/ccxt/base/precise.py,sha256=koce64Yrp6vFbGijJtUt-QQ6XhJgeGTCksZ871FPp_A,8886
|
24
24
|
coinex/ccxt/base/types.py,sha256=SfxIKDSsxP7MPHWiOVI965Nr5NSEPpAno5fuveTRi3w,11423
|
25
|
-
coinex/ccxt/pro/__init__.py,sha256=
|
25
|
+
coinex/ccxt/pro/__init__.py,sha256=7rHprRhDoJUiiFwENgEqAWMf98VV0FD3BwkZ1bxGX9w,619
|
26
26
|
coinex/ccxt/pro/coinex.py,sha256=aQ6Xa4ML0PTCgGleDJuhjqntspAREz6XxQwX9IcD6OY,56616
|
27
27
|
coinex/ccxt/static_dependencies/README.md,sha256=3TCvhhn09_Cqf9BDDpao1V7EfKHDpQ6k9oWRsLFixpU,18
|
28
28
|
coinex/ccxt/static_dependencies/__init__.py,sha256=tzFje8cloqmiIE6kola3EaYC0SnD1izWnri69hzHsSw,168
|
@@ -283,6 +283,6 @@ coinex/ccxt/static_dependencies/toolz/curried/exceptions.py,sha256=gKFOHDIayAWnX
|
|
283
283
|
coinex/ccxt/static_dependencies/toolz/curried/operator.py,sha256=ML92mknkAwzBl2NCm-4werSUmJEtSHNY9NSzhseNM9s,525
|
284
284
|
coinex/ccxt/static_dependencies/typing_inspect/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
285
285
|
coinex/ccxt/static_dependencies/typing_inspect/typing_inspect.py,sha256=5gIWomLPfuDpgd3gX1GlnX0MuXM3VorR4j2W2qXORiQ,28269
|
286
|
-
coinex_api-0.0.
|
287
|
-
coinex_api-0.0.
|
288
|
-
coinex_api-0.0.
|
286
|
+
coinex_api-0.0.25.dist-info/METADATA,sha256=-zyiuZLAYNMnazqPG_UzSgUmcl-l_gpDaSyUYWUqT2k,19969
|
287
|
+
coinex_api-0.0.25.dist-info/WHEEL,sha256=qtCwoSJWgHk21S1Kb4ihdzI2rlJ1ZKaIurTj_ngOhyQ,87
|
288
|
+
coinex_api-0.0.25.dist-info/RECORD,,
|
File without changes
|