ccxt-ir 4.9.32 → 4.11.0
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.
- package/README.md +4 -4
- package/dist/ccxt.browser.min.js +2 -2
- package/dist/cjs/ccxt.js +7 -1
- package/dist/cjs/package.json +1 -1
- package/dist/cjs/src/abstract/asretether.js +11 -0
- package/dist/cjs/src/abstract/bidarz.js +11 -0
- package/dist/cjs/src/asretether.js +325 -0
- package/dist/cjs/src/bidarz.js +337 -0
- package/dist/cjs/src/bit24.js +4 -3
- package/dist/cjs/src/raastin.js +144 -16
- package/js/ccxt.d.ts +8 -2
- package/js/ccxt.js +6 -2
- package/js/src/abstract/asretether.d.ts +8 -0
- package/js/src/abstract/asretether.js +11 -0
- package/js/src/abstract/bidarz.d.ts +9 -0
- package/js/src/abstract/bidarz.js +11 -0
- package/js/src/abstract/raastin.d.ts +1 -0
- package/js/src/asretether.d.ts +21 -0
- package/js/src/asretether.js +324 -0
- package/js/src/bidarz.d.ts +22 -0
- package/js/src/bidarz.js +336 -0
- package/js/src/bit24.js +4 -3
- package/js/src/raastin.d.ts +2 -0
- package/js/src/raastin.js +144 -16
- package/js/src/src/abantether.d.ts +21 -0
- package/js/src/src/abantether.js +353 -0
- package/js/src/src/abstract/abantether.d.ts +8 -0
- package/js/src/src/abstract/abantether.js +11 -0
- package/js/src/src/abstract/afratether.d.ts +9 -0
- package/js/src/src/abstract/afratether.js +11 -0
- package/js/src/src/abstract/alpaca.d.ts +77 -0
- package/js/src/src/abstract/alpaca.js +11 -0
- package/js/src/src/abstract/apex.d.ts +34 -0
- package/js/src/src/abstract/apex.js +11 -0
- package/js/src/src/abstract/arzinja.d.ts +8 -0
- package/js/src/src/abstract/arzinja.js +11 -0
- package/js/src/src/abstract/arzplus.d.ts +11 -0
- package/js/src/src/abstract/arzplus.js +11 -0
- package/js/src/src/abstract/ascendex.d.ts +80 -0
- package/js/src/src/abstract/ascendex.js +11 -0
- package/js/src/src/abstract/asretether.d.ts +8 -0
- package/js/src/src/abstract/asretether.js +11 -0
- package/js/src/src/abstract/bidarz.d.ts +9 -0
- package/js/src/src/abstract/bidarz.js +11 -0
- package/js/src/src/abstract/bigone.d.ts +48 -0
- package/js/src/src/abstract/bigone.js +11 -0
- package/js/src/src/abstract/binance.d.ts +773 -0
- package/js/src/src/abstract/binance.js +11 -0
- package/js/src/src/abstract/bingx.d.ts +165 -0
- package/js/src/src/abstract/bingx.js +11 -0
- package/js/src/src/abstract/bit24.d.ts +9 -0
- package/js/src/src/abstract/bit24.js +11 -0
- package/js/src/src/abstract/bit2c.d.ts +30 -0
- package/js/src/src/abstract/bit2c.js +11 -0
- package/js/src/src/abstract/bitbank.d.ts +35 -0
- package/js/src/src/abstract/bitbank.js +11 -0
- package/js/src/src/abstract/bitbarg.d.ts +8 -0
- package/js/src/src/abstract/bitbarg.js +11 -0
- package/js/src/src/abstract/bitbns.d.ts +43 -0
- package/js/src/src/abstract/bitbns.js +11 -0
- package/js/src/src/abstract/bitfinex.d.ts +143 -0
- package/js/src/src/abstract/bitfinex.js +11 -0
- package/js/src/src/abstract/bitflyer.d.ts +42 -0
- package/js/src/src/abstract/bitflyer.js +11 -0
- package/js/src/src/abstract/bitget.d.ts +578 -0
- package/js/src/src/abstract/bitget.js +11 -0
- package/js/src/src/abstract/bithumb.d.ts +35 -0
- package/js/src/src/abstract/bithumb.js +11 -0
- package/js/src/src/abstract/bitimen.d.ts +10 -0
- package/js/src/src/abstract/bitimen.js +11 -0
- package/js/src/src/abstract/bitir.d.ts +10 -0
- package/js/src/src/abstract/bitir.js +11 -0
- package/js/src/src/abstract/bitmart.d.ts +120 -0
- package/js/src/src/abstract/bitmart.js +11 -0
- package/js/src/src/abstract/bitmex.d.ts +100 -0
- package/js/src/src/abstract/bitmex.js +11 -0
- package/js/src/src/abstract/bitopro.d.ts +33 -0
- package/js/src/src/abstract/bitopro.js +11 -0
- package/js/src/src/abstract/bitpin.d.ts +11 -0
- package/js/src/src/abstract/bitpin.js +11 -0
- package/js/src/src/abstract/bitrue.d.ts +75 -0
- package/js/src/src/abstract/bitrue.js +11 -0
- package/js/src/src/abstract/bitso.d.ts +46 -0
- package/js/src/src/abstract/bitso.js +11 -0
- package/js/src/src/abstract/bitstamp.d.ts +262 -0
- package/js/src/src/abstract/bitstamp.js +11 -0
- package/js/src/src/abstract/bitteam.d.ts +32 -0
- package/js/src/src/abstract/bitteam.js +11 -0
- package/js/src/src/abstract/bittrade.d.ts +117 -0
- package/js/src/src/abstract/bittrade.js +11 -0
- package/js/src/src/abstract/bitunix.d.ts +9 -0
- package/js/src/src/abstract/bitunix.js +11 -0
- package/js/src/src/abstract/bitvavo.d.ts +30 -0
- package/js/src/src/abstract/bitvavo.js +11 -0
- package/js/src/src/abstract/blockchaincom.d.ts +31 -0
- package/js/src/src/abstract/blockchaincom.js +11 -0
- package/js/src/src/abstract/blofin.d.ts +70 -0
- package/js/src/src/abstract/blofin.js +11 -0
- package/js/src/src/abstract/btcalpha.d.ts +21 -0
- package/js/src/src/abstract/btcalpha.js +11 -0
- package/js/src/src/abstract/btcbox.d.ts +18 -0
- package/js/src/src/abstract/btcbox.js +11 -0
- package/js/src/src/abstract/btcmarkets.d.ts +42 -0
- package/js/src/src/abstract/btcmarkets.js +11 -0
- package/js/src/src/abstract/btcturk.d.ts +23 -0
- package/js/src/src/abstract/btcturk.js +11 -0
- package/js/src/src/abstract/bybit.d.ts +316 -0
- package/js/src/src/abstract/bybit.js +11 -0
- package/js/src/src/abstract/bydfi.d.ts +11 -0
- package/js/src/src/abstract/bydfi.js +11 -0
- package/js/src/src/abstract/cafearz.d.ts +8 -0
- package/js/src/src/abstract/cafearz.js +11 -0
- package/js/src/src/abstract/cex.d.ts +35 -0
- package/js/src/src/abstract/cex.js +11 -0
- package/js/src/src/abstract/coinbase.d.ts +97 -0
- package/js/src/src/abstract/coinbase.js +11 -0
- package/js/src/src/abstract/coinbaseexchange.d.ts +71 -0
- package/js/src/src/abstract/coinbaseexchange.js +11 -0
- package/js/src/src/abstract/coinbaseinternational.d.ts +42 -0
- package/js/src/src/abstract/coinbaseinternational.js +11 -0
- package/js/src/src/abstract/coincatch.d.ts +97 -0
- package/js/src/src/abstract/coincatch.js +11 -0
- package/js/src/src/abstract/coincheck.d.ts +36 -0
- package/js/src/src/abstract/coincheck.js +11 -0
- package/js/src/src/abstract/coinex.d.ts +240 -0
- package/js/src/src/abstract/coinex.js +11 -0
- package/js/src/src/abstract/coinmate.d.ts +65 -0
- package/js/src/src/abstract/coinmate.js +11 -0
- package/js/src/src/abstract/coinmetro.d.ts +37 -0
- package/js/src/src/abstract/coinmetro.js +11 -0
- package/js/src/src/abstract/coinone.d.ts +70 -0
- package/js/src/src/abstract/coinone.js +11 -0
- package/js/src/src/abstract/coinsph.d.ts +57 -0
- package/js/src/src/abstract/coinsph.js +11 -0
- package/js/src/src/abstract/coinspot.d.ts +31 -0
- package/js/src/src/abstract/coinspot.js +11 -0
- package/js/src/src/abstract/cryptocom.d.ts +126 -0
- package/js/src/src/abstract/cryptocom.js +11 -0
- package/js/src/src/abstract/cryptomus.d.ts +23 -0
- package/js/src/src/abstract/cryptomus.js +11 -0
- package/js/src/src/abstract/defx.d.ts +72 -0
- package/js/src/src/abstract/defx.js +11 -0
- package/js/src/src/abstract/delta.d.ts +53 -0
- package/js/src/src/abstract/delta.js +11 -0
- package/js/src/src/abstract/deribit.d.ts +129 -0
- package/js/src/src/abstract/deribit.js +11 -0
- package/js/src/src/abstract/derive.d.ts +120 -0
- package/js/src/src/abstract/derive.js +11 -0
- package/js/src/src/abstract/digifinex.d.ts +95 -0
- package/js/src/src/abstract/digifinex.js +11 -0
- package/js/src/src/abstract/ellipx.d.ts +28 -0
- package/js/src/src/abstract/ellipx.js +11 -0
- package/js/src/src/abstract/eterex.d.ts +8 -0
- package/js/src/src/abstract/eterex.js +11 -0
- package/js/src/src/abstract/excoino.d.ts +10 -0
- package/js/src/src/abstract/excoino.js +11 -0
- package/js/src/src/abstract/exir.d.ts +11 -0
- package/js/src/src/abstract/exir.js +11 -0
- package/js/src/src/abstract/exmo.d.ts +58 -0
- package/js/src/src/abstract/exmo.js +11 -0
- package/js/src/src/abstract/exnovin.d.ts +9 -0
- package/js/src/src/abstract/exnovin.js +11 -0
- package/js/src/src/abstract/farhadexchange.d.ts +8 -0
- package/js/src/src/abstract/farhadexchange.js +11 -0
- package/js/src/src/abstract/foxbit.d.ts +29 -0
- package/js/src/src/abstract/foxbit.js +11 -0
- package/js/src/src/abstract/gate.d.ts +287 -0
- package/js/src/src/abstract/gate.js +11 -0
- package/js/src/src/abstract/gemini.d.ts +62 -0
- package/js/src/src/abstract/gemini.js +11 -0
- package/js/src/src/abstract/hamtapay.d.ts +9 -0
- package/js/src/src/abstract/hamtapay.js +11 -0
- package/js/src/src/abstract/hashkey.d.ts +70 -0
- package/js/src/src/abstract/hashkey.js +11 -0
- package/js/src/src/abstract/hibachi.d.ts +29 -0
- package/js/src/src/abstract/hibachi.js +11 -0
- package/js/src/src/abstract/hitbtc.d.ts +118 -0
- package/js/src/src/abstract/hitbtc.js +11 -0
- package/js/src/src/abstract/hitobit.d.ts +11 -0
- package/js/src/src/abstract/hitobit.js +11 -0
- package/js/src/src/abstract/hollaex.d.ts +36 -0
- package/js/src/src/abstract/hollaex.js +11 -0
- package/js/src/src/abstract/htx.d.ts +551 -0
- package/js/src/src/abstract/htx.js +11 -0
- package/js/src/src/abstract/hyperliquid.d.ts +9 -0
- package/js/src/src/abstract/hyperliquid.js +11 -0
- package/js/src/src/abstract/independentreserve.d.ts +46 -0
- package/js/src/src/abstract/independentreserve.js +11 -0
- package/js/src/src/abstract/indodax.d.ts +29 -0
- package/js/src/src/abstract/indodax.js +11 -0
- package/js/src/src/abstract/iranexchange.d.ts +9 -0
- package/js/src/src/abstract/iranexchange.js +11 -0
- package/js/src/src/abstract/jibitex.d.ts +10 -0
- package/js/src/src/abstract/jibitex.js +11 -0
- package/js/src/src/abstract/kcex.d.ts +10 -0
- package/js/src/src/abstract/kcex.js +11 -0
- package/js/src/src/abstract/kifpoolme.d.ts +9 -0
- package/js/src/src/abstract/kifpoolme.js +11 -0
- package/js/src/src/abstract/kraken.d.ts +61 -0
- package/js/src/src/abstract/kraken.js +11 -0
- package/js/src/src/abstract/krakenfutures.d.ts +45 -0
- package/js/src/src/abstract/krakenfutures.js +11 -0
- package/js/src/src/abstract/kucoin.d.ts +227 -0
- package/js/src/src/abstract/kucoin.js +11 -0
- package/js/src/src/abstract/kucoinfutures.d.ts +254 -0
- package/js/src/src/abstract/kucoinfutures.js +11 -0
- package/js/src/src/abstract/latoken.d.ts +59 -0
- package/js/src/src/abstract/latoken.js +11 -0
- package/js/src/src/abstract/lbank.d.ts +65 -0
- package/js/src/src/abstract/lbank.js +11 -0
- package/js/src/src/abstract/luno.d.ts +41 -0
- package/js/src/src/abstract/luno.js +11 -0
- package/js/src/src/abstract/mazdax.d.ts +11 -0
- package/js/src/src/abstract/mazdax.js +11 -0
- package/js/src/src/abstract/mercado.d.ts +28 -0
- package/js/src/src/abstract/mercado.js +11 -0
- package/js/src/src/abstract/mexc.d.ts +183 -0
- package/js/src/src/abstract/mexc.js +11 -0
- package/js/src/src/abstract/modetrade.d.ts +122 -0
- package/js/src/src/abstract/modetrade.js +11 -0
- package/js/src/src/abstract/ndax.d.ts +100 -0
- package/js/src/src/abstract/ndax.js +11 -0
- package/js/src/src/abstract/nobitex.d.ts +10 -0
- package/js/src/src/abstract/nobitex.js +11 -0
- package/js/src/src/abstract/novadax.d.ts +32 -0
- package/js/src/src/abstract/novadax.js +11 -0
- package/js/src/src/abstract/oceanex.d.ts +30 -0
- package/js/src/src/abstract/oceanex.js +11 -0
- package/js/src/src/abstract/okcoin.d.ts +77 -0
- package/js/src/src/abstract/okcoin.js +11 -0
- package/js/src/src/abstract/okexchange.d.ts +11 -0
- package/js/src/src/abstract/okexchange.js +11 -0
- package/js/src/src/abstract/okx.d.ts +352 -0
- package/js/src/src/abstract/okx.js +11 -0
- package/js/src/src/abstract/ompfinex.d.ts +10 -0
- package/js/src/src/abstract/ompfinex.js +11 -0
- package/js/src/src/abstract/onetrading.d.ts +26 -0
- package/js/src/src/abstract/onetrading.js +11 -0
- package/js/src/src/abstract/oxfun.d.ts +37 -0
- package/js/src/src/abstract/oxfun.js +11 -0
- package/js/src/src/abstract/p2b.d.ts +25 -0
- package/js/src/src/abstract/p2b.js +11 -0
- package/js/src/src/abstract/paradex.d.ts +66 -0
- package/js/src/src/abstract/paradex.js +11 -0
- package/js/src/src/abstract/paymium.d.ts +31 -0
- package/js/src/src/abstract/paymium.js +11 -0
- package/js/src/src/abstract/phemex.d.ts +120 -0
- package/js/src/src/abstract/phemex.js +11 -0
- package/js/src/src/abstract/pingi.d.ts +9 -0
- package/js/src/src/abstract/pingi.js +11 -0
- package/js/src/src/abstract/poloniex.d.ts +108 -0
- package/js/src/src/abstract/poloniex.js +11 -0
- package/js/src/src/abstract/pooleno.d.ts +8 -0
- package/js/src/src/abstract/pooleno.js +11 -0
- package/js/src/src/abstract/probit.d.ts +26 -0
- package/js/src/src/abstract/probit.js +11 -0
- package/js/src/src/abstract/raastin.d.ts +11 -0
- package/js/src/src/abstract/raastin.js +11 -0
- package/js/src/src/abstract/ramzinex.d.ts +10 -0
- package/js/src/src/abstract/ramzinex.js +11 -0
- package/js/src/src/abstract/sarmayex.d.ts +8 -0
- package/js/src/src/abstract/sarmayex.js +11 -0
- package/js/src/src/abstract/sarrafex.d.ts +10 -0
- package/js/src/src/abstract/sarrafex.js +11 -0
- package/js/src/src/abstract/tabdeal.d.ts +10 -0
- package/js/src/src/abstract/tabdeal.js +11 -0
- package/js/src/src/abstract/tehran_exchange.d.ts +9 -0
- package/js/src/src/abstract/tehran_exchange.js +11 -0
- package/js/src/src/abstract/tetherland.d.ts +8 -0
- package/js/src/src/abstract/tetherland.js +11 -0
- package/js/src/src/abstract/timex.d.ts +65 -0
- package/js/src/src/abstract/timex.js +11 -0
- package/js/src/src/abstract/tokocrypto.d.ts +40 -0
- package/js/src/src/abstract/tokocrypto.js +11 -0
- package/js/src/src/abstract/toobit.d.ts +10 -0
- package/js/src/src/abstract/toobit.js +11 -0
- package/js/src/src/abstract/tradeogre.d.ts +21 -0
- package/js/src/src/abstract/tradeogre.js +11 -0
- package/js/src/src/abstract/twox.d.ts +8 -0
- package/js/src/src/abstract/twox.js +11 -0
- package/js/src/src/abstract/ubitex.d.ts +10 -0
- package/js/src/src/abstract/ubitex.js +11 -0
- package/js/src/src/abstract/upbit.d.ts +58 -0
- package/js/src/src/abstract/upbit.js +11 -0
- package/js/src/src/abstract/vertex.d.ts +22 -0
- package/js/src/src/abstract/vertex.js +11 -0
- package/js/src/src/abstract/wallex.d.ts +11 -0
- package/js/src/src/abstract/wallex.js +11 -0
- package/js/src/src/abstract/wavesexchange.d.ts +157 -0
- package/js/src/src/abstract/wavesexchange.js +11 -0
- package/js/src/src/abstract/whitebit.d.ts +117 -0
- package/js/src/src/abstract/whitebit.js +11 -0
- package/js/src/src/abstract/woo.d.ts +144 -0
- package/js/src/src/abstract/woo.js +11 -0
- package/js/src/src/abstract/woofipro.d.ts +122 -0
- package/js/src/src/abstract/woofipro.js +11 -0
- package/js/src/src/abstract/xt.d.ts +160 -0
- package/js/src/src/abstract/xt.js +11 -0
- package/js/src/src/abstract/yobit.d.ts +19 -0
- package/js/src/src/abstract/yobit.js +11 -0
- package/js/src/src/abstract/zaif.d.ts +41 -0
- package/js/src/src/abstract/zaif.js +11 -0
- package/js/src/src/abstract/zonda.d.ts +56 -0
- package/js/src/src/abstract/zonda.js +11 -0
- package/js/src/src/afratether.d.ts +21 -0
- package/js/src/src/afratether.js +356 -0
- package/js/src/src/alpaca.d.ts +332 -0
- package/js/src/src/alpaca.js +1908 -0
- package/js/src/src/apex.d.ts +333 -0
- package/js/src/src/apex.js +1942 -0
- package/js/src/src/arzinja.d.ts +21 -0
- package/js/src/src/arzinja.js +298 -0
- package/js/src/src/arzplus.d.ts +26 -0
- package/js/src/src/arzplus.js +581 -0
- package/js/src/src/ascendex.d.ts +424 -0
- package/js/src/src/ascendex.js +3699 -0
- package/js/src/src/asretether.d.ts +21 -0
- package/js/src/src/asretether.js +324 -0
- package/js/src/src/base/Exchange.d.ts +926 -0
- package/js/src/src/base/Exchange.js +7399 -0
- package/js/src/src/base/Precise.d.ts +42 -0
- package/js/src/src/base/Precise.js +275 -0
- package/js/src/src/base/errors.d.ts +168 -0
- package/js/src/src/base/errors.js +255 -0
- package/js/src/src/base/functions/crypto.d.ts +16 -0
- package/js/src/src/base/functions/crypto.js +131 -0
- package/js/src/src/base/functions/encode.d.ts +4 -0
- package/js/src/src/base/functions/encode.js +32 -0
- package/js/src/src/base/functions/generic.d.ts +29 -0
- package/js/src/src/base/functions/generic.js +203 -0
- package/js/src/src/base/functions/misc.d.ts +9 -0
- package/js/src/src/base/functions/misc.js +101 -0
- package/js/src/src/base/functions/number.d.ts +27 -0
- package/js/src/src/base/functions/number.js +313 -0
- package/js/src/src/base/functions/platform.d.ts +7 -0
- package/js/src/src/base/functions/platform.js +27 -0
- package/js/src/src/base/functions/rsa.d.ts +5 -0
- package/js/src/src/base/functions/rsa.js +49 -0
- package/js/src/src/base/functions/string.d.ts +7 -0
- package/js/src/src/base/functions/string.js +44 -0
- package/js/src/src/base/functions/throttle.d.ts +6 -0
- package/js/src/src/base/functions/throttle.js +67 -0
- package/js/src/src/base/functions/time.d.ts +21 -0
- package/js/src/src/base/functions/time.js +171 -0
- package/js/src/src/base/functions/totp.d.ts +3 -0
- package/js/src/src/base/functions/totp.js +25 -0
- package/js/src/src/base/functions/type.d.ts +37 -0
- package/js/src/src/base/functions/type.js +179 -0
- package/js/src/src/base/functions.d.ts +10 -0
- package/js/src/src/base/functions.js +18 -0
- package/js/src/src/base/types.d.ts +586 -0
- package/js/src/src/base/types.js +7 -0
- package/js/src/src/base/ws/Cache.d.ts +27 -0
- package/js/src/src/base/ws/Cache.js +260 -0
- package/js/src/src/base/ws/Client.d.ts +53 -0
- package/js/src/src/base/ws/Client.js +307 -0
- package/js/src/src/base/ws/Future.d.ts +8 -0
- package/js/src/src/base/ws/Future.js +35 -0
- package/js/src/src/base/ws/OrderBook.d.ts +25 -0
- package/js/src/src/base/ws/OrderBook.js +130 -0
- package/js/src/src/base/ws/OrderBookSide.d.ts +40 -0
- package/js/src/src/base/ws/OrderBookSide.js +286 -0
- package/js/src/src/base/ws/WsClient.d.ts +11 -0
- package/js/src/src/base/ws/WsClient.js +69 -0
- package/js/src/src/bequant.d.ts +4 -0
- package/js/src/src/bequant.js +35 -0
- package/js/src/src/bidarz.d.ts +16 -0
- package/js/src/src/bidarz.js +327 -0
- package/js/src/src/bigone.d.ts +296 -0
- package/js/src/src/bigone.js +2340 -0
- package/js/src/src/binance.d.ts +1667 -0
- package/js/src/src/binance.js +14400 -0
- package/js/src/src/binancecoinm.d.ts +6 -0
- package/js/src/src/binancecoinm.js +51 -0
- package/js/src/src/binanceus.d.ts +4 -0
- package/js/src/src/binanceus.js +225 -0
- package/js/src/src/binanceusdm.d.ts +6 -0
- package/js/src/src/binanceusdm.js +63 -0
- package/js/src/src/bingx.d.ts +778 -0
- package/js/src/src/bingx.js +6705 -0
- package/js/src/src/bit24.d.ts +24 -0
- package/js/src/src/bit24.js +520 -0
- package/js/src/src/bit2c.d.ts +146 -0
- package/js/src/src/bit2c.js +1029 -0
- package/js/src/src/bitbank.d.ts +181 -0
- package/js/src/src/bitbank.js +1146 -0
- package/js/src/src/bitbarg.d.ts +21 -0
- package/js/src/src/bitbarg.js +312 -0
- package/js/src/src/bitbns.d.ts +184 -0
- package/js/src/src/bitbns.js +1288 -0
- package/js/src/src/bitfinex.d.ts +516 -0
- package/js/src/src/bitfinex.js +3951 -0
- package/js/src/src/bitflyer.d.ts +229 -0
- package/js/src/src/bitflyer.js +1209 -0
- package/js/src/src/bitget.d.ts +1109 -0
- package/js/src/src/bitget.js +11033 -0
- package/js/src/src/bithumb.d.ts +165 -0
- package/js/src/src/bithumb.js +1257 -0
- package/js/src/src/bitimen.d.ts +23 -0
- package/js/src/src/bitimen.js +424 -0
- package/js/src/src/bitir.d.ts +23 -0
- package/js/src/src/bitir.js +521 -0
- package/js/src/src/bitmart.d.ts +736 -0
- package/js/src/src/bitmart.js +5639 -0
- package/js/src/src/bitmex.d.ts +395 -0
- package/js/src/src/bitmex.js +3088 -0
- package/js/src/src/bitopro.d.ts +295 -0
- package/js/src/src/bitopro.js +1892 -0
- package/js/src/src/bitpin.d.ts +23 -0
- package/js/src/src/bitpin.js +487 -0
- package/js/src/src/bitrue.d.ts +384 -0
- package/js/src/src/bitrue.js +3382 -0
- package/js/src/src/bitso.d.ts +270 -0
- package/js/src/src/bitso.js +1881 -0
- package/js/src/src/bitstamp.d.ts +355 -0
- package/js/src/src/bitstamp.js +2445 -0
- package/js/src/src/bitteam.d.ts +229 -0
- package/js/src/src/bitteam.js +2420 -0
- package/js/src/src/bittrade.d.ts +298 -0
- package/js/src/src/bittrade.js +2050 -0
- package/js/src/src/bitunix.d.ts +21 -0
- package/js/src/src/bitunix.js +326 -0
- package/js/src/src/bitvavo.d.ts +311 -0
- package/js/src/src/bitvavo.js +2204 -0
- package/js/src/src/blockchaincom.d.ts +256 -0
- package/js/src/src/blockchaincom.js +1259 -0
- package/js/src/src/blofin.d.ts +439 -0
- package/js/src/src/blofin.js +2576 -0
- package/js/src/src/btcalpha.d.ts +209 -0
- package/js/src/src/btcalpha.js +1056 -0
- package/js/src/src/btcbox.d.ts +144 -0
- package/js/src/src/btcbox.js +834 -0
- package/js/src/src/btcmarkets.d.ts +253 -0
- package/js/src/src/btcmarkets.js +1418 -0
- package/js/src/src/btcturk.d.ts +161 -0
- package/js/src/src/btcturk.js +1058 -0
- package/js/src/src/bybit.d.ts +1097 -0
- package/js/src/src/bybit.js +9382 -0
- package/js/src/src/bydfi.d.ts +23 -0
- package/js/src/src/bydfi.js +434 -0
- package/js/src/src/cafearz.d.ts +21 -0
- package/js/src/src/cafearz.js +346 -0
- package/js/src/src/cex.d.ts +286 -0
- package/js/src/src/cex.js +1799 -0
- package/js/src/src/coinbase.d.ts +623 -0
- package/js/src/src/coinbase.js +5220 -0
- package/js/src/src/coinbaseadvanced.d.ts +4 -0
- package/js/src/src/coinbaseadvanced.js +18 -0
- package/js/src/src/coinbaseexchange.d.ts +334 -0
- package/js/src/src/coinbaseexchange.js +2127 -0
- package/js/src/src/coinbaseinternational.d.ts +443 -0
- package/js/src/src/coinbaseinternational.js +2336 -0
- package/js/src/src/coincatch.d.ts +786 -0
- package/js/src/src/coincatch.js +5492 -0
- package/js/src/src/coincheck.d.ts +147 -0
- package/js/src/src/coincheck.js +962 -0
- package/js/src/src/coinex.d.ts +719 -0
- package/js/src/src/coinex.js +6166 -0
- package/js/src/src/coinmate.d.ts +202 -0
- package/js/src/src/coinmate.js +1215 -0
- package/js/src/src/coinmetro.d.ts +244 -0
- package/js/src/src/coinmetro.js +2024 -0
- package/js/src/src/coinone.d.ts +158 -0
- package/js/src/src/coinone.js +1278 -0
- package/js/src/src/coinsph.d.ts +310 -0
- package/js/src/src/coinsph.js +2203 -0
- package/js/src/src/coinspot.d.ts +108 -0
- package/js/src/src/coinspot.js +653 -0
- package/js/src/src/cryptocom.d.ts +463 -0
- package/js/src/src/cryptocom.js +3549 -0
- package/js/src/src/cryptomus.d.ts +158 -0
- package/js/src/src/cryptomus.js +1169 -0
- package/js/src/src/defx.d.ts +348 -0
- package/js/src/src/defx.js +2139 -0
- package/js/src/src/delta.d.ts +407 -0
- package/js/src/src/delta.js +3654 -0
- package/js/src/src/deribit.d.ts +516 -0
- package/js/src/src/deribit.js +3790 -0
- package/js/src/src/derive.d.ts +324 -0
- package/js/src/src/derive.js +2655 -0
- package/js/src/src/digifinex.d.ts +544 -0
- package/js/src/src/digifinex.js +4453 -0
- package/js/src/src/ellipx.d.ts +237 -0
- package/js/src/src/ellipx.js +2071 -0
- package/js/src/src/eterex.d.ts +21 -0
- package/js/src/src/eterex.js +299 -0
- package/js/src/src/excoino.d.ts +23 -0
- package/js/src/src/excoino.js +426 -0
- package/js/src/src/exir.d.ts +23 -0
- package/js/src/src/exir.js +403 -0
- package/js/src/src/exmo.d.ts +426 -0
- package/js/src/src/exmo.js +2825 -0
- package/js/src/src/exnovin.d.ts +22 -0
- package/js/src/src/exnovin.js +378 -0
- package/js/src/src/farhadexchange.d.ts +21 -0
- package/js/src/src/farhadexchange.js +280 -0
- package/js/src/src/fmfwio.d.ts +4 -0
- package/js/src/src/fmfwio.js +35 -0
- package/js/src/src/foxbit.d.ts +352 -0
- package/js/src/src/foxbit.js +2016 -0
- package/js/src/src/gate.d.ts +1071 -0
- package/js/src/src/gate.js +8282 -0
- package/js/src/src/gateio.d.ts +4 -0
- package/js/src/src/gateio.js +17 -0
- package/js/src/src/gemini.d.ts +257 -0
- package/js/src/src/gemini.js +2006 -0
- package/js/src/src/hamtapay.d.ts +21 -0
- package/js/src/src/hamtapay.js +303 -0
- package/js/src/src/hashkey.d.ts +628 -0
- package/js/src/src/hashkey.js +4363 -0
- package/js/src/src/hibachi.d.ts +346 -0
- package/js/src/src/hibachi.js +2137 -0
- package/js/src/src/hitbtc.d.ts +558 -0
- package/js/src/src/hitbtc.js +3847 -0
- package/js/src/src/hitobit.d.ts +23 -0
- package/js/src/src/hitobit.js +412 -0
- package/js/src/src/hollaex.d.ts +305 -0
- package/js/src/src/hollaex.js +2046 -0
- package/js/src/src/htx.d.ts +961 -0
- package/js/src/src/htx.js +9668 -0
- package/js/src/src/huobi.d.ts +4 -0
- package/js/src/src/huobi.js +17 -0
- package/js/src/src/hyperliquid.d.ts +651 -0
- package/js/src/src/hyperliquid.js +3937 -0
- package/js/src/src/independentreserve.d.ts +169 -0
- package/js/src/src/independentreserve.js +1115 -0
- package/js/src/src/indodax.d.ts +217 -0
- package/js/src/src/indodax.js +1454 -0
- package/js/src/src/iranexchange.d.ts +21 -0
- package/js/src/src/iranexchange.js +399 -0
- package/js/src/src/jibitex.d.ts +23 -0
- package/js/src/src/jibitex.js +416 -0
- package/js/src/src/kcex.d.ts +21 -0
- package/js/src/src/kcex.js +335 -0
- package/js/src/src/kifpoolme.d.ts +23 -0
- package/js/src/src/kifpoolme.js +410 -0
- package/js/src/src/kraken.d.ts +484 -0
- package/js/src/src/kraken.js +3518 -0
- package/js/src/src/krakenfutures.d.ts +362 -0
- package/js/src/src/krakenfutures.js +2885 -0
- package/js/src/src/kucoin.d.ts +759 -0
- package/js/src/src/kucoin.js +5153 -0
- package/js/src/src/kucoinfutures.d.ts +521 -0
- package/js/src/src/kucoinfutures.js +3381 -0
- package/js/src/src/latoken.d.ts +274 -0
- package/js/src/src/latoken.js +1824 -0
- package/js/src/src/lbank.d.ts +350 -0
- package/js/src/src/lbank.js +3146 -0
- package/js/src/src/luno.d.ts +252 -0
- package/js/src/src/luno.js +1479 -0
- package/js/src/src/mazdax.d.ts +23 -0
- package/js/src/src/mazdax.js +534 -0
- package/js/src/src/mercado.d.ts +160 -0
- package/js/src/src/mercado.js +1011 -0
- package/js/src/src/mexc.d.ts +768 -0
- package/js/src/src/mexc.js +6102 -0
- package/js/src/src/modetrade.d.ts +496 -0
- package/js/src/src/modetrade.js +2936 -0
- package/js/src/src/myokx.d.ts +4 -0
- package/js/src/src/myokx.js +54 -0
- package/js/src/src/ndax.d.ts +285 -0
- package/js/src/src/ndax.js +2598 -0
- package/js/src/src/nobitex.d.ts +23 -0
- package/js/src/src/nobitex.js +454 -0
- package/js/src/src/novadax.d.ts +279 -0
- package/js/src/src/novadax.js +1676 -0
- package/js/src/src/oceanex.d.ts +231 -0
- package/js/src/src/oceanex.js +1123 -0
- package/js/src/src/okcoin.d.ts +346 -0
- package/js/src/src/okcoin.js +3211 -0
- package/js/src/src/okexchange.d.ts +23 -0
- package/js/src/src/okexchange.js +373 -0
- package/js/src/src/okx.d.ts +1125 -0
- package/js/src/src/okx.js +9009 -0
- package/js/src/src/okxus.d.ts +4 -0
- package/js/src/src/okxus.js +54 -0
- package/js/src/src/ompfinex.d.ts +23 -0
- package/js/src/src/ompfinex.js +510 -0
- package/js/src/src/onetrading.d.ts +228 -0
- package/js/src/src/onetrading.js +1769 -0
- package/js/src/src/oxfun.d.ts +442 -0
- package/js/src/src/oxfun.js +2920 -0
- package/js/src/src/p2b.d.ts +189 -0
- package/js/src/src/p2b.js +1344 -0
- package/js/src/src/paradex.d.ts +389 -0
- package/js/src/src/paradex.js +2607 -0
- package/js/src/src/paymium.d.ts +133 -0
- package/js/src/src/paymium.js +644 -0
- package/js/src/src/phemex.d.ts +497 -0
- package/js/src/src/phemex.js +5333 -0
- package/js/src/src/pingi.d.ts +22 -0
- package/js/src/src/pingi.js +446 -0
- package/js/src/src/poloniex.d.ts +441 -0
- package/js/src/src/poloniex.js +3681 -0
- package/js/src/src/pooleno.d.ts +21 -0
- package/js/src/src/pooleno.js +347 -0
- package/js/src/src/pro/alpaca.d.ts +95 -0
- package/js/src/src/pro/alpaca.js +724 -0
- package/js/src/src/pro/apex.d.ts +160 -0
- package/js/src/src/pro/apex.js +1044 -0
- package/js/src/src/pro/ascendex.d.ts +99 -0
- package/js/src/src/pro/ascendex.js +1012 -0
- package/js/src/src/pro/bequant.d.ts +4 -0
- package/js/src/src/pro/bequant.js +42 -0
- package/js/src/src/pro/binance.d.ts +796 -0
- package/js/src/src/pro/binance.js +4373 -0
- package/js/src/src/pro/binancecoinm.d.ts +4 -0
- package/js/src/src/pro/binancecoinm.js +32 -0
- package/js/src/src/pro/binanceus.d.ts +4 -0
- package/js/src/src/pro/binanceus.js +52 -0
- package/js/src/src/pro/binanceusdm.d.ts +4 -0
- package/js/src/src/pro/binanceusdm.js +37 -0
- package/js/src/src/pro/bingx.d.ts +151 -0
- package/js/src/src/pro/bingx.js +1568 -0
- package/js/src/src/pro/bitfinex.d.ts +99 -0
- package/js/src/src/pro/bitfinex.js +1165 -0
- package/js/src/src/pro/bitget.d.ts +257 -0
- package/js/src/src/pro/bitget.js +2327 -0
- package/js/src/src/pro/bithumb.d.ts +59 -0
- package/js/src/src/pro/bithumb.js +395 -0
- package/js/src/src/pro/bitmart.d.ts +168 -0
- package/js/src/src/pro/bitmart.js +1686 -0
- package/js/src/src/pro/bitmex.d.ts +170 -0
- package/js/src/src/pro/bitmex.js +1760 -0
- package/js/src/src/pro/bitopro.d.ts +69 -0
- package/js/src/src/pro/bitopro.js +477 -0
- package/js/src/src/pro/bitrue.d.ts +40 -0
- package/js/src/src/pro/bitrue.js +461 -0
- package/js/src/src/pro/bitstamp.d.ts +53 -0
- package/js/src/src/pro/bitstamp.js +587 -0
- package/js/src/src/pro/bittrade.d.ts +66 -0
- package/js/src/src/pro/bittrade.js +606 -0
- package/js/src/src/pro/bitvavo.d.ts +321 -0
- package/js/src/src/pro/bitvavo.js +1451 -0
- package/js/src/src/pro/blockchaincom.d.ts +89 -0
- package/js/src/src/pro/blockchaincom.js +777 -0
- package/js/src/src/pro/blofin.d.ts +174 -0
- package/js/src/src/pro/blofin.js +743 -0
- package/js/src/src/pro/bybit.d.ts +397 -0
- package/js/src/src/pro/bybit.js +2519 -0
- package/js/src/src/pro/cex.d.ts +220 -0
- package/js/src/src/pro/cex.js +1535 -0
- package/js/src/src/pro/coinbase.d.ts +119 -0
- package/js/src/src/pro/coinbase.js +736 -0
- package/js/src/src/pro/coinbaseadvanced.d.ts +4 -0
- package/js/src/src/pro/coinbaseadvanced.js +18 -0
- package/js/src/src/pro/coinbaseexchange.d.ts +133 -0
- package/js/src/src/pro/coinbaseexchange.js +969 -0
- package/js/src/src/pro/coinbaseinternational.d.ts +143 -0
- package/js/src/src/pro/coinbaseinternational.js +804 -0
- package/js/src/src/pro/coincatch.d.ts +207 -0
- package/js/src/src/pro/coincatch.js +1562 -0
- package/js/src/src/pro/coincheck.d.ts +33 -0
- package/js/src/src/pro/coincheck.js +210 -0
- package/js/src/src/pro/coinex.d.ts +147 -0
- package/js/src/src/pro/coinex.js +1426 -0
- package/js/src/src/pro/coinone.d.ts +51 -0
- package/js/src/src/pro/coinone.js +413 -0
- package/js/src/src/pro/cryptocom.d.ts +300 -0
- package/js/src/src/pro/cryptocom.js +1414 -0
- package/js/src/src/pro/defx.d.ts +236 -0
- package/js/src/src/pro/defx.js +865 -0
- package/js/src/src/pro/deribit.d.ts +163 -0
- package/js/src/src/pro/deribit.js +1066 -0
- package/js/src/src/pro/derive.d.ts +100 -0
- package/js/src/src/pro/derive.js +753 -0
- package/js/src/src/pro/exmo.d.ts +97 -0
- package/js/src/src/pro/exmo.js +903 -0
- package/js/src/src/pro/gate.d.ts +360 -0
- package/js/src/src/pro/gate.js +2119 -0
- package/js/src/src/pro/gateio.d.ts +4 -0
- package/js/src/src/pro/gateio.js +17 -0
- package/js/src/src/pro/gemini.d.ts +106 -0
- package/js/src/src/pro/gemini.js +932 -0
- package/js/src/src/pro/hashkey.d.ts +121 -0
- package/js/src/src/pro/hashkey.js +843 -0
- package/js/src/src/pro/hitbtc.d.ts +235 -0
- package/js/src/src/pro/hitbtc.js +1400 -0
- package/js/src/src/pro/hollaex.d.ts +77 -0
- package/js/src/src/pro/hollaex.js +604 -0
- package/js/src/src/pro/htx.d.ts +141 -0
- package/js/src/src/pro/htx.js +2415 -0
- package/js/src/src/pro/huobi.d.ts +4 -0
- package/js/src/src/pro/huobi.js +17 -0
- package/js/src/src/pro/hyperliquid.d.ts +218 -0
- package/js/src/src/pro/hyperliquid.js +1126 -0
- package/js/src/src/pro/independentreserve.d.ts +36 -0
- package/js/src/src/pro/independentreserve.js +287 -0
- package/js/src/src/pro/kraken.d.ts +233 -0
- package/js/src/src/pro/kraken.js +1785 -0
- package/js/src/src/pro/krakenfutures.d.ts +178 -0
- package/js/src/src/pro/krakenfutures.js +1592 -0
- package/js/src/src/pro/kucoin.d.ts +221 -0
- package/js/src/src/pro/kucoin.js +1430 -0
- package/js/src/src/pro/kucoinfutures.d.ts +205 -0
- package/js/src/src/pro/kucoinfutures.js +1295 -0
- package/js/src/src/pro/lbank.d.ts +134 -0
- package/js/src/src/pro/lbank.js +950 -0
- package/js/src/src/pro/luno.d.ts +44 -0
- package/js/src/src/pro/luno.js +322 -0
- package/js/src/src/pro/mexc.d.ts +210 -0
- package/js/src/src/pro/mexc.js +2009 -0
- package/js/src/src/pro/modetrade.d.ts +155 -0
- package/js/src/src/pro/modetrade.js +1335 -0
- package/js/src/src/pro/myokx.d.ts +4 -0
- package/js/src/src/pro/myokx.js +39 -0
- package/js/src/src/pro/ndax.d.ts +60 -0
- package/js/src/src/pro/ndax.js +545 -0
- package/js/src/src/pro/okcoin.d.ts +91 -0
- package/js/src/src/pro/okcoin.js +763 -0
- package/js/src/src/pro/okx.d.ts +408 -0
- package/js/src/src/pro/okx.js +2479 -0
- package/js/src/src/pro/okxus.d.ts +4 -0
- package/js/src/src/pro/okxus.js +39 -0
- package/js/src/src/pro/onetrading.d.ts +107 -0
- package/js/src/src/pro/onetrading.js +1343 -0
- package/js/src/src/pro/oxfun.d.ts +234 -0
- package/js/src/src/pro/oxfun.js +1112 -0
- package/js/src/src/pro/p2b.d.ts +104 -0
- package/js/src/src/pro/p2b.js +506 -0
- package/js/src/src/pro/paradex.d.ts +54 -0
- package/js/src/src/pro/paradex.js +370 -0
- package/js/src/src/pro/phemex.d.ts +129 -0
- package/js/src/src/pro/phemex.js +1569 -0
- package/js/src/src/pro/poloniex.d.ts +214 -0
- package/js/src/src/pro/poloniex.js +1318 -0
- package/js/src/src/pro/probit.d.ts +91 -0
- package/js/src/src/pro/probit.js +593 -0
- package/js/src/src/pro/tradeogre.d.ts +49 -0
- package/js/src/src/pro/tradeogre.js +284 -0
- package/js/src/src/pro/upbit.d.ts +124 -0
- package/js/src/src/pro/upbit.js +689 -0
- package/js/src/src/pro/vertex.d.ts +104 -0
- package/js/src/src/pro/vertex.js +999 -0
- package/js/src/src/pro/whitebit.d.ts +123 -0
- package/js/src/src/pro/whitebit.js +971 -0
- package/js/src/src/pro/woo.d.ts +161 -0
- package/js/src/src/pro/woo.js +1351 -0
- package/js/src/src/pro/woofipro.d.ts +155 -0
- package/js/src/src/pro/woofipro.js +1335 -0
- package/js/src/src/pro/xt.d.ts +165 -0
- package/js/src/src/pro/xt.js +1230 -0
- package/js/src/src/probit.d.ts +283 -0
- package/js/src/src/probit.js +1935 -0
- package/js/src/src/protobuf/mexc/compiled.cjs +7186 -0
- package/js/src/src/protobuf/mexc/compiled.d.cts +8 -0
- package/js/src/src/raastin.d.ts +24 -0
- package/js/src/src/raastin.js +494 -0
- package/js/src/src/ramzinex.d.ts +23 -0
- package/js/src/src/ramzinex.js +510 -0
- package/js/src/src/sarmayex.d.ts +21 -0
- package/js/src/src/sarmayex.js +376 -0
- package/js/src/src/sarrafex.d.ts +23 -0
- package/js/src/src/sarrafex.js +501 -0
- package/js/src/src/static_dependencies/ethers/abi-coder.d.ts +50 -0
- package/js/src/src/static_dependencies/ethers/abi-coder.js +148 -0
- package/js/src/src/static_dependencies/ethers/address/address.d.ts +55 -0
- package/js/src/src/static_dependencies/ethers/address/address.js +162 -0
- package/js/src/src/static_dependencies/ethers/address/checks.d.ts +80 -0
- package/js/src/src/static_dependencies/ethers/address/checks.js +119 -0
- package/js/src/src/static_dependencies/ethers/address/contract-address.d.ts +47 -0
- package/js/src/src/static_dependencies/ethers/address/contract-address.js +73 -0
- package/js/src/src/static_dependencies/ethers/address/index.d.ts +48 -0
- package/js/src/src/static_dependencies/ethers/address/index.js +24 -0
- package/js/src/src/static_dependencies/ethers/bytes32.d.ts +14 -0
- package/js/src/src/static_dependencies/ethers/bytes32.js +45 -0
- package/js/src/src/static_dependencies/ethers/coders/abstract-coder.d.ts +120 -0
- package/js/src/src/static_dependencies/ethers/coders/abstract-coder.js +424 -0
- package/js/src/src/static_dependencies/ethers/coders/address.d.ts +12 -0
- package/js/src/src/static_dependencies/ethers/coders/address.js +34 -0
- package/js/src/src/static_dependencies/ethers/coders/anonymous.d.ts +14 -0
- package/js/src/src/static_dependencies/ethers/coders/anonymous.js +27 -0
- package/js/src/src/static_dependencies/ethers/coders/array.d.ts +24 -0
- package/js/src/src/static_dependencies/ethers/coders/array.js +162 -0
- package/js/src/src/static_dependencies/ethers/coders/boolean.d.ts +12 -0
- package/js/src/src/static_dependencies/ethers/coders/boolean.js +26 -0
- package/js/src/src/static_dependencies/ethers/coders/bytes.d.ts +18 -0
- package/js/src/src/static_dependencies/ethers/coders/bytes.js +39 -0
- package/js/src/src/static_dependencies/ethers/coders/fixed-bytes.d.ts +14 -0
- package/js/src/src/static_dependencies/ethers/coders/fixed-bytes.js +32 -0
- package/js/src/src/static_dependencies/ethers/coders/null.d.ts +11 -0
- package/js/src/src/static_dependencies/ethers/coders/null.js +29 -0
- package/js/src/src/static_dependencies/ethers/coders/number.d.ts +15 -0
- package/js/src/src/static_dependencies/ethers/coders/number.js +48 -0
- package/js/src/src/static_dependencies/ethers/coders/string.d.ts +12 -0
- package/js/src/src/static_dependencies/ethers/coders/string.js +26 -0
- package/js/src/src/static_dependencies/ethers/coders/tuple.d.ts +15 -0
- package/js/src/src/static_dependencies/ethers/coders/tuple.js +67 -0
- package/js/src/src/static_dependencies/ethers/fragments.d.ts +458 -0
- package/js/src/src/static_dependencies/ethers/fragments.js +1252 -0
- package/js/src/src/static_dependencies/ethers/hash/index.d.ts +10 -0
- package/js/src/src/static_dependencies/ethers/hash/index.js +15 -0
- package/js/src/src/static_dependencies/ethers/hash/solidity.d.ts +30 -0
- package/js/src/src/static_dependencies/ethers/hash/solidity.js +107 -0
- package/js/src/src/static_dependencies/ethers/hash/typed-data.d.ts +144 -0
- package/js/src/src/static_dependencies/ethers/hash/typed-data.js +490 -0
- package/js/src/src/static_dependencies/ethers/index.d.ts +19 -0
- package/js/src/src/static_dependencies/ethers/index.js +22 -0
- package/js/src/src/static_dependencies/ethers/interface.d.ts +380 -0
- package/js/src/src/static_dependencies/ethers/interface.js +990 -0
- package/js/src/src/static_dependencies/ethers/typed.d.ts +569 -0
- package/js/src/src/static_dependencies/ethers/typed.js +608 -0
- package/js/src/src/static_dependencies/ethers/utils/base58.d.ts +22 -0
- package/js/src/src/static_dependencies/ethers/utils/base58.js +68 -0
- package/js/src/src/static_dependencies/ethers/utils/base64.d.ts +39 -0
- package/js/src/src/static_dependencies/ethers/utils/base64.js +58 -0
- package/js/src/src/static_dependencies/ethers/utils/data.d.ts +92 -0
- package/js/src/src/static_dependencies/ethers/utils/data.js +175 -0
- package/js/src/src/static_dependencies/ethers/utils/errors.d.ts +509 -0
- package/js/src/src/static_dependencies/ethers/utils/errors.js +227 -0
- package/js/src/src/static_dependencies/ethers/utils/events.d.ts +76 -0
- package/js/src/src/static_dependencies/ethers/utils/events.js +52 -0
- package/js/src/src/static_dependencies/ethers/utils/fixednumber.d.ts +251 -0
- package/js/src/src/static_dependencies/ethers/utils/fixednumber.js +529 -0
- package/js/src/src/static_dependencies/ethers/utils/index.d.ts +30 -0
- package/js/src/src/static_dependencies/ethers/utils/index.js +38 -0
- package/js/src/src/static_dependencies/ethers/utils/maths.d.ts +65 -0
- package/js/src/src/static_dependencies/ethers/utils/maths.js +220 -0
- package/js/src/src/static_dependencies/ethers/utils/properties.d.ts +22 -0
- package/js/src/src/static_dependencies/ethers/utils/properties.js +59 -0
- package/js/src/src/static_dependencies/ethers/utils/rlp-decode.d.ts +5 -0
- package/js/src/src/static_dependencies/ethers/utils/rlp-decode.js +84 -0
- package/js/src/src/static_dependencies/ethers/utils/rlp-encode.d.ts +5 -0
- package/js/src/src/static_dependencies/ethers/utils/rlp-encode.js +54 -0
- package/js/src/src/static_dependencies/ethers/utils/rlp.d.ts +16 -0
- package/js/src/src/static_dependencies/ethers/utils/rlp.js +14 -0
- package/js/src/src/static_dependencies/ethers/utils/units.d.ts +23 -0
- package/js/src/src/static_dependencies/ethers/utils/units.js +88 -0
- package/js/src/src/static_dependencies/ethers/utils/utf8.d.ts +95 -0
- package/js/src/src/static_dependencies/ethers/utils/utf8.js +225 -0
- package/js/src/src/static_dependencies/ethers/utils/uuid.d.ts +7 -0
- package/js/src/src/static_dependencies/ethers/utils/uuid.js +35 -0
- package/js/src/src/static_dependencies/fflake/browser.d.ts +222 -0
- package/js/src/src/static_dependencies/fflake/browser.js +2578 -0
- package/js/src/src/static_dependencies/jsencrypt/JSEncrypt.d.ts +116 -0
- package/js/src/src/static_dependencies/jsencrypt/JSEncrypt.js +194 -0
- package/js/src/src/static_dependencies/jsencrypt/JSEncryptRSAKey.d.ts +142 -0
- package/js/src/src/static_dependencies/jsencrypt/JSEncryptRSAKey.js +307 -0
- package/js/src/src/static_dependencies/jsencrypt/lib/asn1js/asn1.d.ts +51 -0
- package/js/src/src/static_dependencies/jsencrypt/lib/asn1js/asn1.js +565 -0
- package/js/src/src/static_dependencies/jsencrypt/lib/asn1js/base64.d.ts +5 -0
- package/js/src/src/static_dependencies/jsencrypt/lib/asn1js/base64.js +94 -0
- package/js/src/src/static_dependencies/jsencrypt/lib/asn1js/hex.d.ts +3 -0
- package/js/src/src/static_dependencies/jsencrypt/lib/asn1js/hex.js +70 -0
- package/js/src/src/static_dependencies/jsencrypt/lib/asn1js/int10.d.ts +9 -0
- package/js/src/src/static_dependencies/jsencrypt/lib/asn1js/int10.js +91 -0
- package/js/src/src/static_dependencies/jsencrypt/lib/jsbn/base64.d.ts +3 -0
- package/js/src/src/static_dependencies/jsencrypt/lib/jsbn/base64.js +25 -0
- package/js/src/src/static_dependencies/jsencrypt/lib/jsbn/jsbn.d.ts +101 -0
- package/js/src/src/static_dependencies/jsencrypt/lib/jsbn/jsbn.js +1757 -0
- package/js/src/src/static_dependencies/jsencrypt/lib/jsbn/prng4.d.ts +10 -0
- package/js/src/src/static_dependencies/jsencrypt/lib/jsbn/prng4.js +50 -0
- package/js/src/src/static_dependencies/jsencrypt/lib/jsbn/rng.d.ts +3 -0
- package/js/src/src/static_dependencies/jsencrypt/lib/jsbn/rng.js +80 -0
- package/js/src/src/static_dependencies/jsencrypt/lib/jsbn/rsa.d.ts +23 -0
- package/js/src/src/static_dependencies/jsencrypt/lib/jsbn/rsa.js +377 -0
- package/js/src/src/static_dependencies/jsencrypt/lib/jsbn/util.d.ts +7 -0
- package/js/src/src/static_dependencies/jsencrypt/lib/jsbn/util.js +64 -0
- package/js/src/src/static_dependencies/jsencrypt/lib/jsrsasign/asn1-1.0.d.ts +24 -0
- package/js/src/src/static_dependencies/jsencrypt/lib/jsrsasign/asn1-1.0.js +1627 -0
- package/js/src/src/static_dependencies/noble-curves/_shortw_utils.d.ts +60 -0
- package/js/src/src/static_dependencies/noble-curves/_shortw_utils.js +22 -0
- package/js/src/src/static_dependencies/noble-curves/abstract/curve.d.ts +67 -0
- package/js/src/src/static_dependencies/noble-curves/abstract/curve.js +157 -0
- package/js/src/src/static_dependencies/noble-curves/abstract/edwards.d.ts +79 -0
- package/js/src/src/static_dependencies/noble-curves/abstract/edwards.js +432 -0
- package/js/src/src/static_dependencies/noble-curves/abstract/hash-to-curve.d.ts +56 -0
- package/js/src/src/static_dependencies/noble-curves/abstract/hash-to-curve.js +171 -0
- package/js/src/src/static_dependencies/noble-curves/abstract/modular.d.ts +68 -0
- package/js/src/src/static_dependencies/noble-curves/abstract/modular.js +351 -0
- package/js/src/src/static_dependencies/noble-curves/abstract/montgomery.d.ts +25 -0
- package/js/src/src/static_dependencies/noble-curves/abstract/montgomery.js +162 -0
- package/js/src/src/static_dependencies/noble-curves/abstract/poseidon.d.ts +29 -0
- package/js/src/src/static_dependencies/noble-curves/abstract/poseidon.js +115 -0
- package/js/src/src/static_dependencies/noble-curves/abstract/utils.d.ts +53 -0
- package/js/src/src/static_dependencies/noble-curves/abstract/utils.js +227 -0
- package/js/src/src/static_dependencies/noble-curves/abstract/weierstrass.d.ts +204 -0
- package/js/src/src/static_dependencies/noble-curves/abstract/weierstrass.js +1016 -0
- package/js/src/src/static_dependencies/noble-curves/ed25519.d.ts +53 -0
- package/js/src/src/static_dependencies/noble-curves/ed25519.js +402 -0
- package/js/src/src/static_dependencies/noble-curves/p256.d.ts +103 -0
- package/js/src/src/static_dependencies/noble-curves/p256.js +47 -0
- package/js/src/src/static_dependencies/noble-curves/secp256k1.d.ts +91 -0
- package/js/src/src/static_dependencies/noble-curves/secp256k1.js +257 -0
- package/js/src/src/static_dependencies/noble-hashes/_assert.d.ts +21 -0
- package/js/src/src/static_dependencies/noble-hashes/_assert.js +48 -0
- package/js/src/src/static_dependencies/noble-hashes/_sha2.d.ts +23 -0
- package/js/src/src/static_dependencies/noble-hashes/_sha2.js +119 -0
- package/js/src/src/static_dependencies/noble-hashes/_u64.d.ts +35 -0
- package/js/src/src/static_dependencies/noble-hashes/_u64.js +66 -0
- package/js/src/src/static_dependencies/noble-hashes/crypto.d.ts +1 -0
- package/js/src/src/static_dependencies/noble-hashes/crypto.js +7 -0
- package/js/src/src/static_dependencies/noble-hashes/hmac.d.ts +26 -0
- package/js/src/src/static_dependencies/noble-hashes/hmac.js +82 -0
- package/js/src/src/static_dependencies/noble-hashes/md5.d.ts +18 -0
- package/js/src/src/static_dependencies/noble-hashes/md5.js +242 -0
- package/js/src/src/static_dependencies/noble-hashes/sha1.d.ts +21 -0
- package/js/src/src/static_dependencies/noble-hashes/sha1.js +90 -0
- package/js/src/src/static_dependencies/noble-hashes/sha256.d.ts +34 -0
- package/js/src/src/static_dependencies/noble-hashes/sha256.js +129 -0
- package/js/src/src/static_dependencies/noble-hashes/sha3.d.ts +97 -0
- package/js/src/src/static_dependencies/noble-hashes/sha3.js +211 -0
- package/js/src/src/static_dependencies/noble-hashes/sha512.d.ts +66 -0
- package/js/src/src/static_dependencies/noble-hashes/sha512.js +236 -0
- package/js/src/src/static_dependencies/noble-hashes/utils.d.ts +77 -0
- package/js/src/src/static_dependencies/noble-hashes/utils.js +147 -0
- package/js/src/src/static_dependencies/proxies/agent-base/helpers.d.ts +14 -0
- package/js/src/src/static_dependencies/proxies/agent-base/helpers.js +42 -0
- package/js/src/src/static_dependencies/proxies/agent-base/index.d.ts +33 -0
- package/js/src/src/static_dependencies/proxies/agent-base/index.js +82 -0
- package/js/src/src/static_dependencies/proxies/http-proxy-agent/index.d.ts +40 -0
- package/js/src/src/static_dependencies/proxies/http-proxy-agent/index.js +119 -0
- package/js/src/src/static_dependencies/proxies/https-proxy-agent/index.d.ts +45 -0
- package/js/src/src/static_dependencies/proxies/https-proxy-agent/index.js +150 -0
- package/js/src/src/static_dependencies/proxies/https-proxy-agent/parse-proxy-response.d.ts +15 -0
- package/js/src/src/static_dependencies/proxies/https-proxy-agent/parse-proxy-response.js +95 -0
- package/js/src/src/static_dependencies/qs/formats.cjs +22 -0
- package/js/src/src/static_dependencies/qs/formats.d.cts +14 -0
- package/js/src/src/static_dependencies/qs/index.cjs +15 -0
- package/js/src/src/static_dependencies/qs/index.d.cts +10 -0
- package/js/src/src/static_dependencies/qs/parse.cjs +208 -0
- package/js/src/src/static_dependencies/qs/parse.d.cts +8 -0
- package/js/src/src/static_dependencies/qs/stringify.cjs +192 -0
- package/js/src/src/static_dependencies/qs/stringify.d.cts +8 -0
- package/js/src/src/static_dependencies/qs/utils.cjs +202 -0
- package/js/src/src/static_dependencies/qs/utils.d.cts +15 -0
- package/js/src/src/static_dependencies/scure-base/index.d.ts +92 -0
- package/js/src/src/static_dependencies/scure-base/index.js +420 -0
- package/js/src/src/static_dependencies/scure-starknet/index.d.ts +79 -0
- package/js/src/src/static_dependencies/scure-starknet/index.js +323 -0
- package/js/src/src/static_dependencies/starknet/constants.d.ts +61 -0
- package/js/src/src/static_dependencies/starknet/constants.js +67 -0
- package/js/src/src/static_dependencies/starknet/index.d.ts +3 -0
- package/js/src/src/static_dependencies/starknet/index.js +9 -0
- package/js/src/src/static_dependencies/starknet/types/cairoEnum.d.ts +2 -0
- package/js/src/src/static_dependencies/starknet/types/cairoEnum.js +7 -0
- package/js/src/src/static_dependencies/starknet/types/calldata.d.ts +19 -0
- package/js/src/src/static_dependencies/starknet/types/calldata.js +28 -0
- package/js/src/src/static_dependencies/starknet/types/index.d.ts +13 -0
- package/js/src/src/static_dependencies/starknet/types/index.js +16 -0
- package/js/src/src/static_dependencies/starknet/types/lib/contract/abi.d.ts +71 -0
- package/js/src/src/static_dependencies/starknet/types/lib/contract/abi.js +13 -0
- package/js/src/src/static_dependencies/starknet/types/lib/contract/index.d.ts +24 -0
- package/js/src/src/static_dependencies/starknet/types/lib/contract/index.js +16 -0
- package/js/src/src/static_dependencies/starknet/types/lib/contract/legacy.d.ts +33 -0
- package/js/src/src/static_dependencies/starknet/types/lib/contract/legacy.js +7 -0
- package/js/src/src/static_dependencies/starknet/types/lib/contract/sierra.d.ts +52 -0
- package/js/src/src/static_dependencies/starknet/types/lib/contract/sierra.js +7 -0
- package/js/src/src/static_dependencies/starknet/types/lib/index.d.ts +248 -0
- package/js/src/src/static_dependencies/starknet/types/lib/index.js +52 -0
- package/js/src/src/static_dependencies/starknet/types/typedData.d.ts +44 -0
- package/js/src/src/static_dependencies/starknet/types/typedData.js +19 -0
- package/js/src/src/static_dependencies/starknet/utils/assert.d.ts +7 -0
- package/js/src/src/static_dependencies/starknet/utils/assert.js +17 -0
- package/js/src/src/static_dependencies/starknet/utils/cairoDataTypes/felt.d.ts +6 -0
- package/js/src/src/static_dependencies/starknet/utils/cairoDataTypes/felt.js +43 -0
- package/js/src/src/static_dependencies/starknet/utils/cairoDataTypes/uint256.d.ts +72 -0
- package/js/src/src/static_dependencies/starknet/utils/cairoDataTypes/uint256.js +117 -0
- package/js/src/src/static_dependencies/starknet/utils/cairoDataTypes/uint512.d.ts +76 -0
- package/js/src/src/static_dependencies/starknet/utils/cairoDataTypes/uint512.js +136 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/byteArray.d.ts +32 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/byteArray.js +59 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/cairo.d.ts +183 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/cairo.js +229 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/enum/CairoCustomEnum.d.ts +38 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/enum/CairoCustomEnum.js +57 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/enum/CairoOption.d.ts +35 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/enum/CairoOption.js +64 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/enum/CairoResult.d.ts +34 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/enum/CairoResult.js +63 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/enum/index.d.ts +3 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/enum/index.js +9 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/formatter.d.ts +9 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/formatter.js +67 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/index.d.ts +89 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/index.js +280 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/parser/index.d.ts +5 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/parser/index.js +30 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/parser/interface.d.ts +20 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/parser/interface.js +8 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/parser/parser-0-1.1.0.d.ts +24 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/parser/parser-0-1.1.0.js +36 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/parser/parser-2.0.0.d.ts +23 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/parser/parser-2.0.0.js +40 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/propertyOrder.d.ts +2 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/propertyOrder.js +155 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/requestParser.d.ts +11 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/requestParser.js +248 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/responseParser.d.ts +11 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/responseParser.js +214 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/tuple.d.ts +6 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/tuple.js +113 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/validate.d.ts +6 -0
- package/js/src/src/static_dependencies/starknet/utils/calldata/validate.js +208 -0
- package/js/src/src/static_dependencies/starknet/utils/encode.d.ts +207 -0
- package/js/src/src/static_dependencies/starknet/utils/encode.js +282 -0
- package/js/src/src/static_dependencies/starknet/utils/hash/classHash.d.ts +57 -0
- package/js/src/src/static_dependencies/starknet/utils/hash/classHash.js +223 -0
- package/js/src/src/static_dependencies/starknet/utils/hash/index.d.ts +6 -0
- package/js/src/src/static_dependencies/starknet/utils/hash/index.js +13 -0
- package/js/src/src/static_dependencies/starknet/utils/merkle.d.ts +35 -0
- package/js/src/src/static_dependencies/starknet/utils/merkle.js +84 -0
- package/js/src/src/static_dependencies/starknet/utils/num.d.ts +182 -0
- package/js/src/src/static_dependencies/starknet/utils/num.js +244 -0
- package/js/src/src/static_dependencies/starknet/utils/selector.d.ts +48 -0
- package/js/src/src/static_dependencies/starknet/utils/selector.js +85 -0
- package/js/src/src/static_dependencies/starknet/utils/shortString.d.ts +57 -0
- package/js/src/src/static_dependencies/starknet/utils/shortString.js +96 -0
- package/js/src/src/static_dependencies/starknet/utils/typedData.d.ts +54 -0
- package/js/src/src/static_dependencies/starknet/utils/typedData.js +321 -0
- package/js/src/src/static_dependencies/watchable/src/types.d.ts +28 -0
- package/js/src/src/static_dependencies/watchable/src/types.js +8 -0
- package/js/src/src/static_dependencies/watchable/src/unpromise.d.ts +120 -0
- package/js/src/src/static_dependencies/watchable/src/unpromise.js +297 -0
- package/js/src/src/static_dependencies/zklink/zklink-sdk-web.d.ts +1279 -0
- package/js/src/src/static_dependencies/zklink/zklink-sdk-web.js +4282 -0
- package/js/src/src/tabdeal.d.ts +23 -0
- package/js/src/src/tabdeal.js +387 -0
- package/js/src/src/tehran_exchange.d.ts +21 -0
- package/js/src/src/tehran_exchange.js +333 -0
- package/js/src/src/tetherland.d.ts +21 -0
- package/js/src/src/tetherland.js +367 -0
- package/js/src/src/timex.d.ts +247 -0
- package/js/src/src/timex.js +1792 -0
- package/js/src/src/tokocrypto.d.ts +261 -0
- package/js/src/src/tokocrypto.js +2641 -0
- package/js/src/src/toobit.d.ts +22 -0
- package/js/src/src/toobit.js +445 -0
- package/js/src/src/tradeogre.d.ts +149 -0
- package/js/src/src/tradeogre.js +878 -0
- package/js/src/src/twox.d.ts +21 -0
- package/js/src/src/twox.js +371 -0
- package/js/src/src/ubitex.d.ts +23 -0
- package/js/src/src/ubitex.js +433 -0
- package/js/src/src/upbit.d.ts +377 -0
- package/js/src/src/upbit.js +2340 -0
- package/js/src/src/vertex.d.ts +346 -0
- package/js/src/src/vertex.js +3146 -0
- package/js/src/src/wallex.d.ts +23 -0
- package/js/src/src/wallex.js +467 -0
- package/js/src/src/wavesexchange.d.ts +244 -0
- package/js/src/src/wavesexchange.js +2747 -0
- package/js/src/src/whitebit.d.ts +571 -0
- package/js/src/src/whitebit.js +3437 -0
- package/js/src/src/woo.d.ts +727 -0
- package/js/src/src/woo.js +4183 -0
- package/js/src/src/woofipro.d.ts +497 -0
- package/js/src/src/woofipro.js +2941 -0
- package/js/src/src/xt.d.ts +568 -0
- package/js/src/src/xt.js +5184 -0
- package/js/src/src/yobit.d.ts +197 -0
- package/js/src/src/yobit.js +1453 -0
- package/js/src/src/zaif.d.ts +136 -0
- package/js/src/src/zaif.js +821 -0
- package/js/src/src/zonda.d.ts +214 -0
- package/js/src/src/zonda.js +1984 -0
- package/js/test.d.ts +1 -1
- package/js/test.js +33 -33
- package/package.json +1 -1
|
@@ -0,0 +1,1252 @@
|
|
|
1
|
+
// ----------------------------------------------------------------------------
|
|
2
|
+
|
|
3
|
+
// PLEASE DO NOT EDIT THIS FILE, IT IS GENERATED AND WILL BE OVERWRITTEN:
|
|
4
|
+
// https://github.com/ccxt/ccxt/blob/master/CONTRIBUTING.md#how-to-contribute-code
|
|
5
|
+
// EDIT THE CORRESPONDENT .ts FILE INSTEAD
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* A fragment is a single item from an ABI, which may represent any of:
|
|
9
|
+
*
|
|
10
|
+
* - [Functions](FunctionFragment)
|
|
11
|
+
* - [Events](EventFragment)
|
|
12
|
+
* - [Constructors](ConstructorFragment)
|
|
13
|
+
* - Custom [Errors](ErrorFragment)
|
|
14
|
+
* - [Fallback or Receive](FallbackFragment) functions
|
|
15
|
+
*
|
|
16
|
+
* @_subsection api/abi/abi-coder:Fragments [about-fragments]
|
|
17
|
+
*/
|
|
18
|
+
var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
|
|
19
|
+
if (kind === "m") throw new TypeError("Private method is not writable");
|
|
20
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
|
|
21
|
+
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
|
|
22
|
+
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
23
|
+
};
|
|
24
|
+
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
25
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
26
|
+
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
27
|
+
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
28
|
+
};
|
|
29
|
+
var _TokenString_instances, _TokenString_offset, _TokenString_tokens, _TokenString_subTokenString, _ParamType_instances, _ParamType_walkAsync;
|
|
30
|
+
import { defineProperties, getBigInt, getNumber, assert, assertPrivate, assertArgument, id } from "./utils/index.js";
|
|
31
|
+
;
|
|
32
|
+
// [ "a", "b" ] => { "a": 1, "b": 1 }
|
|
33
|
+
function setify(items) {
|
|
34
|
+
const result = new Set();
|
|
35
|
+
items.forEach((k) => result.add(k));
|
|
36
|
+
return Object.freeze(result);
|
|
37
|
+
}
|
|
38
|
+
const _kwVisibDeploy = "external public payable";
|
|
39
|
+
const KwVisibDeploy = setify(_kwVisibDeploy.split(" "));
|
|
40
|
+
// Visibility Keywords
|
|
41
|
+
const _kwVisib = "constant external internal payable private public pure view";
|
|
42
|
+
const KwVisib = setify(_kwVisib.split(" "));
|
|
43
|
+
const _kwTypes = "constructor error event fallback function receive struct";
|
|
44
|
+
const KwTypes = setify(_kwTypes.split(" "));
|
|
45
|
+
const _kwModifiers = "calldata memory storage payable indexed";
|
|
46
|
+
const KwModifiers = setify(_kwModifiers.split(" "));
|
|
47
|
+
const _kwOther = "tuple returns";
|
|
48
|
+
// All Keywords
|
|
49
|
+
const _keywords = [_kwTypes, _kwModifiers, _kwOther, _kwVisib].join(" ");
|
|
50
|
+
const Keywords = setify(_keywords.split(" "));
|
|
51
|
+
// Single character tokens
|
|
52
|
+
const SimpleTokens = {
|
|
53
|
+
"(": "OPEN_PAREN", ")": "CLOSE_PAREN",
|
|
54
|
+
"[": "OPEN_BRACKET", "]": "CLOSE_BRACKET",
|
|
55
|
+
",": "COMMA", "@": "AT"
|
|
56
|
+
};
|
|
57
|
+
// Parser regexes to consume the next token
|
|
58
|
+
const regexWhitespacePrefix = new RegExp("^(\\s*)");
|
|
59
|
+
const regexNumberPrefix = new RegExp("^([0-9]+)");
|
|
60
|
+
const regexIdPrefix = new RegExp("^([a-zA-Z$_][a-zA-Z0-9$_]*)");
|
|
61
|
+
// Parser regexs to check validity
|
|
62
|
+
const regexId = new RegExp("^([a-zA-Z$_][a-zA-Z0-9$_]*)$");
|
|
63
|
+
const regexType = new RegExp("^(address|bool|bytes([0-9]*)|string|u?int([0-9]*))$");
|
|
64
|
+
class TokenString {
|
|
65
|
+
constructor(tokens) {
|
|
66
|
+
_TokenString_instances.add(this);
|
|
67
|
+
_TokenString_offset.set(this, void 0);
|
|
68
|
+
_TokenString_tokens.set(this, void 0);
|
|
69
|
+
__classPrivateFieldSet(this, _TokenString_offset, 0, "f");
|
|
70
|
+
__classPrivateFieldSet(this, _TokenString_tokens, tokens.slice(), "f");
|
|
71
|
+
}
|
|
72
|
+
get offset() { return __classPrivateFieldGet(this, _TokenString_offset, "f"); }
|
|
73
|
+
get length() { return __classPrivateFieldGet(this, _TokenString_tokens, "f").length - __classPrivateFieldGet(this, _TokenString_offset, "f"); }
|
|
74
|
+
clone() { return new TokenString(__classPrivateFieldGet(this, _TokenString_tokens, "f")); }
|
|
75
|
+
reset() { __classPrivateFieldSet(this, _TokenString_offset, 0, "f"); }
|
|
76
|
+
// Pops and returns the value of the next token, if it is a keyword in allowed; throws if out of tokens
|
|
77
|
+
popKeyword(allowed) {
|
|
78
|
+
const top = this.peek();
|
|
79
|
+
if (top.type !== "KEYWORD" || !allowed.has(top.text)) {
|
|
80
|
+
throw new Error(`expected keyword ${top.text}`);
|
|
81
|
+
}
|
|
82
|
+
return this.pop().text;
|
|
83
|
+
}
|
|
84
|
+
// Pops and returns the value of the next token if it is `type`; throws if out of tokens
|
|
85
|
+
popType(type) {
|
|
86
|
+
if (this.peek().type !== type) {
|
|
87
|
+
throw new Error(`expected ${type}; got ${JSON.stringify(this.peek())}`);
|
|
88
|
+
}
|
|
89
|
+
return this.pop().text;
|
|
90
|
+
}
|
|
91
|
+
// Pops and returns a "(" TOKENS ")"
|
|
92
|
+
popParen() {
|
|
93
|
+
const top = this.peek();
|
|
94
|
+
if (top.type !== "OPEN_PAREN") {
|
|
95
|
+
throw new Error("bad start");
|
|
96
|
+
}
|
|
97
|
+
const result = __classPrivateFieldGet(this, _TokenString_instances, "m", _TokenString_subTokenString).call(this, __classPrivateFieldGet(this, _TokenString_offset, "f") + 1, top.match + 1);
|
|
98
|
+
__classPrivateFieldSet(this, _TokenString_offset, top.match + 1, "f");
|
|
99
|
+
return result;
|
|
100
|
+
}
|
|
101
|
+
// Pops and returns the items within "(" ITEM1 "," ITEM2 "," ... ")"
|
|
102
|
+
popParams() {
|
|
103
|
+
const top = this.peek();
|
|
104
|
+
if (top.type !== "OPEN_PAREN") {
|
|
105
|
+
throw new Error("bad start");
|
|
106
|
+
}
|
|
107
|
+
const result = [];
|
|
108
|
+
while (__classPrivateFieldGet(this, _TokenString_offset, "f") < top.match - 1) {
|
|
109
|
+
const link = this.peek().linkNext;
|
|
110
|
+
result.push(__classPrivateFieldGet(this, _TokenString_instances, "m", _TokenString_subTokenString).call(this, __classPrivateFieldGet(this, _TokenString_offset, "f") + 1, link));
|
|
111
|
+
__classPrivateFieldSet(this, _TokenString_offset, link, "f");
|
|
112
|
+
}
|
|
113
|
+
__classPrivateFieldSet(this, _TokenString_offset, top.match + 1, "f");
|
|
114
|
+
return result;
|
|
115
|
+
}
|
|
116
|
+
// Returns the top Token, throwing if out of tokens
|
|
117
|
+
peek() {
|
|
118
|
+
if (__classPrivateFieldGet(this, _TokenString_offset, "f") >= __classPrivateFieldGet(this, _TokenString_tokens, "f").length) {
|
|
119
|
+
throw new Error("out-of-bounds");
|
|
120
|
+
}
|
|
121
|
+
return __classPrivateFieldGet(this, _TokenString_tokens, "f")[__classPrivateFieldGet(this, _TokenString_offset, "f")];
|
|
122
|
+
}
|
|
123
|
+
// Returns the next value, if it is a keyword in `allowed`
|
|
124
|
+
peekKeyword(allowed) {
|
|
125
|
+
const top = this.peekType("KEYWORD");
|
|
126
|
+
return (top != null && allowed.has(top)) ? top : null;
|
|
127
|
+
}
|
|
128
|
+
// Returns the value of the next token if it is `type`
|
|
129
|
+
peekType(type) {
|
|
130
|
+
if (this.length === 0) {
|
|
131
|
+
return null;
|
|
132
|
+
}
|
|
133
|
+
const top = this.peek();
|
|
134
|
+
return (top.type === type) ? top.text : null;
|
|
135
|
+
}
|
|
136
|
+
// Returns the next token; throws if out of tokens
|
|
137
|
+
pop() {
|
|
138
|
+
var _a;
|
|
139
|
+
const result = this.peek();
|
|
140
|
+
__classPrivateFieldSet(this, _TokenString_offset, (_a = __classPrivateFieldGet(this, _TokenString_offset, "f"), _a++, _a), "f");
|
|
141
|
+
return result;
|
|
142
|
+
}
|
|
143
|
+
toString() {
|
|
144
|
+
const tokens = [];
|
|
145
|
+
for (let i = __classPrivateFieldGet(this, _TokenString_offset, "f"); i < __classPrivateFieldGet(this, _TokenString_tokens, "f").length; i++) {
|
|
146
|
+
const token = __classPrivateFieldGet(this, _TokenString_tokens, "f")[i];
|
|
147
|
+
tokens.push(`${token.type}:${token.text}`);
|
|
148
|
+
}
|
|
149
|
+
return `<TokenString ${tokens.join(" ")}>`;
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
_TokenString_offset = new WeakMap(), _TokenString_tokens = new WeakMap(), _TokenString_instances = new WeakSet(), _TokenString_subTokenString = function _TokenString_subTokenString(from = 0, to = 0) {
|
|
153
|
+
return new TokenString(__classPrivateFieldGet(this, _TokenString_tokens, "f").slice(from, to).map((t) => {
|
|
154
|
+
return Object.freeze(Object.assign({}, t, {
|
|
155
|
+
match: (t.match - from),
|
|
156
|
+
linkBack: (t.linkBack - from),
|
|
157
|
+
linkNext: (t.linkNext - from),
|
|
158
|
+
}));
|
|
159
|
+
}));
|
|
160
|
+
};
|
|
161
|
+
function lex(text) {
|
|
162
|
+
const tokens = [];
|
|
163
|
+
const throwError = (message) => {
|
|
164
|
+
const token = (offset < text.length) ? JSON.stringify(text[offset]) : "$EOI";
|
|
165
|
+
throw new Error(`invalid token ${token} at ${offset}: ${message}`);
|
|
166
|
+
};
|
|
167
|
+
let brackets = [];
|
|
168
|
+
let commas = [];
|
|
169
|
+
let offset = 0;
|
|
170
|
+
while (offset < text.length) {
|
|
171
|
+
// Strip off any leading whitespace
|
|
172
|
+
let cur = text.substring(offset);
|
|
173
|
+
let match = cur.match(regexWhitespacePrefix);
|
|
174
|
+
if (match) {
|
|
175
|
+
offset += match[1].length;
|
|
176
|
+
cur = text.substring(offset);
|
|
177
|
+
}
|
|
178
|
+
const token = { depth: brackets.length, linkBack: -1, linkNext: -1, match: -1, type: "", text: "", offset, value: -1 };
|
|
179
|
+
tokens.push(token);
|
|
180
|
+
let type = (SimpleTokens[cur[0]] || "");
|
|
181
|
+
if (type) {
|
|
182
|
+
token.type = type;
|
|
183
|
+
token.text = cur[0];
|
|
184
|
+
offset++;
|
|
185
|
+
if (type === "OPEN_PAREN") {
|
|
186
|
+
brackets.push(tokens.length - 1);
|
|
187
|
+
commas.push(tokens.length - 1);
|
|
188
|
+
}
|
|
189
|
+
else if (type == "CLOSE_PAREN") {
|
|
190
|
+
if (brackets.length === 0) {
|
|
191
|
+
throwError("no matching open bracket");
|
|
192
|
+
}
|
|
193
|
+
token.match = brackets.pop();
|
|
194
|
+
(tokens[token.match]).match = tokens.length - 1;
|
|
195
|
+
token.depth--;
|
|
196
|
+
token.linkBack = commas.pop();
|
|
197
|
+
(tokens[token.linkBack]).linkNext = tokens.length - 1;
|
|
198
|
+
}
|
|
199
|
+
else if (type === "COMMA") {
|
|
200
|
+
token.linkBack = commas.pop();
|
|
201
|
+
(tokens[token.linkBack]).linkNext = tokens.length - 1;
|
|
202
|
+
commas.push(tokens.length - 1);
|
|
203
|
+
}
|
|
204
|
+
else if (type === "OPEN_BRACKET") {
|
|
205
|
+
token.type = "BRACKET";
|
|
206
|
+
}
|
|
207
|
+
else if (type === "CLOSE_BRACKET") {
|
|
208
|
+
// Remove the CLOSE_BRACKET
|
|
209
|
+
let suffix = tokens.pop().text;
|
|
210
|
+
if (tokens.length > 0 && tokens[tokens.length - 1].type === "NUMBER") {
|
|
211
|
+
const value = tokens.pop().text;
|
|
212
|
+
suffix = value + suffix;
|
|
213
|
+
(tokens[tokens.length - 1]).value = getNumber(value);
|
|
214
|
+
}
|
|
215
|
+
if (tokens.length === 0 || tokens[tokens.length - 1].type !== "BRACKET") {
|
|
216
|
+
throw new Error("missing opening bracket");
|
|
217
|
+
}
|
|
218
|
+
(tokens[tokens.length - 1]).text += suffix;
|
|
219
|
+
}
|
|
220
|
+
continue;
|
|
221
|
+
}
|
|
222
|
+
match = cur.match(regexIdPrefix);
|
|
223
|
+
if (match) {
|
|
224
|
+
token.text = match[1];
|
|
225
|
+
offset += token.text.length;
|
|
226
|
+
if (Keywords.has(token.text)) {
|
|
227
|
+
token.type = "KEYWORD";
|
|
228
|
+
continue;
|
|
229
|
+
}
|
|
230
|
+
if (token.text.match(regexType)) {
|
|
231
|
+
token.type = "TYPE";
|
|
232
|
+
continue;
|
|
233
|
+
}
|
|
234
|
+
token.type = "ID";
|
|
235
|
+
continue;
|
|
236
|
+
}
|
|
237
|
+
match = cur.match(regexNumberPrefix);
|
|
238
|
+
if (match) {
|
|
239
|
+
token.text = match[1];
|
|
240
|
+
token.type = "NUMBER";
|
|
241
|
+
offset += token.text.length;
|
|
242
|
+
continue;
|
|
243
|
+
}
|
|
244
|
+
throw new Error(`unexpected token ${JSON.stringify(cur[0])} at position ${offset}`);
|
|
245
|
+
}
|
|
246
|
+
return new TokenString(tokens.map((t) => Object.freeze(t)));
|
|
247
|
+
}
|
|
248
|
+
// Check only one of `allowed` is in `set`
|
|
249
|
+
function allowSingle(set, allowed) {
|
|
250
|
+
let included = [];
|
|
251
|
+
for (const key in allowed.keys()) {
|
|
252
|
+
if (set.has(key)) {
|
|
253
|
+
included.push(key);
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
if (included.length > 1) {
|
|
257
|
+
throw new Error(`conflicting types: ${included.join(", ")}`);
|
|
258
|
+
}
|
|
259
|
+
}
|
|
260
|
+
// Functions to process a Solidity Signature TokenString from left-to-right for...
|
|
261
|
+
// ...the name with an optional type, returning the name
|
|
262
|
+
function consumeName(type, tokens) {
|
|
263
|
+
if (tokens.peekKeyword(KwTypes)) {
|
|
264
|
+
const keyword = tokens.pop().text;
|
|
265
|
+
if (keyword !== type) {
|
|
266
|
+
throw new Error(`expected ${type}, got ${keyword}`);
|
|
267
|
+
}
|
|
268
|
+
}
|
|
269
|
+
return tokens.popType("ID");
|
|
270
|
+
}
|
|
271
|
+
// ...all keywords matching allowed, returning the keywords
|
|
272
|
+
function consumeKeywords(tokens, allowed) {
|
|
273
|
+
const keywords = new Set();
|
|
274
|
+
while (true) {
|
|
275
|
+
const keyword = tokens.peekType("KEYWORD");
|
|
276
|
+
if (keyword == null || (allowed && !allowed.has(keyword))) {
|
|
277
|
+
break;
|
|
278
|
+
}
|
|
279
|
+
tokens.pop();
|
|
280
|
+
if (keywords.has(keyword)) {
|
|
281
|
+
throw new Error(`duplicate keywords: ${JSON.stringify(keyword)}`);
|
|
282
|
+
}
|
|
283
|
+
keywords.add(keyword);
|
|
284
|
+
}
|
|
285
|
+
return Object.freeze(keywords);
|
|
286
|
+
}
|
|
287
|
+
// ...all visibility keywords, returning the coalesced mutability
|
|
288
|
+
function consumeMutability(tokens) {
|
|
289
|
+
let modifiers = consumeKeywords(tokens, KwVisib);
|
|
290
|
+
// Detect conflicting modifiers
|
|
291
|
+
allowSingle(modifiers, setify("constant payable nonpayable".split(" ")));
|
|
292
|
+
allowSingle(modifiers, setify("pure view payable nonpayable".split(" ")));
|
|
293
|
+
// Process mutability states
|
|
294
|
+
if (modifiers.has("view")) {
|
|
295
|
+
return "view";
|
|
296
|
+
}
|
|
297
|
+
if (modifiers.has("pure")) {
|
|
298
|
+
return "pure";
|
|
299
|
+
}
|
|
300
|
+
if (modifiers.has("payable")) {
|
|
301
|
+
return "payable";
|
|
302
|
+
}
|
|
303
|
+
if (modifiers.has("nonpayable")) {
|
|
304
|
+
return "nonpayable";
|
|
305
|
+
}
|
|
306
|
+
// Process legacy `constant` last
|
|
307
|
+
if (modifiers.has("constant")) {
|
|
308
|
+
return "view";
|
|
309
|
+
}
|
|
310
|
+
return "nonpayable";
|
|
311
|
+
}
|
|
312
|
+
// ...a parameter list, returning the ParamType list
|
|
313
|
+
function consumeParams(tokens, allowIndexed) {
|
|
314
|
+
return tokens.popParams().map((t) => ParamType.from(t, allowIndexed));
|
|
315
|
+
}
|
|
316
|
+
// ...a gas limit, returning a BigNumber or null if none
|
|
317
|
+
function consumeGas(tokens) {
|
|
318
|
+
if (tokens.peekType("AT")) {
|
|
319
|
+
tokens.pop();
|
|
320
|
+
if (tokens.peekType("NUMBER")) {
|
|
321
|
+
return getBigInt(tokens.pop().text);
|
|
322
|
+
}
|
|
323
|
+
throw new Error("invalid gas");
|
|
324
|
+
}
|
|
325
|
+
return null;
|
|
326
|
+
}
|
|
327
|
+
function consumeEoi(tokens) {
|
|
328
|
+
if (tokens.length) {
|
|
329
|
+
throw new Error(`unexpected tokens: ${tokens.toString()}`);
|
|
330
|
+
}
|
|
331
|
+
}
|
|
332
|
+
const regexArrayType = new RegExp(/^(.*)\[([0-9]*)\]$/);
|
|
333
|
+
function verifyBasicType(type) {
|
|
334
|
+
const match = type.match(regexType);
|
|
335
|
+
assertArgument(match, "invalid type", "type", type);
|
|
336
|
+
if (type === "uint") {
|
|
337
|
+
return "uint256";
|
|
338
|
+
}
|
|
339
|
+
if (type === "int") {
|
|
340
|
+
return "int256";
|
|
341
|
+
}
|
|
342
|
+
if (match[2]) {
|
|
343
|
+
// bytesXX
|
|
344
|
+
const length = parseInt(match[2]);
|
|
345
|
+
assertArgument(length !== 0 && length <= 32, "invalid bytes length", "type", type);
|
|
346
|
+
}
|
|
347
|
+
else if (match[3]) {
|
|
348
|
+
// intXX or uintXX
|
|
349
|
+
const size = parseInt(match[3]);
|
|
350
|
+
assertArgument(size !== 0 && size <= 256 && (size % 8) === 0, "invalid numeric width", "type", type);
|
|
351
|
+
}
|
|
352
|
+
return type;
|
|
353
|
+
}
|
|
354
|
+
// Make the Fragment constructors effectively private
|
|
355
|
+
const _guard = {};
|
|
356
|
+
const internal = Symbol.for("_ethers_internal");
|
|
357
|
+
const ParamTypeInternal = "_ParamTypeInternal";
|
|
358
|
+
const ErrorFragmentInternal = "_ErrorInternal";
|
|
359
|
+
const EventFragmentInternal = "_EventInternal";
|
|
360
|
+
const ConstructorFragmentInternal = "_ConstructorInternal";
|
|
361
|
+
const FallbackFragmentInternal = "_FallbackInternal";
|
|
362
|
+
const FunctionFragmentInternal = "_FunctionInternal";
|
|
363
|
+
const StructFragmentInternal = "_StructInternal";
|
|
364
|
+
/**
|
|
365
|
+
* Each input and output of a [[Fragment]] is an Array of **ParamType**.
|
|
366
|
+
*/
|
|
367
|
+
export class ParamType {
|
|
368
|
+
/**
|
|
369
|
+
* @private
|
|
370
|
+
*/
|
|
371
|
+
constructor(guard, name, type, baseType, indexed, components, arrayLength, arrayChildren) {
|
|
372
|
+
_ParamType_instances.add(this);
|
|
373
|
+
assertPrivate(guard, _guard, "ParamType");
|
|
374
|
+
Object.defineProperty(this, internal, { value: ParamTypeInternal });
|
|
375
|
+
if (components) {
|
|
376
|
+
components = Object.freeze(components.slice());
|
|
377
|
+
}
|
|
378
|
+
if (baseType === "array") {
|
|
379
|
+
if (arrayLength == null || arrayChildren == null) {
|
|
380
|
+
throw new Error("");
|
|
381
|
+
}
|
|
382
|
+
}
|
|
383
|
+
else if (arrayLength != null || arrayChildren != null) {
|
|
384
|
+
throw new Error("");
|
|
385
|
+
}
|
|
386
|
+
if (baseType === "tuple") {
|
|
387
|
+
if (components == null) {
|
|
388
|
+
throw new Error("");
|
|
389
|
+
}
|
|
390
|
+
}
|
|
391
|
+
else if (components != null) {
|
|
392
|
+
throw new Error("");
|
|
393
|
+
}
|
|
394
|
+
defineProperties(this, {
|
|
395
|
+
name, type, baseType, indexed, components, arrayLength, arrayChildren
|
|
396
|
+
});
|
|
397
|
+
}
|
|
398
|
+
/**
|
|
399
|
+
* Return a string representation of this type.
|
|
400
|
+
*
|
|
401
|
+
* For example,
|
|
402
|
+
*
|
|
403
|
+
* ``sighash" => "(uint256,address)"``
|
|
404
|
+
*
|
|
405
|
+
* ``"minimal" => "tuple(uint256,address) indexed"``
|
|
406
|
+
*
|
|
407
|
+
* ``"full" => "tuple(uint256 foo, address bar) indexed baz"``
|
|
408
|
+
*/
|
|
409
|
+
format(format) {
|
|
410
|
+
if (format == null) {
|
|
411
|
+
format = "sighash";
|
|
412
|
+
}
|
|
413
|
+
if (format === "json") {
|
|
414
|
+
const name = this.name || "";
|
|
415
|
+
if (this.isArray()) {
|
|
416
|
+
const result = JSON.parse(this.arrayChildren.format("json"));
|
|
417
|
+
result.name = name;
|
|
418
|
+
result.type += `[${(this.arrayLength < 0 ? "" : String(this.arrayLength))}]`;
|
|
419
|
+
return JSON.stringify(result);
|
|
420
|
+
}
|
|
421
|
+
const result = {
|
|
422
|
+
type: ((this.baseType === "tuple") ? "tuple" : this.type),
|
|
423
|
+
name
|
|
424
|
+
};
|
|
425
|
+
if (typeof (this.indexed) === "boolean") {
|
|
426
|
+
result.indexed = this.indexed;
|
|
427
|
+
}
|
|
428
|
+
if (this.isTuple()) {
|
|
429
|
+
result.components = this.components.map((c) => JSON.parse(c.format(format)));
|
|
430
|
+
}
|
|
431
|
+
return JSON.stringify(result);
|
|
432
|
+
}
|
|
433
|
+
let result = "";
|
|
434
|
+
// Array
|
|
435
|
+
if (this.isArray()) {
|
|
436
|
+
result += this.arrayChildren.format(format);
|
|
437
|
+
result += `[${(this.arrayLength < 0 ? "" : String(this.arrayLength))}]`;
|
|
438
|
+
}
|
|
439
|
+
else {
|
|
440
|
+
if (this.isTuple()) {
|
|
441
|
+
result += "(" + this.components.map((comp) => comp.format(format)).join((format === "full") ? ", " : ",") + ")";
|
|
442
|
+
}
|
|
443
|
+
else {
|
|
444
|
+
result += this.type;
|
|
445
|
+
}
|
|
446
|
+
}
|
|
447
|
+
if (format !== "sighash") {
|
|
448
|
+
if (this.indexed === true) {
|
|
449
|
+
result += " indexed";
|
|
450
|
+
}
|
|
451
|
+
if (format === "full" && this.name) {
|
|
452
|
+
result += " " + this.name;
|
|
453
|
+
}
|
|
454
|
+
}
|
|
455
|
+
return result;
|
|
456
|
+
}
|
|
457
|
+
/**
|
|
458
|
+
* Returns true if %%this%% is an Array type.
|
|
459
|
+
*
|
|
460
|
+
* This provides a type gaurd ensuring that [[arrayChildren]]
|
|
461
|
+
* and [[arrayLength]] are non-null.
|
|
462
|
+
*/
|
|
463
|
+
isArray() {
|
|
464
|
+
return (this.baseType === "array");
|
|
465
|
+
}
|
|
466
|
+
/**
|
|
467
|
+
* Returns true if %%this%% is a Tuple type.
|
|
468
|
+
*
|
|
469
|
+
* This provides a type gaurd ensuring that [[components]]
|
|
470
|
+
* is non-null.
|
|
471
|
+
*/
|
|
472
|
+
isTuple() {
|
|
473
|
+
return (this.baseType === "tuple");
|
|
474
|
+
}
|
|
475
|
+
/**
|
|
476
|
+
* Returns true if %%this%% is an Indexable type.
|
|
477
|
+
*
|
|
478
|
+
* This provides a type gaurd ensuring that [[indexed]]
|
|
479
|
+
* is non-null.
|
|
480
|
+
*/
|
|
481
|
+
isIndexable() {
|
|
482
|
+
return (this.indexed != null);
|
|
483
|
+
}
|
|
484
|
+
/**
|
|
485
|
+
* Walks the **ParamType** with %%value%%, calling %%process%%
|
|
486
|
+
* on each type, destructing the %%value%% recursively.
|
|
487
|
+
*/
|
|
488
|
+
walk(value, process) {
|
|
489
|
+
if (this.isArray()) {
|
|
490
|
+
if (!Array.isArray(value)) {
|
|
491
|
+
throw new Error("invalid array value");
|
|
492
|
+
}
|
|
493
|
+
if (this.arrayLength !== -1 && value.length !== this.arrayLength) {
|
|
494
|
+
throw new Error("array is wrong length");
|
|
495
|
+
}
|
|
496
|
+
const _this = this;
|
|
497
|
+
return value.map((v) => (_this.arrayChildren.walk(v, process)));
|
|
498
|
+
}
|
|
499
|
+
if (this.isTuple()) {
|
|
500
|
+
if (!Array.isArray(value)) {
|
|
501
|
+
throw new Error("invalid tuple value");
|
|
502
|
+
}
|
|
503
|
+
if (value.length !== this.components.length) {
|
|
504
|
+
throw new Error("array is wrong length");
|
|
505
|
+
}
|
|
506
|
+
const _this = this;
|
|
507
|
+
return value.map((v, i) => (_this.components[i].walk(v, process)));
|
|
508
|
+
}
|
|
509
|
+
return process(this.type, value);
|
|
510
|
+
}
|
|
511
|
+
/**
|
|
512
|
+
* Walks the **ParamType** with %%value%%, asynchronously calling
|
|
513
|
+
* %%process%% on each type, destructing the %%value%% recursively.
|
|
514
|
+
*
|
|
515
|
+
* This can be used to resolve ENS naes by walking and resolving each
|
|
516
|
+
* ``"address"`` type.
|
|
517
|
+
*/
|
|
518
|
+
async walkAsync(value, process) {
|
|
519
|
+
const promises = [];
|
|
520
|
+
const result = [value];
|
|
521
|
+
__classPrivateFieldGet(this, _ParamType_instances, "m", _ParamType_walkAsync).call(this, promises, value, process, (value) => {
|
|
522
|
+
result[0] = value;
|
|
523
|
+
});
|
|
524
|
+
if (promises.length) {
|
|
525
|
+
await Promise.all(promises);
|
|
526
|
+
}
|
|
527
|
+
return result[0];
|
|
528
|
+
}
|
|
529
|
+
/**
|
|
530
|
+
* Creates a new **ParamType** for %%obj%%.
|
|
531
|
+
*
|
|
532
|
+
* If %%allowIndexed%% then the ``indexed`` keyword is permitted,
|
|
533
|
+
* otherwise the ``indexed`` keyword will throw an error.
|
|
534
|
+
*/
|
|
535
|
+
static from(obj, allowIndexed) {
|
|
536
|
+
if (ParamType.isParamType(obj)) {
|
|
537
|
+
return obj;
|
|
538
|
+
}
|
|
539
|
+
if (typeof (obj) === "string") {
|
|
540
|
+
try {
|
|
541
|
+
return ParamType.from(lex(obj), allowIndexed);
|
|
542
|
+
}
|
|
543
|
+
catch (error) {
|
|
544
|
+
assertArgument(false, "invalid param type", "obj", obj);
|
|
545
|
+
}
|
|
546
|
+
}
|
|
547
|
+
else if (obj instanceof TokenString) {
|
|
548
|
+
let type = "", baseType = "";
|
|
549
|
+
let comps = null;
|
|
550
|
+
if (consumeKeywords(obj, setify(["tuple"])).has("tuple") || obj.peekType("OPEN_PAREN")) {
|
|
551
|
+
// Tuple
|
|
552
|
+
baseType = "tuple";
|
|
553
|
+
comps = obj.popParams().map((t) => ParamType.from(t));
|
|
554
|
+
type = `tuple(${comps.map((c) => c.format()).join(",")})`;
|
|
555
|
+
}
|
|
556
|
+
else {
|
|
557
|
+
// Normal
|
|
558
|
+
type = verifyBasicType(obj.popType("TYPE"));
|
|
559
|
+
baseType = type;
|
|
560
|
+
}
|
|
561
|
+
// Check for Array
|
|
562
|
+
let arrayChildren = null;
|
|
563
|
+
let arrayLength = null;
|
|
564
|
+
while (obj.length && obj.peekType("BRACKET")) {
|
|
565
|
+
const bracket = obj.pop(); //arrays[i];
|
|
566
|
+
arrayChildren = new ParamType(_guard, "", type, baseType, null, comps, arrayLength, arrayChildren);
|
|
567
|
+
arrayLength = bracket.value;
|
|
568
|
+
type += bracket.text;
|
|
569
|
+
baseType = "array";
|
|
570
|
+
comps = null;
|
|
571
|
+
}
|
|
572
|
+
let indexed = null;
|
|
573
|
+
const keywords = consumeKeywords(obj, KwModifiers);
|
|
574
|
+
if (keywords.has("indexed")) {
|
|
575
|
+
if (!allowIndexed) {
|
|
576
|
+
throw new Error("");
|
|
577
|
+
}
|
|
578
|
+
indexed = true;
|
|
579
|
+
}
|
|
580
|
+
const name = (obj.peekType("ID") ? obj.pop().text : "");
|
|
581
|
+
if (obj.length) {
|
|
582
|
+
throw new Error("leftover tokens");
|
|
583
|
+
}
|
|
584
|
+
return new ParamType(_guard, name, type, baseType, indexed, comps, arrayLength, arrayChildren);
|
|
585
|
+
}
|
|
586
|
+
const name = obj.name;
|
|
587
|
+
assertArgument(!name || (typeof (name) === "string" && name.match(regexId)), "invalid name", "obj.name", name);
|
|
588
|
+
let indexed = obj.indexed;
|
|
589
|
+
if (indexed != null) {
|
|
590
|
+
assertArgument(allowIndexed, "parameter cannot be indexed", "obj.indexed", obj.indexed);
|
|
591
|
+
indexed = !!indexed;
|
|
592
|
+
}
|
|
593
|
+
let type = obj.type;
|
|
594
|
+
let arrayMatch = type.match(regexArrayType);
|
|
595
|
+
if (arrayMatch) {
|
|
596
|
+
const arrayLength = parseInt(arrayMatch[2] || "-1");
|
|
597
|
+
const arrayChildren = ParamType.from({
|
|
598
|
+
type: arrayMatch[1],
|
|
599
|
+
components: obj.components
|
|
600
|
+
});
|
|
601
|
+
return new ParamType(_guard, name || "", type, "array", indexed, null, arrayLength, arrayChildren);
|
|
602
|
+
}
|
|
603
|
+
if (type === "tuple" || type.startsWith("tuple(" /* fix: ) */) || type.startsWith("(" /* fix: ) */)) {
|
|
604
|
+
const comps = (obj.components != null) ? obj.components.map((c) => ParamType.from(c)) : null;
|
|
605
|
+
const tuple = new ParamType(_guard, name || "", type, "tuple", indexed, comps, null, null);
|
|
606
|
+
// @TODO: use lexer to validate and normalize type
|
|
607
|
+
return tuple;
|
|
608
|
+
}
|
|
609
|
+
type = verifyBasicType(obj.type);
|
|
610
|
+
return new ParamType(_guard, name || "", type, type, indexed, null, null, null);
|
|
611
|
+
}
|
|
612
|
+
/**
|
|
613
|
+
* Returns true if %%value%% is a **ParamType**.
|
|
614
|
+
*/
|
|
615
|
+
static isParamType(value) {
|
|
616
|
+
return (value && value[internal] === ParamTypeInternal);
|
|
617
|
+
}
|
|
618
|
+
}
|
|
619
|
+
_ParamType_instances = new WeakSet(), _ParamType_walkAsync = function _ParamType_walkAsync(promises, value, process, setValue) {
|
|
620
|
+
if (this.isArray()) {
|
|
621
|
+
if (!Array.isArray(value)) {
|
|
622
|
+
throw new Error("invalid array value");
|
|
623
|
+
}
|
|
624
|
+
if (this.arrayLength !== -1 && value.length !== this.arrayLength) {
|
|
625
|
+
throw new Error("array is wrong length");
|
|
626
|
+
}
|
|
627
|
+
const childType = this.arrayChildren;
|
|
628
|
+
const result = value.slice();
|
|
629
|
+
result.forEach((value, index) => {
|
|
630
|
+
__classPrivateFieldGet(childType, _ParamType_instances, "m", _ParamType_walkAsync).call(childType, promises, value, process, (value) => {
|
|
631
|
+
result[index] = value;
|
|
632
|
+
});
|
|
633
|
+
});
|
|
634
|
+
setValue(result);
|
|
635
|
+
return;
|
|
636
|
+
}
|
|
637
|
+
if (this.isTuple()) {
|
|
638
|
+
const components = this.components;
|
|
639
|
+
// Convert the object into an array
|
|
640
|
+
let result;
|
|
641
|
+
if (Array.isArray(value)) {
|
|
642
|
+
result = value.slice();
|
|
643
|
+
}
|
|
644
|
+
else {
|
|
645
|
+
if (value == null || typeof (value) !== "object") {
|
|
646
|
+
throw new Error("invalid tuple value");
|
|
647
|
+
}
|
|
648
|
+
result = components.map((param) => {
|
|
649
|
+
if (!param.name) {
|
|
650
|
+
throw new Error("cannot use object value with unnamed components");
|
|
651
|
+
}
|
|
652
|
+
if (!(param.name in value)) {
|
|
653
|
+
throw new Error(`missing value for component ${param.name}`);
|
|
654
|
+
}
|
|
655
|
+
return value[param.name];
|
|
656
|
+
});
|
|
657
|
+
}
|
|
658
|
+
if (result.length !== this.components.length) {
|
|
659
|
+
throw new Error("array is wrong length");
|
|
660
|
+
}
|
|
661
|
+
result.forEach((value, index) => {
|
|
662
|
+
var _a;
|
|
663
|
+
__classPrivateFieldGet((_a = components[index]), _ParamType_instances, "m", _ParamType_walkAsync).call(_a, promises, value, process, (value) => {
|
|
664
|
+
result[index] = value;
|
|
665
|
+
});
|
|
666
|
+
});
|
|
667
|
+
setValue(result);
|
|
668
|
+
return;
|
|
669
|
+
}
|
|
670
|
+
const result = process(this.type, value);
|
|
671
|
+
if (result.then) {
|
|
672
|
+
promises.push((async function () { setValue(await result); })());
|
|
673
|
+
}
|
|
674
|
+
else {
|
|
675
|
+
setValue(result);
|
|
676
|
+
}
|
|
677
|
+
};
|
|
678
|
+
/**
|
|
679
|
+
* An abstract class to represent An individual fragment from a parse ABI.
|
|
680
|
+
*/
|
|
681
|
+
export class Fragment {
|
|
682
|
+
/**
|
|
683
|
+
* @private
|
|
684
|
+
*/
|
|
685
|
+
constructor(guard, type, inputs) {
|
|
686
|
+
assertPrivate(guard, _guard, "Fragment");
|
|
687
|
+
inputs = Object.freeze(inputs.slice());
|
|
688
|
+
defineProperties(this, { type, inputs });
|
|
689
|
+
}
|
|
690
|
+
/**
|
|
691
|
+
* Creates a new **Fragment** for %%obj%%, wich can be any supported
|
|
692
|
+
* ABI frgament type.
|
|
693
|
+
*/
|
|
694
|
+
static from(obj) {
|
|
695
|
+
if (typeof (obj) === "string") {
|
|
696
|
+
// Try parsing JSON...
|
|
697
|
+
try {
|
|
698
|
+
Fragment.from(JSON.parse(obj));
|
|
699
|
+
}
|
|
700
|
+
catch (e) { }
|
|
701
|
+
// ...otherwise, use the human-readable lexer
|
|
702
|
+
return Fragment.from(lex(obj));
|
|
703
|
+
}
|
|
704
|
+
if (obj instanceof TokenString) {
|
|
705
|
+
// Human-readable ABI (already lexed)
|
|
706
|
+
const type = obj.peekKeyword(KwTypes);
|
|
707
|
+
switch (type) {
|
|
708
|
+
case "constructor": return ConstructorFragment.from(obj);
|
|
709
|
+
case "error": return ErrorFragment.from(obj);
|
|
710
|
+
case "event": return EventFragment.from(obj);
|
|
711
|
+
case "fallback":
|
|
712
|
+
case "receive":
|
|
713
|
+
return FallbackFragment.from(obj);
|
|
714
|
+
case "function": return FunctionFragment.from(obj);
|
|
715
|
+
case "struct": return StructFragment.from(obj);
|
|
716
|
+
}
|
|
717
|
+
}
|
|
718
|
+
else if (typeof (obj) === "object") {
|
|
719
|
+
// JSON ABI
|
|
720
|
+
switch (obj.type) {
|
|
721
|
+
case "constructor": return ConstructorFragment.from(obj);
|
|
722
|
+
case "error": return ErrorFragment.from(obj);
|
|
723
|
+
case "event": return EventFragment.from(obj);
|
|
724
|
+
case "fallback":
|
|
725
|
+
case "receive":
|
|
726
|
+
return FallbackFragment.from(obj);
|
|
727
|
+
case "function": return FunctionFragment.from(obj);
|
|
728
|
+
case "struct": return StructFragment.from(obj);
|
|
729
|
+
}
|
|
730
|
+
assert(false, `unsupported type: ${obj.type}`, "UNSUPPORTED_OPERATION", {
|
|
731
|
+
operation: "Fragment.from"
|
|
732
|
+
});
|
|
733
|
+
}
|
|
734
|
+
assertArgument(false, "unsupported frgament object", "obj", obj);
|
|
735
|
+
}
|
|
736
|
+
/**
|
|
737
|
+
* Returns true if %%value%% is a [[ConstructorFragment]].
|
|
738
|
+
*/
|
|
739
|
+
static isConstructor(value) {
|
|
740
|
+
return ConstructorFragment.isFragment(value);
|
|
741
|
+
}
|
|
742
|
+
/**
|
|
743
|
+
* Returns true if %%value%% is an [[ErrorFragment]].
|
|
744
|
+
*/
|
|
745
|
+
static isError(value) {
|
|
746
|
+
return ErrorFragment.isFragment(value);
|
|
747
|
+
}
|
|
748
|
+
/**
|
|
749
|
+
* Returns true if %%value%% is an [[EventFragment]].
|
|
750
|
+
*/
|
|
751
|
+
static isEvent(value) {
|
|
752
|
+
return EventFragment.isFragment(value);
|
|
753
|
+
}
|
|
754
|
+
/**
|
|
755
|
+
* Returns true if %%value%% is a [[FunctionFragment]].
|
|
756
|
+
*/
|
|
757
|
+
static isFunction(value) {
|
|
758
|
+
return FunctionFragment.isFragment(value);
|
|
759
|
+
}
|
|
760
|
+
/**
|
|
761
|
+
* Returns true if %%value%% is a [[StructFragment]].
|
|
762
|
+
*/
|
|
763
|
+
static isStruct(value) {
|
|
764
|
+
return StructFragment.isFragment(value);
|
|
765
|
+
}
|
|
766
|
+
}
|
|
767
|
+
/**
|
|
768
|
+
* An abstract class to represent An individual fragment
|
|
769
|
+
* which has a name from a parse ABI.
|
|
770
|
+
*/
|
|
771
|
+
export class NamedFragment extends Fragment {
|
|
772
|
+
/**
|
|
773
|
+
* @private
|
|
774
|
+
*/
|
|
775
|
+
constructor(guard, type, name, inputs) {
|
|
776
|
+
super(guard, type, inputs);
|
|
777
|
+
assertArgument(typeof (name) === "string" && name.match(regexId), "invalid identifier", "name", name);
|
|
778
|
+
inputs = Object.freeze(inputs.slice());
|
|
779
|
+
defineProperties(this, { name });
|
|
780
|
+
}
|
|
781
|
+
}
|
|
782
|
+
function joinParams(format, params) {
|
|
783
|
+
return "(" + params.map((p) => p.format(format)).join((format === "full") ? ", " : ",") + ")";
|
|
784
|
+
}
|
|
785
|
+
/**
|
|
786
|
+
* A Fragment which represents a //Custom Error//.
|
|
787
|
+
*/
|
|
788
|
+
export class ErrorFragment extends NamedFragment {
|
|
789
|
+
/**
|
|
790
|
+
* @private
|
|
791
|
+
*/
|
|
792
|
+
constructor(guard, name, inputs) {
|
|
793
|
+
super(guard, "error", name, inputs);
|
|
794
|
+
Object.defineProperty(this, internal, { value: ErrorFragmentInternal });
|
|
795
|
+
}
|
|
796
|
+
/**
|
|
797
|
+
* The Custom Error selector.
|
|
798
|
+
*/
|
|
799
|
+
get selector() {
|
|
800
|
+
return id(this.format("sighash")).substring(0, 10);
|
|
801
|
+
}
|
|
802
|
+
/**
|
|
803
|
+
* Returns a string representation of this fragment as %%format%%.
|
|
804
|
+
*/
|
|
805
|
+
format(format) {
|
|
806
|
+
if (format == null) {
|
|
807
|
+
format = "sighash";
|
|
808
|
+
}
|
|
809
|
+
if (format === "json") {
|
|
810
|
+
return JSON.stringify({
|
|
811
|
+
type: "error",
|
|
812
|
+
name: this.name,
|
|
813
|
+
inputs: this.inputs.map((input) => JSON.parse(input.format(format))),
|
|
814
|
+
});
|
|
815
|
+
}
|
|
816
|
+
const result = [];
|
|
817
|
+
if (format !== "sighash") {
|
|
818
|
+
result.push("error");
|
|
819
|
+
}
|
|
820
|
+
result.push(this.name + joinParams(format, this.inputs));
|
|
821
|
+
return result.join(" ");
|
|
822
|
+
}
|
|
823
|
+
/**
|
|
824
|
+
* Returns a new **ErrorFragment** for %%obj%%.
|
|
825
|
+
*/
|
|
826
|
+
static from(obj) {
|
|
827
|
+
if (ErrorFragment.isFragment(obj)) {
|
|
828
|
+
return obj;
|
|
829
|
+
}
|
|
830
|
+
if (typeof (obj) === "string") {
|
|
831
|
+
return ErrorFragment.from(lex(obj));
|
|
832
|
+
}
|
|
833
|
+
else if (obj instanceof TokenString) {
|
|
834
|
+
const name = consumeName("error", obj);
|
|
835
|
+
const inputs = consumeParams(obj);
|
|
836
|
+
consumeEoi(obj);
|
|
837
|
+
return new ErrorFragment(_guard, name, inputs);
|
|
838
|
+
}
|
|
839
|
+
return new ErrorFragment(_guard, obj.name, obj.inputs ? obj.inputs.map(ParamType.from) : []);
|
|
840
|
+
}
|
|
841
|
+
/**
|
|
842
|
+
* Returns ``true`` and provides a type guard if %%value%% is an
|
|
843
|
+
* **ErrorFragment**.
|
|
844
|
+
*/
|
|
845
|
+
static isFragment(value) {
|
|
846
|
+
return (value && value[internal] === ErrorFragmentInternal);
|
|
847
|
+
}
|
|
848
|
+
}
|
|
849
|
+
/**
|
|
850
|
+
* A Fragment which represents an Event.
|
|
851
|
+
*/
|
|
852
|
+
export class EventFragment extends NamedFragment {
|
|
853
|
+
/**
|
|
854
|
+
* @private
|
|
855
|
+
*/
|
|
856
|
+
constructor(guard, name, inputs, anonymous) {
|
|
857
|
+
super(guard, "event", name, inputs);
|
|
858
|
+
Object.defineProperty(this, internal, { value: EventFragmentInternal });
|
|
859
|
+
defineProperties(this, { anonymous });
|
|
860
|
+
}
|
|
861
|
+
/**
|
|
862
|
+
* The Event topic hash.
|
|
863
|
+
*/
|
|
864
|
+
get topicHash() {
|
|
865
|
+
return id(this.format("sighash"));
|
|
866
|
+
}
|
|
867
|
+
/**
|
|
868
|
+
* Returns a string representation of this event as %%format%%.
|
|
869
|
+
*/
|
|
870
|
+
format(format) {
|
|
871
|
+
if (format == null) {
|
|
872
|
+
format = "sighash";
|
|
873
|
+
}
|
|
874
|
+
if (format === "json") {
|
|
875
|
+
return JSON.stringify({
|
|
876
|
+
type: "event",
|
|
877
|
+
anonymous: this.anonymous,
|
|
878
|
+
name: this.name,
|
|
879
|
+
inputs: this.inputs.map((i) => JSON.parse(i.format(format)))
|
|
880
|
+
});
|
|
881
|
+
}
|
|
882
|
+
const result = [];
|
|
883
|
+
if (format !== "sighash") {
|
|
884
|
+
result.push("event");
|
|
885
|
+
}
|
|
886
|
+
result.push(this.name + joinParams(format, this.inputs));
|
|
887
|
+
if (format !== "sighash" && this.anonymous) {
|
|
888
|
+
result.push("anonymous");
|
|
889
|
+
}
|
|
890
|
+
return result.join(" ");
|
|
891
|
+
}
|
|
892
|
+
/**
|
|
893
|
+
* Return the topic hash for an event with %%name%% and %%params%%.
|
|
894
|
+
*/
|
|
895
|
+
static getTopicHash(name, params) {
|
|
896
|
+
params = (params || []).map((p) => ParamType.from(p));
|
|
897
|
+
const fragment = new EventFragment(_guard, name, params, false);
|
|
898
|
+
return fragment.topicHash;
|
|
899
|
+
}
|
|
900
|
+
/**
|
|
901
|
+
* Returns a new **EventFragment** for %%obj%%.
|
|
902
|
+
*/
|
|
903
|
+
static from(obj) {
|
|
904
|
+
if (EventFragment.isFragment(obj)) {
|
|
905
|
+
return obj;
|
|
906
|
+
}
|
|
907
|
+
if (typeof (obj) === "string") {
|
|
908
|
+
try {
|
|
909
|
+
return EventFragment.from(lex(obj));
|
|
910
|
+
}
|
|
911
|
+
catch (error) {
|
|
912
|
+
assertArgument(false, "invalid event fragment", "obj", obj);
|
|
913
|
+
}
|
|
914
|
+
}
|
|
915
|
+
else if (obj instanceof TokenString) {
|
|
916
|
+
const name = consumeName("event", obj);
|
|
917
|
+
const inputs = consumeParams(obj, true);
|
|
918
|
+
const anonymous = !!consumeKeywords(obj, setify(["anonymous"])).has("anonymous");
|
|
919
|
+
consumeEoi(obj);
|
|
920
|
+
return new EventFragment(_guard, name, inputs, anonymous);
|
|
921
|
+
}
|
|
922
|
+
return new EventFragment(_guard, obj.name, obj.inputs ? obj.inputs.map((p) => ParamType.from(p, true)) : [], !!obj.anonymous);
|
|
923
|
+
}
|
|
924
|
+
/**
|
|
925
|
+
* Returns ``true`` and provides a type guard if %%value%% is an
|
|
926
|
+
* **EventFragment**.
|
|
927
|
+
*/
|
|
928
|
+
static isFragment(value) {
|
|
929
|
+
return (value && value[internal] === EventFragmentInternal);
|
|
930
|
+
}
|
|
931
|
+
}
|
|
932
|
+
/**
|
|
933
|
+
* A Fragment which represents a constructor.
|
|
934
|
+
*/
|
|
935
|
+
export class ConstructorFragment extends Fragment {
|
|
936
|
+
/**
|
|
937
|
+
* @private
|
|
938
|
+
*/
|
|
939
|
+
constructor(guard, type, inputs, payable, gas) {
|
|
940
|
+
super(guard, type, inputs);
|
|
941
|
+
Object.defineProperty(this, internal, { value: ConstructorFragmentInternal });
|
|
942
|
+
defineProperties(this, { payable, gas });
|
|
943
|
+
}
|
|
944
|
+
/**
|
|
945
|
+
* Returns a string representation of this constructor as %%format%%.
|
|
946
|
+
*/
|
|
947
|
+
format(format) {
|
|
948
|
+
assert(format != null && format !== "sighash", "cannot format a constructor for sighash", "UNSUPPORTED_OPERATION", { operation: "format(sighash)" });
|
|
949
|
+
if (format === "json") {
|
|
950
|
+
return JSON.stringify({
|
|
951
|
+
type: "constructor",
|
|
952
|
+
stateMutability: (this.payable ? "payable" : "undefined"),
|
|
953
|
+
payable: this.payable,
|
|
954
|
+
gas: ((this.gas != null) ? this.gas : undefined),
|
|
955
|
+
inputs: this.inputs.map((i) => JSON.parse(i.format(format)))
|
|
956
|
+
});
|
|
957
|
+
}
|
|
958
|
+
const result = [`constructor${joinParams(format, this.inputs)}`];
|
|
959
|
+
if (this.payable) {
|
|
960
|
+
result.push("payable");
|
|
961
|
+
}
|
|
962
|
+
if (this.gas != null) {
|
|
963
|
+
result.push(`@${this.gas.toString()}`);
|
|
964
|
+
}
|
|
965
|
+
return result.join(" ");
|
|
966
|
+
}
|
|
967
|
+
/**
|
|
968
|
+
* Returns a new **ConstructorFragment** for %%obj%%.
|
|
969
|
+
*/
|
|
970
|
+
static from(obj) {
|
|
971
|
+
if (ConstructorFragment.isFragment(obj)) {
|
|
972
|
+
return obj;
|
|
973
|
+
}
|
|
974
|
+
if (typeof (obj) === "string") {
|
|
975
|
+
try {
|
|
976
|
+
return ConstructorFragment.from(lex(obj));
|
|
977
|
+
}
|
|
978
|
+
catch (error) {
|
|
979
|
+
assertArgument(false, "invalid constuctor fragment", "obj", obj);
|
|
980
|
+
}
|
|
981
|
+
}
|
|
982
|
+
else if (obj instanceof TokenString) {
|
|
983
|
+
consumeKeywords(obj, setify(["constructor"]));
|
|
984
|
+
const inputs = consumeParams(obj);
|
|
985
|
+
const payable = !!consumeKeywords(obj, KwVisibDeploy).has("payable");
|
|
986
|
+
const gas = consumeGas(obj);
|
|
987
|
+
consumeEoi(obj);
|
|
988
|
+
return new ConstructorFragment(_guard, "constructor", inputs, payable, gas);
|
|
989
|
+
}
|
|
990
|
+
return new ConstructorFragment(_guard, "constructor", obj.inputs ? obj.inputs.map(ParamType.from) : [], !!obj.payable, (obj.gas != null) ? obj.gas : null);
|
|
991
|
+
}
|
|
992
|
+
/**
|
|
993
|
+
* Returns ``true`` and provides a type guard if %%value%% is a
|
|
994
|
+
* **ConstructorFragment**.
|
|
995
|
+
*/
|
|
996
|
+
static isFragment(value) {
|
|
997
|
+
return (value && value[internal] === ConstructorFragmentInternal);
|
|
998
|
+
}
|
|
999
|
+
}
|
|
1000
|
+
/**
|
|
1001
|
+
* A Fragment which represents a method.
|
|
1002
|
+
*/
|
|
1003
|
+
export class FallbackFragment extends Fragment {
|
|
1004
|
+
constructor(guard, inputs, payable) {
|
|
1005
|
+
super(guard, "fallback", inputs);
|
|
1006
|
+
Object.defineProperty(this, internal, { value: FallbackFragmentInternal });
|
|
1007
|
+
defineProperties(this, { payable });
|
|
1008
|
+
}
|
|
1009
|
+
/**
|
|
1010
|
+
* Returns a string representation of this fallback as %%format%%.
|
|
1011
|
+
*/
|
|
1012
|
+
format(format) {
|
|
1013
|
+
const type = ((this.inputs.length === 0) ? "receive" : "fallback");
|
|
1014
|
+
if (format === "json") {
|
|
1015
|
+
const stateMutability = (this.payable ? "payable" : "nonpayable");
|
|
1016
|
+
return JSON.stringify({ type, stateMutability });
|
|
1017
|
+
}
|
|
1018
|
+
return `${type}()${this.payable ? " payable" : ""}`;
|
|
1019
|
+
}
|
|
1020
|
+
/**
|
|
1021
|
+
* Returns a new **FallbackFragment** for %%obj%%.
|
|
1022
|
+
*/
|
|
1023
|
+
static from(obj) {
|
|
1024
|
+
if (FallbackFragment.isFragment(obj)) {
|
|
1025
|
+
return obj;
|
|
1026
|
+
}
|
|
1027
|
+
if (typeof (obj) === "string") {
|
|
1028
|
+
try {
|
|
1029
|
+
return FallbackFragment.from(lex(obj));
|
|
1030
|
+
}
|
|
1031
|
+
catch (error) {
|
|
1032
|
+
assertArgument(false, "invalid fallback fragment", "obj", obj);
|
|
1033
|
+
}
|
|
1034
|
+
}
|
|
1035
|
+
else if (obj instanceof TokenString) {
|
|
1036
|
+
const errorObj = obj.toString();
|
|
1037
|
+
const topIsValid = obj.peekKeyword(setify(["fallback", "receive"]));
|
|
1038
|
+
assertArgument(topIsValid, "type must be fallback or receive", "obj", errorObj);
|
|
1039
|
+
const type = obj.popKeyword(setify(["fallback", "receive"]));
|
|
1040
|
+
// receive()
|
|
1041
|
+
if (type === "receive") {
|
|
1042
|
+
const inputs = consumeParams(obj);
|
|
1043
|
+
assertArgument(inputs.length === 0, `receive cannot have arguments`, "obj.inputs", inputs);
|
|
1044
|
+
consumeKeywords(obj, setify(["payable"]));
|
|
1045
|
+
consumeEoi(obj);
|
|
1046
|
+
return new FallbackFragment(_guard, [], true);
|
|
1047
|
+
}
|
|
1048
|
+
// fallback() [payable]
|
|
1049
|
+
// fallback(bytes) [payable] returns (bytes)
|
|
1050
|
+
let inputs = consumeParams(obj);
|
|
1051
|
+
if (inputs.length) {
|
|
1052
|
+
assertArgument(inputs.length === 1 && inputs[0].type === "bytes", "invalid fallback inputs", "obj.inputs", inputs.map((i) => i.format("minimal")).join(", "));
|
|
1053
|
+
}
|
|
1054
|
+
else {
|
|
1055
|
+
inputs = [ParamType.from("bytes")];
|
|
1056
|
+
}
|
|
1057
|
+
const mutability = consumeMutability(obj);
|
|
1058
|
+
assertArgument(mutability === "nonpayable" || mutability === "payable", "fallback cannot be constants", "obj.stateMutability", mutability);
|
|
1059
|
+
if (consumeKeywords(obj, setify(["returns"])).has("returns")) {
|
|
1060
|
+
const outputs = consumeParams(obj);
|
|
1061
|
+
assertArgument(outputs.length === 1 && outputs[0].type === "bytes", "invalid fallback outputs", "obj.outputs", outputs.map((i) => i.format("minimal")).join(", "));
|
|
1062
|
+
}
|
|
1063
|
+
consumeEoi(obj);
|
|
1064
|
+
return new FallbackFragment(_guard, inputs, mutability === "payable");
|
|
1065
|
+
}
|
|
1066
|
+
if (obj.type === "receive") {
|
|
1067
|
+
return new FallbackFragment(_guard, [], true);
|
|
1068
|
+
}
|
|
1069
|
+
if (obj.type === "fallback") {
|
|
1070
|
+
const inputs = [ParamType.from("bytes")];
|
|
1071
|
+
const payable = (obj.stateMutability === "payable");
|
|
1072
|
+
return new FallbackFragment(_guard, inputs, payable);
|
|
1073
|
+
}
|
|
1074
|
+
assertArgument(false, "invalid fallback description", "obj", obj);
|
|
1075
|
+
}
|
|
1076
|
+
/**
|
|
1077
|
+
* Returns ``true`` and provides a type guard if %%value%% is a
|
|
1078
|
+
* **FallbackFragment**.
|
|
1079
|
+
*/
|
|
1080
|
+
static isFragment(value) {
|
|
1081
|
+
return (value && value[internal] === FallbackFragmentInternal);
|
|
1082
|
+
}
|
|
1083
|
+
}
|
|
1084
|
+
/**
|
|
1085
|
+
* A Fragment which represents a method.
|
|
1086
|
+
*/
|
|
1087
|
+
export class FunctionFragment extends NamedFragment {
|
|
1088
|
+
/**
|
|
1089
|
+
* @private
|
|
1090
|
+
*/
|
|
1091
|
+
constructor(guard, name, stateMutability, inputs, outputs, gas) {
|
|
1092
|
+
super(guard, "function", name, inputs);
|
|
1093
|
+
Object.defineProperty(this, internal, { value: FunctionFragmentInternal });
|
|
1094
|
+
outputs = Object.freeze(outputs.slice());
|
|
1095
|
+
const constant = (stateMutability === "view" || stateMutability === "pure");
|
|
1096
|
+
const payable = (stateMutability === "payable");
|
|
1097
|
+
defineProperties(this, { constant, gas, outputs, payable, stateMutability });
|
|
1098
|
+
}
|
|
1099
|
+
/**
|
|
1100
|
+
* The Function selector.
|
|
1101
|
+
*/
|
|
1102
|
+
get selector() {
|
|
1103
|
+
return id(this.format("sighash")).substring(0, 10);
|
|
1104
|
+
}
|
|
1105
|
+
/**
|
|
1106
|
+
* Returns a string representation of this function as %%format%%.
|
|
1107
|
+
*/
|
|
1108
|
+
format(format) {
|
|
1109
|
+
if (format == null) {
|
|
1110
|
+
format = "sighash";
|
|
1111
|
+
}
|
|
1112
|
+
if (format === "json") {
|
|
1113
|
+
return JSON.stringify({
|
|
1114
|
+
type: "function",
|
|
1115
|
+
name: this.name,
|
|
1116
|
+
constant: this.constant,
|
|
1117
|
+
stateMutability: ((this.stateMutability !== "nonpayable") ? this.stateMutability : undefined),
|
|
1118
|
+
payable: this.payable,
|
|
1119
|
+
gas: ((this.gas != null) ? this.gas : undefined),
|
|
1120
|
+
inputs: this.inputs.map((i) => JSON.parse(i.format(format))),
|
|
1121
|
+
outputs: this.outputs.map((o) => JSON.parse(o.format(format))),
|
|
1122
|
+
});
|
|
1123
|
+
}
|
|
1124
|
+
const result = [];
|
|
1125
|
+
if (format !== "sighash") {
|
|
1126
|
+
result.push("function");
|
|
1127
|
+
}
|
|
1128
|
+
result.push(this.name + joinParams(format, this.inputs));
|
|
1129
|
+
if (format !== "sighash") {
|
|
1130
|
+
if (this.stateMutability !== "nonpayable") {
|
|
1131
|
+
result.push(this.stateMutability);
|
|
1132
|
+
}
|
|
1133
|
+
if (this.outputs && this.outputs.length) {
|
|
1134
|
+
result.push("returns");
|
|
1135
|
+
result.push(joinParams(format, this.outputs));
|
|
1136
|
+
}
|
|
1137
|
+
if (this.gas != null) {
|
|
1138
|
+
result.push(`@${this.gas.toString()}`);
|
|
1139
|
+
}
|
|
1140
|
+
}
|
|
1141
|
+
return result.join(" ");
|
|
1142
|
+
}
|
|
1143
|
+
/**
|
|
1144
|
+
* Return the selector for a function with %%name%% and %%params%%.
|
|
1145
|
+
*/
|
|
1146
|
+
static getSelector(name, params) {
|
|
1147
|
+
params = (params || []).map((p) => ParamType.from(p));
|
|
1148
|
+
const fragment = new FunctionFragment(_guard, name, "view", params, [], null);
|
|
1149
|
+
return fragment.selector;
|
|
1150
|
+
}
|
|
1151
|
+
/**
|
|
1152
|
+
* Returns a new **FunctionFragment** for %%obj%%.
|
|
1153
|
+
*/
|
|
1154
|
+
static from(obj) {
|
|
1155
|
+
if (FunctionFragment.isFragment(obj)) {
|
|
1156
|
+
return obj;
|
|
1157
|
+
}
|
|
1158
|
+
if (typeof (obj) === "string") {
|
|
1159
|
+
try {
|
|
1160
|
+
return FunctionFragment.from(lex(obj));
|
|
1161
|
+
}
|
|
1162
|
+
catch (error) {
|
|
1163
|
+
assertArgument(false, "invalid function fragment", "obj", obj);
|
|
1164
|
+
}
|
|
1165
|
+
}
|
|
1166
|
+
else if (obj instanceof TokenString) {
|
|
1167
|
+
const name = consumeName("function", obj);
|
|
1168
|
+
const inputs = consumeParams(obj);
|
|
1169
|
+
const mutability = consumeMutability(obj);
|
|
1170
|
+
let outputs = [];
|
|
1171
|
+
if (consumeKeywords(obj, setify(["returns"])).has("returns")) {
|
|
1172
|
+
outputs = consumeParams(obj);
|
|
1173
|
+
}
|
|
1174
|
+
const gas = consumeGas(obj);
|
|
1175
|
+
consumeEoi(obj);
|
|
1176
|
+
return new FunctionFragment(_guard, name, mutability, inputs, outputs, gas);
|
|
1177
|
+
}
|
|
1178
|
+
let stateMutability = obj.stateMutability;
|
|
1179
|
+
// Use legacy Solidity ABI logic if stateMutability is missing
|
|
1180
|
+
if (stateMutability == null) {
|
|
1181
|
+
stateMutability = "payable";
|
|
1182
|
+
if (typeof (obj.constant) === "boolean") {
|
|
1183
|
+
stateMutability = "view";
|
|
1184
|
+
if (!obj.constant) {
|
|
1185
|
+
stateMutability = "payable";
|
|
1186
|
+
if (typeof (obj.payable) === "boolean" && !obj.payable) {
|
|
1187
|
+
stateMutability = "nonpayable";
|
|
1188
|
+
}
|
|
1189
|
+
}
|
|
1190
|
+
}
|
|
1191
|
+
else if (typeof (obj.payable) === "boolean" && !obj.payable) {
|
|
1192
|
+
stateMutability = "nonpayable";
|
|
1193
|
+
}
|
|
1194
|
+
}
|
|
1195
|
+
// @TODO: verifyState for stateMutability (e.g. throw if
|
|
1196
|
+
// payable: false but stateMutability is "nonpayable")
|
|
1197
|
+
return new FunctionFragment(_guard, obj.name, stateMutability, obj.inputs ? obj.inputs.map(ParamType.from) : [], obj.outputs ? obj.outputs.map(ParamType.from) : [], (obj.gas != null) ? obj.gas : null);
|
|
1198
|
+
}
|
|
1199
|
+
/**
|
|
1200
|
+
* Returns ``true`` and provides a type guard if %%value%% is a
|
|
1201
|
+
* **FunctionFragment**.
|
|
1202
|
+
*/
|
|
1203
|
+
static isFragment(value) {
|
|
1204
|
+
return (value && value[internal] === FunctionFragmentInternal);
|
|
1205
|
+
}
|
|
1206
|
+
}
|
|
1207
|
+
/**
|
|
1208
|
+
* A Fragment which represents a structure.
|
|
1209
|
+
*/
|
|
1210
|
+
export class StructFragment extends NamedFragment {
|
|
1211
|
+
/**
|
|
1212
|
+
* @private
|
|
1213
|
+
*/
|
|
1214
|
+
constructor(guard, name, inputs) {
|
|
1215
|
+
super(guard, "struct", name, inputs);
|
|
1216
|
+
Object.defineProperty(this, internal, { value: StructFragmentInternal });
|
|
1217
|
+
}
|
|
1218
|
+
/**
|
|
1219
|
+
* Returns a string representation of this struct as %%format%%.
|
|
1220
|
+
*/
|
|
1221
|
+
format() {
|
|
1222
|
+
throw new Error("@TODO");
|
|
1223
|
+
}
|
|
1224
|
+
/**
|
|
1225
|
+
* Returns a new **StructFragment** for %%obj%%.
|
|
1226
|
+
*/
|
|
1227
|
+
static from(obj) {
|
|
1228
|
+
if (typeof (obj) === "string") {
|
|
1229
|
+
try {
|
|
1230
|
+
return StructFragment.from(lex(obj));
|
|
1231
|
+
}
|
|
1232
|
+
catch (error) {
|
|
1233
|
+
assertArgument(false, "invalid struct fragment", "obj", obj);
|
|
1234
|
+
}
|
|
1235
|
+
}
|
|
1236
|
+
else if (obj instanceof TokenString) {
|
|
1237
|
+
const name = consumeName("struct", obj);
|
|
1238
|
+
const inputs = consumeParams(obj);
|
|
1239
|
+
consumeEoi(obj);
|
|
1240
|
+
return new StructFragment(_guard, name, inputs);
|
|
1241
|
+
}
|
|
1242
|
+
return new StructFragment(_guard, obj.name, obj.inputs ? obj.inputs.map(ParamType.from) : []);
|
|
1243
|
+
}
|
|
1244
|
+
// @TODO: fix this return type
|
|
1245
|
+
/**
|
|
1246
|
+
* Returns ``true`` and provides a type guard if %%value%% is a
|
|
1247
|
+
* **StructFragment**.
|
|
1248
|
+
*/
|
|
1249
|
+
static isFragment(value) {
|
|
1250
|
+
return (value && value[internal] === StructFragmentInternal);
|
|
1251
|
+
}
|
|
1252
|
+
}
|