@web3auth/no-modal 9.5.4 → 10.0.0-alpha.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/dist/757.noModal.cjs.js +226 -0
- package/dist/lib.cjs/adapters/auth-adapter/authAdapter.js +262 -0
- package/dist/lib.cjs/adapters/auth-adapter/config.js +17 -0
- package/dist/lib.cjs/adapters/base-evm-adapter/baseEvmAdapter.js +72 -0
- package/dist/lib.cjs/adapters/base-solana-adapter/baseSolanaAdapter.js +76 -0
- package/dist/lib.cjs/adapters/coinbase-adapter/coinbaseAdapter.js +156 -0
- package/dist/lib.cjs/adapters/default-evm-adapter/index.js +40 -0
- package/dist/lib.cjs/adapters/default-evm-adapter/injectedAdapters.js +42 -0
- package/dist/lib.cjs/adapters/default-evm-adapter/injectedEvmAdapter.js +160 -0
- package/dist/lib.cjs/adapters/default-solana-adapter/index.js +40 -0
- package/dist/lib.cjs/adapters/default-solana-adapter/injectedAdapters.js +53 -0
- package/dist/lib.cjs/adapters/default-solana-adapter/utils.js +16 -0
- package/dist/lib.cjs/adapters/default-solana-adapter/walletStandardAdapter.js +138 -0
- package/dist/lib.cjs/adapters/default-solana-adapter/walletStandardHandler.js +77 -0
- package/dist/lib.cjs/adapters/wallet-connect-v2-adapter/WalletConnectV2Provider.js +278 -0
- package/dist/lib.cjs/adapters/wallet-connect-v2-adapter/config.js +183 -0
- package/dist/lib.cjs/adapters/wallet-connect-v2-adapter/walletConnectV2Utils.js +165 -0
- package/dist/lib.cjs/adapters/wallet-connect-v2-adapter/walletConnectV2adapter.js +376 -0
- package/dist/lib.cjs/base/adapter/baseAdapter.js +117 -0
- package/dist/lib.cjs/base/adapter/constants.js +24 -0
- package/dist/lib.cjs/base/adapter/utils.js +66 -0
- package/dist/lib.cjs/base/chain/IChainInterface.js +22 -0
- package/dist/lib.cjs/base/chain/config.js +281 -0
- package/dist/lib.cjs/base/composables/index.js +5 -0
- package/dist/lib.cjs/base/errors/index.js +244 -0
- package/dist/lib.cjs/base/loglevel.js +7 -0
- package/dist/lib.cjs/base/plugin/IPlugin.js +31 -0
- package/dist/lib.cjs/base/plugin/errors.js +107 -0
- package/dist/lib.cjs/base/provider/IProvider.js +8 -0
- package/dist/lib.cjs/base/utils.js +56 -0
- package/dist/lib.cjs/base/wallet/index.js +31 -0
- package/dist/lib.cjs/index.js +200 -0
- package/dist/lib.cjs/noModal.js +98 -90
- package/dist/lib.cjs/plugins/nft-checkout-plugin/embed.js +134 -0
- package/dist/lib.cjs/plugins/nft-checkout-plugin/enums.js +24 -0
- package/dist/lib.cjs/plugins/nft-checkout-plugin/plugin.js +71 -0
- package/dist/lib.cjs/plugins/nft-checkout-plugin/utils.js +18 -0
- package/dist/lib.cjs/plugins/wallet-services-plugin/plugin.js +285 -0
- package/dist/lib.cjs/providers/account-abstraction-provider/providers/AccountAbstractionProvider.js +164 -0
- package/dist/lib.cjs/providers/account-abstraction-provider/providers/smartAccounts/BiconomySmartAccount.js +29 -0
- package/dist/lib.cjs/providers/account-abstraction-provider/providers/smartAccounts/KernelSmartAccount.js +22 -0
- package/dist/lib.cjs/providers/account-abstraction-provider/providers/smartAccounts/NexusSmartAccount.js +30 -0
- package/dist/lib.cjs/providers/account-abstraction-provider/providers/smartAccounts/SafeSmartAccount.js +30 -0
- package/dist/lib.cjs/providers/account-abstraction-provider/providers/smartAccounts/TrustSmartAccount.js +29 -0
- package/dist/lib.cjs/providers/account-abstraction-provider/providers/smartAccounts/constants.js +11 -0
- package/dist/lib.cjs/providers/account-abstraction-provider/providers/utils.js +134 -0
- package/dist/lib.cjs/providers/account-abstraction-provider/rpc/ethRpcMiddlewares.js +174 -0
- package/dist/lib.cjs/providers/base-provider/CommonJRPCProvider.js +79 -0
- package/dist/lib.cjs/providers/base-provider/baseProvider.js +127 -0
- package/dist/lib.cjs/providers/base-provider/commonPrivateKeyProvider.js +89 -0
- package/dist/lib.cjs/providers/base-provider/jrpcClient.js +41 -0
- package/dist/lib.cjs/providers/base-provider/utils.js +12 -0
- package/dist/lib.cjs/providers/ethereum-mpc-provider/providers/signingProviders/EthereumSigningProvider.js +199 -0
- package/dist/lib.cjs/providers/ethereum-mpc-provider/providers/signingProviders/signingUtils.js +165 -0
- package/dist/lib.cjs/providers/ethereum-mpc-provider/rpc/ethRpcMiddlewares.js +22 -0
- package/dist/lib.cjs/providers/ethereum-provider/providers/converter.js +89 -0
- package/dist/lib.cjs/providers/ethereum-provider/providers/privateKeyProviders/EthereumPrivateKeyProvider.js +185 -0
- package/dist/lib.cjs/providers/ethereum-provider/providers/privateKeyProviders/TransactionFormatter/constants.js +27 -0
- package/dist/lib.cjs/providers/ethereum-provider/providers/privateKeyProviders/TransactionFormatter/formatter.js +380 -0
- package/dist/lib.cjs/providers/ethereum-provider/providers/privateKeyProviders/TransactionFormatter/interfaces.js +10 -0
- package/dist/lib.cjs/providers/ethereum-provider/providers/privateKeyProviders/TransactionFormatter/utils.js +94 -0
- package/dist/lib.cjs/providers/ethereum-provider/providers/privateKeyProviders/ethPrivatekeyUtils.js +106 -0
- package/dist/lib.cjs/providers/ethereum-provider/providers/utils.js +29 -0
- package/dist/lib.cjs/providers/ethereum-provider/rpc/ethRpcMiddlewares.js +75 -0
- package/dist/lib.cjs/providers/ethereum-provider/rpc/jrpcClient.js +41 -0
- package/dist/lib.cjs/providers/ethereum-provider/rpc/walletMidddleware.js +179 -0
- package/dist/lib.cjs/providers/solana-provider/providers/injectedProviders/base/baseInjectedProvider.js +51 -0
- package/dist/lib.cjs/providers/solana-provider/providers/injectedProviders/base/providerHandlers.js +47 -0
- package/dist/lib.cjs/providers/solana-provider/providers/injectedProviders/injectedProviderProxy.js +12 -0
- package/dist/lib.cjs/providers/solana-provider/providers/injectedProviders/torus/providerHandlers.js +75 -0
- package/dist/lib.cjs/providers/solana-provider/providers/injectedProviders/torus/torusInjectedProvider.js +109 -0
- package/dist/lib.cjs/providers/solana-provider/providers/injectedProviders/walletStandardProvider.js +12 -0
- package/dist/lib.cjs/providers/solana-provider/providers/privateKeyProvider/solanaPrivateKeyProvider.js +180 -0
- package/dist/lib.cjs/providers/solana-provider/providers/privateKeyProvider/solanaPrivateKeyUtils.js +103 -0
- package/dist/lib.cjs/providers/solana-provider/rpc/JrpcClient.js +47 -0
- package/dist/lib.cjs/providers/solana-provider/rpc/solanaRpcMiddlewares.js +97 -0
- package/dist/lib.cjs/providers/solana-provider/solanaWallet.js +62 -0
- package/dist/lib.cjs/providers/xrpl-provider/providers/privateKeyProviders/xrplPrivateKeyProvider.js +158 -0
- package/dist/lib.cjs/providers/xrpl-provider/providers/privateKeyProviders/xrplWalletUtils.js +89 -0
- package/dist/lib.cjs/providers/xrpl-provider/rpc/JrpcClient.js +48 -0
- package/dist/lib.cjs/providers/xrpl-provider/rpc/xrplRpcMiddlewares.js +73 -0
- package/dist/lib.cjs/react/index.js +16 -0
- package/dist/lib.cjs/react/no-modal/Web3AuthInnerContext.js +216 -0
- package/dist/lib.cjs/react/no-modal/Web3AuthProvider.js +15 -0
- package/dist/lib.cjs/react/no-modal/hooks/useWeb3Auth.js +15 -0
- package/dist/lib.cjs/react/wallet-services-plugin/WalletServicesContext.js +86 -0
- package/dist/lib.cjs/react/wallet-services-plugin/WalletServicesProvider.js +16 -0
- package/dist/lib.cjs/react/wallet-services-plugin/hooks/useWalletServicesPlugin.js +15 -0
- package/dist/lib.cjs/vue/index.js +15 -0
- package/dist/lib.cjs/vue/no-modal/Web3AuthProvider.js +222 -0
- package/dist/lib.cjs/vue/no-modal/composables/useWeb3Auth.js +13 -0
- package/dist/lib.cjs/vue/wallet-services-plugin/WalletServicesProvider.js +86 -0
- package/dist/lib.cjs/vue/wallet-services-plugin/composables/useWalletServicesPlugin.js +13 -0
- package/dist/lib.cjs/vue/wallet-services-plugin/context.js +5 -0
- package/dist/lib.esm/adapters/auth-adapter/authAdapter.js +260 -0
- package/dist/lib.esm/adapters/auth-adapter/config.js +15 -0
- package/dist/lib.esm/adapters/base-evm-adapter/baseEvmAdapter.js +70 -0
- package/dist/lib.esm/adapters/base-solana-adapter/baseSolanaAdapter.js +74 -0
- package/dist/lib.esm/adapters/coinbase-adapter/coinbaseAdapter.js +154 -0
- package/dist/lib.esm/adapters/default-evm-adapter/index.js +37 -0
- package/dist/lib.esm/adapters/default-evm-adapter/injectedAdapters.js +40 -0
- package/dist/lib.esm/adapters/default-evm-adapter/injectedEvmAdapter.js +158 -0
- package/dist/lib.esm/adapters/default-solana-adapter/index.js +37 -0
- package/dist/lib.esm/adapters/default-solana-adapter/injectedAdapters.js +51 -0
- package/dist/lib.esm/adapters/default-solana-adapter/utils.js +14 -0
- package/dist/lib.esm/adapters/default-solana-adapter/walletStandardAdapter.js +136 -0
- package/dist/lib.esm/adapters/default-solana-adapter/walletStandardHandler.js +75 -0
- package/dist/lib.esm/adapters/wallet-connect-v2-adapter/WalletConnectV2Provider.js +276 -0
- package/dist/lib.esm/adapters/wallet-connect-v2-adapter/config.js +172 -0
- package/dist/lib.esm/adapters/wallet-connect-v2-adapter/walletConnectV2Utils.js +158 -0
- package/dist/lib.esm/adapters/wallet-connect-v2-adapter/walletConnectV2adapter.js +374 -0
- package/dist/lib.esm/base/adapter/baseAdapter.js +115 -0
- package/dist/lib.esm/base/adapter/constants.js +20 -0
- package/dist/lib.esm/base/adapter/utils.js +60 -0
- package/dist/lib.esm/base/chain/IChainInterface.js +19 -0
- package/dist/lib.esm/base/chain/config.js +276 -0
- package/dist/lib.esm/base/composables/index.js +3 -0
- package/dist/lib.esm/base/errors/index.js +237 -0
- package/dist/lib.esm/base/loglevel.js +5 -0
- package/dist/lib.esm/base/plugin/IPlugin.js +24 -0
- package/dist/lib.esm/base/plugin/errors.js +104 -0
- package/dist/lib.esm/base/provider/IProvider.js +6 -0
- package/dist/lib.esm/base/utils.js +46 -0
- package/dist/lib.esm/base/wallet/index.js +25 -0
- package/dist/lib.esm/index.js +58 -0
- package/dist/lib.esm/noModal.js +12 -4
- package/dist/lib.esm/plugins/nft-checkout-plugin/embed.js +132 -0
- package/dist/lib.esm/plugins/nft-checkout-plugin/enums.js +20 -0
- package/dist/lib.esm/plugins/nft-checkout-plugin/plugin.js +69 -0
- package/dist/lib.esm/plugins/nft-checkout-plugin/utils.js +15 -0
- package/dist/lib.esm/plugins/wallet-services-plugin/plugin.js +276 -0
- package/dist/lib.esm/providers/account-abstraction-provider/providers/AccountAbstractionProvider.js +162 -0
- package/dist/lib.esm/providers/account-abstraction-provider/providers/smartAccounts/BiconomySmartAccount.js +27 -0
- package/dist/lib.esm/providers/account-abstraction-provider/providers/smartAccounts/KernelSmartAccount.js +20 -0
- package/dist/lib.esm/providers/account-abstraction-provider/providers/smartAccounts/NexusSmartAccount.js +28 -0
- package/dist/lib.esm/providers/account-abstraction-provider/providers/smartAccounts/SafeSmartAccount.js +28 -0
- package/dist/lib.esm/providers/account-abstraction-provider/providers/smartAccounts/TrustSmartAccount.js +27 -0
- package/dist/lib.esm/providers/account-abstraction-provider/providers/smartAccounts/constants.js +9 -0
- package/dist/lib.esm/providers/account-abstraction-provider/providers/utils.js +132 -0
- package/dist/lib.esm/providers/account-abstraction-provider/rpc/ethRpcMiddlewares.js +171 -0
- package/dist/lib.esm/providers/base-provider/CommonJRPCProvider.js +77 -0
- package/dist/lib.esm/providers/base-provider/baseProvider.js +125 -0
- package/dist/lib.esm/providers/base-provider/commonPrivateKeyProvider.js +87 -0
- package/dist/lib.esm/providers/base-provider/jrpcClient.js +37 -0
- package/dist/lib.esm/providers/base-provider/utils.js +6 -0
- package/dist/lib.esm/providers/ethereum-mpc-provider/providers/signingProviders/EthereumSigningProvider.js +197 -0
- package/dist/lib.esm/providers/ethereum-mpc-provider/providers/signingProviders/signingUtils.js +163 -0
- package/dist/lib.esm/providers/ethereum-mpc-provider/rpc/ethRpcMiddlewares.js +20 -0
- package/dist/lib.esm/providers/ethereum-provider/providers/converter.js +85 -0
- package/dist/lib.esm/providers/ethereum-provider/providers/privateKeyProviders/EthereumPrivateKeyProvider.js +183 -0
- package/dist/lib.esm/providers/ethereum-provider/providers/privateKeyProviders/TransactionFormatter/constants.js +21 -0
- package/dist/lib.esm/providers/ethereum-provider/providers/privateKeyProviders/TransactionFormatter/formatter.js +378 -0
- package/dist/lib.esm/providers/ethereum-provider/providers/privateKeyProviders/TransactionFormatter/interfaces.js +8 -0
- package/dist/lib.esm/providers/ethereum-provider/providers/privateKeyProviders/TransactionFormatter/utils.js +88 -0
- package/dist/lib.esm/providers/ethereum-provider/providers/privateKeyProviders/ethPrivatekeyUtils.js +104 -0
- package/dist/lib.esm/providers/ethereum-provider/providers/utils.js +24 -0
- package/dist/lib.esm/providers/ethereum-provider/rpc/ethRpcMiddlewares.js +71 -0
- package/dist/lib.esm/providers/ethereum-provider/rpc/jrpcClient.js +37 -0
- package/dist/lib.esm/providers/ethereum-provider/rpc/walletMidddleware.js +177 -0
- package/dist/lib.esm/providers/solana-provider/providers/injectedProviders/base/baseInjectedProvider.js +49 -0
- package/dist/lib.esm/providers/solana-provider/providers/injectedProviders/base/providerHandlers.js +45 -0
- package/dist/lib.esm/providers/solana-provider/providers/injectedProviders/injectedProviderProxy.js +10 -0
- package/dist/lib.esm/providers/solana-provider/providers/injectedProviders/torus/providerHandlers.js +73 -0
- package/dist/lib.esm/providers/solana-provider/providers/injectedProviders/torus/torusInjectedProvider.js +107 -0
- package/dist/lib.esm/providers/solana-provider/providers/injectedProviders/walletStandardProvider.js +10 -0
- package/dist/lib.esm/providers/solana-provider/providers/privateKeyProvider/solanaPrivateKeyProvider.js +178 -0
- package/dist/lib.esm/providers/solana-provider/providers/privateKeyProvider/solanaPrivateKeyUtils.js +101 -0
- package/dist/lib.esm/providers/solana-provider/rpc/JrpcClient.js +42 -0
- package/dist/lib.esm/providers/solana-provider/rpc/solanaRpcMiddlewares.js +89 -0
- package/dist/lib.esm/providers/solana-provider/solanaWallet.js +60 -0
- package/dist/lib.esm/providers/xrpl-provider/providers/privateKeyProviders/xrplPrivateKeyProvider.js +156 -0
- package/dist/lib.esm/providers/xrpl-provider/providers/privateKeyProviders/xrplWalletUtils.js +87 -0
- package/dist/lib.esm/providers/xrpl-provider/rpc/JrpcClient.js +43 -0
- package/dist/lib.esm/providers/xrpl-provider/rpc/xrplRpcMiddlewares.js +67 -0
- package/dist/lib.esm/react/index.js +5 -0
- package/dist/lib.esm/react/no-modal/Web3AuthInnerContext.js +213 -0
- package/dist/lib.esm/react/no-modal/Web3AuthProvider.js +13 -0
- package/dist/lib.esm/react/no-modal/hooks/useWeb3Auth.js +13 -0
- package/dist/lib.esm/react/wallet-services-plugin/WalletServicesContext.js +83 -0
- package/dist/lib.esm/react/wallet-services-plugin/WalletServicesProvider.js +14 -0
- package/dist/lib.esm/react/wallet-services-plugin/hooks/useWalletServicesPlugin.js +13 -0
- package/dist/lib.esm/vue/index.js +5 -0
- package/dist/lib.esm/vue/no-modal/Web3AuthProvider.js +220 -0
- package/dist/lib.esm/vue/no-modal/composables/useWeb3Auth.js +11 -0
- package/dist/lib.esm/vue/wallet-services-plugin/WalletServicesProvider.js +84 -0
- package/dist/lib.esm/vue/wallet-services-plugin/composables/useWalletServicesPlugin.js +11 -0
- package/dist/lib.esm/vue/wallet-services-plugin/context.js +3 -0
- package/dist/noModal.cjs.js +26314 -364
- package/dist/noModal.umd.min.js +1 -1
- package/dist/noModal.umd.min.js.LICENSE.txt +54 -0
- package/dist/types/adapters/auth-adapter/authAdapter.d.ts +42 -0
- package/dist/types/adapters/auth-adapter/config.d.ts +2 -0
- package/dist/types/adapters/auth-adapter/index.d.ts +3 -0
- package/dist/types/adapters/auth-adapter/interface.d.ts +11 -0
- package/dist/types/adapters/base-evm-adapter/baseEvmAdapter.d.ts +7 -0
- package/dist/types/adapters/base-evm-adapter/index.d.ts +1 -0
- package/dist/types/adapters/base-solana-adapter/baseSolanaAdapter.d.ts +7 -0
- package/dist/types/adapters/base-solana-adapter/index.d.ts +1 -0
- package/dist/types/adapters/coinbase-adapter/coinbaseAdapter.d.ts +33 -0
- package/dist/types/adapters/coinbase-adapter/index.d.ts +1 -0
- package/dist/types/adapters/default-evm-adapter/index.d.ts +6 -0
- package/dist/types/adapters/default-evm-adapter/injectedAdapters.d.ts +4 -0
- package/dist/types/adapters/default-evm-adapter/injectedEvmAdapter.d.ts +30 -0
- package/dist/types/adapters/default-solana-adapter/index.d.ts +6 -0
- package/dist/types/adapters/default-solana-adapter/injectedAdapters.d.ts +4 -0
- package/dist/types/adapters/default-solana-adapter/utils.d.ts +3 -0
- package/dist/types/adapters/default-solana-adapter/walletStandardAdapter.d.ts +31 -0
- package/dist/types/adapters/default-solana-adapter/walletStandardHandler.d.ts +27 -0
- package/dist/types/adapters/index.d.ts +7 -0
- package/dist/types/adapters/wallet-connect-v2-adapter/WalletConnectV2Provider.d.ts +36 -0
- package/dist/types/adapters/wallet-connect-v2-adapter/config.d.ts +35 -0
- package/dist/types/adapters/wallet-connect-v2-adapter/index.d.ts +4 -0
- package/dist/types/adapters/wallet-connect-v2-adapter/interface.d.ts +18 -0
- package/dist/types/adapters/wallet-connect-v2-adapter/utils.d.ts +3 -0
- package/dist/types/adapters/wallet-connect-v2-adapter/walletConnectV2Utils.d.ts +23 -0
- package/dist/types/adapters/wallet-connect-v2-adapter/walletConnectV2adapter.d.ts +42 -0
- package/dist/types/base/adapter/baseAdapter.d.ts +44 -0
- package/dist/types/base/adapter/constants.d.ts +22 -0
- package/dist/types/base/adapter/index.d.ts +4 -0
- package/dist/types/base/adapter/interfaces.d.ts +143 -0
- package/dist/types/base/adapter/utils.d.ts +5 -0
- package/dist/types/base/chain/IChainInterface.d.ts +59 -0
- package/dist/types/base/chain/config.d.ts +5 -0
- package/dist/types/base/composables/index.d.ts +1 -0
- package/dist/types/base/core/IWeb3Auth.d.ts +101 -0
- package/dist/types/base/errors/index.d.ts +69 -0
- package/dist/types/base/hooks/index.d.ts +37 -0
- package/dist/types/base/index.d.ts +13 -0
- package/dist/types/base/interfaces.d.ts +44 -0
- package/dist/types/base/loglevel.d.ts +2 -0
- package/dist/types/base/plugin/IPlugin.d.ts +53 -0
- package/dist/types/base/plugin/errors.d.ts +28 -0
- package/dist/types/base/plugin/index.d.ts +2 -0
- package/dist/types/base/provider/IProvider.d.ts +16 -0
- package/dist/types/base/utils.d.ts +9 -0
- package/dist/types/base/wallet/index.d.ts +33 -0
- package/dist/types/index.d.ts +4 -0
- package/dist/types/noModal.d.ts +2 -2
- package/dist/types/plugins/index.d.ts +2 -0
- package/dist/types/plugins/nft-checkout-plugin/embed.d.ts +24 -0
- package/dist/types/plugins/nft-checkout-plugin/enums.d.ts +14 -0
- package/dist/types/plugins/nft-checkout-plugin/index.d.ts +2 -0
- package/dist/types/plugins/nft-checkout-plugin/plugin.d.ts +23 -0
- package/dist/types/plugins/nft-checkout-plugin/utils.d.ts +3 -0
- package/dist/types/plugins/wallet-services-plugin/index.d.ts +1 -0
- package/dist/types/plugins/wallet-services-plugin/plugin.d.ts +51 -0
- package/dist/types/providers/account-abstraction-provider/index.d.ts +1 -0
- package/dist/types/providers/account-abstraction-provider/providers/AccountAbstractionProvider.d.ts +46 -0
- package/dist/types/providers/account-abstraction-provider/providers/index.d.ts +3 -0
- package/dist/types/providers/account-abstraction-provider/providers/smartAccounts/BiconomySmartAccount.d.ts +14 -0
- package/dist/types/providers/account-abstraction-provider/providers/smartAccounts/KernelSmartAccount.d.ts +13 -0
- package/dist/types/providers/account-abstraction-provider/providers/smartAccounts/LightSmartAccount.d.ts +14 -0
- package/dist/types/providers/account-abstraction-provider/providers/smartAccounts/NexusSmartAccount.d.ts +14 -0
- package/dist/types/providers/account-abstraction-provider/providers/smartAccounts/SafeSmartAccount.d.ts +13 -0
- package/dist/types/providers/account-abstraction-provider/providers/smartAccounts/SimpleSmartAccount.d.ts +13 -0
- package/dist/types/providers/account-abstraction-provider/providers/smartAccounts/TrustSmartAccount.d.ts +13 -0
- package/dist/types/providers/account-abstraction-provider/providers/smartAccounts/constants.d.ts +9 -0
- package/dist/types/providers/account-abstraction-provider/providers/smartAccounts/index.d.ts +6 -0
- package/dist/types/providers/account-abstraction-provider/providers/smartAccounts/types.d.ts +22 -0
- package/dist/types/providers/account-abstraction-provider/providers/types.d.ts +17 -0
- package/dist/types/providers/account-abstraction-provider/providers/utils.d.ts +10 -0
- package/dist/types/providers/account-abstraction-provider/rpc/ethRpcMiddlewares.d.ts +8 -0
- package/dist/types/providers/account-abstraction-provider/rpc/index.d.ts +1 -0
- package/dist/types/providers/base-provider/CommonJRPCProvider.d.ts +20 -0
- package/dist/types/providers/base-provider/baseProvider.d.ts +39 -0
- package/dist/types/providers/base-provider/commonPrivateKeyProvider.d.ts +31 -0
- package/dist/types/providers/base-provider/index.d.ts +5 -0
- package/dist/types/providers/base-provider/interfaces.d.ts +3 -0
- package/dist/types/providers/base-provider/jrpcClient.d.ts +8 -0
- package/dist/types/providers/base-provider/utils.d.ts +2 -0
- package/dist/types/providers/ethereum-mpc-provider/index.d.ts +1 -0
- package/dist/types/providers/ethereum-mpc-provider/providers/index.d.ts +1 -0
- package/dist/types/providers/ethereum-mpc-provider/providers/signingProviders/EthereumSigningProvider.d.ts +65 -0
- package/dist/types/providers/ethereum-mpc-provider/providers/signingProviders/index.d.ts +1 -0
- package/dist/types/providers/ethereum-mpc-provider/providers/signingProviders/signingUtils.d.ts +12 -0
- package/dist/types/providers/ethereum-mpc-provider/rpc/ethRpcMiddlewares.d.ts +3 -0
- package/dist/types/providers/ethereum-mpc-provider/rpc/interfaces.d.ts +15 -0
- package/dist/types/providers/ethereum-provider/index.d.ts +2 -0
- package/dist/types/providers/ethereum-provider/providers/converter.d.ts +15 -0
- package/dist/types/providers/ethereum-provider/providers/index.d.ts +1 -0
- package/dist/types/providers/ethereum-provider/providers/privateKeyProviders/EthereumPrivateKeyProvider.d.ts +30 -0
- package/dist/types/providers/ethereum-provider/providers/privateKeyProviders/TransactionFormatter/constants.d.ts +16 -0
- package/dist/types/providers/ethereum-provider/providers/privateKeyProviders/TransactionFormatter/formatter.d.ts +28 -0
- package/dist/types/providers/ethereum-provider/providers/privateKeyProviders/TransactionFormatter/index.d.ts +4 -0
- package/dist/types/providers/ethereum-provider/providers/privateKeyProviders/TransactionFormatter/interfaces.d.ts +46 -0
- package/dist/types/providers/ethereum-provider/providers/privateKeyProviders/TransactionFormatter/utils.d.ts +12 -0
- package/dist/types/providers/ethereum-provider/providers/privateKeyProviders/ethPrivatekeyUtils.d.ts +9 -0
- package/dist/types/providers/ethereum-provider/providers/privateKeyProviders/index.d.ts +2 -0
- package/dist/types/providers/ethereum-provider/providers/utils.d.ts +5 -0
- package/dist/types/providers/ethereum-provider/rpc/ethRpcMiddlewares.d.ts +5 -0
- package/dist/types/providers/ethereum-provider/rpc/index.d.ts +4 -0
- package/dist/types/providers/ethereum-provider/rpc/interfaces.d.ts +65 -0
- package/dist/types/providers/ethereum-provider/rpc/jrpcClient.d.ts +8 -0
- package/dist/types/providers/ethereum-provider/rpc/walletMidddleware.d.ts +3 -0
- package/dist/types/providers/index.d.ts +6 -0
- package/dist/types/providers/solana-provider/index.d.ts +4 -0
- package/dist/types/providers/solana-provider/interface.d.ts +39 -0
- package/dist/types/providers/solana-provider/providers/index.d.ts +2 -0
- package/dist/types/providers/solana-provider/providers/injectedProviders/base/baseInjectedProvider.d.ts +16 -0
- package/dist/types/providers/solana-provider/providers/injectedProviders/base/providerHandlers.d.ts +3 -0
- package/dist/types/providers/solana-provider/providers/injectedProviders/index.d.ts +3 -0
- package/dist/types/providers/solana-provider/providers/injectedProviders/injectedProviderProxy.d.ts +3 -0
- package/dist/types/providers/solana-provider/providers/injectedProviders/interface.d.ts +5 -0
- package/dist/types/providers/solana-provider/providers/injectedProviders/torus/providerHandlers.d.ts +3 -0
- package/dist/types/providers/solana-provider/providers/injectedProviders/torus/torusInjectedProvider.d.ts +18 -0
- package/dist/types/providers/solana-provider/providers/injectedProviders/walletStandardProvider.d.ts +6 -0
- package/dist/types/providers/solana-provider/providers/privateKeyProvider/index.d.ts +1 -0
- package/dist/types/providers/solana-provider/providers/privateKeyProvider/solanaPrivateKeyProvider.d.ts +31 -0
- package/dist/types/providers/solana-provider/providers/privateKeyProvider/solanaPrivateKeyUtils.d.ts +7 -0
- package/dist/types/providers/solana-provider/rpc/JrpcClient.d.ts +9 -0
- package/dist/types/providers/solana-provider/rpc/index.d.ts +3 -0
- package/dist/types/providers/solana-provider/rpc/interfaces.d.ts +42 -0
- package/dist/types/providers/solana-provider/rpc/solanaRpcMiddlewares.d.ts +20 -0
- package/dist/types/providers/solana-provider/solanaWallet.d.ts +14 -0
- package/dist/types/providers/xrpl-provider/index.d.ts +1 -0
- package/dist/types/providers/xrpl-provider/providers/index.d.ts +1 -0
- package/dist/types/providers/xrpl-provider/providers/privateKeyProviders/constants.d.ts +5 -0
- package/dist/types/providers/xrpl-provider/providers/privateKeyProviders/index.d.ts +3 -0
- package/dist/types/providers/xrpl-provider/providers/privateKeyProviders/interface.d.ts +2 -0
- package/dist/types/providers/xrpl-provider/providers/privateKeyProviders/xrplPrivateKeyProvider.d.ts +26 -0
- package/dist/types/providers/xrpl-provider/providers/privateKeyProviders/xrplWalletUtils.d.ts +7 -0
- package/dist/types/providers/xrpl-provider/rpc/JrpcClient.d.ts +9 -0
- package/dist/types/providers/xrpl-provider/rpc/xrplRpcMiddlewares.d.ts +52 -0
- package/dist/types/react/index.d.ts +2 -0
- package/dist/types/react/no-modal/Web3AuthInnerContext.d.ts +4 -0
- package/dist/types/react/no-modal/Web3AuthProvider.d.ts +3 -0
- package/dist/types/react/no-modal/hooks/index.d.ts +1 -0
- package/dist/types/react/no-modal/hooks/useWeb3Auth.d.ts +2 -0
- package/dist/types/react/no-modal/index.d.ts +3 -0
- package/dist/types/react/no-modal/interfaces.d.ts +15 -0
- package/dist/types/react/wallet-services-plugin/WalletServicesContext.d.ts +7 -0
- package/dist/types/react/wallet-services-plugin/WalletServicesProvider.d.ts +7 -0
- package/dist/types/react/wallet-services-plugin/hooks/index.d.ts +1 -0
- package/dist/types/react/wallet-services-plugin/hooks/useWalletServicesPlugin.d.ts +2 -0
- package/dist/types/react/wallet-services-plugin/index.d.ts +4 -0
- package/dist/types/react/wallet-services-plugin/interfaces.d.ts +5 -0
- package/dist/types/vue/index.d.ts +2 -0
- package/dist/types/vue/no-modal/Web3AuthProvider.d.ts +13 -0
- package/dist/types/vue/no-modal/composables/index.d.ts +1 -0
- package/dist/types/vue/no-modal/composables/useWeb3Auth.d.ts +2 -0
- package/dist/types/vue/no-modal/index.d.ts +3 -0
- package/dist/types/vue/no-modal/interfaces.d.ts +42 -0
- package/dist/types/vue/wallet-services-plugin/WalletServicesProvider.d.ts +1 -0
- package/dist/types/vue/wallet-services-plugin/composables/index.d.ts +1 -0
- package/dist/types/vue/wallet-services-plugin/composables/useWalletServicesPlugin.d.ts +2 -0
- package/dist/types/vue/wallet-services-plugin/context.d.ts +3 -0
- package/dist/types/vue/wallet-services-plugin/index.d.ts +4 -0
- package/dist/types/vue/wallet-services-plugin/interfaces.d.ts +13 -0
- package/package.json +76 -15
- package/README.md +0 -82
- package/dist/noModal.esm.js +0 -359
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var auth = require('@web3auth/auth');
|
|
4
|
+
var rippleKeypairs = require('ripple-keypairs');
|
|
5
|
+
var xrpl = require('xrpl');
|
|
6
|
+
var ECDSA = require('xrpl/dist/npm/ECDSA');
|
|
7
|
+
|
|
8
|
+
const deriveKeypair = web3authKey => {
|
|
9
|
+
const seed = rippleKeypairs.generateSeed({
|
|
10
|
+
entropy: Buffer.from(web3authKey.padStart(64, "0"), "hex"),
|
|
11
|
+
algorithm: "ecdsa-secp256k1"
|
|
12
|
+
});
|
|
13
|
+
const wallet = xrpl.Wallet.fromSecret(seed, {
|
|
14
|
+
algorithm: ECDSA.secp256k1
|
|
15
|
+
}); // web3auth network currently only supports the secp256k1 key
|
|
16
|
+
return {
|
|
17
|
+
privateKey: wallet.privateKey,
|
|
18
|
+
publicKey: wallet.publicKey
|
|
19
|
+
};
|
|
20
|
+
};
|
|
21
|
+
async function getProviderHandlers({
|
|
22
|
+
privKey: web3authKey,
|
|
23
|
+
chainConfig,
|
|
24
|
+
keyExportEnabled
|
|
25
|
+
}) {
|
|
26
|
+
const client = new xrpl.Client(chainConfig.wsTarget);
|
|
27
|
+
await client.connect();
|
|
28
|
+
return {
|
|
29
|
+
getAccounts: async _ => {
|
|
30
|
+
const {
|
|
31
|
+
publicKey
|
|
32
|
+
} = deriveKeypair(web3authKey);
|
|
33
|
+
const accAddress = xrpl.deriveAddress(publicKey);
|
|
34
|
+
return [accAddress];
|
|
35
|
+
},
|
|
36
|
+
getKeyPair: async _ => {
|
|
37
|
+
if (!keyExportEnabled) throw auth.providerErrors.custom({
|
|
38
|
+
message: "Private key export is disabled",
|
|
39
|
+
code: 4902
|
|
40
|
+
});
|
|
41
|
+
return deriveKeypair(web3authKey);
|
|
42
|
+
},
|
|
43
|
+
getPublicKey: async _ => {
|
|
44
|
+
const keyPair = deriveKeypair(web3authKey);
|
|
45
|
+
return keyPair.publicKey;
|
|
46
|
+
},
|
|
47
|
+
signTransaction: async req => {
|
|
48
|
+
const {
|
|
49
|
+
transaction,
|
|
50
|
+
multisign
|
|
51
|
+
} = req.params || {};
|
|
52
|
+
if (!transaction) throw auth.rpcErrors.invalidParams("Invalid params, req.params.transaction is required");
|
|
53
|
+
const {
|
|
54
|
+
publicKey,
|
|
55
|
+
privateKey
|
|
56
|
+
} = deriveKeypair(web3authKey);
|
|
57
|
+
const wallet = new xrpl.Wallet(publicKey, privateKey);
|
|
58
|
+
return wallet.sign(transaction, multisign);
|
|
59
|
+
},
|
|
60
|
+
submitTransaction: async req => {
|
|
61
|
+
const {
|
|
62
|
+
transaction
|
|
63
|
+
} = req.params || {};
|
|
64
|
+
if (!transaction) throw auth.rpcErrors.invalidParams("Invalid params, req.params.transaction is required");
|
|
65
|
+
const {
|
|
66
|
+
publicKey,
|
|
67
|
+
privateKey
|
|
68
|
+
} = deriveKeypair(web3authKey);
|
|
69
|
+
const wallet = new xrpl.Wallet(publicKey, privateKey);
|
|
70
|
+
const res = await client.submit(transaction, {
|
|
71
|
+
wallet
|
|
72
|
+
});
|
|
73
|
+
return res;
|
|
74
|
+
},
|
|
75
|
+
signMessage: async req => {
|
|
76
|
+
const {
|
|
77
|
+
message
|
|
78
|
+
} = req.params || {};
|
|
79
|
+
if (!message) throw auth.rpcErrors.invalidParams("Invalid params, req.params.message is required");
|
|
80
|
+
const keyPair = deriveKeypair(web3authKey);
|
|
81
|
+
const signature = rippleKeypairs.sign(message, keyPair.privateKey);
|
|
82
|
+
return {
|
|
83
|
+
signature
|
|
84
|
+
};
|
|
85
|
+
}
|
|
86
|
+
};
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
exports.getProviderHandlers = getProviderHandlers;
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var baseControllers = require('@toruslabs/base-controllers');
|
|
4
|
+
var auth = require('@web3auth/auth');
|
|
5
|
+
var xrplRpcMiddlewares = require('./xrplRpcMiddlewares.js');
|
|
6
|
+
|
|
7
|
+
function createXrplChainIdMiddleware(chainId) {
|
|
8
|
+
return (req, res, next, end) => {
|
|
9
|
+
if (req.method === xrplRpcMiddlewares.RPC_METHODS.CHAIN_ID) {
|
|
10
|
+
res.result = chainId;
|
|
11
|
+
return end();
|
|
12
|
+
}
|
|
13
|
+
return next();
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
function createXrplProviderConfigMiddleware(providerConfig) {
|
|
17
|
+
return (req, res, next, end) => {
|
|
18
|
+
if (req.method === xrplRpcMiddlewares.RPC_METHODS.PROVIDER_CHAIN_CONFIG) {
|
|
19
|
+
res.result = providerConfig;
|
|
20
|
+
return end();
|
|
21
|
+
}
|
|
22
|
+
return next();
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
function createConfigMiddleware(providerConfig) {
|
|
26
|
+
const {
|
|
27
|
+
chainId
|
|
28
|
+
} = providerConfig;
|
|
29
|
+
return auth.mergeMiddleware([createXrplChainIdMiddleware(chainId), createXrplProviderConfigMiddleware(providerConfig)]);
|
|
30
|
+
}
|
|
31
|
+
function createXrplJsonRpcClient(providerConfig) {
|
|
32
|
+
const {
|
|
33
|
+
rpcTarget
|
|
34
|
+
} = providerConfig;
|
|
35
|
+
const fetchMiddleware = baseControllers.createFetchMiddleware({
|
|
36
|
+
rpcTarget
|
|
37
|
+
});
|
|
38
|
+
const networkMiddleware = auth.mergeMiddleware([createConfigMiddleware(providerConfig), fetchMiddleware]);
|
|
39
|
+
return {
|
|
40
|
+
networkMiddleware,
|
|
41
|
+
fetchMiddleware
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
exports.createConfigMiddleware = createConfigMiddleware;
|
|
46
|
+
exports.createXrplChainIdMiddleware = createXrplChainIdMiddleware;
|
|
47
|
+
exports.createXrplJsonRpcClient = createXrplJsonRpcClient;
|
|
48
|
+
exports.createXrplProviderConfigMiddleware = createXrplProviderConfigMiddleware;
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var baseControllers = require('@toruslabs/base-controllers');
|
|
4
|
+
var auth = require('@web3auth/auth');
|
|
5
|
+
|
|
6
|
+
const RPC_METHODS = {
|
|
7
|
+
GET_ACCOUNTS: "xrpl_getAccounts",
|
|
8
|
+
GET_KEY_PAIR: "xrpl_getKeyPair",
|
|
9
|
+
GET_PUBLIC_KEY: "xrpl_getPublicKey",
|
|
10
|
+
SIGN_MESSAGE: "xrpl_signMessage",
|
|
11
|
+
SIGN_TRANSACTION: "xrpl_signTransaction",
|
|
12
|
+
SUBMIT_TRANSACTION: "xrpl_submitTransaction",
|
|
13
|
+
ADD_CHAIN: "xrpl_addChain",
|
|
14
|
+
SWITCH_CHAIN: "xrpl_switchChain",
|
|
15
|
+
CHAIN_ID: "xrpl_chainId",
|
|
16
|
+
PROVIDER_CHAIN_CONFIG: "xrpl_providerChainConfig"
|
|
17
|
+
};
|
|
18
|
+
function createGetAccountsMiddleware({
|
|
19
|
+
getAccounts
|
|
20
|
+
}) {
|
|
21
|
+
return auth.createAsyncMiddleware(async (request, response, next) => {
|
|
22
|
+
const {
|
|
23
|
+
method
|
|
24
|
+
} = request;
|
|
25
|
+
|
|
26
|
+
// hack to override big ids from fetch middleware which are not supported in xrpl servers
|
|
27
|
+
// TODO: fix this for xrpl controllers.
|
|
28
|
+
request.id = baseControllers.randomId();
|
|
29
|
+
if (method !== RPC_METHODS.GET_ACCOUNTS) return next();
|
|
30
|
+
if (!getAccounts) throw new Error("WalletMiddleware - opts.getAccounts not provided");
|
|
31
|
+
// This calls from the prefs controller
|
|
32
|
+
const accounts = await getAccounts(request);
|
|
33
|
+
response.result = accounts;
|
|
34
|
+
return undefined;
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
function createGenericJRPCMiddleware(targetMethod, handler) {
|
|
38
|
+
return auth.createAsyncMiddleware(async (request, response, next) => {
|
|
39
|
+
const {
|
|
40
|
+
method
|
|
41
|
+
} = request;
|
|
42
|
+
if (method !== targetMethod) return next();
|
|
43
|
+
if (!handler) throw new Error(`WalletMiddleware - ${targetMethod} not provided`);
|
|
44
|
+
const result = await handler(request);
|
|
45
|
+
response.result = result;
|
|
46
|
+
return undefined;
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
function createXRPLMiddleware(providerHandlers) {
|
|
50
|
+
const {
|
|
51
|
+
getAccounts,
|
|
52
|
+
submitTransaction,
|
|
53
|
+
signTransaction,
|
|
54
|
+
signMessage,
|
|
55
|
+
getKeyPair,
|
|
56
|
+
getPublicKey
|
|
57
|
+
} = providerHandlers;
|
|
58
|
+
return auth.mergeMiddleware([createGetAccountsMiddleware({
|
|
59
|
+
getAccounts
|
|
60
|
+
}), createGenericJRPCMiddleware(RPC_METHODS.SIGN_TRANSACTION, signTransaction), createGenericJRPCMiddleware(RPC_METHODS.SUBMIT_TRANSACTION, submitTransaction), createGenericJRPCMiddleware(RPC_METHODS.SIGN_MESSAGE, signMessage), createGenericJRPCMiddleware(RPC_METHODS.GET_KEY_PAIR, getKeyPair), createGenericJRPCMiddleware(RPC_METHODS.GET_PUBLIC_KEY, getPublicKey)]);
|
|
61
|
+
}
|
|
62
|
+
function creatXrplChainSwitchMiddleware({
|
|
63
|
+
addChainConfig,
|
|
64
|
+
switchChain
|
|
65
|
+
}) {
|
|
66
|
+
return auth.mergeMiddleware([createGenericJRPCMiddleware(RPC_METHODS.ADD_CHAIN, addChainConfig), createGenericJRPCMiddleware(RPC_METHODS.SWITCH_CHAIN, switchChain)]);
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
exports.RPC_METHODS = RPC_METHODS;
|
|
70
|
+
exports.creatXrplChainSwitchMiddleware = creatXrplChainSwitchMiddleware;
|
|
71
|
+
exports.createGenericJRPCMiddleware = createGenericJRPCMiddleware;
|
|
72
|
+
exports.createGetAccountsMiddleware = createGetAccountsMiddleware;
|
|
73
|
+
exports.createXRPLMiddleware = createXRPLMiddleware;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var useWeb3Auth = require('./no-modal/hooks/useWeb3Auth.js');
|
|
4
|
+
var Web3AuthProvider = require('./no-modal/Web3AuthProvider.js');
|
|
5
|
+
var useWalletServicesPlugin = require('./wallet-services-plugin/hooks/useWalletServicesPlugin.js');
|
|
6
|
+
var WalletServicesContext = require('./wallet-services-plugin/WalletServicesContext.js');
|
|
7
|
+
var WalletServicesProvider = require('./wallet-services-plugin/WalletServicesProvider.js');
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
exports.useWeb3Auth = useWeb3Auth.useWeb3Auth;
|
|
12
|
+
exports.Web3AuthProvider = Web3AuthProvider.Web3AuthProvider;
|
|
13
|
+
exports.useWalletServicesPlugin = useWalletServicesPlugin.useWalletServicesPlugin;
|
|
14
|
+
exports.WalletServicesContext = WalletServicesContext.WalletServicesContext;
|
|
15
|
+
exports.WalletServicesContextProvider = WalletServicesContext.WalletServicesContextProvider;
|
|
16
|
+
exports.WalletServicesProvider = WalletServicesProvider.WalletServicesProvider;
|
|
@@ -0,0 +1,216 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var react = require('react');
|
|
4
|
+
var index = require('../../base/errors/index.js');
|
|
5
|
+
var noModal = require('../../noModal.js');
|
|
6
|
+
var constants = require('../../base/adapter/constants.js');
|
|
7
|
+
|
|
8
|
+
const Web3AuthInnerContext = react.createContext(null);
|
|
9
|
+
function Web3AuthInnerProvider(params) {
|
|
10
|
+
const {
|
|
11
|
+
children,
|
|
12
|
+
config
|
|
13
|
+
} = params;
|
|
14
|
+
const [web3Auth, setWeb3Auth] = react.useState(null);
|
|
15
|
+
const [isConnecting, setIsConnecting] = react.useState(false);
|
|
16
|
+
const [isInitializing, setIsInitializing] = react.useState(false);
|
|
17
|
+
const [initError, setInitError] = react.useState(null);
|
|
18
|
+
const [connectError, setConnectError] = react.useState(null);
|
|
19
|
+
const [isConnected, setIsConnected] = react.useState(false);
|
|
20
|
+
const [provider, setProvider] = react.useState(null);
|
|
21
|
+
const [userInfo, setUserInfo] = react.useState(null);
|
|
22
|
+
const [isMFAEnabled, setIsMFAEnabled] = react.useState(false);
|
|
23
|
+
const [isInitialized, setIsInitialized] = react.useState(false);
|
|
24
|
+
const [status, setStatus] = react.useState(null);
|
|
25
|
+
const addPlugin = react.useCallback(plugin => {
|
|
26
|
+
if (!web3Auth) throw index.WalletInitializationError.notReady();
|
|
27
|
+
return web3Auth.addPlugin(plugin);
|
|
28
|
+
}, [web3Auth]);
|
|
29
|
+
const getPlugin = react.useCallback(name => {
|
|
30
|
+
if (!web3Auth) throw index.WalletInitializationError.notReady();
|
|
31
|
+
return web3Auth.getPlugin(name);
|
|
32
|
+
}, [web3Auth]);
|
|
33
|
+
react.useEffect(() => {
|
|
34
|
+
const resetHookState = () => {
|
|
35
|
+
setProvider(null);
|
|
36
|
+
setUserInfo(null);
|
|
37
|
+
setIsMFAEnabled(false);
|
|
38
|
+
setIsConnected(false);
|
|
39
|
+
setStatus(null);
|
|
40
|
+
};
|
|
41
|
+
resetHookState();
|
|
42
|
+
const {
|
|
43
|
+
web3AuthOptions,
|
|
44
|
+
adapters = [],
|
|
45
|
+
plugins = []
|
|
46
|
+
} = config;
|
|
47
|
+
const web3Instance = new noModal.Web3AuthNoModal(web3AuthOptions);
|
|
48
|
+
if (adapters.length) adapters.map(adapter => web3Instance.configureAdapter(adapter));
|
|
49
|
+
if (plugins.length) plugins.forEach(plugin => {
|
|
50
|
+
web3Instance.addPlugin(plugin);
|
|
51
|
+
});
|
|
52
|
+
setWeb3Auth(web3Instance);
|
|
53
|
+
}, [config]);
|
|
54
|
+
react.useEffect(() => {
|
|
55
|
+
async function init() {
|
|
56
|
+
try {
|
|
57
|
+
setInitError(null);
|
|
58
|
+
setIsInitializing(true);
|
|
59
|
+
await web3Auth.init();
|
|
60
|
+
} catch (error) {
|
|
61
|
+
setInitError(error);
|
|
62
|
+
} finally {
|
|
63
|
+
setIsInitializing(false);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
if (web3Auth) init();
|
|
67
|
+
}, [web3Auth]);
|
|
68
|
+
react.useEffect(() => {
|
|
69
|
+
const addState = async () => {
|
|
70
|
+
setProvider(web3Auth.provider);
|
|
71
|
+
const userState = await web3Auth.getUserInfo();
|
|
72
|
+
setUserInfo(userState);
|
|
73
|
+
setIsMFAEnabled((userState === null || userState === void 0 ? void 0 : userState.isMfaEnabled) || false);
|
|
74
|
+
};
|
|
75
|
+
const resetState = () => {
|
|
76
|
+
setProvider(null);
|
|
77
|
+
setUserInfo(null);
|
|
78
|
+
setIsMFAEnabled(false);
|
|
79
|
+
};
|
|
80
|
+
if (web3Auth) {
|
|
81
|
+
if (isConnected) addState();else resetState();
|
|
82
|
+
}
|
|
83
|
+
}, [web3Auth, isConnected]);
|
|
84
|
+
|
|
85
|
+
// TODO: don't throw error in init, connect in v9
|
|
86
|
+
|
|
87
|
+
react.useEffect(() => {
|
|
88
|
+
const notReadyListener = () => setStatus(constants.ADAPTER_STATUS.NOT_READY);
|
|
89
|
+
const readyListener = () => {
|
|
90
|
+
setStatus(web3Auth.status);
|
|
91
|
+
setIsInitialized(true);
|
|
92
|
+
};
|
|
93
|
+
const connectedListener = () => {
|
|
94
|
+
setStatus(web3Auth.status);
|
|
95
|
+
// we do this because of rehydration issues. status connected is fired first but web3auth sdk is not ready yet.
|
|
96
|
+
if (web3Auth.status === constants.ADAPTER_STATUS.CONNECTED) {
|
|
97
|
+
setIsInitialized(true);
|
|
98
|
+
setIsConnected(true);
|
|
99
|
+
}
|
|
100
|
+
};
|
|
101
|
+
const disconnectedListener = () => {
|
|
102
|
+
setStatus(web3Auth.status);
|
|
103
|
+
setIsConnected(false);
|
|
104
|
+
};
|
|
105
|
+
const connectingListener = () => {
|
|
106
|
+
setStatus(web3Auth.status);
|
|
107
|
+
};
|
|
108
|
+
const errorListener = () => {
|
|
109
|
+
setStatus(constants.ADAPTER_STATUS.ERRORED);
|
|
110
|
+
};
|
|
111
|
+
if (web3Auth) {
|
|
112
|
+
// web3Auth is initialized here.
|
|
113
|
+
setStatus(web3Auth.status);
|
|
114
|
+
web3Auth.on(constants.ADAPTER_EVENTS.NOT_READY, notReadyListener);
|
|
115
|
+
web3Auth.on(constants.ADAPTER_EVENTS.READY, readyListener);
|
|
116
|
+
web3Auth.on(constants.ADAPTER_EVENTS.CONNECTED, connectedListener);
|
|
117
|
+
web3Auth.on(constants.ADAPTER_EVENTS.DISCONNECTED, disconnectedListener);
|
|
118
|
+
web3Auth.on(constants.ADAPTER_EVENTS.CONNECTING, connectingListener);
|
|
119
|
+
web3Auth.on(constants.ADAPTER_EVENTS.ERRORED, errorListener);
|
|
120
|
+
}
|
|
121
|
+
return () => {
|
|
122
|
+
if (web3Auth) {
|
|
123
|
+
web3Auth.off(constants.ADAPTER_EVENTS.NOT_READY, notReadyListener);
|
|
124
|
+
web3Auth.off(constants.ADAPTER_EVENTS.READY, readyListener);
|
|
125
|
+
web3Auth.off(constants.ADAPTER_EVENTS.CONNECTED, connectedListener);
|
|
126
|
+
web3Auth.off(constants.ADAPTER_EVENTS.DISCONNECTED, disconnectedListener);
|
|
127
|
+
web3Auth.off(constants.ADAPTER_EVENTS.CONNECTING, connectingListener);
|
|
128
|
+
web3Auth.off(constants.ADAPTER_EVENTS.ERRORED, errorListener);
|
|
129
|
+
}
|
|
130
|
+
};
|
|
131
|
+
}, [web3Auth]);
|
|
132
|
+
const enableMFA = react.useCallback(async loginParams => {
|
|
133
|
+
if (!web3Auth) throw index.WalletInitializationError.notReady();
|
|
134
|
+
if (!isConnected) throw index.WalletLoginError.notConnectedError();
|
|
135
|
+
await web3Auth.enableMFA(loginParams);
|
|
136
|
+
const localUserInfo = await web3Auth.getUserInfo();
|
|
137
|
+
setUserInfo(localUserInfo);
|
|
138
|
+
setIsMFAEnabled(localUserInfo.isMfaEnabled || false);
|
|
139
|
+
}, [web3Auth, isConnected]);
|
|
140
|
+
const manageMFA = react.useCallback(async loginParams => {
|
|
141
|
+
if (!web3Auth) throw index.WalletInitializationError.notReady();
|
|
142
|
+
if (!isConnected) throw index.WalletLoginError.notConnectedError();
|
|
143
|
+
await web3Auth.manageMFA(loginParams);
|
|
144
|
+
}, [web3Auth, isConnected]);
|
|
145
|
+
const logout = react.useCallback(async (logoutParams = {
|
|
146
|
+
cleanup: false
|
|
147
|
+
}) => {
|
|
148
|
+
if (!web3Auth) throw index.WalletInitializationError.notReady();
|
|
149
|
+
if (!isConnected) throw index.WalletLoginError.notConnectedError();
|
|
150
|
+
await web3Auth.logout(logoutParams);
|
|
151
|
+
}, [web3Auth, isConnected]);
|
|
152
|
+
const connectTo = react.useCallback(async (walletName, loginParams) => {
|
|
153
|
+
if (!web3Auth) throw index.WalletInitializationError.notReady();
|
|
154
|
+
try {
|
|
155
|
+
setConnectError(null);
|
|
156
|
+
setIsConnecting(true);
|
|
157
|
+
const localProvider = await web3Auth.connectTo(walletName, loginParams);
|
|
158
|
+
return localProvider;
|
|
159
|
+
} catch (error) {
|
|
160
|
+
setConnectError(error);
|
|
161
|
+
throw error;
|
|
162
|
+
} finally {
|
|
163
|
+
setIsConnecting(false);
|
|
164
|
+
}
|
|
165
|
+
}, [web3Auth]);
|
|
166
|
+
const addAndSwitchChain = react.useCallback(async chainConfig => {
|
|
167
|
+
if (!web3Auth) throw index.WalletInitializationError.notReady();
|
|
168
|
+
await web3Auth.addChain(chainConfig);
|
|
169
|
+
await web3Auth.switchChain({
|
|
170
|
+
chainId: chainConfig.chainId
|
|
171
|
+
});
|
|
172
|
+
}, [web3Auth]);
|
|
173
|
+
const authenticateUser = react.useCallback(async () => {
|
|
174
|
+
if (!web3Auth) throw index.WalletInitializationError.notReady();
|
|
175
|
+
return web3Auth.authenticateUser();
|
|
176
|
+
}, [web3Auth]);
|
|
177
|
+
const addChain = react.useCallback(async chainConfig => {
|
|
178
|
+
if (!web3Auth) throw index.WalletInitializationError.notReady();
|
|
179
|
+
return web3Auth.addChain(chainConfig);
|
|
180
|
+
}, [web3Auth]);
|
|
181
|
+
const switchChain = react.useCallback(chainParams => {
|
|
182
|
+
if (!web3Auth) throw index.WalletInitializationError.notReady();
|
|
183
|
+
return web3Auth.switchChain(chainParams);
|
|
184
|
+
}, [web3Auth]);
|
|
185
|
+
const value = react.useMemo(() => {
|
|
186
|
+
return {
|
|
187
|
+
web3Auth,
|
|
188
|
+
isConnected,
|
|
189
|
+
isInitialized,
|
|
190
|
+
provider,
|
|
191
|
+
userInfo,
|
|
192
|
+
isMFAEnabled,
|
|
193
|
+
status,
|
|
194
|
+
getPlugin,
|
|
195
|
+
connectTo,
|
|
196
|
+
enableMFA,
|
|
197
|
+
manageMFA,
|
|
198
|
+
logout,
|
|
199
|
+
addAndSwitchChain,
|
|
200
|
+
addChain,
|
|
201
|
+
addPlugin,
|
|
202
|
+
authenticateUser,
|
|
203
|
+
switchChain,
|
|
204
|
+
isInitializing,
|
|
205
|
+
isConnecting,
|
|
206
|
+
initError,
|
|
207
|
+
connectError
|
|
208
|
+
};
|
|
209
|
+
}, [web3Auth, isConnected, isInitialized, provider, userInfo, isMFAEnabled, status, connectTo, getPlugin, enableMFA, manageMFA, logout, addAndSwitchChain, addChain, addPlugin, authenticateUser, switchChain, isConnecting, isInitializing, initError, connectError]);
|
|
210
|
+
return react.createElement(Web3AuthInnerContext.Provider, {
|
|
211
|
+
value
|
|
212
|
+
}, children);
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
exports.Web3AuthInnerContext = Web3AuthInnerContext;
|
|
216
|
+
exports.Web3AuthInnerProvider = Web3AuthInnerProvider;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var react = require('react');
|
|
4
|
+
var Web3AuthInnerContext = require('./Web3AuthInnerContext.js');
|
|
5
|
+
|
|
6
|
+
function Web3AuthProvider({
|
|
7
|
+
config,
|
|
8
|
+
children
|
|
9
|
+
}) {
|
|
10
|
+
return react.createElement(Web3AuthInnerContext.Web3AuthInnerProvider, {
|
|
11
|
+
config
|
|
12
|
+
}, children);
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
exports.Web3AuthProvider = Web3AuthProvider;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var react = require('react');
|
|
4
|
+
var index = require('../../../base/errors/index.js');
|
|
5
|
+
var Web3AuthInnerContext = require('../Web3AuthInnerContext.js');
|
|
6
|
+
|
|
7
|
+
const useWeb3Auth = () => {
|
|
8
|
+
const context = react.useContext(Web3AuthInnerContext.Web3AuthInnerContext);
|
|
9
|
+
if (!context) {
|
|
10
|
+
throw index.WalletInitializationError.fromCode(1000, "usage of useWeb3Auth not wrapped in `Web3AuthContextProvider`.");
|
|
11
|
+
}
|
|
12
|
+
return context;
|
|
13
|
+
};
|
|
14
|
+
|
|
15
|
+
exports.useWeb3Auth = useWeb3Auth;
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var react = require('react');
|
|
4
|
+
var IPlugin = require('../../base/plugin/IPlugin.js');
|
|
5
|
+
var errors = require('../../base/plugin/errors.js');
|
|
6
|
+
|
|
7
|
+
const WalletServicesContext = react.createContext(null);
|
|
8
|
+
function WalletServicesContextProvider({
|
|
9
|
+
children,
|
|
10
|
+
context
|
|
11
|
+
}) {
|
|
12
|
+
const [isPluginConnected, setIsPluginConnected] = react.useState(false);
|
|
13
|
+
const [walletServicesPlugin, setWalletServicesPlugin] = react.useState(null);
|
|
14
|
+
const web3AuthContext = react.useContext(context);
|
|
15
|
+
const {
|
|
16
|
+
getPlugin,
|
|
17
|
+
isInitialized,
|
|
18
|
+
isConnected
|
|
19
|
+
} = web3AuthContext;
|
|
20
|
+
react.useEffect(() => {
|
|
21
|
+
if (isInitialized) {
|
|
22
|
+
const plugin = getPlugin(IPlugin.EVM_PLUGINS.WALLET_SERVICES);
|
|
23
|
+
setWalletServicesPlugin(plugin);
|
|
24
|
+
}
|
|
25
|
+
}, [isInitialized, getPlugin]);
|
|
26
|
+
react.useEffect(() => {
|
|
27
|
+
if (isConnected) {
|
|
28
|
+
const plugin = getPlugin(IPlugin.EVM_PLUGINS.WALLET_SERVICES);
|
|
29
|
+
if (!walletServicesPlugin) setWalletServicesPlugin(plugin);
|
|
30
|
+
}
|
|
31
|
+
}, [isConnected, getPlugin, walletServicesPlugin]);
|
|
32
|
+
react.useEffect(() => {
|
|
33
|
+
const connectedListener = () => {
|
|
34
|
+
setIsPluginConnected(true);
|
|
35
|
+
};
|
|
36
|
+
const disconnectedListener = () => {
|
|
37
|
+
setIsPluginConnected(false);
|
|
38
|
+
};
|
|
39
|
+
if (walletServicesPlugin) {
|
|
40
|
+
walletServicesPlugin.on(IPlugin.PLUGIN_EVENTS.CONNECTED, connectedListener);
|
|
41
|
+
walletServicesPlugin.on(IPlugin.PLUGIN_EVENTS.DISCONNECTED, disconnectedListener);
|
|
42
|
+
}
|
|
43
|
+
return () => {
|
|
44
|
+
if (walletServicesPlugin) {
|
|
45
|
+
walletServicesPlugin.off(IPlugin.PLUGIN_EVENTS.CONNECTED, connectedListener);
|
|
46
|
+
walletServicesPlugin.off(IPlugin.PLUGIN_EVENTS.DISCONNECTED, disconnectedListener);
|
|
47
|
+
}
|
|
48
|
+
};
|
|
49
|
+
}, [walletServicesPlugin]);
|
|
50
|
+
const showWalletConnectScanner = react.useCallback(async showWalletConnectParams => {
|
|
51
|
+
if (!walletServicesPlugin) throw errors.WalletServicesPluginError.notInitialized();
|
|
52
|
+
if (!isPluginConnected) throw errors.WalletServicesPluginError.walletPluginNotConnected();
|
|
53
|
+
return walletServicesPlugin.showWalletConnectScanner(showWalletConnectParams);
|
|
54
|
+
}, [walletServicesPlugin, isPluginConnected]);
|
|
55
|
+
const showWalletUI = react.useCallback(async showWalletUiParams => {
|
|
56
|
+
if (!walletServicesPlugin) throw errors.WalletServicesPluginError.notInitialized();
|
|
57
|
+
if (!isPluginConnected) throw errors.WalletServicesPluginError.walletPluginNotConnected();
|
|
58
|
+
return walletServicesPlugin.showWalletUi(showWalletUiParams);
|
|
59
|
+
}, [walletServicesPlugin, isPluginConnected]);
|
|
60
|
+
const showCheckout = react.useCallback(async showCheckoutParams => {
|
|
61
|
+
if (!walletServicesPlugin) throw errors.WalletServicesPluginError.notInitialized();
|
|
62
|
+
if (!isPluginConnected) throw errors.WalletServicesPluginError.walletPluginNotConnected();
|
|
63
|
+
return walletServicesPlugin.showCheckout(showCheckoutParams);
|
|
64
|
+
}, [walletServicesPlugin, isPluginConnected]);
|
|
65
|
+
const showSwap = react.useCallback(async showSwapParams => {
|
|
66
|
+
if (!walletServicesPlugin) throw errors.WalletServicesPluginError.notInitialized();
|
|
67
|
+
if (!isPluginConnected) throw errors.WalletServicesPluginError.walletPluginNotConnected();
|
|
68
|
+
return walletServicesPlugin.showSwap(showSwapParams);
|
|
69
|
+
}, [walletServicesPlugin, isPluginConnected]);
|
|
70
|
+
const value = react.useMemo(() => {
|
|
71
|
+
return {
|
|
72
|
+
plugin: walletServicesPlugin,
|
|
73
|
+
isPluginConnected,
|
|
74
|
+
showWalletConnectScanner,
|
|
75
|
+
showCheckout,
|
|
76
|
+
showWalletUI,
|
|
77
|
+
showSwap
|
|
78
|
+
};
|
|
79
|
+
}, [walletServicesPlugin, isPluginConnected, showWalletConnectScanner, showCheckout, showWalletUI, showSwap]);
|
|
80
|
+
return react.createElement(WalletServicesContext.Provider, {
|
|
81
|
+
value
|
|
82
|
+
}, children);
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
exports.WalletServicesContext = WalletServicesContext;
|
|
86
|
+
exports.WalletServicesContextProvider = WalletServicesContextProvider;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var react = require('react');
|
|
4
|
+
var WalletServicesContext = require('./WalletServicesContext.js');
|
|
5
|
+
|
|
6
|
+
function WalletServicesProvider({
|
|
7
|
+
children,
|
|
8
|
+
context
|
|
9
|
+
}) {
|
|
10
|
+
const wsElement = react.createElement(WalletServicesContext.WalletServicesContextProvider, {
|
|
11
|
+
context
|
|
12
|
+
}, children);
|
|
13
|
+
return wsElement;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
exports.WalletServicesProvider = WalletServicesProvider;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var react = require('react');
|
|
4
|
+
var index = require('../../../base/errors/index.js');
|
|
5
|
+
var WalletServicesContext = require('../WalletServicesContext.js');
|
|
6
|
+
|
|
7
|
+
const useWalletServicesPlugin = () => {
|
|
8
|
+
const context = react.useContext(WalletServicesContext.WalletServicesContext);
|
|
9
|
+
if (!context) {
|
|
10
|
+
throw index.WalletInitializationError.fromCode(1000, "usage of useWalletServicesPlugin not wrapped in `WalletServicesContextProvider`.");
|
|
11
|
+
}
|
|
12
|
+
return context;
|
|
13
|
+
};
|
|
14
|
+
|
|
15
|
+
exports.useWalletServicesPlugin = useWalletServicesPlugin;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var useWeb3Auth = require('./no-modal/composables/useWeb3Auth.js');
|
|
4
|
+
var Web3AuthProvider = require('./no-modal/Web3AuthProvider.js');
|
|
5
|
+
var useWalletServicesPlugin = require('./wallet-services-plugin/composables/useWalletServicesPlugin.js');
|
|
6
|
+
var context = require('./wallet-services-plugin/context.js');
|
|
7
|
+
var WalletServicesProvider = require('./wallet-services-plugin/WalletServicesProvider.js');
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
exports.useWeb3Auth = useWeb3Auth.useWeb3Auth;
|
|
12
|
+
exports.Web3AuthProvider = Web3AuthProvider.Web3AuthProvider;
|
|
13
|
+
exports.useWalletServicesPlugin = useWalletServicesPlugin.useWalletServicesPlugin;
|
|
14
|
+
exports.WalletServicesContextKey = context.WalletServicesContextKey;
|
|
15
|
+
exports.WalletServicesProvider = WalletServicesProvider.WalletServicesProvider;
|