ccxt 4.2.77__py2.py3-none-any.whl → 4.4.49__py2.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.
- ccxt/__init__.py +36 -14
- ccxt/abstract/alpaca.py +4 -0
- ccxt/abstract/bigone.py +1 -1
- ccxt/abstract/binance.py +112 -48
- ccxt/abstract/binancecoinm.py +112 -48
- ccxt/abstract/binanceus.py +147 -83
- ccxt/abstract/binanceusdm.py +112 -48
- ccxt/abstract/bingx.py +133 -78
- ccxt/abstract/bitbank.py +5 -0
- ccxt/abstract/bitfinex.py +136 -65
- ccxt/abstract/bitfinex1.py +69 -0
- ccxt/abstract/bitflyer.py +1 -0
- ccxt/abstract/bitget.py +8 -1
- ccxt/abstract/bitmart.py +13 -1
- ccxt/abstract/bitopro.py +1 -0
- ccxt/abstract/bitpanda.py +0 -12
- ccxt/abstract/bitrue.py +3 -3
- ccxt/abstract/bitstamp.py +26 -3
- ccxt/abstract/blofin.py +24 -0
- ccxt/abstract/btcbox.py +1 -0
- ccxt/abstract/bybit.py +29 -14
- ccxt/abstract/cex.py +28 -29
- ccxt/abstract/coinbase.py +6 -0
- ccxt/abstract/coinbaseadvanced.py +94 -0
- ccxt/abstract/{coinbasepro.py → coinbaseexchange.py} +1 -0
- ccxt/abstract/coinbaseinternational.py +1 -1
- ccxt/abstract/coincatch.py +94 -0
- ccxt/abstract/coinex.py +233 -123
- ccxt/abstract/coinmetro.py +1 -0
- ccxt/abstract/cryptocom.py +14 -0
- ccxt/abstract/defx.py +69 -0
- ccxt/abstract/deribit.py +1 -0
- ccxt/abstract/digifinex.py +1 -0
- ccxt/abstract/ellipx.py +25 -0
- ccxt/abstract/gate.py +20 -0
- ccxt/abstract/gateio.py +20 -0
- ccxt/abstract/gemini.py +1 -0
- ccxt/abstract/hashkey.py +67 -0
- ccxt/abstract/hyperliquid.py +1 -1
- ccxt/abstract/independentreserve.py +6 -0
- ccxt/abstract/kraken.py +4 -3
- ccxt/abstract/krakenfutures.py +4 -0
- ccxt/abstract/kucoin.py +24 -0
- ccxt/abstract/kucoinfutures.py +34 -0
- ccxt/abstract/luno.py +2 -0
- ccxt/abstract/mexc.py +4 -0
- ccxt/abstract/myokx.py +340 -0
- ccxt/abstract/oceanex.py +5 -0
- ccxt/abstract/okx.py +30 -0
- ccxt/abstract/onetrading.py +0 -12
- ccxt/abstract/oxfun.py +34 -0
- ccxt/abstract/paradex.py +40 -0
- ccxt/abstract/phemex.py +1 -0
- ccxt/abstract/upbit.py +4 -0
- ccxt/abstract/vertex.py +19 -0
- ccxt/abstract/whitebit.py +31 -1
- ccxt/abstract/woo.py +6 -2
- ccxt/abstract/woofipro.py +119 -0
- ccxt/abstract/xt.py +153 -0
- ccxt/abstract/zonda.py +6 -0
- ccxt/ace.py +164 -60
- ccxt/alpaca.py +727 -63
- ccxt/ascendex.py +395 -249
- ccxt/async_support/__init__.py +36 -14
- ccxt/async_support/ace.py +164 -60
- ccxt/async_support/alpaca.py +727 -63
- ccxt/async_support/ascendex.py +396 -249
- ccxt/async_support/base/exchange.py +531 -155
- ccxt/async_support/base/ws/aiohttp_client.py +28 -5
- ccxt/async_support/base/ws/cache.py +3 -2
- ccxt/async_support/base/ws/client.py +26 -5
- ccxt/async_support/base/ws/fast_client.py +4 -3
- ccxt/async_support/base/ws/functions.py +1 -1
- ccxt/async_support/base/ws/future.py +40 -31
- ccxt/async_support/base/ws/order_book_side.py +3 -0
- ccxt/async_support/bequant.py +1 -1
- ccxt/async_support/bigone.py +329 -202
- ccxt/async_support/binance.py +3030 -1087
- ccxt/async_support/binancecoinm.py +2 -1
- ccxt/async_support/binanceus.py +12 -1
- ccxt/async_support/binanceusdm.py +3 -1
- ccxt/async_support/bingx.py +3205 -937
- ccxt/async_support/bit2c.py +119 -38
- ccxt/async_support/bitbank.py +215 -76
- ccxt/async_support/bitbns.py +124 -53
- ccxt/async_support/bitfinex.py +3236 -1078
- ccxt/async_support/bitfinex1.py +1711 -0
- ccxt/async_support/bitflyer.py +238 -49
- ccxt/async_support/bitget.py +1525 -573
- ccxt/async_support/bithumb.py +199 -65
- ccxt/async_support/bitmart.py +1320 -435
- ccxt/async_support/bitmex.py +308 -111
- ccxt/async_support/bitopro.py +256 -96
- ccxt/async_support/bitrue.py +365 -233
- ccxt/async_support/bitso.py +201 -89
- ccxt/async_support/bitstamp.py +438 -269
- ccxt/async_support/bitteam.py +179 -73
- ccxt/async_support/bitvavo.py +180 -70
- ccxt/async_support/bl3p.py +92 -25
- ccxt/async_support/blockchaincom.py +193 -79
- ccxt/async_support/blofin.py +392 -148
- ccxt/async_support/btcalpha.py +161 -55
- ccxt/async_support/btcbox.py +250 -34
- ccxt/async_support/btcmarkets.py +232 -85
- ccxt/async_support/btcturk.py +159 -60
- ccxt/async_support/bybit.py +2231 -1193
- ccxt/async_support/cex.py +1409 -1329
- ccxt/async_support/coinbase.py +1454 -287
- ccxt/async_support/coinbaseadvanced.py +17 -0
- ccxt/async_support/{coinbasepro.py → coinbaseexchange.py} +233 -99
- ccxt/async_support/coinbaseinternational.py +428 -88
- ccxt/async_support/coincatch.py +5152 -0
- ccxt/async_support/coincheck.py +121 -38
- ccxt/async_support/coinex.py +4020 -3339
- ccxt/async_support/coinlist.py +273 -116
- ccxt/async_support/coinmate.py +204 -97
- ccxt/async_support/coinmetro.py +203 -110
- ccxt/async_support/coinone.py +142 -68
- ccxt/async_support/coinsph.py +223 -97
- ccxt/async_support/coinspot.py +137 -62
- ccxt/async_support/cryptocom.py +515 -185
- ccxt/async_support/currencycom.py +203 -85
- ccxt/async_support/defx.py +2066 -0
- ccxt/async_support/delta.py +404 -109
- ccxt/async_support/deribit.py +639 -323
- ccxt/async_support/digifinex.py +465 -233
- ccxt/async_support/ellipx.py +1887 -0
- ccxt/async_support/exmo.py +317 -128
- ccxt/async_support/gate.py +1472 -463
- ccxt/async_support/gemini.py +206 -84
- ccxt/async_support/hashkey.py +4164 -0
- ccxt/async_support/hitbtc.py +433 -178
- ccxt/async_support/hollaex.py +207 -83
- ccxt/async_support/htx.py +1095 -563
- ccxt/async_support/huobijp.py +178 -56
- ccxt/async_support/hyperliquid.py +1678 -292
- ccxt/async_support/idex.py +219 -95
- ccxt/async_support/independentreserve.py +300 -31
- ccxt/async_support/indodax.py +226 -62
- ccxt/async_support/kraken.py +871 -354
- ccxt/async_support/krakenfutures.py +324 -100
- ccxt/async_support/kucoin.py +917 -357
- ccxt/async_support/kucoinfutures.py +1004 -149
- ccxt/async_support/kuna.py +198 -107
- ccxt/async_support/latoken.py +199 -79
- ccxt/async_support/lbank.py +360 -113
- ccxt/async_support/luno.py +185 -62
- ccxt/async_support/lykke.py +168 -55
- ccxt/async_support/mercado.py +101 -29
- ccxt/async_support/mexc.py +995 -429
- ccxt/async_support/myokx.py +53 -0
- ccxt/async_support/ndax.py +234 -82
- ccxt/async_support/novadax.py +195 -75
- ccxt/async_support/oceanex.py +244 -59
- ccxt/async_support/okcoin.py +301 -165
- ccxt/async_support/okx.py +1776 -454
- ccxt/async_support/onetrading.py +198 -414
- ccxt/async_support/oxfun.py +2898 -0
- ccxt/async_support/p2b.py +142 -52
- ccxt/async_support/paradex.py +2085 -0
- ccxt/async_support/paymium.py +56 -32
- ccxt/async_support/phemex.py +572 -196
- ccxt/async_support/poloniex.py +218 -95
- ccxt/async_support/poloniexfutures.py +260 -92
- ccxt/async_support/probit.py +143 -110
- ccxt/async_support/timex.py +123 -70
- ccxt/async_support/tokocrypto.py +129 -93
- ccxt/async_support/tradeogre.py +39 -25
- ccxt/async_support/upbit.py +322 -113
- ccxt/async_support/vertex.py +2983 -0
- ccxt/async_support/wavesexchange.py +227 -173
- ccxt/async_support/wazirx.py +145 -65
- ccxt/async_support/whitebit.py +533 -138
- ccxt/async_support/woo.py +1137 -296
- ccxt/async_support/woofipro.py +2716 -0
- ccxt/async_support/xt.py +4628 -0
- ccxt/async_support/yobit.py +160 -92
- ccxt/async_support/zaif.py +80 -33
- ccxt/async_support/zonda.py +140 -69
- ccxt/base/errors.py +51 -20
- ccxt/base/exchange.py +1722 -480
- ccxt/base/precise.py +10 -0
- ccxt/base/types.py +223 -4
- ccxt/bequant.py +1 -1
- ccxt/bigone.py +329 -202
- ccxt/binance.py +3030 -1087
- ccxt/binancecoinm.py +2 -1
- ccxt/binanceus.py +12 -1
- ccxt/binanceusdm.py +3 -1
- ccxt/bingx.py +3205 -937
- ccxt/bit2c.py +119 -38
- ccxt/bitbank.py +215 -76
- ccxt/bitbns.py +124 -53
- ccxt/bitfinex.py +3235 -1078
- ccxt/bitfinex1.py +1710 -0
- ccxt/bitflyer.py +238 -49
- ccxt/bitget.py +1525 -573
- ccxt/bithumb.py +198 -65
- ccxt/bitmart.py +1320 -435
- ccxt/bitmex.py +308 -111
- ccxt/bitopro.py +256 -96
- ccxt/bitrue.py +365 -233
- ccxt/bitso.py +201 -89
- ccxt/bitstamp.py +438 -269
- ccxt/bitteam.py +179 -73
- ccxt/bitvavo.py +180 -70
- ccxt/bl3p.py +92 -25
- ccxt/blockchaincom.py +193 -79
- ccxt/blofin.py +392 -148
- ccxt/btcalpha.py +161 -55
- ccxt/btcbox.py +250 -34
- ccxt/btcmarkets.py +232 -85
- ccxt/btcturk.py +159 -60
- ccxt/bybit.py +2231 -1193
- ccxt/cex.py +1408 -1329
- ccxt/coinbase.py +1454 -287
- ccxt/coinbaseadvanced.py +17 -0
- ccxt/{coinbasepro.py → coinbaseexchange.py} +233 -99
- ccxt/coinbaseinternational.py +428 -88
- ccxt/coincatch.py +5152 -0
- ccxt/coincheck.py +121 -38
- ccxt/coinex.py +4020 -3339
- ccxt/coinlist.py +273 -116
- ccxt/coinmate.py +204 -97
- ccxt/coinmetro.py +203 -110
- ccxt/coinone.py +142 -68
- ccxt/coinsph.py +223 -97
- ccxt/coinspot.py +137 -62
- ccxt/cryptocom.py +515 -185
- ccxt/currencycom.py +203 -85
- ccxt/defx.py +2065 -0
- ccxt/delta.py +404 -109
- ccxt/deribit.py +639 -323
- ccxt/digifinex.py +465 -233
- ccxt/ellipx.py +1887 -0
- ccxt/exmo.py +317 -128
- ccxt/gate.py +1472 -463
- ccxt/gemini.py +206 -84
- ccxt/hashkey.py +4164 -0
- ccxt/hitbtc.py +433 -178
- ccxt/hollaex.py +207 -83
- ccxt/htx.py +1095 -563
- ccxt/huobijp.py +178 -56
- ccxt/hyperliquid.py +1677 -292
- ccxt/idex.py +219 -95
- ccxt/independentreserve.py +299 -31
- ccxt/indodax.py +226 -62
- ccxt/kraken.py +871 -354
- ccxt/krakenfutures.py +324 -100
- ccxt/kucoin.py +917 -357
- ccxt/kucoinfutures.py +1004 -149
- ccxt/kuna.py +198 -107
- ccxt/latoken.py +199 -79
- ccxt/lbank.py +360 -113
- ccxt/luno.py +185 -62
- ccxt/lykke.py +168 -55
- ccxt/mercado.py +101 -29
- ccxt/mexc.py +994 -429
- ccxt/myokx.py +53 -0
- ccxt/ndax.py +234 -82
- ccxt/novadax.py +195 -75
- ccxt/oceanex.py +244 -59
- ccxt/okcoin.py +301 -165
- ccxt/okx.py +1776 -454
- ccxt/onetrading.py +198 -414
- ccxt/oxfun.py +2897 -0
- ccxt/p2b.py +142 -52
- ccxt/paradex.py +2085 -0
- ccxt/paymium.py +56 -32
- ccxt/phemex.py +572 -196
- ccxt/poloniex.py +218 -95
- ccxt/poloniexfutures.py +260 -92
- ccxt/pro/__init__.py +29 -5
- ccxt/pro/alpaca.py +32 -17
- ccxt/pro/ascendex.py +62 -14
- ccxt/pro/bequant.py +4 -0
- ccxt/pro/binance.py +1596 -329
- ccxt/pro/binancecoinm.py +1 -0
- ccxt/pro/binanceus.py +2 -9
- ccxt/pro/binanceusdm.py +2 -0
- ccxt/pro/bingx.py +527 -134
- ccxt/pro/bitcoincom.py +4 -1
- ccxt/pro/bitfinex.py +731 -266
- ccxt/pro/bitfinex1.py +635 -0
- ccxt/pro/bitget.py +726 -357
- ccxt/pro/bithumb.py +380 -0
- ccxt/pro/bitmart.py +143 -39
- ccxt/pro/bitmex.py +199 -40
- ccxt/pro/bitopro.py +25 -13
- ccxt/pro/bitrue.py +31 -32
- ccxt/pro/bitstamp.py +7 -6
- ccxt/pro/bitvavo.py +203 -81
- ccxt/pro/blockchaincom.py +30 -17
- ccxt/pro/blofin.py +692 -0
- ccxt/pro/bybit.py +791 -82
- ccxt/pro/cex.py +99 -51
- ccxt/pro/coinbase.py +220 -30
- ccxt/{async_support/hitbtc3.py → pro/coinbaseadvanced.py} +5 -5
- ccxt/pro/{coinbasepro.py → coinbaseexchange.py} +19 -19
- ccxt/pro/coinbaseinternational.py +193 -30
- ccxt/pro/coincatch.py +1464 -0
- ccxt/pro/coincheck.py +11 -6
- ccxt/pro/coinex.py +965 -665
- ccxt/pro/coinone.py +17 -10
- ccxt/pro/cryptocom.py +446 -66
- ccxt/pro/currencycom.py +11 -10
- ccxt/pro/defx.py +832 -0
- ccxt/pro/deribit.py +167 -31
- ccxt/pro/exmo.py +252 -20
- ccxt/pro/gate.py +729 -64
- ccxt/pro/gemini.py +44 -26
- ccxt/pro/hashkey.py +802 -0
- ccxt/pro/hitbtc.py +208 -103
- ccxt/pro/hollaex.py +25 -9
- ccxt/pro/htx.py +83 -39
- ccxt/pro/huobijp.py +17 -16
- ccxt/pro/hyperliquid.py +502 -31
- ccxt/pro/idex.py +28 -13
- ccxt/pro/independentreserve.py +21 -16
- ccxt/pro/kraken.py +298 -51
- ccxt/pro/krakenfutures.py +166 -75
- ccxt/pro/kucoin.py +395 -77
- ccxt/pro/kucoinfutures.py +400 -99
- ccxt/pro/lbank.py +52 -31
- ccxt/pro/luno.py +12 -10
- ccxt/pro/mexc.py +400 -50
- ccxt/pro/myokx.py +28 -0
- ccxt/pro/ndax.py +25 -12
- ccxt/pro/okcoin.py +28 -9
- ccxt/pro/okx.py +935 -124
- ccxt/pro/onetrading.py +41 -24
- ccxt/pro/oxfun.py +1054 -0
- ccxt/pro/p2b.py +100 -24
- ccxt/pro/paradex.py +352 -0
- ccxt/pro/phemex.py +92 -33
- ccxt/pro/poloniex.py +128 -49
- ccxt/pro/poloniexfutures.py +53 -32
- ccxt/pro/probit.py +92 -85
- ccxt/pro/upbit.py +401 -8
- ccxt/pro/vertex.py +943 -0
- ccxt/pro/wazirx.py +46 -28
- ccxt/pro/whitebit.py +65 -12
- ccxt/pro/woo.py +437 -65
- ccxt/pro/woofipro.py +1271 -0
- ccxt/pro/xt.py +1067 -0
- ccxt/probit.py +143 -110
- ccxt/static_dependencies/__init__.py +1 -1
- ccxt/static_dependencies/lark/__init__.py +38 -0
- ccxt/static_dependencies/lark/__pyinstaller/__init__.py +6 -0
- ccxt/static_dependencies/lark/__pyinstaller/hook-lark.py +14 -0
- ccxt/static_dependencies/lark/ast_utils.py +59 -0
- ccxt/static_dependencies/lark/common.py +86 -0
- ccxt/static_dependencies/lark/exceptions.py +292 -0
- ccxt/static_dependencies/lark/grammar.py +130 -0
- ccxt/static_dependencies/lark/grammars/__init__.py +0 -0
- ccxt/static_dependencies/lark/indenter.py +143 -0
- ccxt/static_dependencies/lark/lark.py +658 -0
- ccxt/static_dependencies/lark/lexer.py +678 -0
- ccxt/static_dependencies/lark/load_grammar.py +1428 -0
- ccxt/static_dependencies/lark/parse_tree_builder.py +391 -0
- ccxt/static_dependencies/lark/parser_frontends.py +257 -0
- ccxt/static_dependencies/lark/parsers/__init__.py +0 -0
- ccxt/static_dependencies/lark/parsers/cyk.py +340 -0
- ccxt/static_dependencies/lark/parsers/earley.py +314 -0
- ccxt/static_dependencies/lark/parsers/earley_common.py +42 -0
- ccxt/static_dependencies/lark/parsers/earley_forest.py +801 -0
- ccxt/static_dependencies/lark/parsers/grammar_analysis.py +203 -0
- ccxt/static_dependencies/lark/parsers/lalr_analysis.py +332 -0
- ccxt/static_dependencies/lark/parsers/lalr_interactive_parser.py +158 -0
- ccxt/static_dependencies/lark/parsers/lalr_parser.py +122 -0
- ccxt/static_dependencies/lark/parsers/lalr_parser_state.py +110 -0
- ccxt/static_dependencies/lark/parsers/xearley.py +165 -0
- ccxt/static_dependencies/lark/py.typed +0 -0
- ccxt/static_dependencies/lark/reconstruct.py +107 -0
- ccxt/static_dependencies/lark/tools/__init__.py +70 -0
- ccxt/static_dependencies/lark/tools/nearley.py +202 -0
- ccxt/static_dependencies/lark/tools/serialize.py +32 -0
- ccxt/static_dependencies/lark/tools/standalone.py +196 -0
- ccxt/static_dependencies/lark/tree.py +267 -0
- ccxt/static_dependencies/lark/tree_matcher.py +186 -0
- ccxt/static_dependencies/lark/tree_templates.py +180 -0
- ccxt/static_dependencies/lark/utils.py +343 -0
- ccxt/static_dependencies/lark/visitors.py +596 -0
- ccxt/static_dependencies/marshmallow/__init__.py +81 -0
- ccxt/static_dependencies/marshmallow/base.py +65 -0
- ccxt/static_dependencies/marshmallow/class_registry.py +94 -0
- ccxt/static_dependencies/marshmallow/decorators.py +231 -0
- ccxt/static_dependencies/marshmallow/error_store.py +60 -0
- ccxt/static_dependencies/marshmallow/exceptions.py +71 -0
- ccxt/static_dependencies/marshmallow/fields.py +2114 -0
- ccxt/static_dependencies/marshmallow/orderedset.py +89 -0
- ccxt/static_dependencies/marshmallow/py.typed +0 -0
- ccxt/static_dependencies/marshmallow/schema.py +1228 -0
- ccxt/static_dependencies/marshmallow/types.py +12 -0
- ccxt/static_dependencies/marshmallow/utils.py +378 -0
- ccxt/static_dependencies/marshmallow/validate.py +678 -0
- ccxt/static_dependencies/marshmallow/warnings.py +2 -0
- ccxt/static_dependencies/marshmallow_dataclass/__init__.py +1047 -0
- ccxt/static_dependencies/marshmallow_dataclass/collection_field.py +51 -0
- ccxt/static_dependencies/marshmallow_dataclass/lazy_class_attribute.py +45 -0
- ccxt/static_dependencies/marshmallow_dataclass/mypy.py +71 -0
- ccxt/static_dependencies/marshmallow_dataclass/py.typed +0 -0
- ccxt/static_dependencies/marshmallow_dataclass/typing.py +14 -0
- ccxt/static_dependencies/marshmallow_dataclass/union_field.py +82 -0
- ccxt/static_dependencies/marshmallow_oneofschema/__init__.py +1 -0
- ccxt/static_dependencies/marshmallow_oneofschema/one_of_schema.py +193 -0
- ccxt/static_dependencies/marshmallow_oneofschema/py.typed +0 -0
- ccxt/static_dependencies/starknet/__init__.py +0 -0
- ccxt/static_dependencies/starknet/cairo/__init__.py +0 -0
- ccxt/static_dependencies/starknet/cairo/data_types.py +123 -0
- ccxt/static_dependencies/starknet/cairo/deprecated_parse/__init__.py +0 -0
- ccxt/static_dependencies/starknet/cairo/deprecated_parse/cairo_types.py +77 -0
- ccxt/static_dependencies/starknet/cairo/deprecated_parse/parser.py +46 -0
- ccxt/static_dependencies/starknet/cairo/deprecated_parse/parser_transformer.py +138 -0
- ccxt/static_dependencies/starknet/cairo/felt.py +64 -0
- ccxt/static_dependencies/starknet/cairo/type_parser.py +121 -0
- ccxt/static_dependencies/starknet/cairo/v1/__init__.py +0 -0
- ccxt/static_dependencies/starknet/cairo/v1/type_parser.py +59 -0
- ccxt/static_dependencies/starknet/cairo/v2/__init__.py +0 -0
- ccxt/static_dependencies/starknet/cairo/v2/type_parser.py +77 -0
- ccxt/static_dependencies/starknet/ccxt_utils.py +7 -0
- ccxt/static_dependencies/starknet/common.py +15 -0
- ccxt/static_dependencies/starknet/constants.py +39 -0
- ccxt/static_dependencies/starknet/hash/__init__.py +0 -0
- ccxt/static_dependencies/starknet/hash/address.py +79 -0
- ccxt/static_dependencies/starknet/hash/compiled_class_hash_objects.py +111 -0
- ccxt/static_dependencies/starknet/hash/selector.py +16 -0
- ccxt/static_dependencies/starknet/hash/storage.py +12 -0
- ccxt/static_dependencies/starknet/hash/utils.py +78 -0
- ccxt/static_dependencies/starknet/models/__init__.py +0 -0
- ccxt/static_dependencies/starknet/models/typed_data.py +45 -0
- ccxt/static_dependencies/starknet/serialization/__init__.py +24 -0
- ccxt/static_dependencies/starknet/serialization/_calldata_reader.py +40 -0
- ccxt/static_dependencies/starknet/serialization/_context.py +142 -0
- ccxt/static_dependencies/starknet/serialization/data_serializers/__init__.py +10 -0
- ccxt/static_dependencies/starknet/serialization/data_serializers/_common.py +82 -0
- ccxt/static_dependencies/starknet/serialization/data_serializers/array_serializer.py +43 -0
- ccxt/static_dependencies/starknet/serialization/data_serializers/bool_serializer.py +37 -0
- ccxt/static_dependencies/starknet/serialization/data_serializers/byte_array_serializer.py +66 -0
- ccxt/static_dependencies/starknet/serialization/data_serializers/cairo_data_serializer.py +71 -0
- ccxt/static_dependencies/starknet/serialization/data_serializers/enum_serializer.py +71 -0
- ccxt/static_dependencies/starknet/serialization/data_serializers/felt_serializer.py +50 -0
- ccxt/static_dependencies/starknet/serialization/data_serializers/named_tuple_serializer.py +58 -0
- ccxt/static_dependencies/starknet/serialization/data_serializers/option_serializer.py +43 -0
- ccxt/static_dependencies/starknet/serialization/data_serializers/output_serializer.py +40 -0
- ccxt/static_dependencies/starknet/serialization/data_serializers/payload_serializer.py +72 -0
- ccxt/static_dependencies/starknet/serialization/data_serializers/struct_serializer.py +36 -0
- ccxt/static_dependencies/starknet/serialization/data_serializers/tuple_serializer.py +36 -0
- ccxt/static_dependencies/starknet/serialization/data_serializers/uint256_serializer.py +76 -0
- ccxt/static_dependencies/starknet/serialization/data_serializers/uint_serializer.py +100 -0
- ccxt/static_dependencies/starknet/serialization/data_serializers/unit_serializer.py +32 -0
- ccxt/static_dependencies/starknet/serialization/errors.py +10 -0
- ccxt/static_dependencies/starknet/serialization/factory.py +229 -0
- ccxt/static_dependencies/starknet/serialization/function_serialization_adapter.py +110 -0
- ccxt/static_dependencies/starknet/serialization/tuple_dataclass.py +59 -0
- ccxt/static_dependencies/starknet/utils/__init__.py +0 -0
- ccxt/static_dependencies/starknet/utils/constructor_args_translator.py +86 -0
- ccxt/static_dependencies/starknet/utils/iterable.py +13 -0
- ccxt/static_dependencies/starknet/utils/schema.py +13 -0
- ccxt/static_dependencies/starknet/utils/typed_data.py +182 -0
- ccxt/static_dependencies/starkware/__init__.py +0 -0
- ccxt/static_dependencies/starkware/crypto/__init__.py +0 -0
- ccxt/static_dependencies/starkware/crypto/fast_pedersen_hash.py +50 -0
- ccxt/static_dependencies/starkware/crypto/math_utils.py +78 -0
- ccxt/static_dependencies/starkware/crypto/signature.py +2344 -0
- ccxt/static_dependencies/starkware/crypto/utils.py +63 -0
- ccxt/static_dependencies/sympy/__init__.py +0 -0
- ccxt/static_dependencies/sympy/core/__init__.py +0 -0
- ccxt/static_dependencies/sympy/core/intfunc.py +35 -0
- ccxt/static_dependencies/sympy/external/__init__.py +0 -0
- ccxt/static_dependencies/sympy/external/gmpy.py +345 -0
- ccxt/static_dependencies/sympy/external/importtools.py +187 -0
- ccxt/static_dependencies/sympy/external/ntheory.py +637 -0
- ccxt/static_dependencies/sympy/external/pythonmpq.py +341 -0
- ccxt/static_dependencies/typing_inspect/__init__.py +0 -0
- ccxt/static_dependencies/typing_inspect/typing_inspect.py +851 -0
- ccxt/test/{test_async.py → tests_async.py} +456 -391
- ccxt/test/tests_helpers.py +285 -0
- ccxt/test/tests_init.py +39 -0
- ccxt/test/{test_sync.py → tests_sync.py} +456 -393
- ccxt/timex.py +123 -70
- ccxt/tokocrypto.py +129 -93
- ccxt/tradeogre.py +39 -25
- ccxt/upbit.py +322 -113
- ccxt/vertex.py +2983 -0
- ccxt/wavesexchange.py +227 -173
- ccxt/wazirx.py +145 -65
- ccxt/whitebit.py +533 -138
- ccxt/woo.py +1137 -296
- ccxt/woofipro.py +2716 -0
- ccxt/xt.py +4627 -0
- ccxt/yobit.py +159 -92
- ccxt/zaif.py +80 -33
- ccxt/zonda.py +140 -69
- ccxt-4.4.49.dist-info/LICENSE.txt +21 -0
- ccxt-4.4.49.dist-info/METADATA +646 -0
- ccxt-4.4.49.dist-info/RECORD +669 -0
- {ccxt-4.2.77.dist-info → ccxt-4.4.49.dist-info}/WHEEL +1 -1
- ccxt/abstract/bitbay.py +0 -47
- ccxt/abstract/bitfinex2.py +0 -139
- ccxt/abstract/hitbtc3.py +0 -115
- ccxt/async_support/bitbay.py +0 -17
- ccxt/async_support/bitfinex2.py +0 -3496
- ccxt/async_support/flowbtc.py +0 -34
- ccxt/bitbay.py +0 -17
- ccxt/bitfinex2.py +0 -3496
- ccxt/flowbtc.py +0 -34
- ccxt/hitbtc3.py +0 -16
- ccxt/pro/bitfinex2.py +0 -1081
- ccxt/test/base/__init__.py +0 -28
- ccxt/test/base/test_account.py +0 -26
- ccxt/test/base/test_balance.py +0 -56
- ccxt/test/base/test_borrow_interest.py +0 -35
- ccxt/test/base/test_borrow_rate.py +0 -32
- ccxt/test/base/test_calculate_fee.py +0 -51
- ccxt/test/base/test_crypto.py +0 -127
- ccxt/test/base/test_currency.py +0 -76
- ccxt/test/base/test_datetime.py +0 -103
- ccxt/test/base/test_decimal_to_precision.py +0 -392
- ccxt/test/base/test_deep_extend.py +0 -68
- ccxt/test/base/test_deposit_withdrawal.py +0 -50
- ccxt/test/base/test_exchange_datetime_functions.py +0 -76
- ccxt/test/base/test_funding_rate_history.py +0 -29
- ccxt/test/base/test_last_price.py +0 -32
- ccxt/test/base/test_ledger_entry.py +0 -45
- ccxt/test/base/test_ledger_item.py +0 -48
- ccxt/test/base/test_leverage_tier.py +0 -33
- ccxt/test/base/test_margin_mode.py +0 -24
- ccxt/test/base/test_margin_modification.py +0 -35
- ccxt/test/base/test_market.py +0 -190
- ccxt/test/base/test_number.py +0 -411
- ccxt/test/base/test_ohlcv.py +0 -32
- ccxt/test/base/test_open_interest.py +0 -32
- ccxt/test/base/test_order.py +0 -64
- ccxt/test/base/test_order_book.py +0 -63
- ccxt/test/base/test_position.py +0 -60
- ccxt/test/base/test_shared_methods.py +0 -345
- ccxt/test/base/test_status.py +0 -24
- ccxt/test/base/test_throttle.py +0 -126
- ccxt/test/base/test_ticker.py +0 -86
- ccxt/test/base/test_trade.py +0 -47
- ccxt/test/base/test_trading_fee.py +0 -26
- ccxt/test/base/test_transaction.py +0 -39
- ccxt-4.2.77.dist-info/METADATA +0 -626
- ccxt-4.2.77.dist-info/RECORD +0 -534
- {ccxt-4.2.77.dist-info → ccxt-4.4.49.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,46 @@
|
|
1
|
+
from ....lark import Lark
|
2
|
+
|
3
|
+
from .cairo_types import CairoType
|
4
|
+
from .parser_transformer import ParserTransformer
|
5
|
+
|
6
|
+
CAIRO_EBNF = """
|
7
|
+
%import common.WS_INLINE
|
8
|
+
%ignore WS_INLINE
|
9
|
+
|
10
|
+
IDENTIFIER: /[a-zA-Z_][a-zA-Z_0-9]*/
|
11
|
+
_DBL_STAR: "**"
|
12
|
+
COMMA: ","
|
13
|
+
|
14
|
+
?type: non_identifier_type
|
15
|
+
| identifier -> type_struct
|
16
|
+
|
17
|
+
comma_separated{item}: item? (COMMA item)* COMMA?
|
18
|
+
|
19
|
+
named_type: identifier (":" type)? | non_identifier_type
|
20
|
+
non_identifier_type: "felt" -> type_felt
|
21
|
+
| "codeoffset" -> type_codeoffset
|
22
|
+
| type "*" -> type_pointer
|
23
|
+
| type _DBL_STAR -> type_pointer2
|
24
|
+
| "(" comma_separated{named_type} ")" -> type_tuple
|
25
|
+
|
26
|
+
identifier: IDENTIFIER ("." IDENTIFIER)*
|
27
|
+
"""
|
28
|
+
|
29
|
+
|
30
|
+
def parse(code: str) -> CairoType:
|
31
|
+
"""
|
32
|
+
Parses the given string and returns a CairoType.
|
33
|
+
"""
|
34
|
+
|
35
|
+
grammar = CAIRO_EBNF
|
36
|
+
|
37
|
+
grammar_parser = Lark(
|
38
|
+
grammar=grammar,
|
39
|
+
start=["type"],
|
40
|
+
parser="lalr",
|
41
|
+
)
|
42
|
+
|
43
|
+
parsed = grammar_parser.parse(code)
|
44
|
+
transformed = ParserTransformer().transform(parsed)
|
45
|
+
|
46
|
+
return transformed
|
@@ -0,0 +1,138 @@
|
|
1
|
+
import dataclasses
|
2
|
+
from typing import Optional, Tuple
|
3
|
+
|
4
|
+
from ....lark import Token, Transformer, v_args
|
5
|
+
|
6
|
+
from .cairo_types import (
|
7
|
+
CairoType,
|
8
|
+
ExprIdentifier,
|
9
|
+
TypeCodeoffset,
|
10
|
+
TypeFelt,
|
11
|
+
TypeIdentifier,
|
12
|
+
TypePointer,
|
13
|
+
TypeStruct,
|
14
|
+
TypeTuple,
|
15
|
+
)
|
16
|
+
|
17
|
+
|
18
|
+
@dataclasses.dataclass
|
19
|
+
class ParserContext:
|
20
|
+
"""
|
21
|
+
Represents information that affects the parsing process.
|
22
|
+
"""
|
23
|
+
|
24
|
+
# If True, treat type identifiers as resolved.
|
25
|
+
resolved_types: bool = False
|
26
|
+
|
27
|
+
|
28
|
+
class ParserError(Exception):
|
29
|
+
"""
|
30
|
+
Base exception for parsing process.
|
31
|
+
"""
|
32
|
+
|
33
|
+
|
34
|
+
@dataclasses.dataclass
|
35
|
+
class CommaSeparated:
|
36
|
+
"""
|
37
|
+
Represents a list of comma separated values, such as expressions or types.
|
38
|
+
"""
|
39
|
+
|
40
|
+
args: list
|
41
|
+
has_trailing_comma: bool
|
42
|
+
|
43
|
+
|
44
|
+
class ParserTransformer(Transformer):
|
45
|
+
"""
|
46
|
+
Transforms the lark tree into an AST based on the classes defined in cairo_types.py.
|
47
|
+
"""
|
48
|
+
|
49
|
+
# pylint: disable=unused-argument, no-self-use
|
50
|
+
|
51
|
+
def __init__(self):
|
52
|
+
super().__init__()
|
53
|
+
self.parser_context = ParserContext()
|
54
|
+
|
55
|
+
def __default__(self, data: str, children, meta):
|
56
|
+
raise TypeError(f"Unable to parse tree node of type {data}")
|
57
|
+
|
58
|
+
def comma_separated(self, value) -> CommaSeparated:
|
59
|
+
saw_comma = None
|
60
|
+
args: list = []
|
61
|
+
for v in value:
|
62
|
+
if isinstance(v, Token) and v.type == "COMMA":
|
63
|
+
if saw_comma is not False:
|
64
|
+
raise ParserError("Unexpected comma.")
|
65
|
+
saw_comma = True
|
66
|
+
else:
|
67
|
+
if saw_comma is False:
|
68
|
+
raise ParserError("Expected a comma before this expression.")
|
69
|
+
args.append(v)
|
70
|
+
|
71
|
+
# Reset state.
|
72
|
+
saw_comma = False
|
73
|
+
|
74
|
+
if saw_comma is None:
|
75
|
+
saw_comma = False
|
76
|
+
|
77
|
+
return CommaSeparated(args=args, has_trailing_comma=saw_comma)
|
78
|
+
|
79
|
+
# Types.
|
80
|
+
|
81
|
+
@v_args(meta=True)
|
82
|
+
def named_type(self, meta, value) -> TypeTuple.Item:
|
83
|
+
name: Optional[str]
|
84
|
+
if len(value) == 1:
|
85
|
+
# Unnamed type.
|
86
|
+
(typ,) = value
|
87
|
+
name = None
|
88
|
+
if isinstance(typ, ExprIdentifier):
|
89
|
+
typ = self.type_struct([typ])
|
90
|
+
elif len(value) == 2:
|
91
|
+
# Named type.
|
92
|
+
identifier, typ = value
|
93
|
+
assert isinstance(identifier, ExprIdentifier)
|
94
|
+
assert isinstance(typ, CairoType)
|
95
|
+
if "." in identifier.name:
|
96
|
+
raise ParserError("Unexpected . in name.")
|
97
|
+
name = identifier.name
|
98
|
+
else:
|
99
|
+
raise NotImplementedError(f"Unexpected number of values. {value}")
|
100
|
+
|
101
|
+
return TypeTuple.Item(name=name, typ=typ)
|
102
|
+
|
103
|
+
@v_args(meta=True)
|
104
|
+
def type_felt(self, meta, value):
|
105
|
+
return TypeFelt()
|
106
|
+
|
107
|
+
@v_args(meta=True)
|
108
|
+
def type_codeoffset(self, meta, value):
|
109
|
+
return TypeCodeoffset()
|
110
|
+
|
111
|
+
def type_struct(self, value):
|
112
|
+
assert len(value) == 1 and isinstance(value[0], ExprIdentifier)
|
113
|
+
if self.parser_context.resolved_types:
|
114
|
+
# If parser_context.resolved_types is True, assume that the type is a struct.
|
115
|
+
return TypeStruct(scope=value[0].name)
|
116
|
+
|
117
|
+
return TypeIdentifier(name=value[0].name)
|
118
|
+
|
119
|
+
@v_args(meta=True)
|
120
|
+
def type_pointer(self, meta, value):
|
121
|
+
return TypePointer(pointee=value[0])
|
122
|
+
|
123
|
+
@v_args(meta=True)
|
124
|
+
def type_pointer2(self, meta, value):
|
125
|
+
return TypePointer(pointee=TypePointer(pointee=value[0]))
|
126
|
+
|
127
|
+
@v_args(meta=True)
|
128
|
+
def type_tuple(self, meta, value: Tuple[CommaSeparated]):
|
129
|
+
(lst,) = value
|
130
|
+
return TypeTuple(members=lst.args, has_trailing_comma=lst.has_trailing_comma)
|
131
|
+
|
132
|
+
@v_args(meta=True)
|
133
|
+
def identifier(self, meta, value):
|
134
|
+
return ExprIdentifier(name=".".join(x.value for x in value))
|
135
|
+
|
136
|
+
@v_args(meta=True)
|
137
|
+
def identifier_def(self, meta, value):
|
138
|
+
return ExprIdentifier(name=value[0].value)
|
@@ -0,0 +1,64 @@
|
|
1
|
+
from typing import List
|
2
|
+
|
3
|
+
from ..constants import FIELD_PRIME
|
4
|
+
|
5
|
+
CairoData = List[int]
|
6
|
+
|
7
|
+
|
8
|
+
MAX_UINT256 = (1 << 256) - 1
|
9
|
+
MIN_UINT256 = 0
|
10
|
+
|
11
|
+
|
12
|
+
def uint256_range_check(value: int):
|
13
|
+
if not MIN_UINT256 <= value <= MAX_UINT256:
|
14
|
+
raise ValueError(
|
15
|
+
f"Uint256 is expected to be in range [0;2**256), got: {value}."
|
16
|
+
)
|
17
|
+
|
18
|
+
|
19
|
+
MIN_FELT = -FIELD_PRIME // 2
|
20
|
+
MAX_FELT = FIELD_PRIME // 2
|
21
|
+
|
22
|
+
|
23
|
+
def is_in_felt_range(value: int) -> bool:
|
24
|
+
return 0 <= value < FIELD_PRIME
|
25
|
+
|
26
|
+
|
27
|
+
def cairo_vm_range_check(value: int):
|
28
|
+
if not is_in_felt_range(value):
|
29
|
+
raise ValueError(
|
30
|
+
f"Felt is expected to be in range [0; {FIELD_PRIME}), got: {value}."
|
31
|
+
)
|
32
|
+
|
33
|
+
|
34
|
+
def encode_shortstring(text: str) -> int:
|
35
|
+
"""
|
36
|
+
A function which encodes short string value (at most 31 characters) into cairo felt (MSB as first character)
|
37
|
+
|
38
|
+
:param text: A short string value in python
|
39
|
+
:return: Short string value encoded into felt
|
40
|
+
"""
|
41
|
+
if len(text) > 31:
|
42
|
+
raise ValueError(
|
43
|
+
f"Shortstring cannot be longer than 31 characters, got: {len(text)}."
|
44
|
+
)
|
45
|
+
|
46
|
+
try:
|
47
|
+
text_bytes = text.encode("ascii")
|
48
|
+
except UnicodeEncodeError as u_err:
|
49
|
+
raise ValueError(f"Expected an ascii string. Found: {repr(text)}.") from u_err
|
50
|
+
value = int.from_bytes(text_bytes, "big")
|
51
|
+
|
52
|
+
cairo_vm_range_check(value)
|
53
|
+
return value
|
54
|
+
|
55
|
+
|
56
|
+
def decode_shortstring(value: int) -> str:
|
57
|
+
"""
|
58
|
+
A function which decodes a felt value to short string (at most 31 characters)
|
59
|
+
|
60
|
+
:param value: A felt value
|
61
|
+
:return: Decoded string which is corresponds to that felt
|
62
|
+
"""
|
63
|
+
cairo_vm_range_check(value)
|
64
|
+
return "".join([chr(i) for i in value.to_bytes(31, byteorder="big")]).lstrip("\x00")
|
@@ -0,0 +1,121 @@
|
|
1
|
+
from __future__ import annotations
|
2
|
+
|
3
|
+
from collections import OrderedDict
|
4
|
+
from typing import Dict, cast
|
5
|
+
|
6
|
+
from .deprecated_parse import cairo_types as cairo_lang_types
|
7
|
+
from .data_types import (
|
8
|
+
ArrayType,
|
9
|
+
CairoType,
|
10
|
+
FeltType,
|
11
|
+
NamedTupleType,
|
12
|
+
StructType,
|
13
|
+
TupleType,
|
14
|
+
)
|
15
|
+
from .deprecated_parse.parser import parse
|
16
|
+
|
17
|
+
|
18
|
+
class UnknownCairoTypeError(ValueError):
|
19
|
+
"""
|
20
|
+
Error thrown when TypeParser finds type that was not declared prior to parsing.
|
21
|
+
"""
|
22
|
+
|
23
|
+
type_name: str
|
24
|
+
|
25
|
+
def __init__(self, type_name: str):
|
26
|
+
super().__init__(f"Type '{type_name}' is not defined")
|
27
|
+
self.type_name = type_name
|
28
|
+
|
29
|
+
|
30
|
+
class TypeParser:
|
31
|
+
"""
|
32
|
+
Low level utility class for parsing Cairo types that can be used in external methods.
|
33
|
+
"""
|
34
|
+
|
35
|
+
defined_types: Dict[str, StructType]
|
36
|
+
|
37
|
+
def __init__(self, defined_types: Dict[str, StructType]):
|
38
|
+
"""
|
39
|
+
TypeParser constructor.
|
40
|
+
|
41
|
+
:param defined_types: dictionary containing all defined types. For now, they can only be structures.
|
42
|
+
"""
|
43
|
+
self.defined_types = defined_types
|
44
|
+
for name, struct in defined_types.items():
|
45
|
+
if name != struct.name:
|
46
|
+
raise ValueError(
|
47
|
+
f"Keys must match name of type, '{name}' != '{struct.name}'."
|
48
|
+
)
|
49
|
+
|
50
|
+
def parse_inline_type(self, type_string: str) -> CairoType:
|
51
|
+
"""
|
52
|
+
Inline type is one that can be used inline, for instance as return type. For instance
|
53
|
+
(a: Uint256, b: felt*, c: (felt, felt)). Structure can only be referenced in inline type, can't be defined
|
54
|
+
this way.
|
55
|
+
|
56
|
+
:param type_string: type to parse.
|
57
|
+
"""
|
58
|
+
parsed = parse(type_string)
|
59
|
+
return self._transform_cairo_lang_type(parsed)
|
60
|
+
|
61
|
+
def _transform_cairo_lang_type(
|
62
|
+
self, cairo_type: cairo_lang_types.CairoType
|
63
|
+
) -> CairoType:
|
64
|
+
"""
|
65
|
+
For now, we use parse function from cairo-lang package. It will be replaced in the future, but we need to hide
|
66
|
+
it from the users.
|
67
|
+
This function takes types returned by cairo-lang package and maps them to our type classes.
|
68
|
+
|
69
|
+
:param cairo_type: type returned from parse_type function.
|
70
|
+
:return: CairoType defined by our package.
|
71
|
+
"""
|
72
|
+
if isinstance(cairo_type, cairo_lang_types.TypeFelt):
|
73
|
+
return FeltType()
|
74
|
+
|
75
|
+
if isinstance(cairo_type, cairo_lang_types.TypePointer):
|
76
|
+
return ArrayType(self._transform_cairo_lang_type(cairo_type.pointee))
|
77
|
+
|
78
|
+
if isinstance(cairo_type, cairo_lang_types.TypeIdentifier):
|
79
|
+
return self._get_struct(str(cairo_type.name))
|
80
|
+
|
81
|
+
if isinstance(cairo_type, cairo_lang_types.TypeTuple):
|
82
|
+
# Cairo returns is_named when there are no members
|
83
|
+
if cairo_type.is_named and len(cairo_type.members) != 0:
|
84
|
+
assert all(member.name is not None for member in cairo_type.members)
|
85
|
+
|
86
|
+
return NamedTupleType(
|
87
|
+
OrderedDict(
|
88
|
+
(
|
89
|
+
cast(
|
90
|
+
str, member.name
|
91
|
+
), # without that pyright is complaining
|
92
|
+
self._transform_cairo_lang_type(member.typ),
|
93
|
+
)
|
94
|
+
for member in cairo_type.members
|
95
|
+
)
|
96
|
+
)
|
97
|
+
|
98
|
+
return TupleType(
|
99
|
+
[
|
100
|
+
self._transform_cairo_lang_type(member.typ)
|
101
|
+
for member in cairo_type.members
|
102
|
+
]
|
103
|
+
)
|
104
|
+
|
105
|
+
# Contracts don't support codeoffset as input/output type, user can only use it if it was defined in types
|
106
|
+
if isinstance(cairo_type, cairo_lang_types.TypeCodeoffset):
|
107
|
+
return self._get_struct("codeoffset")
|
108
|
+
|
109
|
+
# Other options are: TypeFunction, TypeStruct
|
110
|
+
# Neither of them are possible. In particular TypeStruct is not possible because we parse structs without
|
111
|
+
# info about other structs, so they will be just TypeIdentifier (structure that was not parsed).
|
112
|
+
|
113
|
+
# This is an error of our logic, so we throw a RuntimeError.
|
114
|
+
raise RuntimeError(
|
115
|
+
f"Received unknown type '{cairo_type}' from parser."
|
116
|
+
) # pragma: no cover
|
117
|
+
|
118
|
+
def _get_struct(self, name: str):
|
119
|
+
if name not in self.defined_types:
|
120
|
+
raise UnknownCairoTypeError(name)
|
121
|
+
return self.defined_types[name]
|
File without changes
|
@@ -0,0 +1,59 @@
|
|
1
|
+
from __future__ import annotations
|
2
|
+
|
3
|
+
from typing import Dict, Union
|
4
|
+
|
5
|
+
from ...abi.v1.parser_transformer import parse
|
6
|
+
from ..data_types import CairoType, EnumType, StructType, TypeIdentifier
|
7
|
+
|
8
|
+
|
9
|
+
class UnknownCairoTypeError(ValueError):
|
10
|
+
"""
|
11
|
+
Error thrown when TypeParser finds type that was not declared prior to parsing.
|
12
|
+
"""
|
13
|
+
|
14
|
+
type_name: str
|
15
|
+
|
16
|
+
def __init__(self, type_name: str):
|
17
|
+
super().__init__(
|
18
|
+
# pylint: disable=line-too-long
|
19
|
+
f"Type '{type_name}' is not defined. Please report this issue at https://github.com/software-mansion/starknet.py/issues"
|
20
|
+
)
|
21
|
+
self.type_name = type_name
|
22
|
+
|
23
|
+
|
24
|
+
class TypeParser:
|
25
|
+
"""
|
26
|
+
Low level utility class for parsing Cairo types that can be used in external methods.
|
27
|
+
"""
|
28
|
+
|
29
|
+
defined_types: Dict[str, Union[StructType, EnumType]]
|
30
|
+
|
31
|
+
def __init__(self, defined_types: Dict[str, Union[StructType, EnumType]]):
|
32
|
+
"""
|
33
|
+
TypeParser constructor.
|
34
|
+
|
35
|
+
:param defined_types: dictionary containing all defined types. For now, they can only be structures.
|
36
|
+
"""
|
37
|
+
self.defined_types = defined_types
|
38
|
+
for name, defined_type in defined_types.items():
|
39
|
+
if name != defined_type.name:
|
40
|
+
raise ValueError(
|
41
|
+
f"Keys must match name of type, '{name}' != '{defined_type.name}'."
|
42
|
+
)
|
43
|
+
|
44
|
+
def parse_inline_type(self, type_string: str) -> CairoType:
|
45
|
+
"""
|
46
|
+
Inline type is one that can be used inline, for instance as return type. For instance
|
47
|
+
(core::felt252, (), (core::felt252,)). Structure can only be referenced in inline type, can't be defined
|
48
|
+
this way.
|
49
|
+
|
50
|
+
:param type_string: type to parse.
|
51
|
+
"""
|
52
|
+
parsed = parse(type_string, self.defined_types)
|
53
|
+
if isinstance(parsed, TypeIdentifier):
|
54
|
+
for defined_name in self.defined_types.keys():
|
55
|
+
if parsed.name == defined_name.split("<")[0].strip(":"):
|
56
|
+
return self.defined_types[defined_name]
|
57
|
+
raise UnknownCairoTypeError(parsed.name)
|
58
|
+
|
59
|
+
return parsed
|
File without changes
|
@@ -0,0 +1,77 @@
|
|
1
|
+
from __future__ import annotations
|
2
|
+
|
3
|
+
from typing import Dict, Union
|
4
|
+
|
5
|
+
from ...abi.v2.parser_transformer import parse
|
6
|
+
from ..data_types import (
|
7
|
+
CairoType,
|
8
|
+
EnumType,
|
9
|
+
EventType,
|
10
|
+
StructType,
|
11
|
+
TypeIdentifier,
|
12
|
+
)
|
13
|
+
|
14
|
+
|
15
|
+
class UnknownCairoTypeError(ValueError):
|
16
|
+
"""
|
17
|
+
Error thrown when TypeParser finds type that was not declared prior to parsing.
|
18
|
+
"""
|
19
|
+
|
20
|
+
type_name: str
|
21
|
+
|
22
|
+
def __init__(self, type_name: str):
|
23
|
+
super().__init__(
|
24
|
+
# pylint: disable=line-too-long
|
25
|
+
f"Type '{type_name}' is not defined. Please report this issue at https://github.com/software-mansion/starknet.py/issues"
|
26
|
+
)
|
27
|
+
self.type_name = type_name
|
28
|
+
|
29
|
+
|
30
|
+
class TypeParser:
|
31
|
+
"""
|
32
|
+
Low level utility class for parsing Cairo types that can be used in external methods.
|
33
|
+
"""
|
34
|
+
|
35
|
+
defined_types: Dict[str, Union[StructType, EnumType, EventType]]
|
36
|
+
|
37
|
+
def __init__(
|
38
|
+
self, defined_types: Dict[str, Union[StructType, EnumType, EventType]]
|
39
|
+
):
|
40
|
+
"""
|
41
|
+
TypeParser constructor.
|
42
|
+
|
43
|
+
:param defined_types: dictionary containing all defined types. For now, they can only be structures.
|
44
|
+
"""
|
45
|
+
self.defined_types = defined_types
|
46
|
+
for name, defined_type in defined_types.items():
|
47
|
+
if name != defined_type.name:
|
48
|
+
raise ValueError(
|
49
|
+
f"Keys must match name of type, '{name}' != '{defined_type.name}'."
|
50
|
+
)
|
51
|
+
|
52
|
+
def update_defined_types(
|
53
|
+
self, defined_types: Dict[str, Union[StructType, EnumType, EventType]]
|
54
|
+
) -> None:
|
55
|
+
self.defined_types.update(defined_types)
|
56
|
+
|
57
|
+
def add_defined_type(
|
58
|
+
self, defined_type: Union[StructType, EnumType, EventType]
|
59
|
+
) -> None:
|
60
|
+
self.defined_types.update({defined_type.name: defined_type})
|
61
|
+
|
62
|
+
def parse_inline_type(self, type_string: str) -> CairoType:
|
63
|
+
"""
|
64
|
+
Inline type is one that can be used inline, for instance as return type. For instance
|
65
|
+
(core::felt252, (), (core::felt252,)). Structure can only be referenced in inline type, can't be defined
|
66
|
+
this way.
|
67
|
+
|
68
|
+
:param type_string: type to parse.
|
69
|
+
"""
|
70
|
+
parsed = parse(type_string, self.defined_types)
|
71
|
+
if isinstance(parsed, TypeIdentifier):
|
72
|
+
for defined_name in self.defined_types.keys():
|
73
|
+
if parsed.name == defined_name.split("<")[0].strip(":"):
|
74
|
+
return self.defined_types[defined_name]
|
75
|
+
raise UnknownCairoTypeError(parsed.name)
|
76
|
+
|
77
|
+
return parsed
|
@@ -0,0 +1,7 @@
|
|
1
|
+
# utils to use starknet library in ccxt
|
2
|
+
from .constants import EC_ORDER
|
3
|
+
from ..starkware.crypto.signature import grind_key
|
4
|
+
|
5
|
+
def get_private_key_from_eth_signature(eth_signature_hex: str) -> int:
|
6
|
+
r = eth_signature_hex[2 : 64 + 2] if eth_signature_hex[0:2] == '0x' else eth_signature_hex[0 : 64]
|
7
|
+
return grind_key(int(r, 16), EC_ORDER)
|
@@ -0,0 +1,15 @@
|
|
1
|
+
from typing import Literal, Union
|
2
|
+
|
3
|
+
def int_from_hex(number: Union[str, int]) -> int:
|
4
|
+
return number if isinstance(number, int) else int(number, 16)
|
5
|
+
|
6
|
+
|
7
|
+
def int_from_bytes(
|
8
|
+
value: bytes,
|
9
|
+
byte_order: Literal["big", "little"] = "big",
|
10
|
+
signed: bool = False,
|
11
|
+
) -> int:
|
12
|
+
"""
|
13
|
+
Converts the given bytes object (parsed according to the given byte order) to an integer.
|
14
|
+
"""
|
15
|
+
return int.from_bytes(value, byteorder=byte_order, signed=signed)
|
@@ -0,0 +1,39 @@
|
|
1
|
+
from pathlib import Path
|
2
|
+
|
3
|
+
# Address came from starkware-libs/starknet-addresses repository: https://github.com/starkware-libs/starknet-addresses
|
4
|
+
FEE_CONTRACT_ADDRESS = (
|
5
|
+
"0x049d36570d4e46f48e99674bd3fcc84644ddd6b96f7c741b1562b82f9e004dc7"
|
6
|
+
)
|
7
|
+
|
8
|
+
DEFAULT_DEPLOYER_ADDRESS = (
|
9
|
+
"0x041a78e741e5aF2fEc34B695679bC6891742439f7AFB8484Ecd7766661aD02BF"
|
10
|
+
)
|
11
|
+
|
12
|
+
API_VERSION = 0
|
13
|
+
|
14
|
+
RPC_CONTRACT_NOT_FOUND_ERROR = 20
|
15
|
+
RPC_INVALID_MESSAGE_SELECTOR_ERROR = 21
|
16
|
+
RPC_CLASS_HASH_NOT_FOUND_ERROR = 28
|
17
|
+
RPC_CONTRACT_ERROR = 40
|
18
|
+
|
19
|
+
DEFAULT_ENTRY_POINT_NAME = "__default__"
|
20
|
+
DEFAULT_L1_ENTRY_POINT_NAME = "__l1_default__"
|
21
|
+
DEFAULT_ENTRY_POINT_SELECTOR = 0
|
22
|
+
DEFAULT_DECLARE_SENDER_ADDRESS = 1
|
23
|
+
|
24
|
+
# MAX_STORAGE_ITEM_SIZE and ADDR_BOUND must be consistent with the corresponding constant in
|
25
|
+
# starkware/starknet/common/storage.cairo.
|
26
|
+
MAX_STORAGE_ITEM_SIZE = 256
|
27
|
+
ADDR_BOUND = 2**251 - MAX_STORAGE_ITEM_SIZE
|
28
|
+
|
29
|
+
FIELD_PRIME = 0x800000000000011000000000000000000000000000000000000000000000001
|
30
|
+
EC_ORDER = 0x800000000000010FFFFFFFFFFFFFFFFB781126DCAE7B2321E66A241ADC64D2F
|
31
|
+
|
32
|
+
# From cairo-lang
|
33
|
+
# int_from_bytes(b"STARKNET_CONTRACT_ADDRESS")
|
34
|
+
CONTRACT_ADDRESS_PREFIX = 523065374597054866729014270389667305596563390979550329787219
|
35
|
+
L2_ADDRESS_UPPER_BOUND = 2**251 - 256
|
36
|
+
|
37
|
+
QUERY_VERSION_BASE = 2**128
|
38
|
+
|
39
|
+
ROOT_PATH = Path(__file__).parent
|
File without changes
|
@@ -0,0 +1,79 @@
|
|
1
|
+
from typing import Sequence
|
2
|
+
|
3
|
+
from ..constants import CONTRACT_ADDRESS_PREFIX, L2_ADDRESS_UPPER_BOUND
|
4
|
+
from .utils import (
|
5
|
+
HEX_PREFIX,
|
6
|
+
_starknet_keccak,
|
7
|
+
compute_hash_on_elements,
|
8
|
+
encode_uint,
|
9
|
+
get_bytes_length,
|
10
|
+
)
|
11
|
+
|
12
|
+
|
13
|
+
def compute_address(
|
14
|
+
*,
|
15
|
+
class_hash: int,
|
16
|
+
constructor_calldata: Sequence[int],
|
17
|
+
salt: int,
|
18
|
+
deployer_address: int = 0,
|
19
|
+
) -> int:
|
20
|
+
"""
|
21
|
+
Computes the contract address in the Starknet network - a unique identifier of the contract.
|
22
|
+
|
23
|
+
:param class_hash: class hash of the contract
|
24
|
+
:param constructor_calldata: calldata for the contract constructor
|
25
|
+
:param salt: salt used to calculate contract address
|
26
|
+
:param deployer_address: address of the deployer (if not provided default 0 is used)
|
27
|
+
:return: Contract's address
|
28
|
+
"""
|
29
|
+
|
30
|
+
constructor_calldata_hash = compute_hash_on_elements(data=constructor_calldata)
|
31
|
+
raw_address = compute_hash_on_elements(
|
32
|
+
data=[
|
33
|
+
CONTRACT_ADDRESS_PREFIX,
|
34
|
+
deployer_address,
|
35
|
+
salt,
|
36
|
+
class_hash,
|
37
|
+
constructor_calldata_hash,
|
38
|
+
],
|
39
|
+
)
|
40
|
+
|
41
|
+
return raw_address % L2_ADDRESS_UPPER_BOUND
|
42
|
+
|
43
|
+
|
44
|
+
def get_checksum_address(address: str) -> str:
|
45
|
+
"""
|
46
|
+
Outputs formatted checksum address.
|
47
|
+
|
48
|
+
Follows implementation of starknet.js. It is not compatible with EIP55 as it treats hex string as encoded number,
|
49
|
+
instead of encoding it as ASCII string.
|
50
|
+
|
51
|
+
:param address: Address to encode
|
52
|
+
:return: Checksum address
|
53
|
+
"""
|
54
|
+
if not address.lower().startswith(HEX_PREFIX):
|
55
|
+
raise ValueError(f"{address} is not a valid hexadecimal address.")
|
56
|
+
|
57
|
+
int_address = int(address, 16)
|
58
|
+
string_address = address[2:].zfill(64)
|
59
|
+
|
60
|
+
address_in_bytes = encode_uint(int_address, get_bytes_length(int_address))
|
61
|
+
address_hash = _starknet_keccak(address_in_bytes)
|
62
|
+
|
63
|
+
result = "".join(
|
64
|
+
(
|
65
|
+
char.upper()
|
66
|
+
if char.isalpha() and (address_hash >> 256 - 4 * i - 1) & 1
|
67
|
+
else char
|
68
|
+
)
|
69
|
+
for i, char in enumerate(string_address)
|
70
|
+
)
|
71
|
+
|
72
|
+
return f"{HEX_PREFIX}{result}"
|
73
|
+
|
74
|
+
|
75
|
+
def is_checksum_address(address: str) -> bool:
|
76
|
+
"""
|
77
|
+
Checks if provided string is in a checksum address format.
|
78
|
+
"""
|
79
|
+
return get_checksum_address(address) == address
|