thirdweb 5.74.0 → 5.75.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/cjs/adapters/ethers5.js +2 -2
- package/dist/cjs/adapters/ethers5.js.map +1 -1
- package/dist/cjs/adapters/ethers6.js.map +1 -1
- package/dist/cjs/auth/verify-hash.js +2 -1
- package/dist/cjs/auth/verify-hash.js.map +1 -1
- package/dist/cjs/auth/verify-signature.js.map +1 -1
- package/dist/cjs/contract/actions/resolve-abi.js +4 -0
- package/dist/cjs/contract/actions/resolve-abi.js.map +1 -1
- package/dist/cjs/exports/wallets/smart.js +3 -1
- package/dist/cjs/exports/wallets/smart.js.map +1 -1
- package/dist/cjs/extensions/erc1271/checkContractWalletSignedTypedData.js +6 -2
- package/dist/cjs/extensions/erc1271/checkContractWalletSignedTypedData.js.map +1 -1
- package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/events/ModuleInstalled.js +27 -0
- package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/events/ModuleInstalled.js.map +1 -0
- package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/events/ModuleUninstalled.js +27 -0
- package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/events/ModuleUninstalled.js.map +1 -0
- package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/read/accountId.js +71 -0
- package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/read/accountId.js.map +1 -0
- package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/read/isModuleInstalled.js +132 -0
- package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/read/isModuleInstalled.js.map +1 -0
- package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/read/isValidSignature.js +121 -0
- package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/read/isValidSignature.js.map +1 -0
- package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/read/supportsExecutionMode.js +114 -0
- package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/read/supportsExecutionMode.js.map +1 -0
- package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/read/supportsModule.js +114 -0
- package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/read/supportsModule.js.map +1 -0
- package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/write/execute.js +127 -0
- package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/write/execute.js.map +1 -0
- package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/write/executeFromExecutor.js +132 -0
- package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/write/executeFromExecutor.js.map +1 -0
- package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/write/installModule.js +139 -0
- package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/write/installModule.js.map +1 -0
- package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/write/uninstallModule.js +139 -0
- package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/write/uninstallModule.js.map +1 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/events/OwnershipTransferred.js +32 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/events/OwnershipTransferred.js.map +1 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/events/Upgraded.js +31 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/events/Upgraded.js.map +1 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/read/accountImplementation.js +70 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/read/accountImplementation.js.map +1 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/read/entrypoint.js +70 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/read/entrypoint.js.map +1 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/read/getAddress.js +122 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/read/getAddress.js.map +1 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/read/implementation.js +71 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/read/implementation.js.map +1 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/read/owner.js +71 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/read/owner.js.map +1 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/addStake.js +117 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/addStake.js.map +1 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/createAccountWithModules.js +157 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/createAccountWithModules.js.map +1 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/renounceOwnership.js +51 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/renounceOwnership.js.map +1 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/transferOwnership.js +117 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/transferOwnership.js.map +1 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/unlockStake.js +51 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/unlockStake.js.map +1 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/upgradeTo.js +117 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/upgradeTo.js.map +1 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/withdraw.js +139 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/withdraw.js.map +1 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/withdrawStake.js +117 -0
- package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/withdrawStake.js.map +1 -0
- package/dist/cjs/extensions/marketplace/direct-listings/write/buyFromListing.js +6 -0
- package/dist/cjs/extensions/marketplace/direct-listings/write/buyFromListing.js.map +1 -1
- package/dist/cjs/extensions/pack/createNewPack.js +1 -0
- package/dist/cjs/extensions/pack/createNewPack.js.map +1 -1
- package/dist/cjs/react/web/ui/prebuilt/Account/avatar.js +1 -0
- package/dist/cjs/react/web/ui/prebuilt/Account/avatar.js.map +1 -1
- package/dist/cjs/react/web/ui/prebuilt/Account/balance.js +1 -0
- package/dist/cjs/react/web/ui/prebuilt/Account/balance.js.map +1 -1
- package/dist/cjs/react/web/ui/prebuilt/Account/name.js +1 -0
- package/dist/cjs/react/web/ui/prebuilt/Account/name.js.map +1 -1
- package/dist/cjs/react/web/utils/usePreloadWalletProviders.js +1 -1
- package/dist/cjs/react/web/utils/usePreloadWalletProviders.js.map +1 -1
- package/dist/cjs/transaction/actions/estimate-gas.js.map +1 -1
- package/dist/cjs/transaction/actions/gasless/providers/biconomy.js.map +1 -1
- package/dist/cjs/transaction/actions/gasless/providers/engine.js.map +1 -1
- package/dist/cjs/transaction/actions/gasless/providers/openzeppelin.js.map +1 -1
- package/dist/cjs/transaction/actions/sign-transaction.js +4 -7
- package/dist/cjs/transaction/actions/sign-transaction.js.map +1 -1
- package/dist/cjs/transaction/actions/to-serializable-transaction.js.map +1 -1
- package/dist/cjs/transaction/actions/zksync/getEip721Domain.js.map +1 -1
- package/dist/cjs/transaction/serialize-transaction.js +76 -9
- package/dist/cjs/transaction/serialize-transaction.js.map +1 -1
- package/dist/cjs/utils/any-evm/keyless-transaction.js +25 -4
- package/dist/cjs/utils/any-evm/keyless-transaction.js.map +1 -1
- package/dist/cjs/utils/hashing/hashMessage.js +2 -2
- package/dist/cjs/utils/hashing/hashMessage.js.map +1 -1
- package/dist/cjs/utils/hashing/hashTypedData.js +8 -6
- package/dist/cjs/utils/hashing/hashTypedData.js.map +1 -1
- package/dist/cjs/utils/signatures/helpers/{parseTypedData.js → parse-typed-data.js} +4 -4
- package/dist/cjs/utils/signatures/helpers/parse-typed-data.js.map +1 -0
- package/dist/cjs/utils/signatures/sign-message.js +12 -6
- package/dist/cjs/utils/signatures/sign-message.js.map +1 -1
- package/dist/cjs/utils/signatures/sign-typed-data.js +11 -8
- package/dist/cjs/utils/signatures/sign-typed-data.js.map +1 -1
- package/dist/cjs/utils/signatures/sign.js +4 -4
- package/dist/cjs/utils/signatures/sign.js.map +1 -1
- package/dist/cjs/utils/signatures/signature-to-hex.js +17 -10
- package/dist/cjs/utils/signatures/signature-to-hex.js.map +1 -1
- package/dist/cjs/utils/types.js +5 -0
- package/dist/cjs/utils/types.js.map +1 -1
- package/dist/cjs/version.js +1 -1
- package/dist/cjs/wallets/coinbase/{coinbaseMobileSDK.js → coinbase-mobile.js} +1 -1
- package/dist/cjs/wallets/coinbase/coinbase-mobile.js.map +1 -0
- package/dist/cjs/wallets/coinbase/coinbase-wallet.js +2 -2
- package/dist/cjs/wallets/coinbase/coinbase-wallet.js.map +1 -1
- package/dist/cjs/wallets/coinbase/{coinbaseWebSDK.js → coinbase-web.js} +11 -11
- package/dist/cjs/wallets/coinbase/coinbase-web.js.map +1 -0
- package/dist/cjs/wallets/create-wallet.js +2 -2
- package/dist/cjs/wallets/create-wallet.js.map +1 -1
- package/dist/cjs/wallets/eip5792/get-calls-status.js +3 -3
- package/dist/cjs/wallets/eip5792/get-calls-status.js.map +1 -1
- package/dist/cjs/wallets/eip5792/get-capabilities.js +3 -3
- package/dist/cjs/wallets/eip5792/get-capabilities.js.map +1 -1
- package/dist/cjs/wallets/eip5792/send-calls.js +3 -3
- package/dist/cjs/wallets/eip5792/send-calls.js.map +1 -1
- package/dist/cjs/wallets/eip5792/show-calls-status.js +3 -3
- package/dist/cjs/wallets/eip5792/show-calls-status.js.map +1 -1
- package/dist/cjs/wallets/in-app/core/actions/sign-typed-data.enclave.js.map +1 -1
- package/dist/cjs/wallets/in-app/core/wallet/enclave-wallet.js +2 -2
- package/dist/cjs/wallets/in-app/core/wallet/enclave-wallet.js.map +1 -1
- package/dist/cjs/wallets/in-app/web/lib/iframe-wallet.js +3 -3
- package/dist/cjs/wallets/in-app/web/lib/iframe-wallet.js.map +1 -1
- package/dist/cjs/wallets/injected/index.js +2 -2
- package/dist/cjs/wallets/injected/index.js.map +1 -1
- package/dist/cjs/wallets/native/create-wallet.js +2 -2
- package/dist/cjs/wallets/native/create-wallet.js.map +1 -1
- package/dist/cjs/wallets/private-key.js +2 -5
- package/dist/cjs/wallets/private-key.js.map +1 -1
- package/dist/cjs/wallets/smart/index.js +26 -160
- package/dist/cjs/wallets/smart/index.js.map +1 -1
- package/dist/cjs/wallets/smart/lib/bundler.js +1 -1
- package/dist/cjs/wallets/smart/lib/bundler.js.map +1 -1
- package/dist/cjs/wallets/smart/lib/calls.js +2 -2
- package/dist/cjs/wallets/smart/lib/calls.js.map +1 -1
- package/dist/cjs/wallets/smart/lib/paymaster.js +7 -6
- package/dist/cjs/wallets/smart/lib/paymaster.js.map +1 -1
- package/dist/cjs/wallets/smart/lib/signing.js +166 -0
- package/dist/cjs/wallets/smart/lib/signing.js.map +1 -0
- package/dist/cjs/wallets/smart/lib/userop.js +1 -1
- package/dist/cjs/wallets/smart/lib/userop.js.map +1 -1
- package/dist/cjs/wallets/smart/presets/7579.js +218 -0
- package/dist/cjs/wallets/smart/presets/7579.js.map +1 -0
- package/dist/cjs/wallets/smart/presets/index.js +6 -0
- package/dist/cjs/wallets/smart/presets/index.js.map +1 -0
- package/dist/cjs/wallets/smart/smart-wallet.js.map +1 -1
- package/dist/cjs/wallets/smart/types.js.map +1 -1
- package/dist/cjs/wallets/wallet-connect/controller.js +2 -2
- package/dist/cjs/wallets/wallet-connect/controller.js.map +1 -1
- package/dist/esm/adapters/ethers5.js +2 -2
- package/dist/esm/adapters/ethers5.js.map +1 -1
- package/dist/esm/adapters/ethers6.js.map +1 -1
- package/dist/esm/auth/verify-hash.js +2 -1
- package/dist/esm/auth/verify-hash.js.map +1 -1
- package/dist/esm/auth/verify-signature.js.map +1 -1
- package/dist/esm/contract/actions/resolve-abi.js +4 -0
- package/dist/esm/contract/actions/resolve-abi.js.map +1 -1
- package/dist/esm/exports/wallets/smart.js +2 -0
- package/dist/esm/exports/wallets/smart.js.map +1 -1
- package/dist/esm/extensions/erc1271/checkContractWalletSignedTypedData.js +6 -2
- package/dist/esm/extensions/erc1271/checkContractWalletSignedTypedData.js.map +1 -1
- package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/events/ModuleInstalled.js +24 -0
- package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/events/ModuleInstalled.js.map +1 -0
- package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/events/ModuleUninstalled.js +24 -0
- package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/events/ModuleUninstalled.js.map +1 -0
- package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/read/accountId.js +65 -0
- package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/read/accountId.js.map +1 -0
- package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/read/isModuleInstalled.js +124 -0
- package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/read/isModuleInstalled.js.map +1 -0
- package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/read/isValidSignature.js +113 -0
- package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/read/isValidSignature.js.map +1 -0
- package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/read/supportsExecutionMode.js +106 -0
- package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/read/supportsExecutionMode.js.map +1 -0
- package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/read/supportsModule.js +106 -0
- package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/read/supportsModule.js.map +1 -0
- package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/write/execute.js +120 -0
- package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/write/execute.js.map +1 -0
- package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/write/executeFromExecutor.js +125 -0
- package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/write/executeFromExecutor.js.map +1 -0
- package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/write/installModule.js +132 -0
- package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/write/installModule.js.map +1 -0
- package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/write/uninstallModule.js +132 -0
- package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/write/uninstallModule.js.map +1 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/events/OwnershipTransferred.js +29 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/events/OwnershipTransferred.js.map +1 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/events/Upgraded.js +28 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/events/Upgraded.js.map +1 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/read/accountImplementation.js +64 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/read/accountImplementation.js.map +1 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/read/entrypoint.js +64 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/read/entrypoint.js.map +1 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/read/getAddress.js +114 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/read/getAddress.js.map +1 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/read/implementation.js +65 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/read/implementation.js.map +1 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/read/owner.js +65 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/read/owner.js.map +1 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/addStake.js +110 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/addStake.js.map +1 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/createAccountWithModules.js +150 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/createAccountWithModules.js.map +1 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/renounceOwnership.js +46 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/renounceOwnership.js.map +1 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/transferOwnership.js +110 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/transferOwnership.js.map +1 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/unlockStake.js +46 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/unlockStake.js.map +1 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/upgradeTo.js +110 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/upgradeTo.js.map +1 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/withdraw.js +132 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/withdraw.js.map +1 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/withdrawStake.js +110 -0
- package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/withdrawStake.js.map +1 -0
- package/dist/esm/extensions/marketplace/direct-listings/write/buyFromListing.js +6 -0
- package/dist/esm/extensions/marketplace/direct-listings/write/buyFromListing.js.map +1 -1
- package/dist/esm/extensions/pack/createNewPack.js +1 -0
- package/dist/esm/extensions/pack/createNewPack.js.map +1 -1
- package/dist/esm/react/web/ui/prebuilt/Account/avatar.js +1 -0
- package/dist/esm/react/web/ui/prebuilt/Account/avatar.js.map +1 -1
- package/dist/esm/react/web/ui/prebuilt/Account/balance.js +1 -0
- package/dist/esm/react/web/ui/prebuilt/Account/balance.js.map +1 -1
- package/dist/esm/react/web/ui/prebuilt/Account/name.js +1 -0
- package/dist/esm/react/web/ui/prebuilt/Account/name.js.map +1 -1
- package/dist/esm/react/web/utils/usePreloadWalletProviders.js +1 -1
- package/dist/esm/react/web/utils/usePreloadWalletProviders.js.map +1 -1
- package/dist/esm/transaction/actions/estimate-gas.js +3 -3
- package/dist/esm/transaction/actions/estimate-gas.js.map +1 -1
- package/dist/esm/transaction/actions/gasless/providers/biconomy.js.map +1 -1
- package/dist/esm/transaction/actions/gasless/providers/engine.js.map +1 -1
- package/dist/esm/transaction/actions/gasless/providers/openzeppelin.js.map +1 -1
- package/dist/esm/transaction/actions/sign-transaction.js +5 -8
- package/dist/esm/transaction/actions/sign-transaction.js.map +1 -1
- package/dist/esm/transaction/actions/to-serializable-transaction.js.map +1 -1
- package/dist/esm/transaction/actions/zksync/getEip721Domain.js.map +1 -1
- package/dist/esm/transaction/serialize-transaction.js +76 -9
- package/dist/esm/transaction/serialize-transaction.js.map +1 -1
- package/dist/esm/utils/any-evm/keyless-transaction.js +26 -5
- package/dist/esm/utils/any-evm/keyless-transaction.js.map +1 -1
- package/dist/esm/utils/hashing/hashMessage.js +2 -2
- package/dist/esm/utils/hashing/hashMessage.js.map +1 -1
- package/dist/esm/utils/hashing/hashTypedData.js +8 -6
- package/dist/esm/utils/hashing/hashTypedData.js.map +1 -1
- package/dist/esm/utils/signatures/helpers/parse-typed-data.js +15 -0
- package/dist/esm/utils/signatures/helpers/parse-typed-data.js.map +1 -0
- package/dist/esm/utils/signatures/sign-message.js +12 -6
- package/dist/esm/utils/signatures/sign-message.js.map +1 -1
- package/dist/esm/utils/signatures/sign-typed-data.js +11 -8
- package/dist/esm/utils/signatures/sign-typed-data.js.map +1 -1
- package/dist/esm/utils/signatures/sign.js +4 -4
- package/dist/esm/utils/signatures/sign.js.map +1 -1
- package/dist/esm/utils/signatures/signature-to-hex.js +17 -10
- package/dist/esm/utils/signatures/signature-to-hex.js.map +1 -1
- package/dist/esm/utils/types.js +4 -1
- package/dist/esm/utils/types.js.map +1 -1
- package/dist/esm/version.js +1 -1
- package/dist/esm/wallets/coinbase/{coinbaseMobileSDK.js → coinbase-mobile.js} +1 -1
- package/dist/esm/wallets/coinbase/coinbase-mobile.js.map +1 -0
- package/dist/esm/wallets/coinbase/coinbase-wallet.js +2 -2
- package/dist/esm/wallets/coinbase/coinbase-wallet.js.map +1 -1
- package/dist/esm/wallets/coinbase/{coinbaseWebSDK.js → coinbase-web.js} +11 -11
- package/dist/esm/wallets/coinbase/coinbase-web.js.map +1 -0
- package/dist/esm/wallets/create-wallet.js +1 -1
- package/dist/esm/wallets/create-wallet.js.map +1 -1
- package/dist/esm/wallets/eip5792/get-calls-status.js +2 -2
- package/dist/esm/wallets/eip5792/get-calls-status.js.map +1 -1
- package/dist/esm/wallets/eip5792/get-capabilities.js +2 -2
- package/dist/esm/wallets/eip5792/get-capabilities.js.map +1 -1
- package/dist/esm/wallets/eip5792/send-calls.js +2 -2
- package/dist/esm/wallets/eip5792/send-calls.js.map +1 -1
- package/dist/esm/wallets/eip5792/show-calls-status.js +2 -2
- package/dist/esm/wallets/eip5792/show-calls-status.js.map +1 -1
- package/dist/esm/wallets/in-app/core/actions/sign-typed-data.enclave.js.map +1 -1
- package/dist/esm/wallets/in-app/core/wallet/enclave-wallet.js +1 -1
- package/dist/esm/wallets/in-app/core/wallet/enclave-wallet.js.map +1 -1
- package/dist/esm/wallets/in-app/web/lib/iframe-wallet.js +2 -2
- package/dist/esm/wallets/in-app/web/lib/iframe-wallet.js.map +1 -1
- package/dist/esm/wallets/injected/index.js +1 -1
- package/dist/esm/wallets/injected/index.js.map +1 -1
- package/dist/esm/wallets/native/create-wallet.js +1 -1
- package/dist/esm/wallets/native/create-wallet.js.map +1 -1
- package/dist/esm/wallets/private-key.js +2 -5
- package/dist/esm/wallets/private-key.js.map +1 -1
- package/dist/esm/wallets/smart/index.js +24 -158
- package/dist/esm/wallets/smart/index.js.map +1 -1
- package/dist/esm/wallets/smart/lib/bundler.js +1 -1
- package/dist/esm/wallets/smart/lib/bundler.js.map +1 -1
- package/dist/esm/wallets/smart/lib/calls.js +2 -2
- package/dist/esm/wallets/smart/lib/calls.js.map +1 -1
- package/dist/esm/wallets/smart/lib/paymaster.js +7 -6
- package/dist/esm/wallets/smart/lib/paymaster.js.map +1 -1
- package/dist/esm/wallets/smart/lib/signing.js +161 -0
- package/dist/esm/wallets/smart/lib/signing.js.map +1 -0
- package/dist/esm/wallets/smart/lib/userop.js +1 -1
- package/dist/esm/wallets/smart/lib/userop.js.map +1 -1
- package/dist/esm/wallets/smart/presets/7579.js +215 -0
- package/dist/esm/wallets/smart/presets/7579.js.map +1 -0
- package/dist/esm/wallets/smart/presets/index.js +2 -0
- package/dist/esm/wallets/smart/presets/index.js.map +1 -0
- package/dist/esm/wallets/smart/smart-wallet.js.map +1 -1
- package/dist/esm/wallets/smart/types.js.map +1 -1
- package/dist/esm/wallets/wallet-connect/controller.js +1 -1
- package/dist/esm/wallets/wallet-connect/controller.js.map +1 -1
- package/dist/types/adapters/ethers5.d.ts.map +1 -1
- package/dist/types/adapters/ethers6.d.ts.map +1 -1
- package/dist/types/auth/verify-hash.d.ts.map +1 -1
- package/dist/types/auth/verify-signature.d.ts +2 -2
- package/dist/types/auth/verify-signature.d.ts.map +1 -1
- package/dist/types/contract/actions/resolve-abi.d.ts.map +1 -1
- package/dist/types/exports/wallets/smart.d.ts +1 -0
- package/dist/types/exports/wallets/smart.d.ts.map +1 -1
- package/dist/types/exports/wallets.d.ts +1 -1
- package/dist/types/exports/wallets.d.ts.map +1 -1
- package/dist/types/exports/wallets.native.d.ts +1 -1
- package/dist/types/exports/wallets.native.d.ts.map +1 -1
- package/dist/types/extensions/erc1271/checkContractWalletSignedTypedData.d.ts +4 -4
- package/dist/types/extensions/erc1271/checkContractWalletSignedTypedData.d.ts.map +1 -1
- package/dist/types/extensions/erc7579/__generated__/IERC7579Account/events/ModuleInstalled.d.ts +29 -0
- package/dist/types/extensions/erc7579/__generated__/IERC7579Account/events/ModuleInstalled.d.ts.map +1 -0
- package/dist/types/extensions/erc7579/__generated__/IERC7579Account/events/ModuleUninstalled.d.ts +29 -0
- package/dist/types/extensions/erc7579/__generated__/IERC7579Account/events/ModuleUninstalled.d.ts.map +1 -0
- package/dist/types/extensions/erc7579/__generated__/IERC7579Account/read/accountId.d.ts +44 -0
- package/dist/types/extensions/erc7579/__generated__/IERC7579Account/read/accountId.d.ts.map +1 -0
- package/dist/types/extensions/erc7579/__generated__/IERC7579Account/read/isModuleInstalled.d.ts +97 -0
- package/dist/types/extensions/erc7579/__generated__/IERC7579Account/read/isModuleInstalled.d.ts.map +1 -0
- package/dist/types/extensions/erc7579/__generated__/IERC7579Account/read/isValidSignature.d.ts +90 -0
- package/dist/types/extensions/erc7579/__generated__/IERC7579Account/read/isValidSignature.d.ts.map +1 -0
- package/dist/types/extensions/erc7579/__generated__/IERC7579Account/read/supportsExecutionMode.d.ts +83 -0
- package/dist/types/extensions/erc7579/__generated__/IERC7579Account/read/supportsExecutionMode.d.ts.map +1 -0
- package/dist/types/extensions/erc7579/__generated__/IERC7579Account/read/supportsModule.d.ts +83 -0
- package/dist/types/extensions/erc7579/__generated__/IERC7579Account/read/supportsModule.d.ts.map +1 -0
- package/dist/types/extensions/erc7579/__generated__/IERC7579Account/write/execute.d.ts +86 -0
- package/dist/types/extensions/erc7579/__generated__/IERC7579Account/write/execute.d.ts.map +1 -0
- package/dist/types/extensions/erc7579/__generated__/IERC7579Account/write/executeFromExecutor.d.ts +86 -0
- package/dist/types/extensions/erc7579/__generated__/IERC7579Account/write/executeFromExecutor.d.ts.map +1 -0
- package/dist/types/extensions/erc7579/__generated__/IERC7579Account/write/installModule.d.ts +93 -0
- package/dist/types/extensions/erc7579/__generated__/IERC7579Account/write/installModule.d.ts.map +1 -0
- package/dist/types/extensions/erc7579/__generated__/IERC7579Account/write/uninstallModule.d.ts +93 -0
- package/dist/types/extensions/erc7579/__generated__/IERC7579Account/write/uninstallModule.d.ts.map +1 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/events/OwnershipTransferred.d.ts +51 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/events/OwnershipTransferred.d.ts.map +1 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/events/Upgraded.d.ts +41 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/events/Upgraded.d.ts.map +1 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/read/accountImplementation.d.ts +44 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/read/accountImplementation.d.ts.map +1 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/read/entrypoint.d.ts +44 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/read/entrypoint.d.ts.map +1 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/read/getAddress.d.ts +90 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/read/getAddress.d.ts.map +1 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/read/implementation.d.ts +44 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/read/implementation.d.ts.map +1 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/read/owner.d.ts +44 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/read/owner.d.ts.map +1 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/addStake.d.ts +79 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/addStake.d.ts.map +1 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/createAccountWithModules.d.ts +107 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/createAccountWithModules.d.ts.map +1 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/renounceOwnership.d.ts +33 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/renounceOwnership.d.ts.map +1 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/transferOwnership.d.ts +79 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/transferOwnership.d.ts.map +1 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/unlockStake.d.ts +33 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/unlockStake.d.ts.map +1 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/upgradeTo.d.ts +79 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/upgradeTo.d.ts.map +1 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/withdraw.d.ts +93 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/withdraw.d.ts.map +1 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/withdrawStake.d.ts +79 -0
- package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/withdrawStake.d.ts.map +1 -0
- package/dist/types/extensions/marketplace/direct-listings/write/buyFromListing.d.ts.map +1 -1
- package/dist/types/extensions/pack/createNewPack.d.ts.map +1 -1
- package/dist/types/react/web/ui/prebuilt/Account/avatar.d.ts.map +1 -1
- package/dist/types/react/web/ui/prebuilt/Account/balance.d.ts.map +1 -1
- package/dist/types/react/web/ui/prebuilt/Account/name.d.ts.map +1 -1
- package/dist/types/transaction/actions/gasless/providers/biconomy.d.ts +2 -2
- package/dist/types/transaction/actions/gasless/providers/biconomy.d.ts.map +1 -1
- package/dist/types/transaction/actions/gasless/providers/engine.d.ts +2 -2
- package/dist/types/transaction/actions/gasless/providers/engine.d.ts.map +1 -1
- package/dist/types/transaction/actions/gasless/providers/openzeppelin.d.ts +2 -2
- package/dist/types/transaction/actions/gasless/providers/openzeppelin.d.ts.map +1 -1
- package/dist/types/transaction/actions/gasless/send-gasless-transaction.d.ts +2 -2
- package/dist/types/transaction/actions/gasless/send-gasless-transaction.d.ts.map +1 -1
- package/dist/types/transaction/actions/sign-transaction.d.ts +2 -2
- package/dist/types/transaction/actions/sign-transaction.d.ts.map +1 -1
- package/dist/types/transaction/actions/to-serializable-transaction.d.ts.map +1 -1
- package/dist/types/transaction/actions/zksync/getEip721Domain.d.ts +2 -2
- package/dist/types/transaction/actions/zksync/getEip721Domain.d.ts.map +1 -1
- package/dist/types/transaction/serialize-transaction.d.ts +24 -4
- package/dist/types/transaction/serialize-transaction.d.ts.map +1 -1
- package/dist/types/utils/any-evm/keyless-transaction.d.ts +6 -4
- package/dist/types/utils/any-evm/keyless-transaction.d.ts.map +1 -1
- package/dist/types/utils/hashing/hashMessage.d.ts +3 -2
- package/dist/types/utils/hashing/hashMessage.d.ts.map +1 -1
- package/dist/types/utils/hashing/hashTypedData.d.ts +3 -3
- package/dist/types/utils/hashing/hashTypedData.d.ts.map +1 -1
- package/dist/types/utils/signatures/helpers/parse-typed-data.d.ts +6 -0
- package/dist/types/utils/signatures/helpers/parse-typed-data.d.ts.map +1 -0
- package/dist/types/utils/signatures/sign-message.d.ts.map +1 -1
- package/dist/types/utils/signatures/sign-typed-data.d.ts +3 -4
- package/dist/types/utils/signatures/sign-typed-data.d.ts.map +1 -1
- package/dist/types/utils/signatures/sign.d.ts +6 -2
- package/dist/types/utils/signatures/sign.d.ts.map +1 -1
- package/dist/types/utils/signatures/signature-to-hex.d.ts +7 -3
- package/dist/types/utils/signatures/signature-to-hex.d.ts.map +1 -1
- package/dist/types/utils/types.d.ts +13 -0
- package/dist/types/utils/types.d.ts.map +1 -1
- package/dist/types/version.d.ts +1 -1
- package/dist/types/wallets/coinbase/{coinbaseMobileSDK.d.ts → coinbase-mobile.d.ts} +2 -2
- package/dist/types/wallets/coinbase/coinbase-mobile.d.ts.map +1 -0
- package/dist/types/wallets/coinbase/{coinbaseWebSDK.d.ts → coinbase-web.d.ts} +1 -1
- package/dist/types/wallets/coinbase/coinbase-web.d.ts.map +1 -0
- package/dist/types/wallets/in-app/core/actions/sign-typed-data.enclave.d.ts +3 -4
- package/dist/types/wallets/in-app/core/actions/sign-typed-data.enclave.d.ts.map +1 -1
- package/dist/types/wallets/interfaces/wallet.d.ts +6 -4
- package/dist/types/wallets/interfaces/wallet.d.ts.map +1 -1
- package/dist/types/wallets/private-key.d.ts.map +1 -1
- package/dist/types/wallets/smart/index.d.ts +3 -2
- package/dist/types/wallets/smart/index.d.ts.map +1 -1
- package/dist/types/wallets/smart/lib/bundler.d.ts +3 -3
- package/dist/types/wallets/smart/lib/bundler.d.ts.map +1 -1
- package/dist/types/wallets/smart/lib/calls.d.ts +2 -2
- package/dist/types/wallets/smart/lib/calls.d.ts.map +1 -1
- package/dist/types/wallets/smart/lib/paymaster.d.ts.map +1 -1
- package/dist/types/wallets/smart/lib/signing.d.ts +20 -0
- package/dist/types/wallets/smart/lib/signing.d.ts.map +1 -0
- package/dist/types/wallets/smart/lib/userop.d.ts.map +1 -1
- package/dist/types/wallets/smart/presets/7579.d.ts +34 -0
- package/dist/types/wallets/smart/presets/7579.d.ts.map +1 -0
- package/dist/types/wallets/smart/presets/index.d.ts +2 -0
- package/dist/types/wallets/smart/presets/index.d.ts.map +1 -0
- package/dist/types/wallets/smart/smart-wallet.d.ts +2 -2
- package/dist/types/wallets/smart/smart-wallet.d.ts.map +1 -1
- package/dist/types/wallets/smart/types.d.ts +23 -9
- package/dist/types/wallets/smart/types.d.ts.map +1 -1
- package/dist/types/wallets/wallet-types.d.ts +1 -1
- package/dist/types/wallets/wallet-types.d.ts.map +1 -1
- package/package.json +23 -23
- package/src/adapters/ethers5.test.ts +92 -0
- package/src/adapters/ethers5.ts +6 -5
- package/src/adapters/ethers6.ts +3 -2
- package/src/adapters/viem.test.ts +5 -4
- package/src/auth/verify-hash.ts +2 -1
- package/src/auth/verify-signature.ts +2 -2
- package/src/contract/actions/resolve-abi.ts +6 -0
- package/src/exports/wallets/smart.ts +3 -0
- package/src/exports/wallets.native.ts +1 -1
- package/src/exports/wallets.ts +1 -1
- package/src/extensions/erc1271/checkContractWalletSignedTypedData.ts +9 -5
- package/src/extensions/erc7579/__generated__/IERC7579Account/events/ModuleInstalled.ts +24 -0
- package/src/extensions/erc7579/__generated__/IERC7579Account/events/ModuleUninstalled.ts +24 -0
- package/src/extensions/erc7579/__generated__/IERC7579Account/read/accountId.ts +71 -0
- package/src/extensions/erc7579/__generated__/IERC7579Account/read/isModuleInstalled.ts +153 -0
- package/src/extensions/erc7579/__generated__/IERC7579Account/read/isValidSignature.ts +133 -0
- package/src/extensions/erc7579/__generated__/IERC7579Account/read/supportsExecutionMode.ts +132 -0
- package/src/extensions/erc7579/__generated__/IERC7579Account/read/supportsModule.ts +128 -0
- package/src/extensions/erc7579/__generated__/IERC7579Account/write/execute.ts +149 -0
- package/src/extensions/erc7579/__generated__/IERC7579Account/write/executeFromExecutor.ts +158 -0
- package/src/extensions/erc7579/__generated__/IERC7579Account/write/installModule.ts +164 -0
- package/src/extensions/erc7579/__generated__/IERC7579Account/write/uninstallModule.ts +167 -0
- package/src/extensions/erc7579/__generated__/ModularAccountFactory/events/OwnershipTransferred.ts +49 -0
- package/src/extensions/erc7579/__generated__/ModularAccountFactory/events/Upgraded.ts +40 -0
- package/src/extensions/erc7579/__generated__/ModularAccountFactory/read/accountImplementation.ts +70 -0
- package/src/extensions/erc7579/__generated__/ModularAccountFactory/read/entrypoint.ts +70 -0
- package/src/extensions/erc7579/__generated__/ModularAccountFactory/read/getAddress.ts +134 -0
- package/src/extensions/erc7579/__generated__/ModularAccountFactory/read/implementation.ts +71 -0
- package/src/extensions/erc7579/__generated__/ModularAccountFactory/read/owner.ts +71 -0
- package/src/extensions/erc7579/__generated__/ModularAccountFactory/write/addStake.ts +138 -0
- package/src/extensions/erc7579/__generated__/ModularAccountFactory/write/createAccountWithModules.ts +193 -0
- package/src/extensions/erc7579/__generated__/ModularAccountFactory/write/renounceOwnership.ts +50 -0
- package/src/extensions/erc7579/__generated__/ModularAccountFactory/write/transferOwnership.ts +139 -0
- package/src/extensions/erc7579/__generated__/ModularAccountFactory/write/unlockStake.ts +50 -0
- package/src/extensions/erc7579/__generated__/ModularAccountFactory/write/upgradeTo.ts +140 -0
- package/src/extensions/erc7579/__generated__/ModularAccountFactory/write/withdraw.ts +159 -0
- package/src/extensions/erc7579/__generated__/ModularAccountFactory/write/withdrawStake.ts +137 -0
- package/src/extensions/marketplace/direct-listings/direct-listings.test.ts +74 -14
- package/src/extensions/marketplace/direct-listings/write/buyFromListing.ts +6 -0
- package/src/extensions/pack/createNewPack.ts +1 -0
- package/src/react/web/ui/prebuilt/Account/avatar.tsx +1 -0
- package/src/react/web/ui/prebuilt/Account/balance.tsx +1 -0
- package/src/react/web/ui/prebuilt/Account/name.tsx +1 -0
- package/src/react/web/utils/usePreloadWalletProviders.ts +1 -1
- package/src/transaction/actions/estimate-gas.ts +3 -3
- package/src/transaction/actions/gasless/providers/biconomy.ts +3 -2
- package/src/transaction/actions/gasless/providers/engine.ts +2 -2
- package/src/transaction/actions/gasless/providers/openzeppelin.ts +2 -2
- package/src/transaction/actions/gasless/send-gasless-transaction.ts +2 -2
- package/src/transaction/actions/sign-transaction.test.ts +8 -15
- package/src/transaction/actions/sign-transaction.ts +9 -11
- package/src/transaction/actions/to-serializable-transaction.ts +2 -2
- package/src/transaction/actions/zksync/getEip721Domain.ts +2 -2
- package/src/transaction/serialize-transaction.test.ts +135 -229
- package/src/transaction/serialize-transaction.ts +131 -22
- package/src/utils/any-evm/keyless-transaction.test.ts +91 -0
- package/src/utils/any-evm/keyless-transaction.ts +43 -14
- package/src/utils/hashing/hashMessage.ts +4 -3
- package/src/utils/hashing/hashTypedData.ts +24 -27
- package/src/utils/signatures/helpers/parse-typed-data.test.ts +56 -0
- package/src/utils/signatures/helpers/parse-typed-data.ts +29 -0
- package/src/utils/signatures/sign-message.ts +15 -6
- package/src/utils/signatures/sign-typed-data.ts +18 -12
- package/src/utils/signatures/sign.ts +5 -6
- package/src/utils/signatures/signature-to-hex.ts +29 -13
- package/src/utils/types.ts +17 -0
- package/src/version.ts +1 -1
- package/src/wallets/coinbase/coinbase-mobile.test.ts +69 -0
- package/src/wallets/coinbase/{coinbaseMobileSDK.ts → coinbase-mobile.ts} +1 -1
- package/src/wallets/coinbase/coinbase-wallet.ts +2 -2
- package/src/wallets/coinbase/coinbase-web.test.ts +176 -0
- package/src/wallets/coinbase/{coinbaseWebSDK.ts → coinbase-web.ts} +13 -17
- package/src/wallets/create-wallet.ts +1 -1
- package/src/wallets/eip5792/get-calls-status.ts +2 -2
- package/src/wallets/eip5792/get-capabilities.ts +2 -2
- package/src/wallets/eip5792/send-calls.ts +2 -2
- package/src/wallets/eip5792/show-calls-status.ts +2 -2
- package/src/wallets/in-app/core/actions/sign-typed-data.enclave.ts +3 -4
- package/src/wallets/in-app/core/wallet/enclave-wallet.ts +1 -1
- package/src/wallets/in-app/web/lib/iframe-wallet.ts +2 -2
- package/src/wallets/injected/index.ts +1 -1
- package/src/wallets/interfaces/wallet.ts +7 -11
- package/src/wallets/native/create-wallet.ts +1 -1
- package/src/wallets/private-key.ts +16 -14
- package/src/wallets/smart/index.ts +31 -218
- package/src/wallets/smart/lib/bundler.ts +5 -4
- package/src/wallets/smart/lib/calls.ts +4 -2
- package/src/wallets/smart/lib/paymaster.ts +8 -6
- package/src/wallets/smart/lib/signing.ts +231 -0
- package/src/wallets/smart/lib/userop.ts +3 -2
- package/src/wallets/smart/presets/7579.ts +269 -0
- package/src/wallets/smart/presets/index.ts +1 -0
- package/src/wallets/smart/smart-wallet-dev.test.ts +5 -4
- package/src/wallets/smart/smart-wallet-integration-v07.test.ts +299 -0
- package/src/wallets/smart/smart-wallet-integration.test.ts +399 -0
- package/src/wallets/smart/smart-wallet-modular.test.ts +134 -0
- package/src/wallets/smart/smart-wallet.ts +3 -5
- package/src/wallets/smart/smart.test.ts +87 -0
- package/src/wallets/smart/types.ts +31 -8
- package/src/wallets/wallet-connect/controller.ts +1 -1
- package/src/wallets/wallet-connect/receiver/session-request.test.ts +5 -5
- package/src/wallets/wallet-types.ts +1 -1
- package/dist/cjs/utils/signatures/helpers/parseTypedData.js.map +0 -1
- package/dist/cjs/wallets/coinbase/coinbaseMobileSDK.js.map +0 -1
- package/dist/cjs/wallets/coinbase/coinbaseWebSDK.js.map +0 -1
- package/dist/esm/utils/signatures/helpers/parseTypedData.js +0 -15
- package/dist/esm/utils/signatures/helpers/parseTypedData.js.map +0 -1
- package/dist/esm/wallets/coinbase/coinbaseMobileSDK.js.map +0 -1
- package/dist/esm/wallets/coinbase/coinbaseWebSDK.js.map +0 -1
- package/dist/types/utils/signatures/helpers/parseTypedData.d.ts +0 -7
- package/dist/types/utils/signatures/helpers/parseTypedData.d.ts.map +0 -1
- package/dist/types/wallets/coinbase/coinbaseMobileSDK.d.ts.map +0 -1
- package/dist/types/wallets/coinbase/coinbaseWebSDK.d.ts.map +0 -1
- package/src/utils/signatures/helpers/parseTypedData.ts +0 -25
@@ -0,0 +1,71 @@
|
|
1
|
+
import { readContract } from "../../../../../transaction/read-contract.js";
|
2
|
+
import type { BaseTransactionOptions } from "../../../../../transaction/types.js";
|
3
|
+
|
4
|
+
import { decodeAbiParameters } from "viem";
|
5
|
+
import type { Hex } from "../../../../../utils/encoding/hex.js";
|
6
|
+
import { detectMethod } from "../../../../../utils/bytecode/detectExtension.js";
|
7
|
+
|
8
|
+
export const FN_SELECTOR = "0x5c60da1b" as const;
|
9
|
+
const FN_INPUTS = [] as const;
|
10
|
+
const FN_OUTPUTS = [
|
11
|
+
{
|
12
|
+
type: "address",
|
13
|
+
name: "result",
|
14
|
+
},
|
15
|
+
] as const;
|
16
|
+
|
17
|
+
/**
|
18
|
+
* Checks if the `implementation` method is supported by the given contract.
|
19
|
+
* @param availableSelectors An array of 4byte function selectors of the contract. You can get this in various ways, such as using "whatsabi" or if you have the ABI of the contract available you can use it to generate the selectors.
|
20
|
+
* @returns A boolean indicating if the `implementation` method is supported.
|
21
|
+
* @extension ERC7579
|
22
|
+
* @example
|
23
|
+
* ```ts
|
24
|
+
* import { isImplementationSupported } from "thirdweb/extensions/erc7579";
|
25
|
+
* const supported = isImplementationSupported(["0x..."]);
|
26
|
+
* ```
|
27
|
+
*/
|
28
|
+
export function isImplementationSupported(availableSelectors: string[]) {
|
29
|
+
return detectMethod({
|
30
|
+
availableSelectors,
|
31
|
+
method: [FN_SELECTOR, FN_INPUTS, FN_OUTPUTS] as const,
|
32
|
+
});
|
33
|
+
}
|
34
|
+
|
35
|
+
/**
|
36
|
+
* Decodes the result of the implementation function call.
|
37
|
+
* @param result - The hexadecimal result to decode.
|
38
|
+
* @returns The decoded result as per the FN_OUTPUTS definition.
|
39
|
+
* @extension ERC7579
|
40
|
+
* @example
|
41
|
+
* ```ts
|
42
|
+
* import { decodeImplementationResult } from "thirdweb/extensions/erc7579";
|
43
|
+
* const result = decodeImplementationResultResult("...");
|
44
|
+
* ```
|
45
|
+
*/
|
46
|
+
export function decodeImplementationResult(result: Hex) {
|
47
|
+
return decodeAbiParameters(FN_OUTPUTS, result)[0];
|
48
|
+
}
|
49
|
+
|
50
|
+
/**
|
51
|
+
* Calls the "implementation" function on the contract.
|
52
|
+
* @param options - The options for the implementation function.
|
53
|
+
* @returns The parsed result of the function call.
|
54
|
+
* @extension ERC7579
|
55
|
+
* @example
|
56
|
+
* ```ts
|
57
|
+
* import { implementation } from "thirdweb/extensions/erc7579";
|
58
|
+
*
|
59
|
+
* const result = await implementation({
|
60
|
+
* contract,
|
61
|
+
* });
|
62
|
+
*
|
63
|
+
* ```
|
64
|
+
*/
|
65
|
+
export async function implementation(options: BaseTransactionOptions) {
|
66
|
+
return readContract({
|
67
|
+
contract: options.contract,
|
68
|
+
method: [FN_SELECTOR, FN_INPUTS, FN_OUTPUTS] as const,
|
69
|
+
params: [],
|
70
|
+
});
|
71
|
+
}
|
@@ -0,0 +1,71 @@
|
|
1
|
+
import { readContract } from "../../../../../transaction/read-contract.js";
|
2
|
+
import type { BaseTransactionOptions } from "../../../../../transaction/types.js";
|
3
|
+
|
4
|
+
import { decodeAbiParameters } from "viem";
|
5
|
+
import type { Hex } from "../../../../../utils/encoding/hex.js";
|
6
|
+
import { detectMethod } from "../../../../../utils/bytecode/detectExtension.js";
|
7
|
+
|
8
|
+
export const FN_SELECTOR = "0x8da5cb5b" as const;
|
9
|
+
const FN_INPUTS = [] as const;
|
10
|
+
const FN_OUTPUTS = [
|
11
|
+
{
|
12
|
+
type: "address",
|
13
|
+
name: "result",
|
14
|
+
},
|
15
|
+
] as const;
|
16
|
+
|
17
|
+
/**
|
18
|
+
* Checks if the `owner` method is supported by the given contract.
|
19
|
+
* @param availableSelectors An array of 4byte function selectors of the contract. You can get this in various ways, such as using "whatsabi" or if you have the ABI of the contract available you can use it to generate the selectors.
|
20
|
+
* @returns A boolean indicating if the `owner` method is supported.
|
21
|
+
* @extension ERC7579
|
22
|
+
* @example
|
23
|
+
* ```ts
|
24
|
+
* import { isOwnerSupported } from "thirdweb/extensions/erc7579";
|
25
|
+
* const supported = isOwnerSupported(["0x..."]);
|
26
|
+
* ```
|
27
|
+
*/
|
28
|
+
export function isOwnerSupported(availableSelectors: string[]) {
|
29
|
+
return detectMethod({
|
30
|
+
availableSelectors,
|
31
|
+
method: [FN_SELECTOR, FN_INPUTS, FN_OUTPUTS] as const,
|
32
|
+
});
|
33
|
+
}
|
34
|
+
|
35
|
+
/**
|
36
|
+
* Decodes the result of the owner function call.
|
37
|
+
* @param result - The hexadecimal result to decode.
|
38
|
+
* @returns The decoded result as per the FN_OUTPUTS definition.
|
39
|
+
* @extension ERC7579
|
40
|
+
* @example
|
41
|
+
* ```ts
|
42
|
+
* import { decodeOwnerResult } from "thirdweb/extensions/erc7579";
|
43
|
+
* const result = decodeOwnerResultResult("...");
|
44
|
+
* ```
|
45
|
+
*/
|
46
|
+
export function decodeOwnerResult(result: Hex) {
|
47
|
+
return decodeAbiParameters(FN_OUTPUTS, result)[0];
|
48
|
+
}
|
49
|
+
|
50
|
+
/**
|
51
|
+
* Calls the "owner" function on the contract.
|
52
|
+
* @param options - The options for the owner function.
|
53
|
+
* @returns The parsed result of the function call.
|
54
|
+
* @extension ERC7579
|
55
|
+
* @example
|
56
|
+
* ```ts
|
57
|
+
* import { owner } from "thirdweb/extensions/erc7579";
|
58
|
+
*
|
59
|
+
* const result = await owner({
|
60
|
+
* contract,
|
61
|
+
* });
|
62
|
+
*
|
63
|
+
* ```
|
64
|
+
*/
|
65
|
+
export async function owner(options: BaseTransactionOptions) {
|
66
|
+
return readContract({
|
67
|
+
contract: options.contract,
|
68
|
+
method: [FN_SELECTOR, FN_INPUTS, FN_OUTPUTS] as const,
|
69
|
+
params: [],
|
70
|
+
});
|
71
|
+
}
|
@@ -0,0 +1,138 @@
|
|
1
|
+
import type { AbiParameterToPrimitiveType } from "abitype";
|
2
|
+
import type {
|
3
|
+
BaseTransactionOptions,
|
4
|
+
WithOverrides,
|
5
|
+
} from "../../../../../transaction/types.js";
|
6
|
+
import { prepareContractCall } from "../../../../../transaction/prepare-contract-call.js";
|
7
|
+
import { encodeAbiParameters } from "../../../../../utils/abi/encodeAbiParameters.js";
|
8
|
+
import { once } from "../../../../../utils/promise/once.js";
|
9
|
+
import { detectMethod } from "../../../../../utils/bytecode/detectExtension.js";
|
10
|
+
|
11
|
+
/**
|
12
|
+
* Represents the parameters for the "addStake" function.
|
13
|
+
*/
|
14
|
+
export type AddStakeParams = WithOverrides<{
|
15
|
+
unstakeDelaySec: AbiParameterToPrimitiveType<{
|
16
|
+
type: "uint32";
|
17
|
+
name: "unstakeDelaySec";
|
18
|
+
}>;
|
19
|
+
}>;
|
20
|
+
|
21
|
+
export const FN_SELECTOR = "0x0396cb60" as const;
|
22
|
+
const FN_INPUTS = [
|
23
|
+
{
|
24
|
+
type: "uint32",
|
25
|
+
name: "unstakeDelaySec",
|
26
|
+
},
|
27
|
+
] as const;
|
28
|
+
const FN_OUTPUTS = [] as const;
|
29
|
+
|
30
|
+
/**
|
31
|
+
* Checks if the `addStake` method is supported by the given contract.
|
32
|
+
* @param availableSelectors An array of 4byte function selectors of the contract. You can get this in various ways, such as using "whatsabi" or if you have the ABI of the contract available you can use it to generate the selectors.
|
33
|
+
* @returns A boolean indicating if the `addStake` method is supported.
|
34
|
+
* @extension ERC7579
|
35
|
+
* @example
|
36
|
+
* ```ts
|
37
|
+
* import { isAddStakeSupported } from "thirdweb/extensions/erc7579";
|
38
|
+
*
|
39
|
+
* const supported = isAddStakeSupported(["0x..."]);
|
40
|
+
* ```
|
41
|
+
*/
|
42
|
+
export function isAddStakeSupported(availableSelectors: string[]) {
|
43
|
+
return detectMethod({
|
44
|
+
availableSelectors,
|
45
|
+
method: [FN_SELECTOR, FN_INPUTS, FN_OUTPUTS] as const,
|
46
|
+
});
|
47
|
+
}
|
48
|
+
|
49
|
+
/**
|
50
|
+
* Encodes the parameters for the "addStake" function.
|
51
|
+
* @param options - The options for the addStake function.
|
52
|
+
* @returns The encoded ABI parameters.
|
53
|
+
* @extension ERC7579
|
54
|
+
* @example
|
55
|
+
* ```ts
|
56
|
+
* import { encodeAddStakeParams } from "thirdweb/extensions/erc7579";
|
57
|
+
* const result = encodeAddStakeParams({
|
58
|
+
* unstakeDelaySec: ...,
|
59
|
+
* });
|
60
|
+
* ```
|
61
|
+
*/
|
62
|
+
export function encodeAddStakeParams(options: AddStakeParams) {
|
63
|
+
return encodeAbiParameters(FN_INPUTS, [options.unstakeDelaySec]);
|
64
|
+
}
|
65
|
+
|
66
|
+
/**
|
67
|
+
* Encodes the "addStake" function into a Hex string with its parameters.
|
68
|
+
* @param options - The options for the addStake function.
|
69
|
+
* @returns The encoded hexadecimal string.
|
70
|
+
* @extension ERC7579
|
71
|
+
* @example
|
72
|
+
* ```ts
|
73
|
+
* import { encodeAddStake } from "thirdweb/extensions/erc7579";
|
74
|
+
* const result = encodeAddStake({
|
75
|
+
* unstakeDelaySec: ...,
|
76
|
+
* });
|
77
|
+
* ```
|
78
|
+
*/
|
79
|
+
export function encodeAddStake(options: AddStakeParams) {
|
80
|
+
// we do a "manual" concat here to avoid the overhead of the "concatHex" function
|
81
|
+
// we can do this because we know the specific formats of the values
|
82
|
+
return (FN_SELECTOR +
|
83
|
+
encodeAddStakeParams(options).slice(2)) as `${typeof FN_SELECTOR}${string}`;
|
84
|
+
}
|
85
|
+
|
86
|
+
/**
|
87
|
+
* Prepares a transaction to call the "addStake" function on the contract.
|
88
|
+
* @param options - The options for the "addStake" function.
|
89
|
+
* @returns A prepared transaction object.
|
90
|
+
* @extension ERC7579
|
91
|
+
* @example
|
92
|
+
* ```ts
|
93
|
+
* import { sendTransaction } from "thirdweb";
|
94
|
+
* import { addStake } from "thirdweb/extensions/erc7579";
|
95
|
+
*
|
96
|
+
* const transaction = addStake({
|
97
|
+
* contract,
|
98
|
+
* unstakeDelaySec: ...,
|
99
|
+
* overrides: {
|
100
|
+
* ...
|
101
|
+
* }
|
102
|
+
* });
|
103
|
+
*
|
104
|
+
* // Send the transaction
|
105
|
+
* await sendTransaction({ transaction, account });
|
106
|
+
* ```
|
107
|
+
*/
|
108
|
+
export function addStake(
|
109
|
+
options: BaseTransactionOptions<
|
110
|
+
| AddStakeParams
|
111
|
+
| {
|
112
|
+
asyncParams: () => Promise<AddStakeParams>;
|
113
|
+
}
|
114
|
+
>,
|
115
|
+
) {
|
116
|
+
const asyncOptions = once(async () => {
|
117
|
+
return "asyncParams" in options ? await options.asyncParams() : options;
|
118
|
+
});
|
119
|
+
|
120
|
+
return prepareContractCall({
|
121
|
+
contract: options.contract,
|
122
|
+
method: [FN_SELECTOR, FN_INPUTS, FN_OUTPUTS] as const,
|
123
|
+
params: async () => {
|
124
|
+
const resolvedOptions = await asyncOptions();
|
125
|
+
return [resolvedOptions.unstakeDelaySec] as const;
|
126
|
+
},
|
127
|
+
value: async () => (await asyncOptions()).overrides?.value,
|
128
|
+
accessList: async () => (await asyncOptions()).overrides?.accessList,
|
129
|
+
gas: async () => (await asyncOptions()).overrides?.gas,
|
130
|
+
gasPrice: async () => (await asyncOptions()).overrides?.gasPrice,
|
131
|
+
maxFeePerGas: async () => (await asyncOptions()).overrides?.maxFeePerGas,
|
132
|
+
maxPriorityFeePerGas: async () =>
|
133
|
+
(await asyncOptions()).overrides?.maxPriorityFeePerGas,
|
134
|
+
nonce: async () => (await asyncOptions()).overrides?.nonce,
|
135
|
+
extraGas: async () => (await asyncOptions()).overrides?.extraGas,
|
136
|
+
erc20Value: async () => (await asyncOptions()).overrides?.erc20Value,
|
137
|
+
});
|
138
|
+
}
|
package/src/extensions/erc7579/__generated__/ModularAccountFactory/write/createAccountWithModules.ts
ADDED
@@ -0,0 +1,193 @@
|
|
1
|
+
import type { AbiParameterToPrimitiveType } from "abitype";
|
2
|
+
import type {
|
3
|
+
BaseTransactionOptions,
|
4
|
+
WithOverrides,
|
5
|
+
} from "../../../../../transaction/types.js";
|
6
|
+
import { prepareContractCall } from "../../../../../transaction/prepare-contract-call.js";
|
7
|
+
import { encodeAbiParameters } from "../../../../../utils/abi/encodeAbiParameters.js";
|
8
|
+
import { once } from "../../../../../utils/promise/once.js";
|
9
|
+
import { detectMethod } from "../../../../../utils/bytecode/detectExtension.js";
|
10
|
+
|
11
|
+
/**
|
12
|
+
* Represents the parameters for the "createAccountWithModules" function.
|
13
|
+
*/
|
14
|
+
export type CreateAccountWithModulesParams = WithOverrides<{
|
15
|
+
owner: AbiParameterToPrimitiveType<{ type: "address"; name: "owner" }>;
|
16
|
+
salt: AbiParameterToPrimitiveType<{ type: "bytes"; name: "salt" }>;
|
17
|
+
modules: AbiParameterToPrimitiveType<{
|
18
|
+
type: "tuple[]";
|
19
|
+
name: "modules";
|
20
|
+
components: [
|
21
|
+
{ type: "uint256"; name: "moduleTypeId" },
|
22
|
+
{ type: "address"; name: "module" },
|
23
|
+
{ type: "bytes"; name: "initData" },
|
24
|
+
];
|
25
|
+
}>;
|
26
|
+
}>;
|
27
|
+
|
28
|
+
export const FN_SELECTOR = "0x7c37d0dc" as const;
|
29
|
+
const FN_INPUTS = [
|
30
|
+
{
|
31
|
+
type: "address",
|
32
|
+
name: "owner",
|
33
|
+
},
|
34
|
+
{
|
35
|
+
type: "bytes",
|
36
|
+
name: "salt",
|
37
|
+
},
|
38
|
+
{
|
39
|
+
type: "tuple[]",
|
40
|
+
name: "modules",
|
41
|
+
components: [
|
42
|
+
{
|
43
|
+
type: "uint256",
|
44
|
+
name: "moduleTypeId",
|
45
|
+
},
|
46
|
+
{
|
47
|
+
type: "address",
|
48
|
+
name: "module",
|
49
|
+
},
|
50
|
+
{
|
51
|
+
type: "bytes",
|
52
|
+
name: "initData",
|
53
|
+
},
|
54
|
+
],
|
55
|
+
},
|
56
|
+
] as const;
|
57
|
+
const FN_OUTPUTS = [
|
58
|
+
{
|
59
|
+
type: "address",
|
60
|
+
},
|
61
|
+
] as const;
|
62
|
+
|
63
|
+
/**
|
64
|
+
* Checks if the `createAccountWithModules` method is supported by the given contract.
|
65
|
+
* @param availableSelectors An array of 4byte function selectors of the contract. You can get this in various ways, such as using "whatsabi" or if you have the ABI of the contract available you can use it to generate the selectors.
|
66
|
+
* @returns A boolean indicating if the `createAccountWithModules` method is supported.
|
67
|
+
* @extension ERC7579
|
68
|
+
* @example
|
69
|
+
* ```ts
|
70
|
+
* import { isCreateAccountWithModulesSupported } from "thirdweb/extensions/erc7579";
|
71
|
+
*
|
72
|
+
* const supported = isCreateAccountWithModulesSupported(["0x..."]);
|
73
|
+
* ```
|
74
|
+
*/
|
75
|
+
export function isCreateAccountWithModulesSupported(
|
76
|
+
availableSelectors: string[],
|
77
|
+
) {
|
78
|
+
return detectMethod({
|
79
|
+
availableSelectors,
|
80
|
+
method: [FN_SELECTOR, FN_INPUTS, FN_OUTPUTS] as const,
|
81
|
+
});
|
82
|
+
}
|
83
|
+
|
84
|
+
/**
|
85
|
+
* Encodes the parameters for the "createAccountWithModules" function.
|
86
|
+
* @param options - The options for the createAccountWithModules function.
|
87
|
+
* @returns The encoded ABI parameters.
|
88
|
+
* @extension ERC7579
|
89
|
+
* @example
|
90
|
+
* ```ts
|
91
|
+
* import { encodeCreateAccountWithModulesParams } from "thirdweb/extensions/erc7579";
|
92
|
+
* const result = encodeCreateAccountWithModulesParams({
|
93
|
+
* owner: ...,
|
94
|
+
* salt: ...,
|
95
|
+
* modules: ...,
|
96
|
+
* });
|
97
|
+
* ```
|
98
|
+
*/
|
99
|
+
export function encodeCreateAccountWithModulesParams(
|
100
|
+
options: CreateAccountWithModulesParams,
|
101
|
+
) {
|
102
|
+
return encodeAbiParameters(FN_INPUTS, [
|
103
|
+
options.owner,
|
104
|
+
options.salt,
|
105
|
+
options.modules,
|
106
|
+
]);
|
107
|
+
}
|
108
|
+
|
109
|
+
/**
|
110
|
+
* Encodes the "createAccountWithModules" function into a Hex string with its parameters.
|
111
|
+
* @param options - The options for the createAccountWithModules function.
|
112
|
+
* @returns The encoded hexadecimal string.
|
113
|
+
* @extension ERC7579
|
114
|
+
* @example
|
115
|
+
* ```ts
|
116
|
+
* import { encodeCreateAccountWithModules } from "thirdweb/extensions/erc7579";
|
117
|
+
* const result = encodeCreateAccountWithModules({
|
118
|
+
* owner: ...,
|
119
|
+
* salt: ...,
|
120
|
+
* modules: ...,
|
121
|
+
* });
|
122
|
+
* ```
|
123
|
+
*/
|
124
|
+
export function encodeCreateAccountWithModules(
|
125
|
+
options: CreateAccountWithModulesParams,
|
126
|
+
) {
|
127
|
+
// we do a "manual" concat here to avoid the overhead of the "concatHex" function
|
128
|
+
// we can do this because we know the specific formats of the values
|
129
|
+
return (FN_SELECTOR +
|
130
|
+
encodeCreateAccountWithModulesParams(options).slice(
|
131
|
+
2,
|
132
|
+
)) as `${typeof FN_SELECTOR}${string}`;
|
133
|
+
}
|
134
|
+
|
135
|
+
/**
|
136
|
+
* Prepares a transaction to call the "createAccountWithModules" function on the contract.
|
137
|
+
* @param options - The options for the "createAccountWithModules" function.
|
138
|
+
* @returns A prepared transaction object.
|
139
|
+
* @extension ERC7579
|
140
|
+
* @example
|
141
|
+
* ```ts
|
142
|
+
* import { sendTransaction } from "thirdweb";
|
143
|
+
* import { createAccountWithModules } from "thirdweb/extensions/erc7579";
|
144
|
+
*
|
145
|
+
* const transaction = createAccountWithModules({
|
146
|
+
* contract,
|
147
|
+
* owner: ...,
|
148
|
+
* salt: ...,
|
149
|
+
* modules: ...,
|
150
|
+
* overrides: {
|
151
|
+
* ...
|
152
|
+
* }
|
153
|
+
* });
|
154
|
+
*
|
155
|
+
* // Send the transaction
|
156
|
+
* await sendTransaction({ transaction, account });
|
157
|
+
* ```
|
158
|
+
*/
|
159
|
+
export function createAccountWithModules(
|
160
|
+
options: BaseTransactionOptions<
|
161
|
+
| CreateAccountWithModulesParams
|
162
|
+
| {
|
163
|
+
asyncParams: () => Promise<CreateAccountWithModulesParams>;
|
164
|
+
}
|
165
|
+
>,
|
166
|
+
) {
|
167
|
+
const asyncOptions = once(async () => {
|
168
|
+
return "asyncParams" in options ? await options.asyncParams() : options;
|
169
|
+
});
|
170
|
+
|
171
|
+
return prepareContractCall({
|
172
|
+
contract: options.contract,
|
173
|
+
method: [FN_SELECTOR, FN_INPUTS, FN_OUTPUTS] as const,
|
174
|
+
params: async () => {
|
175
|
+
const resolvedOptions = await asyncOptions();
|
176
|
+
return [
|
177
|
+
resolvedOptions.owner,
|
178
|
+
resolvedOptions.salt,
|
179
|
+
resolvedOptions.modules,
|
180
|
+
] as const;
|
181
|
+
},
|
182
|
+
value: async () => (await asyncOptions()).overrides?.value,
|
183
|
+
accessList: async () => (await asyncOptions()).overrides?.accessList,
|
184
|
+
gas: async () => (await asyncOptions()).overrides?.gas,
|
185
|
+
gasPrice: async () => (await asyncOptions()).overrides?.gasPrice,
|
186
|
+
maxFeePerGas: async () => (await asyncOptions()).overrides?.maxFeePerGas,
|
187
|
+
maxPriorityFeePerGas: async () =>
|
188
|
+
(await asyncOptions()).overrides?.maxPriorityFeePerGas,
|
189
|
+
nonce: async () => (await asyncOptions()).overrides?.nonce,
|
190
|
+
extraGas: async () => (await asyncOptions()).overrides?.extraGas,
|
191
|
+
erc20Value: async () => (await asyncOptions()).overrides?.erc20Value,
|
192
|
+
});
|
193
|
+
}
|
@@ -0,0 +1,50 @@
|
|
1
|
+
import type { BaseTransactionOptions } from "../../../../../transaction/types.js";
|
2
|
+
import { prepareContractCall } from "../../../../../transaction/prepare-contract-call.js";
|
3
|
+
|
4
|
+
import { detectMethod } from "../../../../../utils/bytecode/detectExtension.js";
|
5
|
+
|
6
|
+
export const FN_SELECTOR = "0x715018a6" as const;
|
7
|
+
const FN_INPUTS = [] as const;
|
8
|
+
const FN_OUTPUTS = [] as const;
|
9
|
+
|
10
|
+
/**
|
11
|
+
* Checks if the `renounceOwnership` method is supported by the given contract.
|
12
|
+
* @param availableSelectors An array of 4byte function selectors of the contract. You can get this in various ways, such as using "whatsabi" or if you have the ABI of the contract available you can use it to generate the selectors.
|
13
|
+
* @returns A boolean indicating if the `renounceOwnership` method is supported.
|
14
|
+
* @extension ERC7579
|
15
|
+
* @example
|
16
|
+
* ```ts
|
17
|
+
* import { isRenounceOwnershipSupported } from "thirdweb/extensions/erc7579";
|
18
|
+
*
|
19
|
+
* const supported = isRenounceOwnershipSupported(["0x..."]);
|
20
|
+
* ```
|
21
|
+
*/
|
22
|
+
export function isRenounceOwnershipSupported(availableSelectors: string[]) {
|
23
|
+
return detectMethod({
|
24
|
+
availableSelectors,
|
25
|
+
method: [FN_SELECTOR, FN_INPUTS, FN_OUTPUTS] as const,
|
26
|
+
});
|
27
|
+
}
|
28
|
+
|
29
|
+
/**
|
30
|
+
* Prepares a transaction to call the "renounceOwnership" function on the contract.
|
31
|
+
* @param options - The options for the "renounceOwnership" function.
|
32
|
+
* @returns A prepared transaction object.
|
33
|
+
* @extension ERC7579
|
34
|
+
* @example
|
35
|
+
* ```ts
|
36
|
+
* import { sendTransaction } from "thirdweb";
|
37
|
+
* import { renounceOwnership } from "thirdweb/extensions/erc7579";
|
38
|
+
*
|
39
|
+
* const transaction = renounceOwnership();
|
40
|
+
*
|
41
|
+
* // Send the transaction
|
42
|
+
* await sendTransaction({ transaction, account });
|
43
|
+
* ```
|
44
|
+
*/
|
45
|
+
export function renounceOwnership(options: BaseTransactionOptions) {
|
46
|
+
return prepareContractCall({
|
47
|
+
contract: options.contract,
|
48
|
+
method: [FN_SELECTOR, FN_INPUTS, FN_OUTPUTS] as const,
|
49
|
+
});
|
50
|
+
}
|
@@ -0,0 +1,139 @@
|
|
1
|
+
import type { AbiParameterToPrimitiveType } from "abitype";
|
2
|
+
import type {
|
3
|
+
BaseTransactionOptions,
|
4
|
+
WithOverrides,
|
5
|
+
} from "../../../../../transaction/types.js";
|
6
|
+
import { prepareContractCall } from "../../../../../transaction/prepare-contract-call.js";
|
7
|
+
import { encodeAbiParameters } from "../../../../../utils/abi/encodeAbiParameters.js";
|
8
|
+
import { once } from "../../../../../utils/promise/once.js";
|
9
|
+
import { detectMethod } from "../../../../../utils/bytecode/detectExtension.js";
|
10
|
+
|
11
|
+
/**
|
12
|
+
* Represents the parameters for the "transferOwnership" function.
|
13
|
+
*/
|
14
|
+
export type TransferOwnershipParams = WithOverrides<{
|
15
|
+
newOwner: AbiParameterToPrimitiveType<{ type: "address"; name: "newOwner" }>;
|
16
|
+
}>;
|
17
|
+
|
18
|
+
export const FN_SELECTOR = "0xf2fde38b" as const;
|
19
|
+
const FN_INPUTS = [
|
20
|
+
{
|
21
|
+
type: "address",
|
22
|
+
name: "newOwner",
|
23
|
+
},
|
24
|
+
] as const;
|
25
|
+
const FN_OUTPUTS = [] as const;
|
26
|
+
|
27
|
+
/**
|
28
|
+
* Checks if the `transferOwnership` method is supported by the given contract.
|
29
|
+
* @param availableSelectors An array of 4byte function selectors of the contract. You can get this in various ways, such as using "whatsabi" or if you have the ABI of the contract available you can use it to generate the selectors.
|
30
|
+
* @returns A boolean indicating if the `transferOwnership` method is supported.
|
31
|
+
* @extension ERC7579
|
32
|
+
* @example
|
33
|
+
* ```ts
|
34
|
+
* import { isTransferOwnershipSupported } from "thirdweb/extensions/erc7579";
|
35
|
+
*
|
36
|
+
* const supported = isTransferOwnershipSupported(["0x..."]);
|
37
|
+
* ```
|
38
|
+
*/
|
39
|
+
export function isTransferOwnershipSupported(availableSelectors: string[]) {
|
40
|
+
return detectMethod({
|
41
|
+
availableSelectors,
|
42
|
+
method: [FN_SELECTOR, FN_INPUTS, FN_OUTPUTS] as const,
|
43
|
+
});
|
44
|
+
}
|
45
|
+
|
46
|
+
/**
|
47
|
+
* Encodes the parameters for the "transferOwnership" function.
|
48
|
+
* @param options - The options for the transferOwnership function.
|
49
|
+
* @returns The encoded ABI parameters.
|
50
|
+
* @extension ERC7579
|
51
|
+
* @example
|
52
|
+
* ```ts
|
53
|
+
* import { encodeTransferOwnershipParams } from "thirdweb/extensions/erc7579";
|
54
|
+
* const result = encodeTransferOwnershipParams({
|
55
|
+
* newOwner: ...,
|
56
|
+
* });
|
57
|
+
* ```
|
58
|
+
*/
|
59
|
+
export function encodeTransferOwnershipParams(
|
60
|
+
options: TransferOwnershipParams,
|
61
|
+
) {
|
62
|
+
return encodeAbiParameters(FN_INPUTS, [options.newOwner]);
|
63
|
+
}
|
64
|
+
|
65
|
+
/**
|
66
|
+
* Encodes the "transferOwnership" function into a Hex string with its parameters.
|
67
|
+
* @param options - The options for the transferOwnership function.
|
68
|
+
* @returns The encoded hexadecimal string.
|
69
|
+
* @extension ERC7579
|
70
|
+
* @example
|
71
|
+
* ```ts
|
72
|
+
* import { encodeTransferOwnership } from "thirdweb/extensions/erc7579";
|
73
|
+
* const result = encodeTransferOwnership({
|
74
|
+
* newOwner: ...,
|
75
|
+
* });
|
76
|
+
* ```
|
77
|
+
*/
|
78
|
+
export function encodeTransferOwnership(options: TransferOwnershipParams) {
|
79
|
+
// we do a "manual" concat here to avoid the overhead of the "concatHex" function
|
80
|
+
// we can do this because we know the specific formats of the values
|
81
|
+
return (FN_SELECTOR +
|
82
|
+
encodeTransferOwnershipParams(options).slice(
|
83
|
+
2,
|
84
|
+
)) as `${typeof FN_SELECTOR}${string}`;
|
85
|
+
}
|
86
|
+
|
87
|
+
/**
|
88
|
+
* Prepares a transaction to call the "transferOwnership" function on the contract.
|
89
|
+
* @param options - The options for the "transferOwnership" function.
|
90
|
+
* @returns A prepared transaction object.
|
91
|
+
* @extension ERC7579
|
92
|
+
* @example
|
93
|
+
* ```ts
|
94
|
+
* import { sendTransaction } from "thirdweb";
|
95
|
+
* import { transferOwnership } from "thirdweb/extensions/erc7579";
|
96
|
+
*
|
97
|
+
* const transaction = transferOwnership({
|
98
|
+
* contract,
|
99
|
+
* newOwner: ...,
|
100
|
+
* overrides: {
|
101
|
+
* ...
|
102
|
+
* }
|
103
|
+
* });
|
104
|
+
*
|
105
|
+
* // Send the transaction
|
106
|
+
* await sendTransaction({ transaction, account });
|
107
|
+
* ```
|
108
|
+
*/
|
109
|
+
export function transferOwnership(
|
110
|
+
options: BaseTransactionOptions<
|
111
|
+
| TransferOwnershipParams
|
112
|
+
| {
|
113
|
+
asyncParams: () => Promise<TransferOwnershipParams>;
|
114
|
+
}
|
115
|
+
>,
|
116
|
+
) {
|
117
|
+
const asyncOptions = once(async () => {
|
118
|
+
return "asyncParams" in options ? await options.asyncParams() : options;
|
119
|
+
});
|
120
|
+
|
121
|
+
return prepareContractCall({
|
122
|
+
contract: options.contract,
|
123
|
+
method: [FN_SELECTOR, FN_INPUTS, FN_OUTPUTS] as const,
|
124
|
+
params: async () => {
|
125
|
+
const resolvedOptions = await asyncOptions();
|
126
|
+
return [resolvedOptions.newOwner] as const;
|
127
|
+
},
|
128
|
+
value: async () => (await asyncOptions()).overrides?.value,
|
129
|
+
accessList: async () => (await asyncOptions()).overrides?.accessList,
|
130
|
+
gas: async () => (await asyncOptions()).overrides?.gas,
|
131
|
+
gasPrice: async () => (await asyncOptions()).overrides?.gasPrice,
|
132
|
+
maxFeePerGas: async () => (await asyncOptions()).overrides?.maxFeePerGas,
|
133
|
+
maxPriorityFeePerGas: async () =>
|
134
|
+
(await asyncOptions()).overrides?.maxPriorityFeePerGas,
|
135
|
+
nonce: async () => (await asyncOptions()).overrides?.nonce,
|
136
|
+
extraGas: async () => (await asyncOptions()).overrides?.extraGas,
|
137
|
+
erc20Value: async () => (await asyncOptions()).overrides?.erc20Value,
|
138
|
+
});
|
139
|
+
}
|