thirdweb 5.59.0-nightly-e2b3484764275560aa899f3f894b767faedaa9a1-20240925000331 → 5.59.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/contract/actions/compiler-metadata.js +16 -10
- package/dist/cjs/contract/actions/compiler-metadata.js.map +1 -1
- package/dist/cjs/contract/deployment/publisher.js +2 -0
- package/dist/cjs/contract/deployment/publisher.js.map +1 -1
- package/dist/cjs/contract/deployment/utils/bootstrap.js +3 -2
- package/dist/cjs/contract/deployment/utils/bootstrap.js.map +1 -1
- package/dist/cjs/exports/utils.js +4 -2
- package/dist/cjs/exports/utils.js.map +1 -1
- package/dist/cjs/exports/wallets.native.js +3 -1
- package/dist/cjs/exports/wallets.native.js.map +1 -1
- package/dist/cjs/extensions/erc20/write/transfer.js +1 -0
- package/dist/cjs/extensions/erc20/write/transfer.js.map +1 -1
- package/dist/cjs/extensions/erc20/write/transferFrom.js +1 -0
- package/dist/cjs/extensions/erc20/write/transferFrom.js.map +1 -1
- package/dist/cjs/extensions/prebuilts/deploy-published.js +6 -3
- package/dist/cjs/extensions/prebuilts/deploy-published.js.map +1 -1
- package/dist/cjs/extensions/vote/types.js +2 -0
- package/dist/cjs/extensions/vote/types.js.map +1 -1
- package/dist/cjs/react/core/hooks/wallets/useAutoConnect.js +2 -3
- package/dist/cjs/react/core/hooks/wallets/useAutoConnect.js.map +1 -1
- package/dist/cjs/react/native/hooks/wallets/useAutoConnect.js +2 -1
- package/dist/cjs/react/native/hooks/wallets/useAutoConnect.js.map +1 -1
- package/dist/cjs/react/web/hooks/wallets/useAutoConnect.js +1 -1
- package/dist/cjs/react/web/hooks/wallets/useAutoConnect.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/Details.js +4 -1
- package/dist/cjs/react/web/ui/ConnectWallet/Details.js.map +1 -1
- package/dist/cjs/storage/upload.js +19 -0
- package/dist/cjs/storage/upload.js.map +1 -1
- package/dist/cjs/transaction/actions/zksync/send-eip712-transaction.js +10 -2
- package/dist/cjs/transaction/actions/zksync/send-eip712-transaction.js.map +1 -1
- package/dist/cjs/transaction/extract-error.js +2 -2
- package/dist/cjs/transaction/extract-error.js.map +1 -1
- package/dist/cjs/utils/any-evm/deploy-metadata.js +14 -5
- package/dist/cjs/utils/any-evm/deploy-metadata.js.map +1 -1
- package/dist/cjs/utils/fetch.js +2 -2
- package/dist/cjs/utils/fetch.js.map +1 -1
- package/dist/cjs/utils/process.js +7 -0
- package/dist/cjs/utils/process.js.map +1 -0
- package/dist/cjs/version.js +1 -1
- package/dist/cjs/version.js.map +1 -1
- package/dist/cjs/wallets/create-wallet.js +5 -2
- package/dist/cjs/wallets/create-wallet.js.map +1 -1
- package/dist/cjs/wallets/in-app/core/authentication/authEndpoint.js +30 -0
- package/dist/cjs/wallets/in-app/core/authentication/authEndpoint.js.map +1 -0
- package/dist/cjs/wallets/in-app/core/authentication/jwt.js +30 -0
- package/dist/cjs/wallets/in-app/core/authentication/jwt.js.map +1 -0
- package/dist/cjs/wallets/in-app/core/authentication/passkeys.js +3 -14
- package/dist/cjs/wallets/in-app/core/authentication/passkeys.js.map +1 -1
- package/dist/cjs/wallets/in-app/core/authentication/types.js +0 -35
- package/dist/cjs/wallets/in-app/core/authentication/types.js.map +1 -1
- package/dist/cjs/wallets/in-app/{web/lib → core/wallet}/enclave-wallet.js +15 -13
- package/dist/cjs/wallets/in-app/core/wallet/enclave-wallet.js.map +1 -0
- package/dist/cjs/wallets/in-app/core/wallet/in-app-core.js +9 -8
- package/dist/cjs/wallets/in-app/core/wallet/in-app-core.js.map +1 -1
- package/dist/cjs/wallets/in-app/core/wallet/index.js +1 -2
- package/dist/cjs/wallets/in-app/core/wallet/index.js.map +1 -1
- package/dist/cjs/wallets/in-app/core/wallet/web-wallet.js.map +1 -0
- package/dist/cjs/wallets/in-app/native/auth/index.js +1 -2
- package/dist/cjs/wallets/in-app/native/auth/index.js.map +1 -1
- package/dist/cjs/wallets/in-app/native/auth/native-auth.js +8 -178
- package/dist/cjs/wallets/in-app/native/auth/native-auth.js.map +1 -1
- package/dist/cjs/wallets/in-app/native/ecosystem.js +84 -0
- package/dist/cjs/wallets/in-app/native/ecosystem.js.map +1 -0
- package/dist/cjs/wallets/in-app/native/helpers/api/fetchers.js +50 -24
- package/dist/cjs/wallets/in-app/native/helpers/api/fetchers.js.map +1 -1
- package/dist/cjs/wallets/in-app/native/helpers/auth/logout.js +3 -3
- package/dist/cjs/wallets/in-app/native/helpers/auth/logout.js.map +1 -1
- package/dist/cjs/wallets/in-app/native/helpers/auth/middleware.js +28 -54
- package/dist/cjs/wallets/in-app/native/helpers/auth/middleware.js.map +1 -1
- package/dist/cjs/wallets/in-app/native/helpers/storage/local.js +20 -18
- package/dist/cjs/wallets/in-app/native/helpers/storage/local.js.map +1 -1
- package/dist/cjs/wallets/in-app/native/helpers/wallet/creation.js +8 -4
- package/dist/cjs/wallets/in-app/native/helpers/wallet/creation.js.map +1 -1
- package/dist/cjs/wallets/in-app/native/helpers/wallet/recoveryCode.js +16 -6
- package/dist/cjs/wallets/in-app/native/helpers/wallet/recoveryCode.js.map +1 -1
- package/dist/cjs/wallets/in-app/native/helpers/wallet/retrieval.js +7 -4
- package/dist/cjs/wallets/in-app/native/helpers/wallet/retrieval.js.map +1 -1
- package/dist/cjs/wallets/in-app/native/helpers/wallet/sharded-wallet.js +72 -0
- package/dist/cjs/wallets/in-app/native/helpers/wallet/sharded-wallet.js.map +1 -0
- package/dist/cjs/wallets/in-app/native/in-app.js.map +1 -1
- package/dist/cjs/wallets/in-app/native/native-connector.js +105 -243
- package/dist/cjs/wallets/in-app/native/native-connector.js.map +1 -1
- package/dist/cjs/wallets/in-app/web/ecosystem.js +13 -7
- package/dist/cjs/wallets/in-app/web/ecosystem.js.map +1 -1
- package/dist/cjs/wallets/in-app/web/in-app.js.map +1 -1
- package/dist/cjs/wallets/in-app/web/lib/actions/get-enclave-user-status.js +2 -0
- package/dist/cjs/wallets/in-app/web/lib/actions/get-enclave-user-status.js.map +1 -1
- package/dist/cjs/wallets/in-app/web/lib/actions/sign-message.enclave.js +2 -3
- package/dist/cjs/wallets/in-app/web/lib/actions/sign-message.enclave.js.map +1 -1
- package/dist/cjs/wallets/in-app/web/lib/actions/sign-transaction.enclave.js +2 -3
- package/dist/cjs/wallets/in-app/web/lib/actions/sign-transaction.enclave.js.map +1 -1
- package/dist/cjs/wallets/in-app/web/lib/actions/sign-typed-data.enclave.js +2 -3
- package/dist/cjs/wallets/in-app/web/lib/actions/sign-typed-data.enclave.js.map +1 -1
- package/dist/cjs/wallets/in-app/web/lib/auth/iframe-auth.js +6 -0
- package/dist/cjs/wallets/in-app/web/lib/auth/iframe-auth.js.map +1 -1
- package/dist/cjs/wallets/in-app/web/lib/auth/index.js +1 -2
- package/dist/cjs/wallets/in-app/web/lib/auth/index.js.map +1 -1
- package/dist/cjs/wallets/in-app/web/lib/iframe-wallet.js +9 -14
- package/dist/cjs/wallets/in-app/web/lib/iframe-wallet.js.map +1 -1
- package/dist/cjs/wallets/in-app/web/lib/web-connector.js +13 -13
- package/dist/cjs/wallets/in-app/web/lib/web-connector.js.map +1 -1
- package/dist/cjs/wallets/native/create-wallet.js +2 -1
- package/dist/cjs/wallets/native/create-wallet.js.map +1 -1
- package/dist/esm/contract/actions/compiler-metadata.js +16 -10
- package/dist/esm/contract/actions/compiler-metadata.js.map +1 -1
- package/dist/esm/contract/deployment/publisher.js +2 -0
- package/dist/esm/contract/deployment/publisher.js.map +1 -1
- package/dist/esm/contract/deployment/utils/bootstrap.js +3 -2
- package/dist/esm/contract/deployment/utils/bootstrap.js.map +1 -1
- package/dist/esm/exports/utils.js +1 -0
- package/dist/esm/exports/utils.js.map +1 -1
- package/dist/esm/exports/wallets.native.js +1 -0
- package/dist/esm/exports/wallets.native.js.map +1 -1
- package/dist/esm/extensions/erc20/write/transfer.js +1 -0
- package/dist/esm/extensions/erc20/write/transfer.js.map +1 -1
- package/dist/esm/extensions/erc20/write/transferFrom.js +1 -0
- package/dist/esm/extensions/erc20/write/transferFrom.js.map +1 -1
- package/dist/esm/extensions/prebuilts/deploy-published.js +6 -3
- package/dist/esm/extensions/prebuilts/deploy-published.js.map +1 -1
- package/dist/esm/extensions/vote/types.js +2 -0
- package/dist/esm/extensions/vote/types.js.map +1 -1
- package/dist/esm/react/core/hooks/wallets/useAutoConnect.js +2 -3
- package/dist/esm/react/core/hooks/wallets/useAutoConnect.js.map +1 -1
- package/dist/esm/react/native/hooks/wallets/useAutoConnect.js +2 -1
- package/dist/esm/react/native/hooks/wallets/useAutoConnect.js.map +1 -1
- package/dist/esm/react/web/hooks/wallets/useAutoConnect.js +1 -1
- package/dist/esm/react/web/hooks/wallets/useAutoConnect.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/Details.js +4 -1
- package/dist/esm/react/web/ui/ConnectWallet/Details.js.map +1 -1
- package/dist/esm/storage/upload.js +19 -0
- package/dist/esm/storage/upload.js.map +1 -1
- package/dist/esm/transaction/actions/zksync/send-eip712-transaction.js +11 -3
- package/dist/esm/transaction/actions/zksync/send-eip712-transaction.js.map +1 -1
- package/dist/esm/transaction/extract-error.js +2 -2
- package/dist/esm/transaction/extract-error.js.map +1 -1
- package/dist/esm/utils/any-evm/deploy-metadata.js +14 -5
- package/dist/esm/utils/any-evm/deploy-metadata.js.map +1 -1
- package/dist/esm/utils/fetch.js +2 -2
- package/dist/esm/utils/fetch.js.map +1 -1
- package/dist/esm/utils/process.js +4 -0
- package/dist/esm/utils/process.js.map +1 -0
- package/dist/esm/version.js +1 -1
- package/dist/esm/version.js.map +1 -1
- package/dist/esm/wallets/create-wallet.js +5 -2
- package/dist/esm/wallets/create-wallet.js.map +1 -1
- package/dist/esm/wallets/in-app/core/authentication/authEndpoint.js +27 -0
- package/dist/esm/wallets/in-app/core/authentication/authEndpoint.js.map +1 -0
- package/dist/esm/wallets/in-app/core/authentication/jwt.js +27 -0
- package/dist/esm/wallets/in-app/core/authentication/jwt.js.map +1 -0
- package/dist/esm/wallets/in-app/core/authentication/passkeys.js +3 -14
- package/dist/esm/wallets/in-app/core/authentication/passkeys.js.map +1 -1
- package/dist/esm/wallets/in-app/core/authentication/types.js +1 -34
- package/dist/esm/wallets/in-app/core/authentication/types.js.map +1 -1
- package/dist/esm/wallets/in-app/{web/lib → core/wallet}/enclave-wallet.js +15 -13
- package/dist/esm/wallets/in-app/core/wallet/enclave-wallet.js.map +1 -0
- package/dist/esm/wallets/in-app/core/wallet/in-app-core.js +9 -8
- package/dist/esm/wallets/in-app/core/wallet/in-app-core.js.map +1 -1
- package/dist/esm/wallets/in-app/core/wallet/index.js +1 -2
- package/dist/esm/wallets/in-app/core/wallet/index.js.map +1 -1
- package/dist/esm/wallets/in-app/core/wallet/web-wallet.js.map +1 -0
- package/dist/esm/wallets/in-app/native/auth/index.js +1 -2
- package/dist/esm/wallets/in-app/native/auth/index.js.map +1 -1
- package/dist/esm/wallets/in-app/native/auth/native-auth.js +8 -172
- package/dist/esm/wallets/in-app/native/auth/native-auth.js.map +1 -1
- package/dist/esm/wallets/in-app/native/ecosystem.js +81 -0
- package/dist/esm/wallets/in-app/native/ecosystem.js.map +1 -0
- package/dist/esm/wallets/in-app/native/helpers/api/fetchers.js +48 -22
- package/dist/esm/wallets/in-app/native/helpers/api/fetchers.js.map +1 -1
- package/dist/esm/wallets/in-app/native/helpers/auth/logout.js +4 -4
- package/dist/esm/wallets/in-app/native/helpers/auth/logout.js.map +1 -1
- package/dist/esm/wallets/in-app/native/helpers/auth/middleware.js +29 -54
- package/dist/esm/wallets/in-app/native/helpers/auth/middleware.js.map +1 -1
- package/dist/esm/wallets/in-app/native/helpers/storage/local.js +21 -16
- package/dist/esm/wallets/in-app/native/helpers/storage/local.js.map +1 -1
- package/dist/esm/wallets/in-app/native/helpers/wallet/creation.js +8 -4
- package/dist/esm/wallets/in-app/native/helpers/wallet/creation.js.map +1 -1
- package/dist/esm/wallets/in-app/native/helpers/wallet/recoveryCode.js +16 -6
- package/dist/esm/wallets/in-app/native/helpers/wallet/recoveryCode.js.map +1 -1
- package/dist/esm/wallets/in-app/native/helpers/wallet/retrieval.js +7 -4
- package/dist/esm/wallets/in-app/native/helpers/wallet/retrieval.js.map +1 -1
- package/dist/esm/wallets/in-app/native/helpers/wallet/sharded-wallet.js +68 -0
- package/dist/esm/wallets/in-app/native/helpers/wallet/sharded-wallet.js.map +1 -0
- package/dist/esm/wallets/in-app/native/in-app.js.map +1 -1
- package/dist/esm/wallets/in-app/native/native-connector.js +106 -244
- package/dist/esm/wallets/in-app/native/native-connector.js.map +1 -1
- package/dist/esm/wallets/in-app/web/ecosystem.js +13 -7
- package/dist/esm/wallets/in-app/web/ecosystem.js.map +1 -1
- package/dist/esm/wallets/in-app/web/in-app.js.map +1 -1
- package/dist/esm/wallets/in-app/web/lib/actions/get-enclave-user-status.js +2 -0
- package/dist/esm/wallets/in-app/web/lib/actions/get-enclave-user-status.js.map +1 -1
- package/dist/esm/wallets/in-app/web/lib/actions/sign-message.enclave.js +2 -3
- package/dist/esm/wallets/in-app/web/lib/actions/sign-message.enclave.js.map +1 -1
- package/dist/esm/wallets/in-app/web/lib/actions/sign-transaction.enclave.js +2 -3
- package/dist/esm/wallets/in-app/web/lib/actions/sign-transaction.enclave.js.map +1 -1
- package/dist/esm/wallets/in-app/web/lib/actions/sign-typed-data.enclave.js +2 -3
- package/dist/esm/wallets/in-app/web/lib/actions/sign-typed-data.enclave.js.map +1 -1
- package/dist/esm/wallets/in-app/web/lib/auth/iframe-auth.js +6 -0
- package/dist/esm/wallets/in-app/web/lib/auth/iframe-auth.js.map +1 -1
- package/dist/esm/wallets/in-app/web/lib/auth/index.js +1 -2
- package/dist/esm/wallets/in-app/web/lib/auth/index.js.map +1 -1
- package/dist/esm/wallets/in-app/web/lib/iframe-wallet.js +9 -14
- package/dist/esm/wallets/in-app/web/lib/iframe-wallet.js.map +1 -1
- package/dist/esm/wallets/in-app/web/lib/web-connector.js +13 -13
- package/dist/esm/wallets/in-app/web/lib/web-connector.js.map +1 -1
- package/dist/esm/wallets/native/create-wallet.js +2 -1
- package/dist/esm/wallets/native/create-wallet.js.map +1 -1
- package/dist/types/contract/actions/compiler-metadata.d.ts +2 -1
- package/dist/types/contract/actions/compiler-metadata.d.ts.map +1 -1
- package/dist/types/contract/deployment/publisher.d.ts +2 -0
- package/dist/types/contract/deployment/publisher.d.ts.map +1 -1
- package/dist/types/contract/deployment/utils/bootstrap.d.ts +1 -0
- package/dist/types/contract/deployment/utils/bootstrap.d.ts.map +1 -1
- package/dist/types/exports/utils.d.ts +1 -0
- package/dist/types/exports/utils.d.ts.map +1 -1
- package/dist/types/exports/wallets.native.d.ts +2 -0
- package/dist/types/exports/wallets.native.d.ts.map +1 -1
- package/dist/types/extensions/erc20/write/transfer.d.ts +3 -3
- package/dist/types/extensions/erc20/write/transfer.d.ts.map +1 -1
- package/dist/types/extensions/erc20/write/transferFrom.d.ts +3 -3
- package/dist/types/extensions/erc20/write/transferFrom.d.ts.map +1 -1
- package/dist/types/extensions/prebuilts/deploy-published.d.ts +2 -0
- package/dist/types/extensions/prebuilts/deploy-published.d.ts.map +1 -1
- package/dist/types/extensions/vote/types.d.ts.map +1 -1
- package/dist/types/react/core/hooks/wallets/useAutoConnect.d.ts +2 -1
- package/dist/types/react/core/hooks/wallets/useAutoConnect.d.ts.map +1 -1
- package/dist/types/react/native/hooks/wallets/useAutoConnect.d.ts.map +1 -1
- package/dist/types/react/web/hooks/wallets/useAutoConnect.d.ts.map +1 -1
- package/dist/types/react/web/ui/ConnectWallet/Details.d.ts.map +1 -1
- package/dist/types/storage/upload.d.ts +19 -0
- package/dist/types/storage/upload.d.ts.map +1 -1
- package/dist/types/transaction/actions/zksync/send-eip712-transaction.d.ts.map +1 -1
- package/dist/types/transaction/extract-error.d.ts.map +1 -1
- package/dist/types/utils/any-evm/deploy-metadata.d.ts +2 -0
- package/dist/types/utils/any-evm/deploy-metadata.d.ts.map +1 -1
- package/dist/types/utils/fetch.d.ts.map +1 -1
- package/dist/types/utils/process.d.ts +2 -0
- package/dist/types/utils/process.d.ts.map +1 -0
- package/dist/types/version.d.ts +1 -1
- package/dist/types/version.d.ts.map +1 -1
- package/dist/types/wallets/create-wallet.d.ts.map +1 -1
- package/dist/types/wallets/ecosystem/types.d.ts +10 -1
- package/dist/types/wallets/ecosystem/types.d.ts.map +1 -1
- package/dist/types/wallets/in-app/core/authentication/authEndpoint.d.ts +9 -0
- package/dist/types/wallets/in-app/core/authentication/authEndpoint.d.ts.map +1 -0
- package/dist/types/wallets/in-app/core/authentication/jwt.d.ts +9 -0
- package/dist/types/wallets/in-app/core/authentication/jwt.d.ts.map +1 -0
- package/dist/types/wallets/in-app/core/authentication/passkeys.d.ts +3 -3
- package/dist/types/wallets/in-app/core/authentication/passkeys.d.ts.map +1 -1
- package/dist/types/wallets/in-app/core/authentication/types.d.ts +16 -38
- package/dist/types/wallets/in-app/core/authentication/types.d.ts.map +1 -1
- package/dist/types/wallets/in-app/{web/lib → core/wallet}/enclave-wallet.d.ts +5 -5
- package/dist/types/wallets/in-app/core/wallet/enclave-wallet.d.ts.map +1 -0
- package/dist/types/wallets/in-app/core/wallet/in-app-core.d.ts +3 -2
- package/dist/types/wallets/in-app/core/wallet/in-app-core.d.ts.map +1 -1
- package/dist/types/wallets/in-app/core/wallet/index.d.ts.map +1 -1
- package/dist/types/wallets/in-app/core/wallet/web-wallet.d.ts +11 -0
- package/dist/types/wallets/in-app/core/wallet/web-wallet.d.ts.map +1 -0
- package/dist/types/wallets/in-app/native/auth/index.d.ts +1 -1
- package/dist/types/wallets/in-app/native/auth/index.d.ts.map +1 -1
- package/dist/types/wallets/in-app/native/auth/native-auth.d.ts +5 -16
- package/dist/types/wallets/in-app/native/auth/native-auth.d.ts.map +1 -1
- package/dist/types/wallets/in-app/native/ecosystem.d.ts +59 -0
- package/dist/types/wallets/in-app/native/ecosystem.d.ts.map +1 -0
- package/dist/types/wallets/in-app/native/helpers/api/fetchers.d.ts +20 -4
- package/dist/types/wallets/in-app/native/helpers/api/fetchers.d.ts.map +1 -1
- package/dist/types/wallets/in-app/native/helpers/auth/logout.d.ts +6 -1
- package/dist/types/wallets/in-app/native/helpers/auth/logout.d.ts.map +1 -1
- package/dist/types/wallets/in-app/native/helpers/auth/middleware.d.ts +7 -35
- package/dist/types/wallets/in-app/native/helpers/auth/middleware.d.ts.map +1 -1
- package/dist/types/wallets/in-app/native/helpers/storage/local.d.ts +0 -3
- package/dist/types/wallets/in-app/native/helpers/storage/local.d.ts.map +1 -1
- package/dist/types/wallets/in-app/native/helpers/wallet/creation.d.ts +11 -3
- package/dist/types/wallets/in-app/native/helpers/wallet/creation.d.ts.map +1 -1
- package/dist/types/wallets/in-app/native/helpers/wallet/recoveryCode.d.ts +9 -2
- package/dist/types/wallets/in-app/native/helpers/wallet/recoveryCode.d.ts.map +1 -1
- package/dist/types/wallets/in-app/native/helpers/wallet/retrieval.d.ts +4 -1
- package/dist/types/wallets/in-app/native/helpers/wallet/retrieval.d.ts.map +1 -1
- package/dist/types/wallets/in-app/native/helpers/wallet/sharded-wallet.d.ts +17 -0
- package/dist/types/wallets/in-app/native/helpers/wallet/sharded-wallet.d.ts.map +1 -0
- package/dist/types/wallets/in-app/native/native-connector.d.ts +4 -8
- package/dist/types/wallets/in-app/native/native-connector.d.ts.map +1 -1
- package/dist/types/wallets/in-app/web/ecosystem.d.ts.map +1 -1
- package/dist/types/wallets/in-app/web/lib/actions/get-enclave-user-status.d.ts +1 -1
- package/dist/types/wallets/in-app/web/lib/actions/get-enclave-user-status.d.ts.map +1 -1
- package/dist/types/wallets/in-app/web/lib/actions/sign-message.enclave.d.ts +3 -1
- package/dist/types/wallets/in-app/web/lib/actions/sign-message.enclave.d.ts.map +1 -1
- package/dist/types/wallets/in-app/web/lib/actions/sign-transaction.enclave.d.ts +3 -1
- package/dist/types/wallets/in-app/web/lib/actions/sign-transaction.enclave.d.ts.map +1 -1
- package/dist/types/wallets/in-app/web/lib/actions/sign-typed-data.enclave.d.ts +3 -1
- package/dist/types/wallets/in-app/web/lib/actions/sign-typed-data.enclave.d.ts.map +1 -1
- package/dist/types/wallets/in-app/web/lib/auth/iframe-auth.d.ts.map +1 -1
- package/dist/types/wallets/in-app/web/lib/auth/index.d.ts +1 -1
- package/dist/types/wallets/in-app/web/lib/auth/index.d.ts.map +1 -1
- package/dist/types/wallets/in-app/web/lib/iframe-wallet.d.ts +3 -3
- package/dist/types/wallets/in-app/web/lib/iframe-wallet.d.ts.map +1 -1
- package/dist/types/wallets/in-app/web/lib/web-connector.d.ts +1 -1
- package/dist/types/wallets/in-app/web/lib/web-connector.d.ts.map +1 -1
- package/dist/types/wallets/native/create-wallet.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/contract/actions/compiler-metadata.ts +20 -11
- package/src/contract/deployment/publisher.ts +4 -0
- package/src/contract/deployment/utils/bootstrap.ts +4 -1
- package/src/exports/utils.ts +1 -0
- package/src/exports/wallets.native.ts +6 -0
- package/src/extensions/erc1155/drop1155.test.ts +4 -4
- package/src/extensions/erc20/drop20.test.ts +4 -4
- package/src/extensions/erc20/write/transfer.ts +15 -9
- package/src/extensions/erc20/write/transferFrom.ts +15 -9
- package/src/extensions/erc721/drop721.test.ts +4 -4
- package/src/extensions/prebuilts/deploy-published.test.ts +1 -1
- package/src/extensions/prebuilts/deploy-published.ts +8 -1
- package/src/extensions/vote/types.ts +2 -0
- package/src/react/core/hooks/wallets/useAutoConnect.ts +3 -2
- package/src/react/native/hooks/wallets/useAutoConnect.ts +9 -4
- package/src/react/web/hooks/wallets/useAutoConnect.ts +1 -0
- package/src/react/web/ui/ConnectWallet/Details.tsx +4 -1
- package/src/storage/upload.ts +19 -0
- package/src/transaction/actions/zksync/send-eip712-transaction.ts +21 -20
- package/src/transaction/extract-error.ts +2 -3
- package/src/utils/any-evm/deploy-metadata.ts +26 -11
- package/src/utils/fetch.ts +2 -4
- package/src/utils/process.ts +3 -0
- package/src/version.ts +1 -1
- package/src/wallets/create-wallet.ts +7 -5
- package/src/wallets/ecosystem/types.ts +10 -1
- package/src/wallets/in-app/core/authentication/authEndpoint.ts +42 -0
- package/src/wallets/in-app/core/authentication/jwt.ts +37 -0
- package/src/wallets/in-app/core/authentication/passkeys.ts +7 -17
- package/src/wallets/in-app/core/authentication/types.ts +33 -39
- package/src/wallets/in-app/{web/lib → core/wallet}/enclave-wallet.ts +24 -25
- package/src/wallets/in-app/core/wallet/in-app-core.ts +16 -7
- package/src/wallets/in-app/core/wallet/index.ts +1 -2
- package/src/wallets/in-app/core/wallet/web-wallet.ts +14 -0
- package/src/wallets/in-app/native/auth/index.ts +5 -6
- package/src/wallets/in-app/native/auth/native-auth.ts +14 -242
- package/src/wallets/in-app/native/ecosystem.ts +89 -0
- package/src/wallets/in-app/native/helpers/api/fetchers.ts +54 -25
- package/src/wallets/in-app/native/helpers/auth/logout.ts +9 -8
- package/src/wallets/in-app/native/helpers/auth/middleware.ts +39 -82
- package/src/wallets/in-app/native/helpers/storage/local.ts +22 -23
- package/src/wallets/in-app/native/helpers/wallet/creation.ts +15 -5
- package/src/wallets/in-app/native/helpers/wallet/recoveryCode.ts +21 -12
- package/src/wallets/in-app/native/helpers/wallet/retrieval.ts +14 -3
- package/src/wallets/in-app/native/helpers/wallet/sharded-wallet.ts +72 -0
- package/src/wallets/in-app/native/in-app.ts +1 -1
- package/src/wallets/in-app/native/native-connector.ts +120 -297
- package/src/wallets/in-app/web/ecosystem.ts +14 -8
- package/src/wallets/in-app/web/in-app.ts +1 -1
- package/src/wallets/in-app/web/lib/actions/get-enclave-user-status.ts +3 -1
- package/src/wallets/in-app/web/lib/actions/sign-message.enclave.ts +4 -2
- package/src/wallets/in-app/web/lib/actions/sign-transaction.enclave.ts +4 -2
- package/src/wallets/in-app/web/lib/actions/sign-typed-data.enclave.ts +4 -2
- package/src/wallets/in-app/web/lib/auth/iframe-auth.ts +7 -0
- package/src/wallets/in-app/web/lib/auth/index.ts +6 -7
- package/src/wallets/in-app/web/lib/iframe-wallet.ts +17 -24
- package/src/wallets/in-app/web/lib/web-connector.ts +26 -23
- package/src/wallets/native/create-wallet.ts +5 -3
- package/dist/cjs/wallets/in-app/core/wallet/ecosystem-core.js +0 -85
- package/dist/cjs/wallets/in-app/core/wallet/ecosystem-core.js.map +0 -1
- package/dist/cjs/wallets/in-app/web/lib/enclave-wallet.js.map +0 -1
- package/dist/cjs/wallets/in-app/web/lib/get-auth-token.js +0 -15
- package/dist/cjs/wallets/in-app/web/lib/get-auth-token.js.map +0 -1
- package/dist/cjs/wallets/in-app/web/lib/web-wallet.js.map +0 -1
- package/dist/esm/wallets/in-app/core/wallet/ecosystem-core.js +0 -82
- package/dist/esm/wallets/in-app/core/wallet/ecosystem-core.js.map +0 -1
- package/dist/esm/wallets/in-app/web/lib/enclave-wallet.js.map +0 -1
- package/dist/esm/wallets/in-app/web/lib/get-auth-token.js +0 -12
- package/dist/esm/wallets/in-app/web/lib/get-auth-token.js.map +0 -1
- package/dist/esm/wallets/in-app/web/lib/web-wallet.js.map +0 -1
- package/dist/types/wallets/in-app/core/wallet/ecosystem-core.d.ts +0 -13
- package/dist/types/wallets/in-app/core/wallet/ecosystem-core.d.ts.map +0 -1
- package/dist/types/wallets/in-app/web/lib/enclave-wallet.d.ts.map +0 -1
- package/dist/types/wallets/in-app/web/lib/get-auth-token.d.ts +0 -4
- package/dist/types/wallets/in-app/web/lib/get-auth-token.d.ts.map +0 -1
- package/dist/types/wallets/in-app/web/lib/web-wallet.d.ts +0 -15
- package/dist/types/wallets/in-app/web/lib/web-wallet.d.ts.map +0 -1
- package/src/wallets/in-app/core/wallet/ecosystem-core.ts +0 -121
- package/src/wallets/in-app/web/lib/get-auth-token.ts +0 -18
- package/src/wallets/in-app/web/lib/web-wallet.ts +0 -23
- /package/dist/cjs/wallets/in-app/{web/lib → core/wallet}/web-wallet.js +0 -0
- /package/dist/esm/wallets/in-app/{web/lib → core/wallet}/web-wallet.js +0 -0
@@ -22,13 +22,14 @@ async function getOrCreateInAppWalletConnector(client, connectorFactory, ecosyst
|
|
22
22
|
* @internal
|
23
23
|
*/
|
24
24
|
function createInAppWallet(args) {
|
25
|
-
const { createOptions, connectorFactory } = args;
|
25
|
+
const { createOptions, connectorFactory, ecosystem } = args;
|
26
|
+
const walletId = ecosystem ? ecosystem.id : "inApp";
|
26
27
|
const emitter = (0, wallet_emitter_js_1.createWalletEmitter)();
|
27
28
|
let account = undefined;
|
28
29
|
let chain = undefined;
|
29
30
|
let client;
|
30
31
|
return {
|
31
|
-
id:
|
32
|
+
id: walletId,
|
32
33
|
subscribe: emitter.subscribe,
|
33
34
|
getChain() {
|
34
35
|
if (!chain) {
|
@@ -41,7 +42,7 @@ function createInAppWallet(args) {
|
|
41
42
|
getAccount: () => account,
|
42
43
|
autoConnect: async (options) => {
|
43
44
|
const { autoConnectInAppWallet } = await Promise.resolve().then(() => require("./index.js"));
|
44
|
-
const connector = await getOrCreateInAppWalletConnector(options.client, connectorFactory);
|
45
|
+
const connector = await getOrCreateInAppWalletConnector(options.client, connectorFactory, ecosystem);
|
45
46
|
const [connectedAccount, connectedChain] = await autoConnectInAppWallet(options, createOptions, connector);
|
46
47
|
// set the states
|
47
48
|
client = options.client;
|
@@ -49,7 +50,7 @@ function createInAppWallet(args) {
|
|
49
50
|
chain = connectedChain;
|
50
51
|
(0, track_js_1.trackConnect)({
|
51
52
|
client: options.client,
|
52
|
-
walletType:
|
53
|
+
walletType: walletId,
|
53
54
|
walletAddress: account.address,
|
54
55
|
});
|
55
56
|
// return only the account
|
@@ -57,7 +58,7 @@ function createInAppWallet(args) {
|
|
57
58
|
},
|
58
59
|
connect: async (options) => {
|
59
60
|
const { connectInAppWallet } = await Promise.resolve().then(() => require("./index.js"));
|
60
|
-
const connector = await getOrCreateInAppWalletConnector(options.client, connectorFactory);
|
61
|
+
const connector = await getOrCreateInAppWalletConnector(options.client, connectorFactory, ecosystem);
|
61
62
|
const [connectedAccount, connectedChain] = await connectInAppWallet(options, createOptions, connector);
|
62
63
|
// set the states
|
63
64
|
client = options.client;
|
@@ -65,7 +66,7 @@ function createInAppWallet(args) {
|
|
65
66
|
chain = connectedChain;
|
66
67
|
(0, track_js_1.trackConnect)({
|
67
68
|
client: options.client,
|
68
|
-
walletType:
|
69
|
+
walletType: walletId,
|
69
70
|
walletAddress: account.address,
|
70
71
|
});
|
71
72
|
// return only the account
|
@@ -74,7 +75,7 @@ function createInAppWallet(args) {
|
|
74
75
|
disconnect: async () => {
|
75
76
|
// If no client is assigned, we should be fine just unsetting the states
|
76
77
|
if (client) {
|
77
|
-
const connector = await getOrCreateInAppWalletConnector(client, connectorFactory);
|
78
|
+
const connector = await getOrCreateInAppWalletConnector(client, connectorFactory, ecosystem);
|
78
79
|
const result = await connector.logout();
|
79
80
|
if (!result.success) {
|
80
81
|
throw new Error("Failed to logout");
|
@@ -88,7 +89,7 @@ function createInAppWallet(args) {
|
|
88
89
|
if (createOptions?.smartAccount && client && account) {
|
89
90
|
// if account abstraction is enabled, reconnect to smart account on the new chain
|
90
91
|
const { autoConnectInAppWallet } = await Promise.resolve().then(() => require("./index.js"));
|
91
|
-
const connector = await getOrCreateInAppWalletConnector(client, connectorFactory);
|
92
|
+
const connector = await getOrCreateInAppWalletConnector(client, connectorFactory, ecosystem);
|
92
93
|
const [connectedAccount, connectedChain] = await autoConnectInAppWallet({
|
93
94
|
chain: newChain,
|
94
95
|
client,
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"in-app-core.js","sourceRoot":"","sources":["../../../../../../src/wallets/in-app/core/wallet/in-app-core.ts"],"names":[],"mappings":";;
|
1
|
+
{"version":3,"file":"in-app-core.js","sourceRoot":"","sources":["../../../../../../src/wallets/in-app/core/wallet/in-app-core.ts"],"names":[],"mappings":"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"}
|
@@ -5,7 +5,6 @@ exports.connectInAppWallet = connectInAppWallet;
|
|
5
5
|
exports.autoConnectInAppWallet = autoConnectInAppWallet;
|
6
6
|
const ethereum_js_1 = require("../../../../chains/chain-definitions/ethereum.js");
|
7
7
|
const types_js_1 = require("../../../../wallets/types.js");
|
8
|
-
const types_js_2 = require("../authentication/types.js");
|
9
8
|
/**
|
10
9
|
* Checks if the provided wallet is an in-app wallet.
|
11
10
|
*
|
@@ -85,7 +84,7 @@ async function convertToSmartAccount(options) {
|
|
85
84
|
async function getAuthenticatedUser(connector) {
|
86
85
|
const user = await connector.getUser();
|
87
86
|
switch (user.status) {
|
88
|
-
case
|
87
|
+
case "Logged In, Wallet Initialized": {
|
89
88
|
return user;
|
90
89
|
}
|
91
90
|
}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../src/wallets/in-app/core/wallet/index.ts"],"names":[],"mappings":";;
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../src/wallets/in-app/core/wallet/index.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"web-wallet.js","sourceRoot":"","sources":["../../../../../../src/wallets/in-app/core/wallet/web-wallet.ts"],"names":[],"mappings":""}
|
@@ -6,7 +6,6 @@ exports.preAuthenticate = preAuthenticate;
|
|
6
6
|
exports.authenticate = authenticate;
|
7
7
|
exports.linkProfile = linkProfile;
|
8
8
|
exports.getProfiles = getProfiles;
|
9
|
-
const types_js_1 = require("../../core/authentication/types.js");
|
10
9
|
const in_app_core_js_1 = require("../../core/wallet/in-app-core.js");
|
11
10
|
// ---- KEEP IN SYNC WITH /wallets/in-app/web/lib/auth/index.ts ---- //
|
12
11
|
// duplication needed for separate exports between web and native
|
@@ -42,7 +41,7 @@ async function getAuthenticatedUser(options) {
|
|
42
41
|
const connector = await getInAppWalletConnector(client);
|
43
42
|
const user = await connector.getUser();
|
44
43
|
switch (user.status) {
|
45
|
-
case
|
44
|
+
case "Logged In, Wallet Initialized": {
|
46
45
|
return user;
|
47
46
|
}
|
48
47
|
}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../src/wallets/in-app/native/auth/index.ts"],"names":[],"mappings":";;
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../src/wallets/in-app/native/auth/index.ts"],"names":[],"mappings":";;AAoEA,oCAMC;AAeD,gDAMC;AAmBD,0CAGC;AAmBD,oCAGC;AAyBD,kCAGC;AAuBD,kCAGC;AA3LD,qEAAmF;AAGnF,uEAAuE;AACvE,iEAAiE;AAEjE;;GAEG;AACH,KAAK,UAAU,uBAAuB,CACpC,MAAsB,EACtB,SAAqB;IAErB,OAAO,IAAA,gDAA+B,EAAC,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE;QAC9D,MAAM,EAAE,oBAAoB,EAAE,GAAG,2CAAa,wBAAwB,EAAC,CAAC;QACxE,OAAO,IAAI,oBAAoB,CAAC;YAC9B,MAAM,EAAE,MAAM;YACd,SAAS,EAAE,SAAS;SACrB,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC;AAED;;;;;;;;;;;;;;GAcG;AACH,KAAK,UAAU,oBAAoB,CAAC,OAAmC;IACrE,MAAM,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC;IAC3B,MAAM,SAAS,GAAG,MAAM,uBAAuB,CAAC,MAAM,CAAC,CAAC;IACxD,MAAM,IAAI,GAAG,MAAM,SAAS,CAAC,OAAO,EAAE,CAAC;IACvC,QAAQ,IAAI,CAAC,MAAM,EAAE,CAAC;QACpB,KAAK,+BAA+B,CAAC,CAAC,CAAC;YACrC,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;IACD,OAAO,SAAS,CAAC;AACnB,CAAC;AAED;;;;;;;;;;;;GAYG;AACI,KAAK,UAAU,YAAY,CAAC,OAAmC;IACpE,MAAM,IAAI,GAAG,MAAM,oBAAoB,CAAC,OAAO,CAAC,CAAC;IACjD,IAAI,IAAI,IAAI,OAAO,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;QACxC,OAAO,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;IAChC,CAAC;IACD,OAAO,SAAS,CAAC;AACnB,CAAC;AAED;;;;;;;;;;;;GAYG;AACI,KAAK,UAAU,kBAAkB,CAAC,OAAmC;IAC1E,MAAM,IAAI,GAAG,MAAM,oBAAoB,CAAC,OAAO,CAAC,CAAC;IACjD,IAAI,IAAI,IAAI,aAAa,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;QAC9C,OAAO,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC;IACtC,CAAC;IACD,OAAO,SAAS,CAAC;AACnB,CAAC;AAED;;;;;;;;;;;;;;;;GAgBG;AACI,KAAK,UAAU,eAAe,CAAC,IAAqB;IACzD,MAAM,SAAS,GAAG,MAAM,uBAAuB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC7D,OAAO,SAAS,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;AACzC,CAAC;AAED;;;;;;;;;;;;;;;;GAgBG;AACI,KAAK,UAAU,YAAY,CAAC,IAAkB;IACnD,MAAM,SAAS,GAAG,MAAM,uBAAuB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC7D,OAAO,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;AACtC,CAAC;AAED;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACI,KAAK,UAAU,WAAW,CAAC,IAAkB;IAClD,MAAM,SAAS,GAAG,MAAM,uBAAuB,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;IAC7E,OAAO,MAAM,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;AAC3C,CAAC;AAED;;;;;;;;;;;;;;;;;;;;GAoBG;AACI,KAAK,UAAU,WAAW,CAAC,IAAgC;IAChE,MAAM,SAAS,GAAG,MAAM,uBAAuB,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;IAC7E,OAAO,SAAS,CAAC,WAAW,EAAE,CAAC;AACjC,CAAC"}
|
@@ -1,49 +1,19 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
exports.
|
4
|
-
exports.authenticate = authenticate;
|
5
|
-
exports.socialLogin = socialLogin;
|
6
|
-
exports.siweLogin = siweLogin;
|
7
|
-
exports.guestLogin = guestLogin;
|
8
|
-
exports.customJwt = customJwt;
|
9
|
-
exports.authEndpoint = authEndpoint;
|
3
|
+
exports.socialAuth = socialAuth;
|
10
4
|
exports.deleteActiveAccount = deleteActiveAccount;
|
11
5
|
const WebBrowser = require("expo-web-browser");
|
12
|
-
const nativeStorage_js_1 = require("../../../../utils/storage/nativeStorage.js");
|
13
6
|
const getLoginPath_js_1 = require("../../core/authentication/getLoginPath.js");
|
14
|
-
const guest_js_1 = require("../../core/authentication/guest.js");
|
15
|
-
const siwe_js_1 = require("../../core/authentication/siwe.js");
|
16
|
-
const otp_js_1 = require("../../web/lib/auth/otp.js");
|
17
7
|
const fetchers_js_1 = require("../helpers/api/fetchers.js");
|
18
|
-
const middleware_js_1 = require("../helpers/auth/middleware.js");
|
19
|
-
const constants_js_1 = require("../helpers/constants.js");
|
20
8
|
const errors_js_1 = require("../helpers/errors.js");
|
21
|
-
async function
|
22
|
-
const {
|
23
|
-
try {
|
24
|
-
const toStoreToken = {
|
25
|
-
jwtToken: storedToken.jwtToken,
|
26
|
-
authDetails: storedToken.authDetails,
|
27
|
-
authProvider: storedToken.authProvider,
|
28
|
-
developerClientId: storedToken.developerClientId,
|
29
|
-
cookieString: storedToken.cookieString,
|
30
|
-
// we should always store the jwt cookie since there's no concept of cookie in react native
|
31
|
-
shouldStoreCookieString: true,
|
32
|
-
isNewUser: storedToken.isNewUser,
|
33
|
-
};
|
34
|
-
await (0, middleware_js_1.postAuth)({ storedToken: toStoreToken, client: options.client });
|
35
|
-
return { storedToken };
|
36
|
-
}
|
37
|
-
catch (e) {
|
38
|
-
throw new Error((0, errors_js_1.createErrorMessage)("Malformed response from post authentication", e));
|
39
|
-
}
|
40
|
-
}
|
41
|
-
async function authenticate(auth, client) {
|
9
|
+
async function socialAuth(args) {
|
10
|
+
const { auth, client, ecosystem } = args;
|
42
11
|
const loginUrl = (0, getLoginPath_js_1.getLoginUrl)({
|
43
12
|
authOption: auth.strategy,
|
44
13
|
client,
|
45
14
|
mode: "window",
|
46
15
|
redirectUrl: auth.redirectUrl,
|
16
|
+
ecosystem,
|
47
17
|
});
|
48
18
|
const result = await WebBrowser.openAuthSessionAsync(loginUrl, auth.redirectUrl, {
|
49
19
|
preferEphemeralSession: false,
|
@@ -69,153 +39,13 @@ async function authenticate(auth, client) {
|
|
69
39
|
}
|
70
40
|
return JSON.parse(authResult);
|
71
41
|
}
|
72
|
-
async function socialLogin(auth, client) {
|
73
|
-
const { storedToken } = await authenticate(auth, client);
|
74
|
-
try {
|
75
|
-
const toStoreToken = {
|
76
|
-
jwtToken: storedToken.jwtToken,
|
77
|
-
authDetails: storedToken.authDetails,
|
78
|
-
authProvider: storedToken.authProvider,
|
79
|
-
developerClientId: storedToken.developerClientId,
|
80
|
-
cookieString: storedToken.cookieString,
|
81
|
-
// we should always store the jwt cookie since there's no concept of cookie in react native
|
82
|
-
shouldStoreCookieString: true,
|
83
|
-
isNewUser: storedToken.isNewUser,
|
84
|
-
};
|
85
|
-
await (0, middleware_js_1.postAuth)({ storedToken: toStoreToken, client });
|
86
|
-
return { storedToken };
|
87
|
-
}
|
88
|
-
catch (e) {
|
89
|
-
throw new Error((0, errors_js_1.createErrorMessage)("Malformed response from post authentication", e));
|
90
|
-
}
|
91
|
-
}
|
92
|
-
async function siweLogin(client, wallet, chain, ecosystem) {
|
93
|
-
const { storedToken } = await (0, siwe_js_1.siweAuthenticate)({
|
94
|
-
client,
|
95
|
-
ecosystem,
|
96
|
-
wallet,
|
97
|
-
chain,
|
98
|
-
});
|
99
|
-
try {
|
100
|
-
const toStoreToken = {
|
101
|
-
jwtToken: storedToken.jwtToken,
|
102
|
-
authDetails: storedToken.authDetails,
|
103
|
-
authProvider: storedToken.authProvider,
|
104
|
-
developerClientId: storedToken.developerClientId,
|
105
|
-
cookieString: storedToken.cookieString,
|
106
|
-
// we should always store the jwt cookie since there's no concept of cookie in react native
|
107
|
-
shouldStoreCookieString: true,
|
108
|
-
isNewUser: storedToken.isNewUser,
|
109
|
-
};
|
110
|
-
await (0, middleware_js_1.postAuth)({ storedToken: toStoreToken, client });
|
111
|
-
return { storedToken };
|
112
|
-
}
|
113
|
-
catch (e) {
|
114
|
-
throw new Error((0, errors_js_1.createErrorMessage)("Malformed response from post authentication", e));
|
115
|
-
}
|
116
|
-
}
|
117
|
-
async function guestLogin(client, ecosystem) {
|
118
|
-
const { storedToken } = await (0, guest_js_1.guestAuthenticate)({
|
119
|
-
client,
|
120
|
-
ecosystem,
|
121
|
-
storage: nativeStorage_js_1.nativeLocalStorage,
|
122
|
-
});
|
123
|
-
try {
|
124
|
-
const toStoreToken = {
|
125
|
-
jwtToken: storedToken.jwtToken,
|
126
|
-
authDetails: storedToken.authDetails,
|
127
|
-
authProvider: storedToken.authProvider,
|
128
|
-
developerClientId: storedToken.developerClientId,
|
129
|
-
cookieString: storedToken.cookieString,
|
130
|
-
// we should always store the jwt cookie since there's no concept of cookie in react native
|
131
|
-
shouldStoreCookieString: true,
|
132
|
-
isNewUser: storedToken.isNewUser,
|
133
|
-
};
|
134
|
-
await (0, middleware_js_1.postAuth)({ storedToken: toStoreToken, client });
|
135
|
-
return { storedToken };
|
136
|
-
}
|
137
|
-
catch (e) {
|
138
|
-
throw new Error((0, errors_js_1.createErrorMessage)("Malformed response from post authentication", e));
|
139
|
-
}
|
140
|
-
}
|
141
|
-
async function customJwt(authOptions, client) {
|
142
|
-
const { jwt, password } = authOptions;
|
143
|
-
const resp = await fetch(constants_js_1.ROUTE_AUTH_JWT_CALLBACK, {
|
144
|
-
method: "POST",
|
145
|
-
headers: {
|
146
|
-
...(0, fetchers_js_1.getSessionHeaders)(),
|
147
|
-
},
|
148
|
-
body: JSON.stringify({
|
149
|
-
jwt: jwt,
|
150
|
-
developerClientId: client.clientId,
|
151
|
-
}),
|
152
|
-
});
|
153
|
-
if (!resp.ok) {
|
154
|
-
const error = await resp.json();
|
155
|
-
throw new Error(`JWT authentication error: ${error.message}`);
|
156
|
-
}
|
157
|
-
try {
|
158
|
-
const { verifiedToken, verifiedTokenJwtString } = await resp.json();
|
159
|
-
const toStoreToken = {
|
160
|
-
jwtToken: verifiedToken.jwtToken,
|
161
|
-
authProvider: verifiedToken.authProvider,
|
162
|
-
authDetails: {
|
163
|
-
...verifiedToken.authDetails,
|
164
|
-
email: verifiedToken.authDetails.email,
|
165
|
-
},
|
166
|
-
developerClientId: verifiedToken.developerClientId,
|
167
|
-
cookieString: verifiedTokenJwtString,
|
168
|
-
shouldStoreCookieString: true,
|
169
|
-
isNewUser: verifiedToken.isNewUser,
|
170
|
-
};
|
171
|
-
await (0, middleware_js_1.postAuthUserManaged)(toStoreToken, client, password);
|
172
|
-
return { storedToken: verifiedToken };
|
173
|
-
}
|
174
|
-
catch (e) {
|
175
|
-
throw new Error((0, errors_js_1.createErrorMessage)("Malformed response from post jwt authentication", e));
|
176
|
-
}
|
177
|
-
}
|
178
|
-
async function authEndpoint(authOptions, client) {
|
179
|
-
const { payload, encryptionKey } = authOptions;
|
180
|
-
const resp = await fetch(constants_js_1.ROUTE_AUTH_ENDPOINT_CALLBACK, {
|
181
|
-
method: "POST",
|
182
|
-
headers: {
|
183
|
-
...(0, fetchers_js_1.getSessionHeaders)(),
|
184
|
-
},
|
185
|
-
body: JSON.stringify({
|
186
|
-
payload: payload,
|
187
|
-
developerClientId: client.clientId,
|
188
|
-
}),
|
189
|
-
});
|
190
|
-
if (!resp.ok) {
|
191
|
-
const error = await resp.json();
|
192
|
-
throw new Error(`Custom auth endpoint authentication error: ${error.message}`);
|
193
|
-
}
|
194
|
-
try {
|
195
|
-
const { verifiedToken, verifiedTokenJwtString } = await resp.json();
|
196
|
-
const toStoreToken = {
|
197
|
-
jwtToken: verifiedToken.jwtToken,
|
198
|
-
authProvider: verifiedToken.authProvider,
|
199
|
-
authDetails: {
|
200
|
-
...verifiedToken.authDetails,
|
201
|
-
email: verifiedToken.authDetails.email,
|
202
|
-
},
|
203
|
-
developerClientId: verifiedToken.developerClientId,
|
204
|
-
cookieString: verifiedTokenJwtString,
|
205
|
-
shouldStoreCookieString: true,
|
206
|
-
isNewUser: verifiedToken.isNewUser,
|
207
|
-
};
|
208
|
-
await (0, middleware_js_1.postAuthUserManaged)(toStoreToken, client, encryptionKey);
|
209
|
-
return { storedToken: verifiedToken };
|
210
|
-
}
|
211
|
-
catch (e) {
|
212
|
-
throw new Error((0, errors_js_1.createErrorMessage)("Malformed response from post auth_endpoint authentication", e));
|
213
|
-
}
|
214
|
-
}
|
215
42
|
async function deleteActiveAccount(options) {
|
216
43
|
await (0, fetchers_js_1.verifyClientId)(options.client);
|
217
44
|
try {
|
218
|
-
return (0, fetchers_js_1.deleteAccount)(
|
45
|
+
return (0, fetchers_js_1.deleteAccount)({
|
46
|
+
client: options.client,
|
47
|
+
storage: options.storage,
|
48
|
+
});
|
219
49
|
}
|
220
50
|
catch (e) {
|
221
51
|
throw new Error((0, errors_js_1.createErrorMessage)("Error deleting the active account", e));
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"native-auth.js","sourceRoot":"","sources":["../../../../../../src/wallets/in-app/native/auth/native-auth.ts"],"names":[],"mappings":";;
|
1
|
+
{"version":3,"file":"native-auth.js","sourceRoot":"","sources":["../../../../../../src/wallets/in-app/native/auth/native-auth.ts"],"names":[],"mappings":";;AAYA,gCA8CC;AAED,kDAcC;AA1ED,+CAA+C;AAG/C,+EAAwE;AAMxE,4DAA2E;AAC3E,oDAA0D;AAEnD,KAAK,UAAU,UAAU,CAAC,IAIhC;IACC,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,GAAG,IAAI,CAAC;IACzC,MAAM,QAAQ,GAAG,IAAA,6BAAW,EAAC;QAC3B,UAAU,EAAE,IAAI,CAAC,QAAQ;QACzB,MAAM;QACN,IAAI,EAAE,QAAQ;QACd,WAAW,EAAE,IAAI,CAAC,WAAW;QAC7B,SAAS;KACV,CAAC,CAAC;IAEH,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,oBAAoB,CAClD,QAAQ,EACR,IAAI,CAAC,WAAW,EAChB;QACE,sBAAsB,EAAE,KAAK;QAC7B,SAAS,EAAE,KAAK;QAChB,0BAA0B,EAAE,KAAK;QACjC,mBAAmB,EAAE,KAAK;KAC3B,CACF,CAAC;IAEF,IAAI,MAAM,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;QAC7B,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;IACvC,CAAC;IAED,IAAI,MAAM,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;QAC9B,MAAM,IAAI,KAAK,CAAC,sBAAsB,IAAI,CAAC,QAAQ,KAAK,MAAM,EAAE,CAAC,CAAC;IACpE,CAAC;IAED,MAAM,SAAS,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;IACtC,MAAM,UAAU,GAAG,SAAS,CAAC,YAAY,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;IAC5D,MAAM,KAAK,GAAG,SAAS,CAAC,YAAY,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;IAElD,eAAe;IACf,IAAI,KAAK,EAAE,CAAC;QACV,MAAM,IAAI,KAAK,CAAC,yBAAyB,KAAK,EAAE,CAAC,CAAC;IACpD,CAAC;IAED,IAAI,CAAC,UAAU,EAAE,CAAC;QAChB,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC;IAC1C,CAAC;IACD,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;AAChC,CAAC;AAEM,KAAK,UAAU,mBAAmB,CAAC,OAGzC;IACC,MAAM,IAAA,4BAAc,EAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IAErC,IAAI,CAAC;QACH,OAAO,IAAA,2BAAa,EAAC;YACnB,MAAM,EAAE,OAAO,CAAC,MAAM;YACtB,OAAO,EAAE,OAAO,CAAC,OAAO;SACzB,CAAC,CAAC;IACL,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,MAAM,IAAI,KAAK,CAAC,IAAA,8BAAkB,EAAC,mCAAmC,EAAE,CAAC,CAAC,CAAC,CAAC;IAC9E,CAAC;AACH,CAAC"}
|
@@ -0,0 +1,84 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.ecosystemWallet = ecosystemWallet;
|
4
|
+
const in_app_core_js_1 = require("../core/wallet/in-app-core.js");
|
5
|
+
/**
|
6
|
+
* Creates an [Ecosystem Wallet](https://portal.thirdweb.com/connect/ecosystems/overview) based on various authentication methods.
|
7
|
+
*
|
8
|
+
* Available authentication methods:
|
9
|
+
* - Email
|
10
|
+
* - Phone
|
11
|
+
* - Passkey
|
12
|
+
* - Google
|
13
|
+
* - Apple
|
14
|
+
* - Facebook
|
15
|
+
* - Discord
|
16
|
+
* - LINE
|
17
|
+
* - X
|
18
|
+
* - Farcaster
|
19
|
+
*
|
20
|
+
* Can also be configured to use Account Abstraction to directly connect to a ERC4337 smart account based on those authentication methods.
|
21
|
+
*
|
22
|
+
* Refer to [inAppWallet](https://portal.thirdweb.com/references/typescript/v5/inAppWallet) for detailed usage examples.
|
23
|
+
*
|
24
|
+
* @param createOptions - configuration options
|
25
|
+
* Refer to [EcosystemWalletCreationOptions](https://portal.thirdweb.com/references/typescript/v5/EcosystemWalletCreationOptions) for more details.
|
26
|
+
* @returns The created ecosystem wallet.
|
27
|
+
* @example
|
28
|
+
*
|
29
|
+
* ### Connect to an ecosystem wallet
|
30
|
+
*
|
31
|
+
* ```ts
|
32
|
+
* import { ecosystemWallet } from "thirdweb/wallets";
|
33
|
+
*
|
34
|
+
* const wallet = ecosystemWallet("ecosystem.hooli");
|
35
|
+
*
|
36
|
+
* const account = await wallet.connect({
|
37
|
+
* client,
|
38
|
+
* chain,
|
39
|
+
* strategy: "google",
|
40
|
+
* });
|
41
|
+
* ```
|
42
|
+
*
|
43
|
+
* [View all connection options](https://portal.thirdweb.com/references/typescript/v5/EcosystemWalletConnectionOptions)
|
44
|
+
*
|
45
|
+
* ### Connect to a restricted ecosystem wallet with your designated partner ID
|
46
|
+
*
|
47
|
+
* The parnter ID will be provided to you by the ecosystem with which you're integrating.
|
48
|
+
*
|
49
|
+
* ```ts
|
50
|
+
* import { ecosystemWallet } from "thirdweb/wallets";
|
51
|
+
* const wallet = ecosystemWallet("ecosystem.hooli", {
|
52
|
+
* partnerId: "..."
|
53
|
+
* });
|
54
|
+
* ```
|
55
|
+
*
|
56
|
+
* Refer to [inAppWallet](https://portal.thirdweb.com/references/typescript/v5/inAppWallet) for more usage examples.
|
57
|
+
*
|
58
|
+
* @wallet
|
59
|
+
*/
|
60
|
+
function ecosystemWallet(...args) {
|
61
|
+
const [ecosystemId, createOptions] = args;
|
62
|
+
const ecosystem = {
|
63
|
+
id: ecosystemId,
|
64
|
+
partnerId: createOptions?.partnerId,
|
65
|
+
};
|
66
|
+
return (0, in_app_core_js_1.createInAppWallet)({
|
67
|
+
ecosystem,
|
68
|
+
createOptions: {
|
69
|
+
auth: {
|
70
|
+
...createOptions?.auth,
|
71
|
+
options: [], // controlled by ecosystem
|
72
|
+
},
|
73
|
+
},
|
74
|
+
connectorFactory: async (client) => {
|
75
|
+
const { InAppNativeConnector } = await Promise.resolve().then(() => require("./native-connector.js"));
|
76
|
+
return new InAppNativeConnector({
|
77
|
+
client,
|
78
|
+
ecosystem,
|
79
|
+
// TODO (enclave): passkeyDomain for ecosystem wallets
|
80
|
+
});
|
81
|
+
},
|
82
|
+
});
|
83
|
+
}
|
84
|
+
//# sourceMappingURL=ecosystem.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"ecosystem.js","sourceRoot":"","sources":["../../../../../src/wallets/in-app/native/ecosystem.ts"],"names":[],"mappings":";;AA+DA,0CAyBC;AAlFD,kEAAkE;AAElE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAsDG;AACH,SAAgB,eAAe,CAC7B,GAAG,IAAyC;IAE5C,MAAM,CAAC,WAAW,EAAE,aAAa,CAAC,GAAG,IAAI,CAAC;IAC1C,MAAM,SAAS,GAAG;QAChB,EAAE,EAAE,WAAW;QACf,SAAS,EAAE,aAAa,EAAE,SAAS;KACpC,CAAC;IACF,OAAO,IAAA,kCAAiB,EAAC;QACvB,SAAS;QACT,aAAa,EAAE;YACb,IAAI,EAAE;gBACJ,GAAG,aAAa,EAAE,IAAI;gBACtB,OAAO,EAAE,EAAE,EAAE,0BAA0B;aACxC;SACF;QACD,gBAAgB,EAAE,KAAK,EAAE,MAAsB,EAAE,EAAE;YACjD,MAAM,EAAE,oBAAoB,EAAE,GAAG,2CAAa,uBAAuB,EAAC,CAAC;YACvE,OAAO,IAAI,oBAAoB,CAAC;gBAC9B,MAAM;gBACN,SAAS;gBACT,sDAAsD;aACvD,CAAC,CAAC;QACL,CAAC;KACF,CAA8B,CAAC;AAClC,CAAC"}
|
@@ -1,7 +1,8 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
exports.
|
3
|
+
exports.verifyClientId = void 0;
|
4
4
|
exports.getSessionHeaders = getSessionHeaders;
|
5
|
+
exports.authFetchEmbeddedWalletUser = authFetchEmbeddedWalletUser;
|
5
6
|
exports.fetchUserDetails = fetchUserDetails;
|
6
7
|
exports.storeUserShares = storeUserShares;
|
7
8
|
exports.getUserShares = getUserShares;
|
@@ -10,7 +11,6 @@ const fetch_js_1 = require("../../../../../utils/fetch.js");
|
|
10
11
|
const random_js_1 = require("../../../../../utils/random.js");
|
11
12
|
const constants_js_1 = require("../constants.js");
|
12
13
|
const errors_js_1 = require("../errors.js");
|
13
|
-
const local_js_1 = require("../storage/local.js");
|
14
14
|
const EMBEDDED_WALLET_TOKEN_HEADER = "embedded-wallet-token";
|
15
15
|
const PAPER_CLIENT_ID_HEADER = "x-thirdweb-client-id";
|
16
16
|
let sessionNonce = undefined;
|
@@ -40,8 +40,9 @@ const verifyClientId = async (client) => {
|
|
40
40
|
};
|
41
41
|
};
|
42
42
|
exports.verifyClientId = verifyClientId;
|
43
|
-
|
44
|
-
const
|
43
|
+
async function authFetchEmbeddedWalletUser(args) {
|
44
|
+
const { client, url, props, storage, retries = 0 } = args;
|
45
|
+
const authTokenClient = await storage.getAuthCookie();
|
45
46
|
const params = { ...props };
|
46
47
|
params.headers = params?.headers
|
47
48
|
? {
|
@@ -61,12 +62,17 @@ const authFetchEmbeddedWalletUser = async (client, url, props, retries = 3) => {
|
|
61
62
|
catch (e) {
|
62
63
|
if (retries > 0) {
|
63
64
|
await new Promise((resolve) => setTimeout(resolve, 500));
|
64
|
-
return await
|
65
|
+
return await authFetchEmbeddedWalletUser({
|
66
|
+
client,
|
67
|
+
url,
|
68
|
+
props: params,
|
69
|
+
storage,
|
70
|
+
retries: retries - 1,
|
71
|
+
});
|
65
72
|
}
|
66
73
|
throw e;
|
67
74
|
}
|
68
|
-
}
|
69
|
-
exports.authFetchEmbeddedWalletUser = authFetchEmbeddedWalletUser;
|
75
|
+
}
|
70
76
|
async function fetchUserDetails(args) {
|
71
77
|
const url = new URL(constants_js_1.ROUTE_EMBEDDED_WALLET_DETAILS);
|
72
78
|
if (args) {
|
@@ -74,8 +80,13 @@ async function fetchUserDetails(args) {
|
|
74
80
|
url.searchParams.append("email", args.email ?? "none");
|
75
81
|
url.searchParams.append("clientId", args.client.clientId);
|
76
82
|
}
|
77
|
-
const resp = await
|
78
|
-
|
83
|
+
const resp = await authFetchEmbeddedWalletUser({
|
84
|
+
client: args.client,
|
85
|
+
url: url.href,
|
86
|
+
props: {
|
87
|
+
method: "GET",
|
88
|
+
},
|
89
|
+
storage: args.storage,
|
79
90
|
});
|
80
91
|
if (!resp.ok) {
|
81
92
|
const error = await resp.json();
|
@@ -84,24 +95,34 @@ async function fetchUserDetails(args) {
|
|
84
95
|
const result = (await resp.json());
|
85
96
|
return result;
|
86
97
|
}
|
87
|
-
async function storeUserShares({ client, walletAddress, maybeEncryptedRecoveryShares, authShare, }) {
|
88
|
-
const resp = await
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
98
|
+
async function storeUserShares({ client, walletAddress, maybeEncryptedRecoveryShares, authShare, storage, }) {
|
99
|
+
const resp = await authFetchEmbeddedWalletUser({
|
100
|
+
client,
|
101
|
+
url: constants_js_1.ROUTE_STORE_USER_SHARES,
|
102
|
+
props: {
|
103
|
+
method: "POST",
|
104
|
+
headers: { "Content-Type": "application/json" },
|
105
|
+
body: JSON.stringify({
|
106
|
+
walletAddress,
|
107
|
+
maybeEncryptedRecoveryShares,
|
108
|
+
authShare,
|
109
|
+
}),
|
110
|
+
},
|
111
|
+
storage,
|
96
112
|
});
|
97
113
|
if (!resp.ok) {
|
98
114
|
const error = await resp.json();
|
99
115
|
throw new Error(`Something went wrong storing user wallet shares: ${JSON.stringify(error.message, null, 2)}`);
|
100
116
|
}
|
101
117
|
}
|
102
|
-
async function getUserShares(
|
103
|
-
const resp = await
|
104
|
-
|
118
|
+
async function getUserShares(args) {
|
119
|
+
const resp = await authFetchEmbeddedWalletUser({
|
120
|
+
client: args.client,
|
121
|
+
url: args.getShareUrl.href,
|
122
|
+
props: {
|
123
|
+
method: "GET",
|
124
|
+
},
|
125
|
+
storage: args.storage,
|
105
126
|
});
|
106
127
|
if (!resp.ok) {
|
107
128
|
const error = await resp.json();
|
@@ -115,10 +136,15 @@ async function getUserShares(client, getShareUrl) {
|
|
115
136
|
throw new Error((0, errors_js_1.createErrorMessage)("Malformed response from the ews user wallet API", e));
|
116
137
|
}
|
117
138
|
}
|
118
|
-
async function deleteAccount(
|
139
|
+
async function deleteAccount(args) {
|
119
140
|
const url = new URL(constants_js_1.ROUTE_EMBEDDED_WALLET_DETAILS);
|
120
|
-
const resp = await
|
121
|
-
|
141
|
+
const resp = await authFetchEmbeddedWalletUser({
|
142
|
+
client: args.client,
|
143
|
+
url: url.href,
|
144
|
+
props: {
|
145
|
+
method: "DELETE",
|
146
|
+
},
|
147
|
+
storage: args.storage,
|
122
148
|
});
|
123
149
|
if (!resp.ok) {
|
124
150
|
const error = await resp.json();
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"fetchers.js","sourceRoot":"","sources":["../../../../../../../src/wallets/in-app/native/helpers/api/fetchers.ts"],"names":[],"mappings":";;;AAmBA,8CAQC;
|
1
|
+
{"version":3,"file":"fetchers.js","sourceRoot":"","sources":["../../../../../../../src/wallets/in-app/native/helpers/api/fetchers.ts"],"names":[],"mappings":"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"}
|