@layerswap/widget 0.1.4 → 0.1.14
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 +78 -3
- package/dist/Models/Theme.d.ts +7 -6
- package/dist/Models/Theme.js +7 -7
- package/dist/Models/WalletProvider.d.ts +0 -4
- package/dist/Models/WalletProvider.js +2 -0
- package/dist/components/Buttons/copyButton.js +4 -3
- package/dist/components/ColorSchema.js +79 -45
- package/dist/components/Common/AddressIcon.js +1 -0
- package/dist/components/Common/AverageCompletionTime.js +1 -1
- package/dist/components/Common/CountDownTimer.js +2 -2
- package/dist/components/Common/FormattedAverageCompletionTime.js +1 -1
- package/dist/components/HeaderWithMenu/index.js +1 -8
- package/dist/components/Input/Address/AddressNote.js +3 -2
- package/dist/components/Input/Address/AddressPicker/AddressWithIcon.js +2 -2
- package/dist/components/Input/Address/AddressPicker/ConnectedWallets/ConnectWalletButton.js +12 -5
- package/dist/components/Input/Address/AddressPicker/ExchangeNote.d.ts +1 -1
- package/dist/components/Input/Address/AddressPicker/ExchangeNote.js +1 -1
- package/dist/components/Input/RouteIcon.js +1 -1
- package/dist/components/LayerswapMenu/MenuList.js +2 -56
- package/dist/components/Pages/404/index.js +1 -0
- package/dist/components/Pages/Auth/Steps/CodeStep/VerifyEmailCode.js +1 -0
- package/dist/components/Pages/Auth/index.d.ts +1 -1
- package/dist/components/Pages/Auth/index.js +3 -2
- package/dist/components/Pages/Campaigns/Details/Leaderboard.js +1 -0
- package/dist/components/Pages/Campaigns/Details/index.d.ts +1 -1
- package/dist/components/Pages/Campaigns/Details/index.js +3 -2
- package/dist/components/Pages/Campaigns/index.d.ts +1 -1
- package/dist/components/Pages/Campaigns/index.js +3 -2
- package/dist/components/Pages/Maintanance/index.js +1 -0
- package/dist/components/Pages/NoCookies/index.js +1 -0
- package/dist/components/Pages/SwapHistory/History.js +1 -2
- package/dist/components/Pages/SwapHistory/index.d.ts +1 -1
- package/dist/components/Pages/SwapHistory/index.js +4 -3
- package/dist/components/Pages/SwapPages/Form/FeeDetails/Campaign.js +1 -0
- package/dist/components/Pages/SwapPages/Form/Form.js +1 -4
- package/dist/components/Pages/SwapPages/Form/SecondaryComponents/ValidationError.js +1 -1
- package/dist/components/Pages/SwapPages/Form/Select/Popover/PopoverSelect.js +1 -1
- package/dist/components/Pages/SwapPages/Form/index.js +1 -0
- package/dist/components/Pages/SwapPages/Withdraw/Coinbase/Carousel.js +8 -6
- package/dist/components/Pages/SwapPages/Withdraw/Processing/Processing.js +2 -2
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/FuelWalletWithdrawal.d.ts +0 -4
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/FuelWalletWithdrawal.js +159 -125
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/ImtblxWalletWithdrawStep.d.ts +0 -4
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/ImtblxWalletWithdrawStep.js +69 -51
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/Loopring/ActivationTokentPicker.d.ts +0 -8
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/Loopring/ActivationTokentPicker.js +87 -45
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/Loopring/hooks.d.ts +0 -40
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/Loopring/hooks.js +73 -46
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/Loopring/index.d.ts +0 -4
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/Loopring/index.js +175 -128
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/SVMWalletWithdraw/index.d.ts +0 -7
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/SVMWalletWithdraw/index.js +138 -116
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/SVMWalletWithdraw/transactionSender.d.ts +0 -8
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/SVMWalletWithdraw/transactionSender.js +96 -75
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/SophonWalletWithdraw.js +2 -2
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/StarknetWalletWithdraw.d.ts +0 -4
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/StarknetWalletWithdraw.js +88 -71
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/TonWalletWithdraw.d.ts +0 -4
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/TonWalletWithdraw.js +146 -136
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/TronWalletWithdraw.d.ts +0 -4
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/TronWalletWithdraw.js +120 -99
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/WalletTransfer/TransferToken.js +3 -3
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/WalletTransfer/buttons.js +1 -0
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/WalletTransfer/index.js +1 -1
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/WalletTransfer/transactionMessage.js +2 -2
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/WalletTransferContent.js +101 -33
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/paradex/Evm.d.ts +0 -4
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/paradex/Evm.js +60 -55
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/paradex/Starknet.d.ts +0 -4
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/paradex/Starknet.js +71 -55
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/paradex/buttons.js +1 -0
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/paradex/index.d.ts +0 -4
- package/dist/components/Pages/SwapPages/Withdraw/Wallet/paradex/index.js +56 -52
- package/dist/components/Pages/SwapPages/Withdraw/index.d.ts +1 -1
- package/dist/components/Pages/SwapPages/Withdraw/index.js +3 -2
- package/dist/components/Wallet/WalletModal/Connector.js +1 -1
- package/dist/components/Wallet/WalletProviders/FuelProvider.d.ts +0 -5
- package/dist/components/Wallet/WalletProviders/FuelProvider.js +25 -20
- package/dist/components/Wallet/WalletProviders/ImtblPassportProvider.d.ts +0 -5
- package/dist/components/Wallet/WalletProviders/ImtblPassportProvider.js +39 -36
- package/dist/components/Wallet/WalletProviders/SolanaProvider.d.ts +0 -5
- package/dist/components/Wallet/WalletProviders/SolanaProvider.js +49 -38
- package/dist/components/Wallet/WalletProviders/StarknetProvider.d.ts +0 -5
- package/dist/components/Wallet/WalletProviders/StarknetProvider.js +112 -117
- package/dist/components/Wallet/WalletProviders/TonConnectProvider.d.ts +0 -6
- package/dist/components/Wallet/WalletProviders/TonConnectProvider.js +58 -50
- package/dist/components/Wallet/WalletProviders/TronProvider.d.ts +0 -3
- package/dist/components/Wallet/WalletProviders/TronProvider.js +23 -15
- package/dist/components/Wallet/WalletProviders/Wagmi.d.ts +1 -1
- package/dist/components/Wallet/WalletProviders/Wagmi.js +20 -10
- package/dist/components/Wallet/WalletProviders/index.js +13 -6
- package/dist/components/Widget/Footer.d.ts +2 -1
- package/dist/components/Widget/Footer.js +13 -4
- package/dist/components/Widget/Index.d.ts +1 -1
- package/dist/components/Widget/Index.js +1 -1
- package/dist/components/WidgetLoading.d.ts +1 -0
- package/dist/components/WidgetLoading.js +5 -0
- package/dist/components/Wizard/Wizard.js +1 -1
- package/dist/components/shadcn/command.js +1 -1
- package/dist/components/themeWrapper.js +3 -2
- package/dist/context/{LayerswapContext.d.ts → LayerswapProvider.d.ts} +3 -8
- package/dist/context/{LayerswapContext.js → LayerswapProvider.js} +8 -9
- package/dist/context/authContext.js +1 -0
- package/dist/context/walletHooksProvider.js +1 -0
- package/dist/hooks/useWallet.js +10 -14
- package/dist/index.css +1 -1
- package/dist/index.d.ts +3 -5
- package/dist/index.js +2 -4
- package/dist/index.mjs +19 -0
- package/dist/lib/AppSettings.d.ts +7 -3
- package/dist/lib/AppSettings.js +8 -7
- package/dist/lib/address/formatter/index.js +8 -9
- package/dist/lib/address/validator/index.js +18 -20
- package/dist/lib/axiosInterceptor.js +1 -2
- package/dist/lib/balances/balanceResolver.js +16 -16
- package/dist/lib/balances/providers/evmBalanceProvider.js +3 -3
- package/dist/lib/balances/providers/loopringBalanceProvider.d.ts +0 -6
- package/dist/lib/balances/providers/loopringBalanceProvider.js +56 -43
- package/dist/lib/balances/providers/paradexBalanceProvider.d.ts +0 -6
- package/dist/lib/balances/providers/paradexBalanceProvider.js +42 -42
- package/dist/lib/balances/providers/solanaBalanceProvider.d.ts +0 -6
- package/dist/lib/balances/providers/solanaBalanceProvider.js +70 -71
- package/dist/lib/balances/providers/starknetBalanceProvider.d.ts +0 -6
- package/dist/lib/balances/providers/starknetBalanceProvider.js +48 -45
- package/dist/lib/balances/providers/tonBalanceProvider.d.ts +0 -18
- package/dist/lib/balances/providers/tonBalanceProvider.js +104 -100
- package/dist/lib/balances/providers/tronBalanceResolver.js +2 -3
- package/dist/lib/fuels/common/FakeAccount.d.ts +0 -24
- package/dist/lib/fuels/common/FakeAccount.js +58 -36
- package/dist/lib/fuels/common/PredicateConnector.d.ts +0 -54
- package/dist/lib/fuels/common/PredicateConnector.js +292 -205
- package/dist/lib/fuels/common/PredicateFactory.d.ts +0 -29
- package/dist/lib/fuels/common/PredicateFactory.js +123 -76
- package/dist/lib/fuels/common/PredicateWalletAdapter.d.ts +0 -17
- package/dist/lib/fuels/common/PredicateWalletAdapter.js +44 -29
- package/dist/lib/fuels/common/index.d.ts +0 -4
- package/dist/lib/fuels/common/index.js +4 -4
- package/dist/lib/fuels/connectors/fuel-wallet/FuelWalletConnector.d.ts +0 -51
- package/dist/lib/fuels/connectors/fuel-wallet/FuelWalletConnector.js +268 -234
- package/dist/lib/fuels/connectors/fuel-wallet/index.d.ts +0 -2
- package/dist/lib/fuels/connectors/fuel-wallet/index.js +2 -2
- package/dist/lib/fuels/connectors/fuel-wallet/types.d.ts +0 -50
- package/dist/lib/fuels/connectors/fuel-wallet/types.js +53 -9
- package/dist/lib/fuels/connectors/fuelet-wallet/FueletWalletConnector.d.ts +0 -7
- package/dist/lib/fuels/connectors/fuelet-wallet/FueletWalletConnector.js +20 -19
- package/dist/lib/fuels/connectors/fuelet-wallet/index.d.ts +0 -1
- package/dist/lib/fuels/connectors/fuelet-wallet/index.js +1 -1
- package/dist/lib/gases/gasResolver.d.ts +1 -1
- package/dist/lib/gases/gasResolver.js +10 -10
- package/dist/lib/gases/providers/evmGasProvider.js +5 -4
- package/dist/lib/gases/providers/loopringGasProvider.d.ts +0 -6
- package/dist/lib/gases/providers/loopringGasProvider.js +27 -24
- package/dist/lib/gases/providers/solanaGasProvider.d.ts +0 -7
- package/dist/lib/gases/providers/solanaGasProvider.js +32 -31
- package/dist/lib/gases/providers/starknetGasProvider.d.ts +0 -7
- package/dist/lib/gases/providers/starknetGasProvider.js +34 -33
- package/dist/lib/imtbl.d.ts +0 -69
- package/dist/lib/imtbl.js +63 -60
- package/dist/lib/internalApiClient.d.ts +0 -2
- package/dist/lib/internalApiClient.js +1 -4
- package/dist/lib/layerSwapApiClient.js +3 -3
- package/dist/lib/logError.js +2 -2
- package/dist/lib/nft/nftBalanceResolver.js +1 -2
- package/dist/lib/nft/providers/starknetNftProvider.d.ts +0 -6
- package/dist/lib/nft/providers/starknetNftProvider.js +49 -50
- package/dist/lib/wallets/connectors/EthereumProvider.d.ts +2 -2
- package/dist/lib/wallets/connectors/useSyncProviders/store.d.ts +1 -4
- package/dist/lib/wallets/fuel/Bako.d.ts +0 -15
- package/dist/lib/wallets/fuel/Bako.js +34 -29
- package/dist/lib/wallets/fuel/Basko.d.ts +0 -15
- package/dist/lib/wallets/fuel/Basko.js +34 -29
- package/dist/lib/wallets/fuel/useFuel.d.ts +0 -2
- package/dist/lib/wallets/fuel/useFuel.js +211 -192
- package/dist/lib/wallets/imtblX/useImtblX.d.ts +0 -2
- package/dist/lib/wallets/imtblX/useImtblX.js +87 -87
- package/dist/lib/wallets/paradex/Authorize/Ethereum.d.ts +0 -2
- package/dist/lib/wallets/paradex/Authorize/Ethereum.js +24 -23
- package/dist/lib/wallets/paradex/Authorize/Starknet.d.ts +0 -2
- package/dist/lib/wallets/paradex/Authorize/Starknet.js +14 -13
- package/dist/lib/wallets/paradex/lib/account.d.ts +0 -28
- package/dist/lib/wallets/paradex/lib/account.js +102 -53
- package/dist/lib/wallets/paradex/lib/index.d.ts +0 -24
- package/dist/lib/wallets/paradex/lib/index.js +20 -20
- package/dist/lib/wallets/paradex/lib/paraclear-provider.d.ts +0 -6
- package/dist/lib/wallets/paradex/lib/paraclear-provider.js +13 -9
- package/dist/lib/wallets/paradex/lib/paraclear.d.ts +0 -137
- package/dist/lib/wallets/paradex/lib/paraclear.js +258 -131
- package/dist/lib/wallets/paradex/lib/starknet-account-support.d.ts +0 -22
- package/dist/lib/wallets/paradex/lib/starknet-account-support.js +296 -220
- package/dist/lib/wallets/paradex/lib/starknet-signer.d.ts +0 -15
- package/dist/lib/wallets/paradex/lib/starknet-signer.js +120 -94
- package/dist/lib/wallets/paradex/useParadex.d.ts +0 -7
- package/dist/lib/wallets/paradex/useParadex.js +197 -194
- package/dist/lib/wallets/solana/transactionBuilder.d.ts +0 -4
- package/dist/lib/wallets/solana/transactionBuilder.js +63 -39
- package/dist/lib/wallets/solana/useSVM.d.ts +0 -5
- package/dist/lib/wallets/solana/useSVM.js +139 -142
- package/dist/lib/wallets/starknet/useStarknet.d.ts +0 -2
- package/dist/lib/wallets/starknet/useStarknet.js +139 -139
- package/dist/lib/wallets/ton/client.d.ts +0 -3
- package/dist/lib/wallets/ton/client.js +7 -7
- package/dist/lib/wallets/ton/useTON.d.ts +0 -2
- package/dist/lib/wallets/ton/useTON.js +121 -122
- package/dist/lib/wallets/tron/connectors/bitkeep.d.ts +0 -61
- package/dist/lib/wallets/tron/connectors/bitkeep.js +326 -303
- package/dist/lib/wallets/tron/connectors/index.d.ts +0 -4
- package/dist/lib/wallets/tron/connectors/index.js +4 -4
- package/dist/lib/wallets/tron/connectors/okxWallet.d.ts +0 -66
- package/dist/lib/wallets/tron/connectors/okxWallet.js +364 -336
- package/dist/lib/wallets/tron/connectors/tokenPocket.d.ts +0 -72
- package/dist/lib/wallets/tron/connectors/tokenPocket.js +337 -308
- package/dist/lib/wallets/tron/connectors/tronLink/index.d.ts +0 -102
- package/dist/lib/wallets/tron/connectors/tronLink/index.js +560 -520
- package/dist/lib/wallets/tron/connectors/tronLink/types.d.ts +0 -56
- package/dist/lib/wallets/tron/connectors/tronLink/types.js +53 -1
- package/dist/lib/wallets/tron/connectors/tronLink/utils.d.ts +0 -14
- package/dist/lib/wallets/tron/connectors/tronLink/utils.js +64 -61
- package/dist/lib/wallets/tron/useTron.d.ts +0 -2
- package/dist/lib/wallets/tron/useTron.js +111 -111
- package/dist/lib/wallets/utils/resolveWalletIcon.js +1 -0
- package/package.json +26 -77
- package/dist/hooks/useCopyClipboard.d.ts +0 -1
- package/dist/hooks/useCopyClipboard.js +0 -21
- package/dist/index.cjs +0 -125
- package/dist/lib/abis/ERC20.json +0 -258
- package/dist/lib/fuels/connectors/walletConnect/WalletConnectConnector.d.ts +0 -42
- package/dist/lib/fuels/connectors/walletConnect/WalletConnectConnector.js +0 -357
- package/dist/lib/fuels/connectors/walletConnect/constants.d.ts +0 -6
- package/dist/lib/fuels/connectors/walletConnect/constants.js +0 -7
- package/dist/lib/fuels/connectors/walletConnect/index.d.ts +0 -3
- package/dist/lib/fuels/connectors/walletConnect/index.js +0 -3
- package/dist/lib/fuels/connectors/walletConnect/types.d.ts +0 -12
- package/dist/lib/fuels/connectors/walletConnect/types.js +0 -1
- package/dist/lib/fuels/connectors/walletConnect/utils/index.d.ts +0 -1
- package/dist/lib/fuels/connectors/walletConnect/utils/index.js +0 -1
- package/dist/lib/fuels/connectors/walletConnect/utils/subscribeAndEnforceChain.d.ts +0 -2
- package/dist/lib/fuels/connectors/walletConnect/utils/subscribeAndEnforceChain.js +0 -39
- package/dist/lib/fuels/connectors/walletConnect/web3Modal.d.ts +0 -10
- package/dist/lib/fuels/connectors/walletConnect/web3Modal.js +0 -38
- package/dist/lib/loopring/LoopringAPI.d.ts +0 -12
- package/dist/lib/loopring/LoopringAPI.js +0 -13
- package/dist/lib/loopring/defs.d.ts +0 -425
- package/dist/lib/loopring/defs.js +0 -217
- package/dist/lib/loopring/eddsa.d.ts +0 -29
- package/dist/lib/loopring/eddsa.js +0 -208
- package/dist/lib/loopring/field.d.ts +0 -17
- package/dist/lib/loopring/field.js +0 -61
- package/dist/lib/loopring/formatter.d.ts +0 -137
- package/dist/lib/loopring/formatter.js +0 -516
- package/dist/lib/loopring/helpers.d.ts +0 -36
- package/dist/lib/loopring/helpers.js +0 -140
- package/dist/lib/loopring/jubjub.d.ts +0 -19
- package/dist/lib/loopring/jubjub.js +0 -79
- package/dist/lib/loopring/permutation.d.ts +0 -22
- package/dist/lib/loopring/permutation.js +0 -198
- package/dist/lib/loopring/poseidon/EDDSAUtil.d.ts +0 -14
- package/dist/lib/loopring/poseidon/EDDSAUtil.js +0 -61
- package/dist/lib/loopring/poseidon/babyJub.d.ts +0 -6
- package/dist/lib/loopring/poseidon/babyJub.js +0 -51
- package/dist/lib/loopring/poseidon/eddsa.d.ts +0 -29
- package/dist/lib/loopring/poseidon/eddsa.js +0 -210
- package/dist/lib/loopring/utils.d.ts +0 -76
- package/dist/lib/loopring/utils.js +0 -230
- package/dist/styles/dialog-transition.css +0 -28
- package/dist/styles/globals.css +0 -372
- package/dist/styles/manual-trasnfer-svg.css +0 -299
- package/dist/styles/vaul.css +0 -256
|
@@ -1,220 +1,296 @@
|
|
|
1
|
-
import * as Starknet from 'starknet';
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
}
|
|
1
|
+
// import * as Starknet from 'starknet';
|
|
2
|
+
// type SignatureFormat =
|
|
3
|
+
// | 'argent-v0.3.0'
|
|
4
|
+
// | 'argent-v0.3.1'
|
|
5
|
+
// | 'argent-v0.4.0-starknet-signer'
|
|
6
|
+
// | 'argent-v0.4.0-secp256k1-signer'
|
|
7
|
+
// | 'argent-v0.4.0-secp256r1-signer'
|
|
8
|
+
// | 'argent-v0.4.0-eip191-signer'
|
|
9
|
+
// | 'argent-v0.4.0-webauthn-signer'
|
|
10
|
+
// | 'argent-multicall'
|
|
11
|
+
// | 'argent-multisig-v0.1.0'
|
|
12
|
+
// | 'argent-multisig-v0.1.1'
|
|
13
|
+
// | 'argent-multisig-v0.2.0'
|
|
14
|
+
// | 'braavos-v1.0.0-stark-signer'
|
|
15
|
+
// | 'braavos-v1.0.0-strong-signer'
|
|
16
|
+
// | 'braavos-v1.0.0-multisig'
|
|
17
|
+
// | 'braavos-v1.1.0-stark-signer'
|
|
18
|
+
// | 'braavos-v1.1.0-strong-signer'
|
|
19
|
+
// | 'braavos-v1.1.0-multisig'
|
|
20
|
+
// | 'braavos-multi-owner-v1.0.0'
|
|
21
|
+
// | 'unknown';
|
|
22
|
+
// interface CheckResult {
|
|
23
|
+
// readonly ok: boolean;
|
|
24
|
+
// readonly reason?: string;
|
|
25
|
+
// }
|
|
26
|
+
// export class AccountSupport {
|
|
27
|
+
// private signatureFormat: SignatureFormat | null = null;
|
|
28
|
+
// constructor(
|
|
29
|
+
// /** The contract instance of the account. */
|
|
30
|
+
// private readonly contract: Starknet.Contract,
|
|
31
|
+
// /** The class hash of the account contract. */
|
|
32
|
+
// private readonly classHash: string,
|
|
33
|
+
// ) {
|
|
34
|
+
// this.classHash = Starknet.num.cleanHex(this.classHash);
|
|
35
|
+
// }
|
|
36
|
+
// private testClassHash(classHash: string): boolean {
|
|
37
|
+
// return this.classHash === Starknet.num.cleanHex(classHash);
|
|
38
|
+
// }
|
|
39
|
+
// private async getFormat(): Promise<SignatureFormat> {
|
|
40
|
+
// if (
|
|
41
|
+
// this.testClassHash(
|
|
42
|
+
// '0x1a736d6ed154502257f02b1ccdf4d9d1089f80811cd6acad48e6b6a9d1f2003',
|
|
43
|
+
// )
|
|
44
|
+
// ) {
|
|
45
|
+
// return 'argent-v0.3.0';
|
|
46
|
+
// }
|
|
47
|
+
// if (
|
|
48
|
+
// this.testClassHash(
|
|
49
|
+
// '0x29927c8af6bccf3f6fda035981e765a7bdbf18a2dc0d630494f8758aa908e2b',
|
|
50
|
+
// )
|
|
51
|
+
// ) {
|
|
52
|
+
// return 'argent-v0.3.1';
|
|
53
|
+
// }
|
|
54
|
+
// if (
|
|
55
|
+
// this.testClassHash(
|
|
56
|
+
// '0x036078334509b514626504edc9fb252328d1a240e4e948bef8d0c08dff45927f',
|
|
57
|
+
// )
|
|
58
|
+
// ) {
|
|
59
|
+
// const ownerTypeResp = (await this.contract.call(
|
|
60
|
+
// 'get_owner_type',
|
|
61
|
+
// )) as Starknet.CairoCustomEnum;
|
|
62
|
+
// const ownerType = ownerTypeResp.activeVariant();
|
|
63
|
+
// switch (ownerType) {
|
|
64
|
+
// case 'Starknet':
|
|
65
|
+
// return 'argent-v0.4.0-starknet-signer';
|
|
66
|
+
// case 'Secp256k1':
|
|
67
|
+
// return 'argent-v0.4.0-secp256k1-signer';
|
|
68
|
+
// case 'Secp256r1':
|
|
69
|
+
// return 'argent-v0.4.0-secp256r1-signer';
|
|
70
|
+
// case 'Eip191':
|
|
71
|
+
// return 'argent-v0.4.0-eip191-signer';
|
|
72
|
+
// case 'Webauthn':
|
|
73
|
+
// return 'argent-v0.4.0-webauthn-signer';
|
|
74
|
+
// default:
|
|
75
|
+
// return 'unknown';
|
|
76
|
+
// }
|
|
77
|
+
// }
|
|
78
|
+
// if (
|
|
79
|
+
// this.testClassHash(
|
|
80
|
+
// '0x0381f14e5e0db5889c981bf050fb034c0fbe0c4f070ee79346a05dbe2bf2af90',
|
|
81
|
+
// )
|
|
82
|
+
// ) {
|
|
83
|
+
// return 'argent-multicall';
|
|
84
|
+
// }
|
|
85
|
+
// if (
|
|
86
|
+
// this.testClassHash(
|
|
87
|
+
// '0x737ee2f87ce571a58c6c8da558ec18a07ceb64a6172d5ec46171fbc80077a48',
|
|
88
|
+
// )
|
|
89
|
+
// ) {
|
|
90
|
+
// return 'argent-multisig-v0.1.0';
|
|
91
|
+
// }
|
|
92
|
+
// if (
|
|
93
|
+
// this.testClassHash(
|
|
94
|
+
// '0x6e150953b26271a740bf2b6e9bca17cc52c68d765f761295de51ceb8526ee72',
|
|
95
|
+
// )
|
|
96
|
+
// ) {
|
|
97
|
+
// return 'argent-multisig-v0.1.1';
|
|
98
|
+
// }
|
|
99
|
+
// if (
|
|
100
|
+
// this.testClassHash(
|
|
101
|
+
// '0x07aeca3456816e3b833506d7cc5c1313d371fbdb0ae95ee70af72a4ddbf42594',
|
|
102
|
+
// )
|
|
103
|
+
// ) {
|
|
104
|
+
// return 'argent-multisig-v0.2.0';
|
|
105
|
+
// }
|
|
106
|
+
// // https://github.com/myBraavos/braavos-account-cairo/blob/6efdfd597bb051e99c79a512fccd14ee2523c898/README_MOA.md
|
|
107
|
+
// if (
|
|
108
|
+
// this.testClassHash(
|
|
109
|
+
// '0x041bf1e71792aecb9df3e9d04e1540091c5e13122a731e02bec588f71dc1a5c3',
|
|
110
|
+
// )
|
|
111
|
+
// ) {
|
|
112
|
+
// return 'braavos-multi-owner-v1.0.0';
|
|
113
|
+
// }
|
|
114
|
+
// // https://github.com/myBraavos/braavos-account-cairo/tree/v1.0.0
|
|
115
|
+
// if (
|
|
116
|
+
// this.testClassHash(
|
|
117
|
+
// '0x00816dd0297efc55dc1e7559020a3a825e81ef734b558f03c83325d4da7e6253',
|
|
118
|
+
// )
|
|
119
|
+
// ) {
|
|
120
|
+
// const multiSigThreshold = (await this.contract.call(
|
|
121
|
+
// 'get_multisig_threshold',
|
|
122
|
+
// )) as bigint;
|
|
123
|
+
// if (multiSigThreshold !== 0n) {
|
|
124
|
+
// return 'braavos-v1.0.0-multisig';
|
|
125
|
+
// }
|
|
126
|
+
// const signers = (await this.contract.call('get_signers')) as {
|
|
127
|
+
// readonly secp256r1?: string[];
|
|
128
|
+
// readonly stark?: string[];
|
|
129
|
+
// readonly webauthn?: string[];
|
|
130
|
+
// };
|
|
131
|
+
// if (signers.secp256r1 != null && signers.secp256r1.length > 0)
|
|
132
|
+
// return 'braavos-v1.0.0-strong-signer';
|
|
133
|
+
// if (signers.webauthn != null && signers.webauthn.length > 0)
|
|
134
|
+
// return 'braavos-v1.0.0-strong-signer';
|
|
135
|
+
// if (signers.stark != null && signers.stark.length === 1)
|
|
136
|
+
// return 'braavos-v1.0.0-stark-signer';
|
|
137
|
+
// return 'unknown';
|
|
138
|
+
// }
|
|
139
|
+
// // New Braavos account contract, not available on GitHub
|
|
140
|
+
// // Reported to be an upgrade to the previous Braavos account contract
|
|
141
|
+
// // https://tradeparadigm.slack.com/archives/C06TRUBLSDB/p1731706968018819?thread_ts=1720108178.898199&cid=C06TRUBLSDB
|
|
142
|
+
// if (
|
|
143
|
+
// this.testClassHash(
|
|
144
|
+
// '0x02c8c7e6fbcfb3e8e15a46648e8914c6aa1fc506fc1e7fb3d1e19630716174bc',
|
|
145
|
+
// )
|
|
146
|
+
// ) {
|
|
147
|
+
// const multiSigThreshold = (await this.contract.call(
|
|
148
|
+
// 'get_multisig_threshold',
|
|
149
|
+
// )) as bigint;
|
|
150
|
+
// if (multiSigThreshold !== 0n) {
|
|
151
|
+
// return 'braavos-v1.1.0-multisig';
|
|
152
|
+
// }
|
|
153
|
+
// const signers = (await this.contract.call('get_signers')) as {
|
|
154
|
+
// readonly secp256r1?: string[];
|
|
155
|
+
// readonly stark?: string[];
|
|
156
|
+
// readonly webauthn?: string[];
|
|
157
|
+
// };
|
|
158
|
+
// if (signers.secp256r1 != null && signers.secp256r1.length > 0)
|
|
159
|
+
// return 'braavos-v1.1.0-strong-signer';
|
|
160
|
+
// if (signers.webauthn != null && signers.webauthn.length > 0)
|
|
161
|
+
// return 'braavos-v1.1.0-strong-signer';
|
|
162
|
+
// if (signers.stark != null && signers.stark.length === 1)
|
|
163
|
+
// return 'braavos-v1.1.0-stark-signer';
|
|
164
|
+
// return 'unknown';
|
|
165
|
+
// }
|
|
166
|
+
// return 'unknown';
|
|
167
|
+
// }
|
|
168
|
+
// async check(): Promise<CheckResult> {
|
|
169
|
+
// this.signatureFormat = await this.getFormat();
|
|
170
|
+
// switch (this.signatureFormat) {
|
|
171
|
+
// case 'argent-v0.3.0':
|
|
172
|
+
// case 'argent-v0.3.1':
|
|
173
|
+
// case 'argent-v0.4.0-starknet-signer':
|
|
174
|
+
// case 'braavos-v1.0.0-stark-signer':
|
|
175
|
+
// case 'braavos-v1.1.0-stark-signer':
|
|
176
|
+
// return { ok: true };
|
|
177
|
+
// case 'argent-v0.4.0-secp256k1-signer':
|
|
178
|
+
// return {
|
|
179
|
+
// ok: false,
|
|
180
|
+
// reason: 'Argent Secp256k1Signer is not supported',
|
|
181
|
+
// };
|
|
182
|
+
// case 'argent-v0.4.0-secp256r1-signer':
|
|
183
|
+
// return {
|
|
184
|
+
// ok: false,
|
|
185
|
+
// reason: 'Argent Secp256r1Signer is not supported',
|
|
186
|
+
// };
|
|
187
|
+
// case 'argent-v0.4.0-eip191-signer':
|
|
188
|
+
// return {
|
|
189
|
+
// ok: false,
|
|
190
|
+
// reason: 'Argent Eip191Signer is not supported',
|
|
191
|
+
// };
|
|
192
|
+
// case 'argent-v0.4.0-webauthn-signer':
|
|
193
|
+
// return {
|
|
194
|
+
// ok: false,
|
|
195
|
+
// reason: 'Argent WebauthnSigner is not supported',
|
|
196
|
+
// };
|
|
197
|
+
// case 'argent-multicall':
|
|
198
|
+
// return {
|
|
199
|
+
// ok: false,
|
|
200
|
+
// reason: 'Argent multicall is not supported',
|
|
201
|
+
// };
|
|
202
|
+
// case 'argent-multisig-v0.1.0':
|
|
203
|
+
// case 'argent-multisig-v0.1.1':
|
|
204
|
+
// case 'argent-multisig-v0.2.0':
|
|
205
|
+
// return {
|
|
206
|
+
// ok: false,
|
|
207
|
+
// reason: 'Argent multisig is not supported',
|
|
208
|
+
// };
|
|
209
|
+
// case 'braavos-v1.0.0-strong-signer':
|
|
210
|
+
// case 'braavos-v1.1.0-strong-signer':
|
|
211
|
+
// return {
|
|
212
|
+
// ok: false,
|
|
213
|
+
// reason: 'Braavos strong signer is not supported',
|
|
214
|
+
// };
|
|
215
|
+
// case 'braavos-v1.0.0-multisig':
|
|
216
|
+
// case 'braavos-v1.1.0-multisig':
|
|
217
|
+
// return {
|
|
218
|
+
// ok: false,
|
|
219
|
+
// reason: 'Braavos multisig is not supported',
|
|
220
|
+
// };
|
|
221
|
+
// case 'braavos-multi-owner-v1.0.0':
|
|
222
|
+
// return {
|
|
223
|
+
// ok: false,
|
|
224
|
+
// reason: 'Braavos Multi Owner Account is not supported',
|
|
225
|
+
// };
|
|
226
|
+
// case 'unknown':
|
|
227
|
+
// return {
|
|
228
|
+
// ok: false,
|
|
229
|
+
// reason: 'Unsupported account contract',
|
|
230
|
+
// };
|
|
231
|
+
// // no default
|
|
232
|
+
// }
|
|
233
|
+
// }
|
|
234
|
+
// getSeedFromSignature(signature: Starknet.Signature): string {
|
|
235
|
+
// const segments = Starknet.stark.signatureToHexArray(signature);
|
|
236
|
+
// if (this.signatureFormat == null) {
|
|
237
|
+
// throw new Error('Check account contract support first');
|
|
238
|
+
// }
|
|
239
|
+
// switch (this.signatureFormat) {
|
|
240
|
+
// case 'argent-v0.3.0':
|
|
241
|
+
// case 'argent-v0.3.1': {
|
|
242
|
+
// const [r, _s] = segments;
|
|
243
|
+
// if (r == null) throw new Error('Argent signature is missing R segment');
|
|
244
|
+
// return r;
|
|
245
|
+
// }
|
|
246
|
+
// case 'argent-v0.4.0-starknet-signer': {
|
|
247
|
+
// if (segments.length === 2 || segments.length === 4) {
|
|
248
|
+
// const [r, _s] = segments;
|
|
249
|
+
// if (r == null)
|
|
250
|
+
// throw new Error('Argent signature is missing R segment');
|
|
251
|
+
// return r;
|
|
252
|
+
// }
|
|
253
|
+
// if (segments.length === 5 || segments.length === 9) {
|
|
254
|
+
// const [_numSignatures, _sigType, _pubKey, r, _s] = segments;
|
|
255
|
+
// if (r == null)
|
|
256
|
+
// throw new Error('Argent signature is missing R segment');
|
|
257
|
+
// return r;
|
|
258
|
+
// }
|
|
259
|
+
// throw new Error('Unsupported Argent signature');
|
|
260
|
+
// }
|
|
261
|
+
// case 'braavos-v1.0.0-stark-signer':
|
|
262
|
+
// case 'braavos-v1.1.0-stark-signer': {
|
|
263
|
+
// if (segments.length === 2) {
|
|
264
|
+
// const [r, _s] = segments;
|
|
265
|
+
// if (r == null)
|
|
266
|
+
// throw new Error('Braavos signature is missing R segment');
|
|
267
|
+
// return r;
|
|
268
|
+
// }
|
|
269
|
+
// if (segments.length === 3) {
|
|
270
|
+
// const [_signerType, r, _s] = segments;
|
|
271
|
+
// if (r == null)
|
|
272
|
+
// throw new Error('Braavos signature is missing R segment');
|
|
273
|
+
// return r;
|
|
274
|
+
// }
|
|
275
|
+
// throw new Error('Unsupported Braavos signature');
|
|
276
|
+
// }
|
|
277
|
+
// case 'argent-v0.4.0-secp256k1-signer':
|
|
278
|
+
// case 'argent-v0.4.0-secp256r1-signer':
|
|
279
|
+
// case 'argent-v0.4.0-eip191-signer':
|
|
280
|
+
// case 'argent-v0.4.0-webauthn-signer':
|
|
281
|
+
// case 'argent-multicall':
|
|
282
|
+
// case 'argent-multisig-v0.1.0':
|
|
283
|
+
// case 'argent-multisig-v0.1.1':
|
|
284
|
+
// case 'argent-multisig-v0.2.0':
|
|
285
|
+
// case 'braavos-v1.0.0-strong-signer':
|
|
286
|
+
// case 'braavos-v1.1.0-strong-signer':
|
|
287
|
+
// case 'braavos-v1.0.0-multisig':
|
|
288
|
+
// case 'braavos-v1.1.0-multisig':
|
|
289
|
+
// case 'braavos-multi-owner-v1.0.0':
|
|
290
|
+
// throw new Error(`${this.signatureFormat} is not supported`);
|
|
291
|
+
// case 'unknown':
|
|
292
|
+
// throw new Error('Unsupported account contract');
|
|
293
|
+
// // no default
|
|
294
|
+
// }
|
|
295
|
+
// }
|
|
296
|
+
// }
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import type { Signature, SignerInterface, TypedData } from 'starknet';
|
|
2
|
-
import * as Starknet from 'starknet';
|
|
3
|
-
import { AccountSupport } from './starknet-account-support';
|
|
4
|
-
export type { SignerInterface as Signer, TypedData, Signature };
|
|
5
|
-
export declare function buildStarknetStarkKeyTypedData(starknetChainId: string): TypedData;
|
|
6
|
-
type StarknetKeypair = [string, string];
|
|
7
|
-
/**
|
|
8
|
-
* This function borrows from starkware-crypto-utils's implementation
|
|
9
|
-
* of `getPrivateKeyFromEthSignature()` where a deterministic
|
|
10
|
-
* signature R segment, is hex encoded as the `keySeed` for
|
|
11
|
-
* `grindKey()` along the Stark curve.
|
|
12
|
-
*/
|
|
13
|
-
export declare function getStarkKeypairFromStarknetSignature(signatureR: string): Promise<StarknetKeypair>;
|
|
14
|
-
export declare function getAccountSupport(account: Starknet.AccountInterface, starknetProvider: Starknet.ProviderInterface): Promise<AccountSupport>;
|
|
15
|
-
export declare function getPublicProvider(chainId: string): Starknet.ProviderInterface;
|