ccxt-ir 4.10.0 → 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 +4 -1
- package/dist/cjs/src/abstract/bidarz.js +11 -0
- package/dist/cjs/src/bidarz.js +337 -0
- package/dist/cjs/src/bit24.js +4 -3
- package/js/ccxt.d.ts +5 -2
- package/js/ccxt.js +4 -2
- package/js/src/abstract/bidarz.d.ts +9 -0
- package/js/src/abstract/bidarz.js +11 -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/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.js +3 -3
- package/package.json +1 -1
|
@@ -0,0 +1,432 @@
|
|
|
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
|
+
/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */
|
|
8
|
+
// Twisted Edwards curve. The formula is: ax² + y² = 1 + dx²y²
|
|
9
|
+
import { mod } from './modular.js';
|
|
10
|
+
import * as ut from './utils.js';
|
|
11
|
+
import { ensureBytes } from './utils.js';
|
|
12
|
+
import { wNAF, validateBasic } from './curve.js';
|
|
13
|
+
// Be friendly to bad ECMAScript parsers by not using bigint literals like 123n
|
|
14
|
+
const _0n = BigInt(0);
|
|
15
|
+
const _1n = BigInt(1);
|
|
16
|
+
const _2n = BigInt(2);
|
|
17
|
+
const _8n = BigInt(8);
|
|
18
|
+
function validateOpts(curve) {
|
|
19
|
+
const opts = validateBasic(curve);
|
|
20
|
+
ut.validateObject(curve, {
|
|
21
|
+
hash: 'function',
|
|
22
|
+
a: 'bigint',
|
|
23
|
+
d: 'bigint',
|
|
24
|
+
randomBytes: 'function',
|
|
25
|
+
}, {
|
|
26
|
+
adjustScalarBytes: 'function',
|
|
27
|
+
domain: 'function',
|
|
28
|
+
uvRatio: 'function',
|
|
29
|
+
mapToCurve: 'function',
|
|
30
|
+
});
|
|
31
|
+
// Set defaults
|
|
32
|
+
return Object.freeze({ ...opts });
|
|
33
|
+
}
|
|
34
|
+
// It is not generic twisted curve for now, but ed25519/ed448 generic implementation
|
|
35
|
+
export function twistedEdwards(curveDef) {
|
|
36
|
+
const CURVE = validateOpts(curveDef);
|
|
37
|
+
const { Fp, n: CURVE_ORDER, preHash, hash: cHash, randomBytes, nByteLength, h: cofactor } = CURVE;
|
|
38
|
+
const MASK = _2n ** BigInt(nByteLength * 8);
|
|
39
|
+
const modP = Fp.create; // Function overrides
|
|
40
|
+
// sqrt(u/v)
|
|
41
|
+
const uvRatio = CURVE.uvRatio ||
|
|
42
|
+
((u, v) => {
|
|
43
|
+
try {
|
|
44
|
+
return { isValid: true, value: Fp.sqrt(u * Fp.inv(v)) };
|
|
45
|
+
}
|
|
46
|
+
catch (e) {
|
|
47
|
+
return { isValid: false, value: _0n };
|
|
48
|
+
}
|
|
49
|
+
});
|
|
50
|
+
const adjustScalarBytes = CURVE.adjustScalarBytes || ((bytes) => bytes); // NOOP
|
|
51
|
+
const domain = CURVE.domain ||
|
|
52
|
+
((data, ctx, phflag) => {
|
|
53
|
+
if (ctx.length || phflag)
|
|
54
|
+
throw new Error('Contexts/pre-hash are not supported');
|
|
55
|
+
return data;
|
|
56
|
+
}); // NOOP
|
|
57
|
+
const inBig = (n) => typeof n === 'bigint' && 0n < n; // n in [1..]
|
|
58
|
+
const inRange = (n, max) => inBig(n) && inBig(max) && n < max; // n in [1..max-1]
|
|
59
|
+
const in0MaskRange = (n) => n === _0n || inRange(n, MASK); // n in [0..MASK-1]
|
|
60
|
+
function assertInRange(n, max) {
|
|
61
|
+
// n in [1..max-1]
|
|
62
|
+
if (inRange(n, max))
|
|
63
|
+
return n;
|
|
64
|
+
throw new Error(`Expected valid scalar < ${max}, got ${typeof n} ${n}`);
|
|
65
|
+
}
|
|
66
|
+
function assertGE0(n) {
|
|
67
|
+
// n in [0..CURVE_ORDER-1]
|
|
68
|
+
return n === _0n ? n : assertInRange(n, CURVE_ORDER); // GE = prime subgroup, not full group
|
|
69
|
+
}
|
|
70
|
+
const pointPrecomputes = new Map();
|
|
71
|
+
function isPoint(other) {
|
|
72
|
+
if (!(other instanceof Point))
|
|
73
|
+
throw new Error('ExtendedPoint expected');
|
|
74
|
+
}
|
|
75
|
+
// Extended Point works in extended coordinates: (x, y, z, t) ∋ (x=x/z, y=y/z, t=xy).
|
|
76
|
+
// https://en.wikipedia.org/wiki/Twisted_Edwards_curve#Extended_coordinates
|
|
77
|
+
class Point {
|
|
78
|
+
constructor(ex, ey, ez, et) {
|
|
79
|
+
this.ex = ex;
|
|
80
|
+
this.ey = ey;
|
|
81
|
+
this.ez = ez;
|
|
82
|
+
this.et = et;
|
|
83
|
+
if (!in0MaskRange(ex))
|
|
84
|
+
throw new Error('x required');
|
|
85
|
+
if (!in0MaskRange(ey))
|
|
86
|
+
throw new Error('y required');
|
|
87
|
+
if (!in0MaskRange(ez))
|
|
88
|
+
throw new Error('z required');
|
|
89
|
+
if (!in0MaskRange(et))
|
|
90
|
+
throw new Error('t required');
|
|
91
|
+
}
|
|
92
|
+
get x() {
|
|
93
|
+
return this.toAffine().x;
|
|
94
|
+
}
|
|
95
|
+
get y() {
|
|
96
|
+
return this.toAffine().y;
|
|
97
|
+
}
|
|
98
|
+
static fromAffine(p) {
|
|
99
|
+
if (p instanceof Point)
|
|
100
|
+
throw new Error('extended point not allowed');
|
|
101
|
+
const { x, y } = p || {};
|
|
102
|
+
if (!in0MaskRange(x) || !in0MaskRange(y))
|
|
103
|
+
throw new Error('invalid affine point');
|
|
104
|
+
return new Point(x, y, _1n, modP(x * y));
|
|
105
|
+
}
|
|
106
|
+
static normalizeZ(points) {
|
|
107
|
+
const toInv = Fp.invertBatch(points.map((p) => p.ez));
|
|
108
|
+
return points.map((p, i) => p.toAffine(toInv[i])).map(Point.fromAffine);
|
|
109
|
+
}
|
|
110
|
+
// "Private method", don't use it directly
|
|
111
|
+
_setWindowSize(windowSize) {
|
|
112
|
+
this._WINDOW_SIZE = windowSize;
|
|
113
|
+
pointPrecomputes.delete(this);
|
|
114
|
+
}
|
|
115
|
+
// Not required for fromHex(), which always creates valid points.
|
|
116
|
+
// Could be useful for fromAffine().
|
|
117
|
+
assertValidity() {
|
|
118
|
+
const { a, d } = CURVE;
|
|
119
|
+
if (this.is0())
|
|
120
|
+
throw new Error('bad point: ZERO'); // TODO: optimize, with vars below?
|
|
121
|
+
// Equation in affine coordinates: ax² + y² = 1 + dx²y²
|
|
122
|
+
// Equation in projective coordinates (X/Z, Y/Z, Z): (aX² + Y²)Z² = Z⁴ + dX²Y²
|
|
123
|
+
const { ex: X, ey: Y, ez: Z, et: T } = this;
|
|
124
|
+
const X2 = modP(X * X); // X²
|
|
125
|
+
const Y2 = modP(Y * Y); // Y²
|
|
126
|
+
const Z2 = modP(Z * Z); // Z²
|
|
127
|
+
const Z4 = modP(Z2 * Z2); // Z⁴
|
|
128
|
+
const aX2 = modP(X2 * a); // aX²
|
|
129
|
+
const left = modP(Z2 * modP(aX2 + Y2)); // (aX² + Y²)Z²
|
|
130
|
+
const right = modP(Z4 + modP(d * modP(X2 * Y2))); // Z⁴ + dX²Y²
|
|
131
|
+
if (left !== right)
|
|
132
|
+
throw new Error('bad point: equation left != right (1)');
|
|
133
|
+
// In Extended coordinates we also have T, which is x*y=T/Z: check X*Y == Z*T
|
|
134
|
+
const XY = modP(X * Y);
|
|
135
|
+
const ZT = modP(Z * T);
|
|
136
|
+
if (XY !== ZT)
|
|
137
|
+
throw new Error('bad point: equation left != right (2)');
|
|
138
|
+
}
|
|
139
|
+
// Compare one point to another.
|
|
140
|
+
equals(other) {
|
|
141
|
+
isPoint(other);
|
|
142
|
+
const { ex: X1, ey: Y1, ez: Z1 } = this;
|
|
143
|
+
const { ex: X2, ey: Y2, ez: Z2 } = other;
|
|
144
|
+
const X1Z2 = modP(X1 * Z2);
|
|
145
|
+
const X2Z1 = modP(X2 * Z1);
|
|
146
|
+
const Y1Z2 = modP(Y1 * Z2);
|
|
147
|
+
const Y2Z1 = modP(Y2 * Z1);
|
|
148
|
+
return X1Z2 === X2Z1 && Y1Z2 === Y2Z1;
|
|
149
|
+
}
|
|
150
|
+
is0() {
|
|
151
|
+
return this.equals(Point.ZERO);
|
|
152
|
+
}
|
|
153
|
+
negate() {
|
|
154
|
+
// Flips point sign to a negative one (-x, y in affine coords)
|
|
155
|
+
return new Point(modP(-this.ex), this.ey, this.ez, modP(-this.et));
|
|
156
|
+
}
|
|
157
|
+
// Fast algo for doubling Extended Point.
|
|
158
|
+
// https://hyperelliptic.org/EFD/g1p/auto-twisted-extended.html#doubling-dbl-2008-hwcd
|
|
159
|
+
// Cost: 4M + 4S + 1*a + 6add + 1*2.
|
|
160
|
+
double() {
|
|
161
|
+
const { a } = CURVE;
|
|
162
|
+
const { ex: X1, ey: Y1, ez: Z1 } = this;
|
|
163
|
+
const A = modP(X1 * X1); // A = X12
|
|
164
|
+
const B = modP(Y1 * Y1); // B = Y12
|
|
165
|
+
const C = modP(_2n * modP(Z1 * Z1)); // C = 2*Z12
|
|
166
|
+
const D = modP(a * A); // D = a*A
|
|
167
|
+
const x1y1 = X1 + Y1;
|
|
168
|
+
const E = modP(modP(x1y1 * x1y1) - A - B); // E = (X1+Y1)2-A-B
|
|
169
|
+
const G = D + B; // G = D+B
|
|
170
|
+
const F = G - C; // F = G-C
|
|
171
|
+
const H = D - B; // H = D-B
|
|
172
|
+
const X3 = modP(E * F); // X3 = E*F
|
|
173
|
+
const Y3 = modP(G * H); // Y3 = G*H
|
|
174
|
+
const T3 = modP(E * H); // T3 = E*H
|
|
175
|
+
const Z3 = modP(F * G); // Z3 = F*G
|
|
176
|
+
return new Point(X3, Y3, Z3, T3);
|
|
177
|
+
}
|
|
178
|
+
// Fast algo for adding 2 Extended Points.
|
|
179
|
+
// https://hyperelliptic.org/EFD/g1p/auto-twisted-extended.html#addition-add-2008-hwcd
|
|
180
|
+
// Cost: 9M + 1*a + 1*d + 7add.
|
|
181
|
+
add(other) {
|
|
182
|
+
isPoint(other);
|
|
183
|
+
const { a, d } = CURVE;
|
|
184
|
+
const { ex: X1, ey: Y1, ez: Z1, et: T1 } = this;
|
|
185
|
+
const { ex: X2, ey: Y2, ez: Z2, et: T2 } = other;
|
|
186
|
+
// Faster algo for adding 2 Extended Points when curve's a=-1.
|
|
187
|
+
// http://hyperelliptic.org/EFD/g1p/auto-twisted-extended-1.html#addition-add-2008-hwcd-4
|
|
188
|
+
// Cost: 8M + 8add + 2*2.
|
|
189
|
+
// Note: It does not check whether the `other` point is valid.
|
|
190
|
+
if (a === BigInt(-1)) {
|
|
191
|
+
const A = modP((Y1 - X1) * (Y2 + X2));
|
|
192
|
+
const B = modP((Y1 + X1) * (Y2 - X2));
|
|
193
|
+
const F = modP(B - A);
|
|
194
|
+
if (F === _0n)
|
|
195
|
+
return this.double(); // Same point. Tests say it doesn't affect timing
|
|
196
|
+
const C = modP(Z1 * _2n * T2);
|
|
197
|
+
const D = modP(T1 * _2n * Z2);
|
|
198
|
+
const E = D + C;
|
|
199
|
+
const G = B + A;
|
|
200
|
+
const H = D - C;
|
|
201
|
+
const X3 = modP(E * F);
|
|
202
|
+
const Y3 = modP(G * H);
|
|
203
|
+
const T3 = modP(E * H);
|
|
204
|
+
const Z3 = modP(F * G);
|
|
205
|
+
return new Point(X3, Y3, Z3, T3);
|
|
206
|
+
}
|
|
207
|
+
const A = modP(X1 * X2); // A = X1*X2
|
|
208
|
+
const B = modP(Y1 * Y2); // B = Y1*Y2
|
|
209
|
+
const C = modP(T1 * d * T2); // C = T1*d*T2
|
|
210
|
+
const D = modP(Z1 * Z2); // D = Z1*Z2
|
|
211
|
+
const E = modP((X1 + Y1) * (X2 + Y2) - A - B); // E = (X1+Y1)*(X2+Y2)-A-B
|
|
212
|
+
const F = D - C; // F = D-C
|
|
213
|
+
const G = D + C; // G = D+C
|
|
214
|
+
const H = modP(B - a * A); // H = B-a*A
|
|
215
|
+
const X3 = modP(E * F); // X3 = E*F
|
|
216
|
+
const Y3 = modP(G * H); // Y3 = G*H
|
|
217
|
+
const T3 = modP(E * H); // T3 = E*H
|
|
218
|
+
const Z3 = modP(F * G); // Z3 = F*G
|
|
219
|
+
return new Point(X3, Y3, Z3, T3);
|
|
220
|
+
}
|
|
221
|
+
subtract(other) {
|
|
222
|
+
return this.add(other.negate());
|
|
223
|
+
}
|
|
224
|
+
wNAF(n) {
|
|
225
|
+
return wnaf.wNAFCached(this, pointPrecomputes, n, Point.normalizeZ);
|
|
226
|
+
}
|
|
227
|
+
// Constant-time multiplication.
|
|
228
|
+
multiply(scalar) {
|
|
229
|
+
const { p, f } = this.wNAF(assertInRange(scalar, CURVE_ORDER));
|
|
230
|
+
return Point.normalizeZ([p, f])[0];
|
|
231
|
+
}
|
|
232
|
+
// Non-constant-time multiplication. Uses double-and-add algorithm.
|
|
233
|
+
// It's faster, but should only be used when you don't care about
|
|
234
|
+
// an exposed private key e.g. sig verification.
|
|
235
|
+
multiplyUnsafe(scalar) {
|
|
236
|
+
let n = assertGE0(scalar);
|
|
237
|
+
if (n === _0n)
|
|
238
|
+
return I;
|
|
239
|
+
if (this.equals(I) || n === _1n)
|
|
240
|
+
return this;
|
|
241
|
+
if (this.equals(G))
|
|
242
|
+
return this.wNAF(n).p;
|
|
243
|
+
return wnaf.unsafeLadder(this, n);
|
|
244
|
+
}
|
|
245
|
+
// Checks if point is of small order.
|
|
246
|
+
// If you add something to small order point, you will have "dirty"
|
|
247
|
+
// point with torsion component.
|
|
248
|
+
// Multiplies point by cofactor and checks if the result is 0.
|
|
249
|
+
isSmallOrder() {
|
|
250
|
+
return this.multiplyUnsafe(cofactor).is0();
|
|
251
|
+
}
|
|
252
|
+
// Multiplies point by curve order and checks if the result is 0.
|
|
253
|
+
// Returns `false` is the point is dirty.
|
|
254
|
+
isTorsionFree() {
|
|
255
|
+
return wnaf.unsafeLadder(this, CURVE_ORDER).is0();
|
|
256
|
+
}
|
|
257
|
+
// Converts Extended point to default (x, y) coordinates.
|
|
258
|
+
// Can accept precomputed Z^-1 - for example, from invertBatch.
|
|
259
|
+
toAffine(iz) {
|
|
260
|
+
const { ex: x, ey: y, ez: z } = this;
|
|
261
|
+
const is0 = this.is0();
|
|
262
|
+
if (iz == null)
|
|
263
|
+
iz = is0 ? _8n : Fp.inv(z); // 8 was chosen arbitrarily
|
|
264
|
+
const ax = modP(x * iz);
|
|
265
|
+
const ay = modP(y * iz);
|
|
266
|
+
const zz = modP(z * iz);
|
|
267
|
+
if (is0)
|
|
268
|
+
return { x: _0n, y: _1n };
|
|
269
|
+
if (zz !== _1n)
|
|
270
|
+
throw new Error('invZ was invalid');
|
|
271
|
+
return { x: ax, y: ay };
|
|
272
|
+
}
|
|
273
|
+
clearCofactor() {
|
|
274
|
+
const { h: cofactor } = CURVE;
|
|
275
|
+
if (cofactor === _1n)
|
|
276
|
+
return this;
|
|
277
|
+
return this.multiplyUnsafe(cofactor);
|
|
278
|
+
}
|
|
279
|
+
// Converts hash string or Uint8Array to Point.
|
|
280
|
+
// Uses algo from RFC8032 5.1.3.
|
|
281
|
+
static fromHex(hex, strict = true) {
|
|
282
|
+
const { d, a } = CURVE;
|
|
283
|
+
const len = Fp.BYTES;
|
|
284
|
+
hex = ensureBytes('pointHex', hex, len); // copy hex to a new array
|
|
285
|
+
const normed = hex.slice(); // copy again, we'll manipulate it
|
|
286
|
+
const lastByte = hex[len - 1]; // select last byte
|
|
287
|
+
normed[len - 1] = lastByte & ~0x80; // clear last bit
|
|
288
|
+
const y = ut.bytesToNumberLE(normed);
|
|
289
|
+
if (y === _0n) {
|
|
290
|
+
// y=0 is allowed
|
|
291
|
+
}
|
|
292
|
+
else {
|
|
293
|
+
// RFC8032 prohibits >= p, but ZIP215 doesn't
|
|
294
|
+
if (strict)
|
|
295
|
+
assertInRange(y, Fp.ORDER); // strict=true [1..P-1] (2^255-19-1 for ed25519)
|
|
296
|
+
else
|
|
297
|
+
assertInRange(y, MASK); // strict=false [1..MASK-1] (2^256-1 for ed25519)
|
|
298
|
+
}
|
|
299
|
+
// Ed25519: x² = (y²-1)/(dy²+1) mod p. Ed448: x² = (y²-1)/(dy²-1) mod p. Generic case:
|
|
300
|
+
// ax²+y²=1+dx²y² => y²-1=dx²y²-ax² => y²-1=x²(dy²-a) => x²=(y²-1)/(dy²-a)
|
|
301
|
+
const y2 = modP(y * y); // denominator is always non-0 mod p.
|
|
302
|
+
const u = modP(y2 - _1n); // u = y² - 1
|
|
303
|
+
const v = modP(d * y2 - a); // v = d y² + 1.
|
|
304
|
+
let { isValid, value: x } = uvRatio(u, v); // √(u/v)
|
|
305
|
+
if (!isValid)
|
|
306
|
+
throw new Error('Point.fromHex: invalid y coordinate');
|
|
307
|
+
const isXOdd = (x & _1n) === _1n; // There are 2 square roots. Use x_0 bit to select proper
|
|
308
|
+
const isLastByteOdd = (lastByte & 0x80) !== 0; // if x=0 and x_0 = 1, fail
|
|
309
|
+
if (isLastByteOdd !== isXOdd)
|
|
310
|
+
x = modP(-x); // if x_0 != x mod 2, set x = p-x
|
|
311
|
+
return Point.fromAffine({ x, y });
|
|
312
|
+
}
|
|
313
|
+
static fromPrivateKey(privKey) {
|
|
314
|
+
return getExtendedPublicKey(privKey).point;
|
|
315
|
+
}
|
|
316
|
+
toRawBytes() {
|
|
317
|
+
const { x, y } = this.toAffine();
|
|
318
|
+
const bytes = ut.numberToBytesLE(y, Fp.BYTES); // each y has 2 x values (x, -y)
|
|
319
|
+
bytes[bytes.length - 1] |= x & _1n ? 0x80 : 0; // when compressing, it's enough to store y
|
|
320
|
+
return bytes; // and use the last byte to encode sign of x
|
|
321
|
+
}
|
|
322
|
+
toHex() {
|
|
323
|
+
return ut.bytesToHex(this.toRawBytes()); // Same as toRawBytes, but returns string.
|
|
324
|
+
}
|
|
325
|
+
}
|
|
326
|
+
Point.BASE = new Point(CURVE.Gx, CURVE.Gy, _1n, modP(CURVE.Gx * CURVE.Gy));
|
|
327
|
+
Point.ZERO = new Point(_0n, _1n, _1n, _0n); // 0, 1, 1, 0
|
|
328
|
+
const { BASE: G, ZERO: I } = Point;
|
|
329
|
+
const wnaf = wNAF(Point, nByteLength * 8);
|
|
330
|
+
function modN(a) {
|
|
331
|
+
return mod(a, CURVE_ORDER);
|
|
332
|
+
}
|
|
333
|
+
// Little-endian SHA512 with modulo n
|
|
334
|
+
function modN_LE(hash) {
|
|
335
|
+
return modN(ut.bytesToNumberLE(hash));
|
|
336
|
+
}
|
|
337
|
+
/** Convenience method that creates public key and other stuff. RFC8032 5.1.5 */
|
|
338
|
+
function getExtendedPublicKey(key) {
|
|
339
|
+
const len = nByteLength;
|
|
340
|
+
key = ensureBytes('private key', key, len);
|
|
341
|
+
// Hash private key with curve's hash function to produce uniformingly random input
|
|
342
|
+
// Check byte lengths: ensure(64, h(ensure(32, key)))
|
|
343
|
+
const hashed = ensureBytes('hashed private key', cHash(key), 2 * len);
|
|
344
|
+
const head = adjustScalarBytes(hashed.slice(0, len)); // clear first half bits, produce FE
|
|
345
|
+
const prefix = hashed.slice(len, 2 * len); // second half is called key prefix (5.1.6)
|
|
346
|
+
const scalar = modN_LE(head); // The actual private scalar
|
|
347
|
+
const point = G.multiply(scalar); // Point on Edwards curve aka public key
|
|
348
|
+
const pointBytes = point.toRawBytes(); // Uint8Array representation
|
|
349
|
+
return { head, prefix, scalar, point, pointBytes };
|
|
350
|
+
}
|
|
351
|
+
// Calculates EdDSA pub key. RFC8032 5.1.5. Privkey is hashed. Use first half with 3 bits cleared
|
|
352
|
+
function getPublicKey(privKey) {
|
|
353
|
+
return getExtendedPublicKey(privKey).pointBytes;
|
|
354
|
+
}
|
|
355
|
+
// int('LE', SHA512(dom2(F, C) || msgs)) mod N
|
|
356
|
+
function hashDomainToScalar(context = new Uint8Array(), ...msgs) {
|
|
357
|
+
const msg = ut.concatBytes(...msgs);
|
|
358
|
+
return modN_LE(cHash(domain(msg, ensureBytes('context', context), !!preHash)));
|
|
359
|
+
}
|
|
360
|
+
/** Signs message with privateKey. RFC8032 5.1.6 */
|
|
361
|
+
function sign(msg, privKey, context) {
|
|
362
|
+
msg = ensureBytes('message', msg);
|
|
363
|
+
if (preHash)
|
|
364
|
+
msg = preHash(msg); // for ed25519ph etc.
|
|
365
|
+
const { prefix, scalar, pointBytes } = getExtendedPublicKey(privKey);
|
|
366
|
+
const r = hashDomainToScalar(context, prefix, msg); // r = dom2(F, C) || prefix || PH(M)
|
|
367
|
+
const R = G.multiply(r).toRawBytes(); // R = rG
|
|
368
|
+
const k = hashDomainToScalar(context, R, pointBytes, msg); // R || A || PH(M)
|
|
369
|
+
const s = modN(r + k * scalar); // S = (r + k * s) mod L
|
|
370
|
+
assertGE0(s); // 0 <= s < l
|
|
371
|
+
const res = ut.concatBytes(R, ut.numberToBytesLE(s, Fp.BYTES));
|
|
372
|
+
return ensureBytes('result', res, nByteLength * 2); // 64-byte signature
|
|
373
|
+
}
|
|
374
|
+
function signModified(msg, privKey, context) {
|
|
375
|
+
msg = ensureBytes('message', msg);
|
|
376
|
+
const privKeyBytes = ensureBytes('privKey', privKey);
|
|
377
|
+
const privKeyNumber = ut.bytesToNumberLE(privKeyBytes);
|
|
378
|
+
const publicKey = G.multiply(modN(privKeyNumber)).toRawBytes();
|
|
379
|
+
const signBit = publicKey[31] & 0x80;
|
|
380
|
+
const r = hashDomainToScalar(context, privKeyBytes, msg); // r = dom2(F, C) || prefix || PH(M)
|
|
381
|
+
const R = G.multiply(r).toRawBytes(); // R = rG
|
|
382
|
+
const k = hashDomainToScalar(context, R, publicKey, msg); // R || A || PH(M)
|
|
383
|
+
const s = k * privKeyNumber; // S = (r + k * s) mod L
|
|
384
|
+
const S = modN(r + s);
|
|
385
|
+
assertGE0(S); // 0 <= s < l
|
|
386
|
+
const Sencoded = ut.numberToBytesLE(S, Fp.BYTES);
|
|
387
|
+
Sencoded[31] |= signBit;
|
|
388
|
+
const res = ut.concatBytes(R, Sencoded);
|
|
389
|
+
return ensureBytes('result', res, nByteLength * 2); // 64-byte signature
|
|
390
|
+
}
|
|
391
|
+
function verify(sig, msg, publicKey, context) {
|
|
392
|
+
const len = Fp.BYTES; // Verifies EdDSA signature against message and public key. RFC8032 5.1.7.
|
|
393
|
+
sig = ensureBytes('signature', sig, 2 * len); // An extended group equation is checked.
|
|
394
|
+
msg = ensureBytes('message', msg); // ZIP215 compliant, which means not fully RFC8032 compliant.
|
|
395
|
+
if (preHash)
|
|
396
|
+
msg = preHash(msg); // for ed25519ph, etc
|
|
397
|
+
const A = Point.fromHex(publicKey, false); // Check for s bounds, hex validity
|
|
398
|
+
const R = Point.fromHex(sig.slice(0, len), false); // 0 <= R < 2^256: ZIP215 R can be >= P
|
|
399
|
+
const s = ut.bytesToNumberLE(sig.slice(len, 2 * len)); // 0 <= s < l
|
|
400
|
+
const SB = G.multiplyUnsafe(s);
|
|
401
|
+
const k = hashDomainToScalar(context, R.toRawBytes(), A.toRawBytes(), msg);
|
|
402
|
+
const RkA = R.add(A.multiplyUnsafe(k));
|
|
403
|
+
// [8][S]B = [8]R + [8][k]A'
|
|
404
|
+
return RkA.subtract(SB).clearCofactor().equals(Point.ZERO);
|
|
405
|
+
}
|
|
406
|
+
G._setWindowSize(8); // Enable precomputes. Slows down first publicKey computation by 20ms.
|
|
407
|
+
const utils = {
|
|
408
|
+
getExtendedPublicKey,
|
|
409
|
+
// ed25519 private keys are uniform 32b. No need to check for modulo bias, like in secp256k1.
|
|
410
|
+
randomPrivateKey: () => randomBytes(Fp.BYTES),
|
|
411
|
+
/**
|
|
412
|
+
* We're doing scalar multiplication (used in getPublicKey etc) with precomputed BASE_POINT
|
|
413
|
+
* values. This slows down first getPublicKey() by milliseconds (see Speed section),
|
|
414
|
+
* but allows to speed-up subsequent getPublicKey() calls up to 20x.
|
|
415
|
+
* @param windowSize 2, 4, 8, 16
|
|
416
|
+
*/
|
|
417
|
+
precompute(windowSize = 8, point = Point.BASE) {
|
|
418
|
+
point._setWindowSize(windowSize);
|
|
419
|
+
point.multiply(BigInt(3));
|
|
420
|
+
return point;
|
|
421
|
+
},
|
|
422
|
+
};
|
|
423
|
+
return {
|
|
424
|
+
CURVE,
|
|
425
|
+
getPublicKey,
|
|
426
|
+
sign,
|
|
427
|
+
signModified,
|
|
428
|
+
verify,
|
|
429
|
+
ExtendedPoint: Point,
|
|
430
|
+
utils,
|
|
431
|
+
};
|
|
432
|
+
}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */
|
|
2
|
+
import type { Group, GroupConstructor, AffinePoint } from './curve.js';
|
|
3
|
+
import { Field } from './modular.js';
|
|
4
|
+
import { CHash } from './utils.js';
|
|
5
|
+
/**
|
|
6
|
+
* * `DST` is a domain separation tag, defined in section 2.2.5
|
|
7
|
+
* * `p` characteristic of F, where F is a finite field of characteristic p and order q = p^m
|
|
8
|
+
* * `m` is extension degree (1 for prime fields)
|
|
9
|
+
* * `k` is the target security target in bits (e.g. 128), from section 5.1
|
|
10
|
+
* * `expand` is `xmd` (SHA2, SHA3, BLAKE) or `xof` (SHAKE, BLAKE-XOF)
|
|
11
|
+
* * `hash` conforming to `utils.CHash` interface, with `outputLen` / `blockLen` props
|
|
12
|
+
*/
|
|
13
|
+
declare type UnicodeOrBytes = string | Uint8Array;
|
|
14
|
+
export declare type Opts = {
|
|
15
|
+
DST: UnicodeOrBytes;
|
|
16
|
+
p: bigint;
|
|
17
|
+
m: number;
|
|
18
|
+
k: number;
|
|
19
|
+
expand?: 'xmd' | 'xof';
|
|
20
|
+
hash: CHash;
|
|
21
|
+
};
|
|
22
|
+
export declare function expand_message_xmd(msg: Uint8Array, DST: Uint8Array, lenInBytes: number, H: CHash): Uint8Array;
|
|
23
|
+
export declare function expand_message_xof(msg: Uint8Array, DST: Uint8Array, lenInBytes: number, k: number, H: CHash): Uint8Array;
|
|
24
|
+
/**
|
|
25
|
+
* Hashes arbitrary-length byte strings to a list of one or more elements of a finite field F
|
|
26
|
+
* https://datatracker.ietf.org/doc/html/draft-irtf-cfrg-hash-to-curve-11#section-5.3
|
|
27
|
+
* @param msg a byte string containing the message to hash
|
|
28
|
+
* @param count the number of elements of F to output
|
|
29
|
+
* @param options `{DST: string, p: bigint, m: number, k: number, expand: 'xmd' | 'xof', hash: H}`, see above
|
|
30
|
+
* @returns [u_0, ..., u_(count - 1)], a list of field elements.
|
|
31
|
+
*/
|
|
32
|
+
export declare function hash_to_field(msg: Uint8Array, count: number, options: Opts): bigint[][];
|
|
33
|
+
export declare function isogenyMap<T, F extends Field<T>>(field: F, map: [T[], T[], T[], T[]]): (x: T, y: T) => {
|
|
34
|
+
x: T;
|
|
35
|
+
y: T;
|
|
36
|
+
};
|
|
37
|
+
export interface H2CPoint<T> extends Group<H2CPoint<T>> {
|
|
38
|
+
add(rhs: H2CPoint<T>): H2CPoint<T>;
|
|
39
|
+
toAffine(iz?: bigint): AffinePoint<T>;
|
|
40
|
+
clearCofactor(): H2CPoint<T>;
|
|
41
|
+
assertValidity(): void;
|
|
42
|
+
}
|
|
43
|
+
export interface H2CPointConstructor<T> extends GroupConstructor<H2CPoint<T>> {
|
|
44
|
+
fromAffine(ap: AffinePoint<T>): H2CPoint<T>;
|
|
45
|
+
}
|
|
46
|
+
export declare type MapToCurve<T> = (scalar: bigint[]) => AffinePoint<T>;
|
|
47
|
+
export declare type htfBasicOpts = {
|
|
48
|
+
DST: UnicodeOrBytes;
|
|
49
|
+
};
|
|
50
|
+
export declare function createHasher<T>(Point: H2CPointConstructor<T>, mapToCurve: MapToCurve<T>, def: Opts & {
|
|
51
|
+
encodeDST?: UnicodeOrBytes;
|
|
52
|
+
}): {
|
|
53
|
+
hashToCurve(msg: Uint8Array, options?: htfBasicOpts): H2CPoint<T>;
|
|
54
|
+
encodeToCurve(msg: Uint8Array, options?: htfBasicOpts): H2CPoint<T>;
|
|
55
|
+
};
|
|
56
|
+
export {};
|
|
@@ -0,0 +1,171 @@
|
|
|
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
|
+
import { mod } from './modular.js';
|
|
8
|
+
import { bytesToNumberBE, concatBytes, utf8ToBytes, validateObject } from './utils.js';
|
|
9
|
+
function validateDST(dst) {
|
|
10
|
+
if (dst instanceof Uint8Array)
|
|
11
|
+
return dst;
|
|
12
|
+
if (typeof dst === 'string')
|
|
13
|
+
return utf8ToBytes(dst);
|
|
14
|
+
throw new Error('DST must be Uint8Array or string');
|
|
15
|
+
}
|
|
16
|
+
// Octet Stream to Integer. "spec" implementation of os2ip is 2.5x slower vs bytesToNumberBE.
|
|
17
|
+
const os2ip = bytesToNumberBE;
|
|
18
|
+
// Integer to Octet Stream (numberToBytesBE)
|
|
19
|
+
function i2osp(value, length) {
|
|
20
|
+
if (value < 0 || value >= 1 << (8 * length)) {
|
|
21
|
+
throw new Error(`bad I2OSP call: value=${value} length=${length}`);
|
|
22
|
+
}
|
|
23
|
+
const res = Array.from({ length }).fill(0);
|
|
24
|
+
for (let i = length - 1; i >= 0; i--) {
|
|
25
|
+
res[i] = value & 0xff;
|
|
26
|
+
value >>>= 8;
|
|
27
|
+
}
|
|
28
|
+
return new Uint8Array(res);
|
|
29
|
+
}
|
|
30
|
+
function strxor(a, b) {
|
|
31
|
+
const arr = new Uint8Array(a.length);
|
|
32
|
+
for (let i = 0; i < a.length; i++) {
|
|
33
|
+
arr[i] = a[i] ^ b[i];
|
|
34
|
+
}
|
|
35
|
+
return arr;
|
|
36
|
+
}
|
|
37
|
+
function isBytes(item) {
|
|
38
|
+
if (!(item instanceof Uint8Array))
|
|
39
|
+
throw new Error('Uint8Array expected');
|
|
40
|
+
}
|
|
41
|
+
function isNum(item) {
|
|
42
|
+
if (!Number.isSafeInteger(item))
|
|
43
|
+
throw new Error('number expected');
|
|
44
|
+
}
|
|
45
|
+
// Produces a uniformly random byte string using a cryptographic hash function H that outputs b bits
|
|
46
|
+
// https://datatracker.ietf.org/doc/html/draft-irtf-cfrg-hash-to-curve-11#section-5.4.1
|
|
47
|
+
export function expand_message_xmd(msg, DST, lenInBytes, H) {
|
|
48
|
+
isBytes(msg);
|
|
49
|
+
isBytes(DST);
|
|
50
|
+
isNum(lenInBytes);
|
|
51
|
+
// https://datatracker.ietf.org/doc/html/draft-irtf-cfrg-hash-to-curve-16#section-5.3.3
|
|
52
|
+
if (DST.length > 255)
|
|
53
|
+
DST = H(concatBytes(utf8ToBytes('H2C-OVERSIZE-DST-'), DST));
|
|
54
|
+
const { outputLen: b_in_bytes, blockLen: r_in_bytes } = H;
|
|
55
|
+
const ell = Math.ceil(lenInBytes / b_in_bytes);
|
|
56
|
+
if (ell > 255)
|
|
57
|
+
throw new Error('Invalid xmd length');
|
|
58
|
+
const DST_prime = concatBytes(DST, i2osp(DST.length, 1));
|
|
59
|
+
const Z_pad = i2osp(0, r_in_bytes);
|
|
60
|
+
const l_i_b_str = i2osp(lenInBytes, 2); // len_in_bytes_str
|
|
61
|
+
const b = new Array(ell);
|
|
62
|
+
const b_0 = H(concatBytes(Z_pad, msg, l_i_b_str, i2osp(0, 1), DST_prime));
|
|
63
|
+
b[0] = H(concatBytes(b_0, i2osp(1, 1), DST_prime));
|
|
64
|
+
for (let i = 1; i <= ell; i++) {
|
|
65
|
+
const args = [strxor(b_0, b[i - 1]), i2osp(i + 1, 1), DST_prime];
|
|
66
|
+
b[i] = H(concatBytes(...args));
|
|
67
|
+
}
|
|
68
|
+
const pseudo_random_bytes = concatBytes(...b);
|
|
69
|
+
return pseudo_random_bytes.slice(0, lenInBytes);
|
|
70
|
+
}
|
|
71
|
+
export function expand_message_xof(msg, DST, lenInBytes, k, H) {
|
|
72
|
+
isBytes(msg);
|
|
73
|
+
isBytes(DST);
|
|
74
|
+
isNum(lenInBytes);
|
|
75
|
+
// https://datatracker.ietf.org/doc/html/draft-irtf-cfrg-hash-to-curve-16#section-5.3.3
|
|
76
|
+
// DST = H('H2C-OVERSIZE-DST-' || a_very_long_DST, Math.ceil((lenInBytes * k) / 8));
|
|
77
|
+
if (DST.length > 255) {
|
|
78
|
+
const dkLen = Math.ceil((2 * k) / 8);
|
|
79
|
+
DST = H.create({ dkLen }).update(utf8ToBytes('H2C-OVERSIZE-DST-')).update(DST).digest();
|
|
80
|
+
}
|
|
81
|
+
if (lenInBytes > 65535 || DST.length > 255)
|
|
82
|
+
throw new Error('expand_message_xof: invalid lenInBytes');
|
|
83
|
+
return (H.create({ dkLen: lenInBytes })
|
|
84
|
+
.update(msg)
|
|
85
|
+
.update(i2osp(lenInBytes, 2))
|
|
86
|
+
// 2. DST_prime = DST || I2OSP(len(DST), 1)
|
|
87
|
+
.update(DST)
|
|
88
|
+
.update(i2osp(DST.length, 1))
|
|
89
|
+
.digest());
|
|
90
|
+
}
|
|
91
|
+
/**
|
|
92
|
+
* Hashes arbitrary-length byte strings to a list of one or more elements of a finite field F
|
|
93
|
+
* https://datatracker.ietf.org/doc/html/draft-irtf-cfrg-hash-to-curve-11#section-5.3
|
|
94
|
+
* @param msg a byte string containing the message to hash
|
|
95
|
+
* @param count the number of elements of F to output
|
|
96
|
+
* @param options `{DST: string, p: bigint, m: number, k: number, expand: 'xmd' | 'xof', hash: H}`, see above
|
|
97
|
+
* @returns [u_0, ..., u_(count - 1)], a list of field elements.
|
|
98
|
+
*/
|
|
99
|
+
export function hash_to_field(msg, count, options) {
|
|
100
|
+
validateObject(options, {
|
|
101
|
+
DST: 'string',
|
|
102
|
+
p: 'bigint',
|
|
103
|
+
m: 'isSafeInteger',
|
|
104
|
+
k: 'isSafeInteger',
|
|
105
|
+
hash: 'hash',
|
|
106
|
+
});
|
|
107
|
+
const { p, k, m, hash, expand, DST: _DST } = options;
|
|
108
|
+
isBytes(msg);
|
|
109
|
+
isNum(count);
|
|
110
|
+
const DST = validateDST(_DST);
|
|
111
|
+
const log2p = p.toString(2).length;
|
|
112
|
+
const L = Math.ceil((log2p + k) / 8); // section 5.1 of ietf draft link above
|
|
113
|
+
const len_in_bytes = count * m * L;
|
|
114
|
+
let prb; // pseudo_random_bytes
|
|
115
|
+
if (expand === 'xmd') {
|
|
116
|
+
prb = expand_message_xmd(msg, DST, len_in_bytes, hash);
|
|
117
|
+
}
|
|
118
|
+
else if (expand === 'xof') {
|
|
119
|
+
prb = expand_message_xof(msg, DST, len_in_bytes, k, hash);
|
|
120
|
+
}
|
|
121
|
+
else if (expand === undefined) {
|
|
122
|
+
prb = msg;
|
|
123
|
+
}
|
|
124
|
+
else {
|
|
125
|
+
throw new Error('expand must be "xmd", "xof" or undefined');
|
|
126
|
+
}
|
|
127
|
+
const u = new Array(count);
|
|
128
|
+
for (let i = 0; i < count; i++) {
|
|
129
|
+
const e = new Array(m);
|
|
130
|
+
for (let j = 0; j < m; j++) {
|
|
131
|
+
const elm_offset = L * (j + i * m);
|
|
132
|
+
const tv = prb.subarray(elm_offset, elm_offset + L);
|
|
133
|
+
e[j] = mod(os2ip(tv), p);
|
|
134
|
+
}
|
|
135
|
+
u[i] = e;
|
|
136
|
+
}
|
|
137
|
+
return u;
|
|
138
|
+
}
|
|
139
|
+
export function isogenyMap(field, map) {
|
|
140
|
+
// Make same order as in spec
|
|
141
|
+
const COEFF = map.map((i) => Array.from(i).reverse());
|
|
142
|
+
return (x, y) => {
|
|
143
|
+
const [xNum, xDen, yNum, yDen] = COEFF.map((val) => val.reduce((acc, i) => field.add(field.mul(acc, x), i)));
|
|
144
|
+
x = field.div(xNum, xDen); // xNum / xDen
|
|
145
|
+
y = field.mul(y, field.div(yNum, yDen)); // y * (yNum / yDev)
|
|
146
|
+
return { x, y };
|
|
147
|
+
};
|
|
148
|
+
}
|
|
149
|
+
export function createHasher(Point, mapToCurve, def) {
|
|
150
|
+
if (typeof mapToCurve !== 'function')
|
|
151
|
+
throw new Error('mapToCurve() must be defined');
|
|
152
|
+
return {
|
|
153
|
+
// Encodes byte string to elliptic curve
|
|
154
|
+
// https://datatracker.ietf.org/doc/html/draft-irtf-cfrg-hash-to-curve-16#section-3
|
|
155
|
+
hashToCurve(msg, options) {
|
|
156
|
+
const u = hash_to_field(msg, 2, { ...def, DST: def.DST, ...options });
|
|
157
|
+
const u0 = Point.fromAffine(mapToCurve(u[0]));
|
|
158
|
+
const u1 = Point.fromAffine(mapToCurve(u[1]));
|
|
159
|
+
const P = u0.add(u1).clearCofactor();
|
|
160
|
+
P.assertValidity();
|
|
161
|
+
return P;
|
|
162
|
+
},
|
|
163
|
+
// https://datatracker.ietf.org/doc/html/draft-irtf-cfrg-hash-to-curve-16#section-3
|
|
164
|
+
encodeToCurve(msg, options) {
|
|
165
|
+
const u = hash_to_field(msg, 1, { ...def, DST: def.encodeDST, ...options });
|
|
166
|
+
const P = Point.fromAffine(mapToCurve(u[0])).clearCofactor();
|
|
167
|
+
P.assertValidity();
|
|
168
|
+
return P;
|
|
169
|
+
},
|
|
170
|
+
};
|
|
171
|
+
}
|