@privy-io/react-auth 3.14.0 → 3.14.1
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/{AccountNotFoundScreen-B2BwM9IL.js → AccountNotFoundScreen-C25iBRLm.js} +1 -1
- package/dist/cjs/{Address-CMUXgM3h.js → Address-CHKhHgKJ.js} +1 -1
- package/dist/cjs/{AffirmativeConsentScreen-B7nTfKFs.js → AffirmativeConsentScreen-DT0ojGpw.js} +1 -1
- package/dist/cjs/{AllowlistRejectionScreen-C0ubkz2f.js → AllowlistRejectionScreen-D0I4vTcK.js} +1 -1
- package/dist/cjs/{AuthenticateWithWalletScreen-DHRXcjT5.js → AuthenticateWithWalletScreen-dcVrFqXU.js} +1 -1
- package/dist/cjs/{AwaitingEvmToSolBridgingScreen-D6MB0SW8.js → AwaitingEvmToSolBridgingScreen-20Lokl_2.js} +1 -1
- package/dist/cjs/{AwaitingExternalEthereumTransferScreen-BcnofXQv.js → AwaitingExternalEthereumTransferScreen-B2BOyvEP.js} +1 -1
- package/dist/cjs/{AwaitingPasswordlessCodeScreen-CMMIM_Pj.js → AwaitingPasswordlessCodeScreen-CjeHuBk7.js} +1 -1
- package/dist/cjs/{AwaitingSolToEvmBridgingScreen-C2Op_A4L.js → AwaitingSolToEvmBridgingScreen-NSyS8djM.js} +1 -1
- package/dist/cjs/{BridgeNetworkSelectionView-BU5hxQ4Z.js → BridgeNetworkSelectionView-Cy4dUUah.js} +1 -1
- package/dist/cjs/{CaptchaScreen-TVUbEsJK.js → CaptchaScreen-CchfnELg.js} +1 -1
- package/dist/cjs/{CoinbaseOnrampStatusScreen-_mCdKOIM.js → CoinbaseOnrampStatusScreen-RmmivwEu.js} +1 -1
- package/dist/cjs/{ConnectEmailForm-BgS2Yn3u.js → ConnectEmailForm-BibKRhlR.js} +1 -1
- package/dist/cjs/{ConnectLedgerScreen-DjDvgzxV.js → ConnectLedgerScreen-CB1oTLjq.js} +1 -1
- package/dist/cjs/{ConnectOnlyLandingScreen-CbUMwYrO.js → ConnectOnlyLandingScreen-BI0zDj3o.js} +1 -1
- package/dist/cjs/{ConnectOnlyStatusScreen-DyoV_8V9.js → ConnectOnlyStatusScreen-BAUS-OpP.js} +1 -1
- package/dist/cjs/{ConnectOrCreateScreen-DpR4OmSO.js → ConnectOrCreateScreen-CdoSL34u.js} +1 -1
- package/dist/cjs/{ConnectPhoneForm-CdRNa4Lg.js → ConnectPhoneForm-BPgbe0j3.js} +1 -1
- package/dist/cjs/{ConnectWalletView-Bb4271wb.js → ConnectWalletView-BB2DjcE-.js} +1 -1
- package/dist/cjs/{ConnectionStatusScreen-B8TxWdVC.js → ConnectionStatusScreen-D2pFs10v.js} +1 -1
- package/dist/cjs/{CrossAppAuthScreen-By4i5UqT.js → CrossAppAuthScreen-Dzqgp4fv.js} +1 -1
- package/dist/cjs/{CustomLandingScreenView-C0Vky31_.js → CustomLandingScreenView-Pamy7vPb.js} +1 -1
- package/dist/cjs/{DelegatedActionsConsentScreen-CjUYU339.js → DelegatedActionsConsentScreen-B1RznIyD.js} +1 -1
- package/dist/cjs/{DelegatedActionsRevokeScreen-BGATOJGL.js → DelegatedActionsRevokeScreen-BfYkymoM.js} +1 -1
- package/dist/cjs/{EmbeddedWalletConnectingScreen-GZ8nOvWq.js → EmbeddedWalletConnectingScreen-DaOL3Ico.js} +1 -1
- package/dist/cjs/{EmbeddedWalletCreatedScreen-Be8AYwZh.js → EmbeddedWalletCreatedScreen-B5K1ek4V.js} +1 -1
- package/dist/cjs/{EmbeddedWalletKeyExportScreen-DXa54jFw.js → EmbeddedWalletKeyExportScreen-BJTyn-Lk.js} +1 -1
- package/dist/cjs/{EmbeddedWalletOnAccountCreateScreen-C8-LkEhs.js → EmbeddedWalletOnAccountCreateScreen-BbZKkeLp.js} +1 -1
- package/dist/cjs/{EmbeddedWalletPasswordUpdateScreen-B7N8Noqf.js → EmbeddedWalletPasswordUpdateScreen-DMx4Tn8E.js} +1 -1
- package/dist/cjs/{EmbeddedWalletPasswordUpdateSplashScreen-kiTrvJ2h.js → EmbeddedWalletPasswordUpdateSplashScreen-wUfHEYpF.js} +1 -1
- package/dist/cjs/{EnrollTotp-Bxzun51r.js → EnrollTotp-B1qE1mCx.js} +1 -1
- package/dist/cjs/{ErrorScreen-BsvL8i4R.js → ErrorScreen-BPXQabSS.js} +1 -1
- package/dist/cjs/{FarcasterConnectStatusScreen-DMnzjTAV.js → FarcasterConnectStatusScreen-C_NK2UCS.js} +1 -1
- package/dist/cjs/{FarcasterSignerStatusScreen-Xb4KBH8f.js → FarcasterSignerStatusScreen-D3DUvPPw.js} +1 -1
- package/dist/cjs/{FundSolWalletWithExternalSolanaWallet-BT4nT21N.js → FundSolWalletWithExternalSolanaWallet-BoOhBVX9.js} +1 -1
- package/dist/cjs/{FundWalletMethodHeader-D_l3529h.js → FundWalletMethodHeader-BUHyY_8M.js} +1 -1
- package/dist/cjs/FundWithBankDepositScreen-D_qA2wCk.js +176 -0
- package/dist/cjs/{FundingEditAmountScreen-CBp--May.js → FundingEditAmountScreen-DLWLIjEZ.js} +1 -1
- package/dist/cjs/FundingMethodSelectionScreen-BRz8TLz5.js +1 -0
- package/dist/cjs/{InAppBrowserLoginNotPossible-fTc3VwS8.js → InAppBrowserLoginNotPossible-iLA0OVLk.js} +1 -1
- package/dist/cjs/{InstallWalletScreen-Bm_jzHEL.js → InstallWalletScreen-BS2Bwxvi.js} +1 -1
- package/dist/cjs/{LandingScreen-D6094d73.js → LandingScreen-C4KpTL08.js} +1 -1
- package/dist/cjs/{LinkConflictScreen-Bic4pZUv.js → LinkConflictScreen-CNQSun1F.js} +1 -1
- package/dist/cjs/{LinkEmailScreen-BuuqcFAa.js → LinkEmailScreen-oNzcpVes.js} +1 -1
- package/dist/cjs/{LinkPasskeyScreen-CbuNym_z.js → LinkPasskeyScreen-CjdxFDoA.js} +1 -1
- package/dist/cjs/{LinkPhoneScreen-ZIe5uzPN.js → LinkPhoneScreen-B6OzKZnd.js} +1 -1
- package/dist/cjs/{LoginFailedScreen-JnBtBxi1.js → LoginFailedScreen-Cj3ATfwH.js} +1 -1
- package/dist/cjs/{ManualTransferScreen-B4TkbelL.js → ManualTransferScreen-M26HCQmU.js} +1 -1
- package/dist/cjs/{MfaAuthEnrollmentFlowScreen-CmLIp9Ll.js → MfaAuthEnrollmentFlowScreen-D1zKxqD8.js} +1 -1
- package/dist/cjs/{MfaAuthVerifyFlowScreen-B3ATEO7f.js → MfaAuthVerifyFlowScreen-D3eQj9zt.js} +1 -1
- package/dist/cjs/{MfaEnrollmentFlowScreen-COciRqP3.js → MfaEnrollmentFlowScreen-B2gvvMfX.js} +1 -1
- package/dist/cjs/{MfaVerifyFlowScreen-BuljrcdS.js → MfaVerifyFlowScreen-AyHxACnF.js} +1 -1
- package/dist/cjs/{ModalHeader-C45fdSY0.js → ModalHeader-BCPQgekO.js} +1 -1
- package/dist/cjs/{MoonpayStatusScreen-zWJq589Z.js → MoonpayStatusScreen-BQaJBdWu.js} +1 -1
- package/dist/cjs/{OAuthStatusScreen-ecJqpiHx.js → OAuthStatusScreen-JHIOff6A.js} +1 -1
- package/dist/cjs/{PasskeySelectSignupOrLogin-B-0EIFsW.js → PasskeySelectSignupOrLogin-B9J49RMF.js} +1 -1
- package/dist/cjs/{PasskeyStatusScreen-DzuiIFq2.js → PasskeyStatusScreen-ms-tH4cc.js} +1 -1
- package/dist/cjs/{PasswordRecoveryScreen-DQEy0Nqy.js → PasswordRecoveryScreen-CDHZosNL.js} +1 -1
- package/dist/cjs/{QrCode-BKnLFoFt.js → QrCode-CE12LRBB.js} +1 -1
- package/dist/cjs/{RecoveryOAuthStatusScreen-06xKXwi8.js → RecoveryOAuthStatusScreen-BUxNTtqd.js} +1 -1
- package/dist/cjs/{RecoveryPasswordCreateScreen-yfl_af11.js → RecoveryPasswordCreateScreen-BkFOrb6m.js} +1 -1
- package/dist/cjs/{RecoverySelectionScreen-BdHkBTuB.js → RecoverySelectionScreen-HBLOm2va.js} +1 -1
- package/dist/cjs/{Screen-ChnafgL7.js → Screen-BfKedqka.js} +1 -1
- package/dist/cjs/{ScreenLayout-CpclvUVQ.js → ScreenLayout-CMb-Fua0.js} +1 -1
- package/dist/cjs/{SetAutomaticRecoveryScreen-JwwwXok0.js → SetAutomaticRecoveryScreen-DPjXBMos.js} +1 -1
- package/dist/cjs/{SetWalletPasswordForm-ByGHfNqH.js → SetWalletPasswordForm-BslxSGLC.js} +1 -1
- package/dist/cjs/{SignRequestScreen-Bcr25XmN.js → SignRequestScreen-Cjn1PsqC.js} +1 -1
- package/dist/cjs/{StandardSignAndSendTransactionScreen-D-63yMIJ.js → StandardSignAndSendTransactionScreen-BIh1TSV6.js} +1 -1
- package/dist/cjs/{TelegramAuthScreen-DxZS64fR.js → TelegramAuthScreen-BZpPqkC8.js} +1 -1
- package/dist/cjs/{TransactionDetails-DBFsWnn1.js → TransactionDetails-BY2Ynu2J.js} +1 -1
- package/dist/cjs/{TransactionErrorView-nUOKizXV.js → TransactionErrorView-CueeggTz.js} +1 -1
- package/dist/cjs/{TransferFromWalletScreen-CYPZmSPV.js → TransferFromWalletScreen-BfWPkgYH.js} +1 -1
- package/dist/cjs/{TransferOrBridgeLoadingScreen-DiPwnn60.js → TransferOrBridgeLoadingScreen-CI2oh7CB.js} +1 -1
- package/dist/cjs/{UpdateEmailScreen-Bwxxqz1k.js → UpdateEmailScreen-BHgHi-KQ.js} +1 -1
- package/dist/cjs/{UpdatePhoneScreen-DU7RGenX.js → UpdatePhoneScreen-J83rbDYY.js} +1 -1
- package/dist/cjs/{UserLimitReachedScreen-fuIfecOX.js → UserLimitReachedScreen-CYNd-wAp.js} +1 -1
- package/dist/cjs/{WalletInfoCard-DmD26XB9.js → WalletInfoCard-CHdyZdLe.js} +1 -1
- package/dist/cjs/{WalletInterstitialScreen-Bn8l3kCq.js → WalletInterstitialScreen-CmqF-Oas.js} +1 -1
- package/dist/cjs/{WalletLink-D7Q4z7WW.js → WalletLink-Bs_1C81F.js} +1 -1
- package/dist/cjs/{WalletOverflowButton-fU7XMRV1.js → WalletOverflowButton-BqeWaSEy.js} +1 -1
- package/dist/cjs/abstract-smart-wallets.js +1 -1
- package/dist/cjs/{context-DK3qW12H.js → context-D-ZJYjUg.js} +1 -1
- package/dist/cjs/{ethers-DpiO5t5F.js → ethers-SCb3aakT.js} +1 -1
- package/dist/cjs/extended-chains.js +1 -1
- package/dist/cjs/{get-is-unified-wallet-CMHZpDfE.js → get-is-unified-wallet-UpdjHxOV.js} +1 -1
- package/dist/cjs/{index-DhmrMcn2.js → index-BcyDbfqY.js} +1 -1
- package/dist/cjs/{index-CgsQCH2r.js → index-C8lpxYDX.js} +3 -3
- package/dist/cjs/{index-VgEQ4kaA.js → index-gohEbwKU.js} +1 -1
- package/dist/cjs/index.js +1 -1
- package/dist/cjs/internal.js +1 -1
- package/dist/cjs/{shared-BTeM_5HJ.js → shared-e1wjsjhc.js} +1 -1
- package/dist/cjs/{shouldProceedtoEmbeddedWalletCreationFlow-eB6IctoD.js → shouldProceedtoEmbeddedWalletCreationFlow-DADJI9f0.js} +1 -1
- package/dist/cjs/{smart-wallets-DPXIV14D.js → smart-wallets-D-oPjsFS.js} +1 -1
- package/dist/cjs/smart-wallets.js +1 -1
- package/dist/cjs/solana.js +1 -1
- package/dist/cjs/{styles-BfCR4pAO.js → styles-DUvzIwf1.js} +1 -1
- package/dist/cjs/{to-ui-error-CQ9FNFg-.js → to-ui-error-BJRhg6yc.js} +1 -1
- package/dist/cjs/ui.js +1 -1
- package/dist/cjs/use-export-wallet-B5ujV5Nk.js +1 -0
- package/dist/cjs/{use-export-wallet-Ddpx0kgg.js → use-export-wallet-Dt1qheK5.js} +1 -1
- package/dist/cjs/{useActiveWallet-BgdIZtS6.js → useActiveWallet-Cn6zOXx5.js} +1 -1
- package/dist/cjs/{useGetTokenPrice-CouzWOSt.js → useGetTokenPrice-761HAiva.js} +1 -1
- package/dist/cjs/{useI18n-DDbtkfuB.js → useI18n-DFGBJl_S.js} +1 -1
- package/dist/cjs/{usePrivy-DUT7RIf5.js → usePrivy-cfS6o4tX.js} +1 -1
- package/dist/cjs/{useSolanaRpcClient-CefJOh8Z.js → useSolanaRpcClient-PnNtmWdo.js} +1 -1
- package/dist/cjs/{useWallets-XTVLGZyz.js → useWallets-CKAypPZB.js} +1 -1
- package/dist/cjs/{useWallets-DXWvKTyb.js → useWallets-DeTGSqF_.js} +1 -1
- package/dist/dts/{events-context-Fks6josE.d.ts → events-context-Bz1yk0zU.d.mts} +1 -1
- package/dist/dts/{events-context-Fks6josE.d.mts → events-context-Bz1yk0zU.d.ts} +1 -1
- package/dist/dts/extended-chains.d.mts +1 -1
- package/dist/dts/extended-chains.d.ts +1 -1
- package/dist/dts/farcaster.d.mts +1 -1
- package/dist/dts/farcaster.d.ts +1 -1
- package/dist/dts/index.d.mts +4 -4
- package/dist/dts/index.d.ts +4 -4
- package/dist/dts/internal.d.mts +1 -1
- package/dist/dts/internal.d.ts +1 -1
- package/dist/dts/smart-wallets.d.mts +1 -1
- package/dist/dts/smart-wallets.d.ts +1 -1
- package/dist/dts/solana.d.mts +3 -3
- package/dist/dts/solana.d.ts +3 -3
- package/dist/dts/{types-CjDYScKX.d.mts → types-CIvz-X6P.d.mts} +21 -5
- package/dist/dts/{types-CjDYScKX.d.ts → types-CIvz-X6P.d.ts} +21 -5
- package/dist/dts/ui.d.mts +1 -1
- package/dist/dts/ui.d.ts +1 -1
- package/dist/esm/{AccountNotFoundScreen-DzQ8Ded6.mjs → AccountNotFoundScreen-C055cesr.mjs} +1 -1
- package/dist/esm/{Address-ClnXOtX_.mjs → Address-BjZb-TIL.mjs} +1 -1
- package/dist/esm/{AffirmativeConsentScreen-CGLpvQm4.mjs → AffirmativeConsentScreen-DXy2kEcy.mjs} +1 -1
- package/dist/esm/{AllowlistRejectionScreen-0T0W1npW.mjs → AllowlistRejectionScreen-BIzWPeoe.mjs} +1 -1
- package/dist/esm/{AuthenticateWithWalletScreen-aIIbB44q.mjs → AuthenticateWithWalletScreen-q3jQKiH6.mjs} +1 -1
- package/dist/esm/{AwaitingEvmToSolBridgingScreen-Bcx6oRJE.mjs → AwaitingEvmToSolBridgingScreen-B4R4PEVm.mjs} +1 -1
- package/dist/esm/{AwaitingExternalEthereumTransferScreen-BlmM5W1W.mjs → AwaitingExternalEthereumTransferScreen-Dwy69FD1.mjs} +1 -1
- package/dist/esm/{AwaitingPasswordlessCodeScreen-DxV44L8v.mjs → AwaitingPasswordlessCodeScreen-Ch_YXDTX.mjs} +1 -1
- package/dist/esm/{AwaitingSolToEvmBridgingScreen-C_VwI_Sw.mjs → AwaitingSolToEvmBridgingScreen-spElnpUE.mjs} +1 -1
- package/dist/esm/{BridgeNetworkSelectionView-F7koQMl8.mjs → BridgeNetworkSelectionView-CaDh-Zck.mjs} +1 -1
- package/dist/esm/{CaptchaScreen-BeoBh2yB.mjs → CaptchaScreen-BZy78GrD.mjs} +1 -1
- package/dist/esm/{CoinbaseOnrampStatusScreen-h359lw0u.mjs → CoinbaseOnrampStatusScreen-CTWZaE1o.mjs} +1 -1
- package/dist/esm/{ConnectEmailForm-D96RP15S.mjs → ConnectEmailForm-0GOHNayM.mjs} +1 -1
- package/dist/esm/{ConnectLedgerScreen-DlzVqbV7.mjs → ConnectLedgerScreen-CIPOaq8e.mjs} +1 -1
- package/dist/esm/{ConnectOnlyLandingScreen-wbu-70B6.mjs → ConnectOnlyLandingScreen-CbLV-cj4.mjs} +1 -1
- package/dist/esm/{ConnectOnlyStatusScreen-CbWmfcm8.mjs → ConnectOnlyStatusScreen-bmx1wwk1.mjs} +1 -1
- package/dist/esm/{ConnectOrCreateScreen-CSKKpNhC.mjs → ConnectOrCreateScreen-DXw5Y8gN.mjs} +1 -1
- package/dist/esm/{ConnectPhoneForm-Cfdo1Hxx.mjs → ConnectPhoneForm-_lOAQG_X.mjs} +1 -1
- package/dist/esm/{ConnectWalletView-D9FJQoQd.mjs → ConnectWalletView-CDqboUej.mjs} +1 -1
- package/dist/esm/{ConnectionStatusScreen-BCZOSVuo.mjs → ConnectionStatusScreen-D-9fLZfA.mjs} +1 -1
- package/dist/esm/{CrossAppAuthScreen-C9Y8UmMT.mjs → CrossAppAuthScreen-Co723kT3.mjs} +1 -1
- package/dist/esm/{CustomLandingScreenView-C9zIdEBy.mjs → CustomLandingScreenView-9mrgsDhT.mjs} +1 -1
- package/dist/esm/{DelegatedActionsConsentScreen-CRlv1sFS.mjs → DelegatedActionsConsentScreen-CyQTJHgT.mjs} +1 -1
- package/dist/esm/{DelegatedActionsRevokeScreen-CfOOZLtD.mjs → DelegatedActionsRevokeScreen-CFm4F3CM.mjs} +1 -1
- package/dist/esm/{EmbeddedWalletConnectingScreen-DuSxBQbx.mjs → EmbeddedWalletConnectingScreen-DmTtzGwq.mjs} +1 -1
- package/dist/esm/{EmbeddedWalletCreatedScreen--ZpH1G0k.mjs → EmbeddedWalletCreatedScreen-Cj1c5KyP.mjs} +1 -1
- package/dist/esm/{EmbeddedWalletKeyExportScreen-CSJq1Sik.mjs → EmbeddedWalletKeyExportScreen-CsWRTEgd.mjs} +1 -1
- package/dist/esm/{EmbeddedWalletOnAccountCreateScreen-DOSya90v.mjs → EmbeddedWalletOnAccountCreateScreen-DBAmWm90.mjs} +1 -1
- package/dist/esm/{EmbeddedWalletPasswordUpdateScreen-C_es2EpS.mjs → EmbeddedWalletPasswordUpdateScreen-B5w6wtgf.mjs} +1 -1
- package/dist/esm/{EmbeddedWalletPasswordUpdateSplashScreen-DhwnqiCK.mjs → EmbeddedWalletPasswordUpdateSplashScreen-BvsscceO.mjs} +1 -1
- package/dist/esm/{EnrollTotp-YxZ_oitd.mjs → EnrollTotp-uSQt9d2Q.mjs} +1 -1
- package/dist/esm/{ErrorScreen-DZ153hPv.mjs → ErrorScreen-DtGc3Chy.mjs} +1 -1
- package/dist/esm/{FarcasterConnectStatusScreen-CwQhh_aC.mjs → FarcasterConnectStatusScreen-DGeCyr6b.mjs} +1 -1
- package/dist/esm/{FarcasterSignerStatusScreen-D1SKEl4x.mjs → FarcasterSignerStatusScreen-DASa1xq2.mjs} +1 -1
- package/dist/esm/{FundSolWalletWithExternalSolanaWallet-CH85fmbL.mjs → FundSolWalletWithExternalSolanaWallet-0jNi_hvn.mjs} +1 -1
- package/dist/esm/{FundWalletMethodHeader-D0DhWPu0.mjs → FundWalletMethodHeader-Cfci4-83.mjs} +1 -1
- package/dist/esm/FundWithBankDepositScreen-D_uu3GEF.mjs +176 -0
- package/dist/esm/{FundingEditAmountScreen-C_YGQD1r.mjs → FundingEditAmountScreen-vQUS-a80.mjs} +1 -1
- package/dist/esm/FundingMethodSelectionScreen-G8gkM1Mk.mjs +1 -0
- package/dist/esm/{InAppBrowserLoginNotPossible-BiwxWFju.mjs → InAppBrowserLoginNotPossible-C8mlSbYe.mjs} +1 -1
- package/dist/esm/{InstallWalletScreen-DHPONpNA.mjs → InstallWalletScreen-D0kdHc5W.mjs} +1 -1
- package/dist/esm/{LandingScreen-DBZbonr_.mjs → LandingScreen-0MlIkV3C.mjs} +1 -1
- package/dist/esm/{LinkConflictScreen-D0TlabXV.mjs → LinkConflictScreen-DW31R5fr.mjs} +1 -1
- package/dist/esm/{LinkEmailScreen-D9zKrb4E.mjs → LinkEmailScreen-B10iXGH8.mjs} +1 -1
- package/dist/esm/{LinkPasskeyScreen-3_thbT6t.mjs → LinkPasskeyScreen-OxaghvUl.mjs} +1 -1
- package/dist/esm/{LinkPhoneScreen-BwBdaLqt.mjs → LinkPhoneScreen-Cdg3eg7w.mjs} +1 -1
- package/dist/esm/{LoginFailedScreen-Dxi-7tx8.mjs → LoginFailedScreen-BVOo2ycm.mjs} +1 -1
- package/dist/esm/{ManualTransferScreen-e347H8JC.mjs → ManualTransferScreen-_04Sq7zU.mjs} +1 -1
- package/dist/esm/{MfaAuthEnrollmentFlowScreen-BUF154dJ.mjs → MfaAuthEnrollmentFlowScreen-DApO6DPY.mjs} +1 -1
- package/dist/esm/{MfaAuthVerifyFlowScreen-BJ4ZNRWe.mjs → MfaAuthVerifyFlowScreen-mdmdgWdO.mjs} +1 -1
- package/dist/esm/{MfaEnrollmentFlowScreen-B5DfdOkM.mjs → MfaEnrollmentFlowScreen-DRZTnt-I.mjs} +1 -1
- package/dist/esm/{MfaVerifyFlowScreen-fjVmi3M8.mjs → MfaVerifyFlowScreen-mrf95cEs.mjs} +1 -1
- package/dist/esm/{ModalHeader-DBfMXKy4.mjs → ModalHeader-D8-mhjp4.mjs} +1 -1
- package/dist/esm/{MoonpayStatusScreen-BeZtoeAo.mjs → MoonpayStatusScreen-DDSK5dda.mjs} +1 -1
- package/dist/esm/{OAuthStatusScreen-BVLexXQC.mjs → OAuthStatusScreen-DSAUQ_YN.mjs} +1 -1
- package/dist/esm/{PasskeySelectSignupOrLogin-CejGrqSb.mjs → PasskeySelectSignupOrLogin-G19VpAdI.mjs} +1 -1
- package/dist/esm/{PasskeyStatusScreen-BrDLZfaA.mjs → PasskeyStatusScreen-TD2nYAnk.mjs} +1 -1
- package/dist/esm/{PasswordRecoveryScreen-Bks4ITku.mjs → PasswordRecoveryScreen-C0oVVZYe.mjs} +1 -1
- package/dist/esm/{QrCode-CKNL79V_.mjs → QrCode-C1tgJtOy.mjs} +1 -1
- package/dist/esm/{RecoveryOAuthStatusScreen-TsrFc2KU.mjs → RecoveryOAuthStatusScreen-Ca9VYOrA.mjs} +1 -1
- package/dist/esm/{RecoveryPasswordCreateScreen--aWRhenB.mjs → RecoveryPasswordCreateScreen-Q1zuy9fu.mjs} +1 -1
- package/dist/esm/{RecoverySelectionScreen-DJ33E1hd.mjs → RecoverySelectionScreen-scmqFA8Y.mjs} +1 -1
- package/dist/esm/{Screen-omroCwTV.mjs → Screen-Bp-TN9gb.mjs} +1 -1
- package/dist/esm/{ScreenLayout-z1I4hafk.mjs → ScreenLayout-DTmQLGPf.mjs} +1 -1
- package/dist/esm/{SetAutomaticRecoveryScreen-DelsQl1S.mjs → SetAutomaticRecoveryScreen-D-__1Pf7.mjs} +1 -1
- package/dist/esm/{SetWalletPasswordForm-DyVubYdV.mjs → SetWalletPasswordForm-0nuoz3XZ.mjs} +1 -1
- package/dist/esm/{SignRequestScreen-C6XvfvXV.mjs → SignRequestScreen-D6HSUOxx.mjs} +1 -1
- package/dist/esm/{StandardSignAndSendTransactionScreen-FQcyAQoq.mjs → StandardSignAndSendTransactionScreen-YlstFfkB.mjs} +1 -1
- package/dist/esm/{TelegramAuthScreen-LB2IdLqW.mjs → TelegramAuthScreen-DHCcieoC.mjs} +1 -1
- package/dist/esm/{TransactionDetails-CLHEcWFe.mjs → TransactionDetails-BurRo8R0.mjs} +1 -1
- package/dist/esm/{TransactionErrorView-D7uZmR_V.mjs → TransactionErrorView-CPFrt0L4.mjs} +1 -1
- package/dist/esm/{TransferFromWalletScreen-BLLYNl1T.mjs → TransferFromWalletScreen-BG5Mj5tz.mjs} +1 -1
- package/dist/esm/{TransferOrBridgeLoadingScreen-DgS9Jr0v.mjs → TransferOrBridgeLoadingScreen-DcCdHB-g.mjs} +1 -1
- package/dist/esm/{UpdateEmailScreen-DGAco54E.mjs → UpdateEmailScreen-ndRi1gY6.mjs} +1 -1
- package/dist/esm/{UpdatePhoneScreen-CLCixHYj.mjs → UpdatePhoneScreen-DoH__glA.mjs} +1 -1
- package/dist/esm/{UserLimitReachedScreen-ClahBH0m.mjs → UserLimitReachedScreen-BLzaOW7F.mjs} +1 -1
- package/dist/esm/{WalletInfoCard-BURM3rIP.mjs → WalletInfoCard-DFt8ndGE.mjs} +1 -1
- package/dist/esm/{WalletInterstitialScreen-CBzg1He2.mjs → WalletInterstitialScreen-BQ-ku50j.mjs} +1 -1
- package/dist/esm/{WalletLink-BXlPbPVx.mjs → WalletLink--05Hzo2b.mjs} +1 -1
- package/dist/esm/{WalletOverflowButton-CWeBF-Wv.mjs → WalletOverflowButton-BlijhJnI.mjs} +1 -1
- package/dist/esm/abstract-smart-wallets.mjs +1 -1
- package/dist/esm/{context-CCRnMB8L.mjs → context-WTldtXS8.mjs} +1 -1
- package/dist/esm/{ethers-B0Y3_-Pp.mjs → ethers-D1WT71Ay.mjs} +1 -1
- package/dist/esm/extended-chains.mjs +1 -1
- package/dist/esm/{get-is-unified-wallet-j2fzd2YE.mjs → get-is-unified-wallet-Boa8DYrQ.mjs} +1 -1
- package/dist/esm/{index-BgGYO9kN.mjs → index-BBRkihRn.mjs} +3 -3
- package/dist/esm/{index-CIjObncO.mjs → index-BH9-XZRZ.mjs} +1 -1
- package/dist/esm/{index-Dk-s5iXx.mjs → index-C9k7EfLZ.mjs} +1 -1
- package/dist/esm/index.mjs +1 -1
- package/dist/esm/internal.mjs +1 -1
- package/dist/esm/{shared-B_TYFBiH.mjs → shared-CwuyxHmv.mjs} +1 -1
- package/dist/esm/{shouldProceedtoEmbeddedWalletCreationFlow-DjxNSuIS.mjs → shouldProceedtoEmbeddedWalletCreationFlow-BMF_3TVv.mjs} +1 -1
- package/dist/esm/{smart-wallets-DL1EjW8i.mjs → smart-wallets-DOAgnxKI.mjs} +1 -1
- package/dist/esm/smart-wallets.mjs +1 -1
- package/dist/esm/solana.mjs +1 -1
- package/dist/esm/{styles-BeQ5nIO3.mjs → styles-BmZHuqSX.mjs} +1 -1
- package/dist/esm/{to-ui-error-DR840l8Y.mjs → to-ui-error-REESv0kM.mjs} +1 -1
- package/dist/esm/ui.mjs +1 -1
- package/dist/esm/use-export-wallet-CV4p7L0b.mjs +1 -0
- package/dist/esm/{use-export-wallet-AwUSjJIc.mjs → use-export-wallet-DQde4t0V.mjs} +1 -1
- package/dist/esm/{useActiveWallet-Dqi9nNxj.mjs → useActiveWallet-3RHPIBxJ.mjs} +1 -1
- package/dist/esm/{useGetTokenPrice-Djb6UHOW.mjs → useGetTokenPrice-BPBpM07F.mjs} +1 -1
- package/dist/esm/{useI18n-BK0a87xw.mjs → useI18n-BuIe8nUA.mjs} +1 -1
- package/dist/esm/{usePrivy-D9f62ILp.mjs → usePrivy-6nkpbErN.mjs} +1 -1
- package/dist/esm/{useSolanaRpcClient-DizarIU5.mjs → useSolanaRpcClient-BUWOblv_.mjs} +1 -1
- package/dist/esm/{useWallets-BKPOCKnv.mjs → useWallets-CR0z5IIt.mjs} +1 -1
- package/dist/esm/{useWallets-DQOA0__U.mjs → useWallets-C_dCo2_Q.mjs} +1 -1
- package/package.json +6 -6
- package/dist/cjs/FundWithBankDepositScreen-C1BRYtc8.js +0 -175
- package/dist/cjs/FundingMethodSelectionScreen-CL9xLuBR.js +0 -1
- package/dist/cjs/use-export-wallet-BEW54Ynq.js +0 -1
- package/dist/esm/FundWithBankDepositScreen-BJk-wxSq.mjs +0 -175
- package/dist/esm/FundingMethodSelectionScreen-gGZKP4LD.mjs +0 -1
- package/dist/esm/use-export-wallet-Voe8hSb9.mjs +0 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{jsxs as e,jsx as t,Fragment as n}from"react/jsx-runtime";import r,{useContext as a,createContext as i,useRef as s,useState as o,useMemo as l,useEffect as c,Suspense as d,lazy as u,useCallback as h}from"react";import p,{DEFAULT_SUPPORTED_CHAIN_IDS as w,rpc as m,PrivyClientError as y,getWallet as g,updateWallet as f,generateAuthorizationSignature as v}from"@privy-io/js-sdk-core";import{v4 as A}from"uuid";import*as k from"jose";import{base64url as T}from"jose";import{u as C,a as _,g as S,i as b,b as E,c as I,d as P,e as W,f as U,P as N,M as O,h as R,j as M,k as x,l as F}from"./get-is-unified-wallet-j2fzd2YE.mjs";import D from"eventemitter3";import{E as L,P as j,t as q,p as z,H,u as B,L as V,g as K,s as $,a as G,b as Y,c as J,i as Q,d as Z,e as X,R as ee,f as te,h as ne,j as re,k as ae,l as ie,m as se,n as oe,M as le,o as ce,q as de,S as ue,r as he,v as pe,w as we,x as me}from"./useActiveWallet-Dqi9nNxj.mjs";import{u as ye,t as ge,U as fe,g as ve}from"./useWallets-BKPOCKnv.mjs";import{P as Ae,a as ke,f as Te,b as Ce,c as _e,n as Se,d as be,u as Ee,e as Ie,I as Pe,g as We,h as Ue,i as Ne}from"./internal-context-Z-fyxadS.mjs";import{f as Oe,s as Re,W as Me,i as xe,a as Fe,P as De,e as Le,p as je,b as qe,l as ze}from"./use-export-wallet-Voe8hSb9.mjs";import{createCoinbaseWalletSDK as He}from"@coinbase/wallet-sdk";import{toViemTransactionSerializable as Be,STRING_TO_NUMBER_TXN_TYPE as Ve}from"@privy-io/ethereum";import{P as Ke,C as $e,a as Ge,H as Ye,O as Je,S as Qe,u as Ze,b as Xe,c as et,D as tt,d as nt,g as rt,V as at,R as it,e as st,f as ot,h as lt,i as ct,j as dt,I as ut,k as ht,l as pt,m as wt,W as mt}from"./context-CCRnMB8L.mjs";import{createStore as yt}from"mipd";import{isMobile as gt,isIOS as ft,isAndroid as vt,isSafari as At}from"react-device-detect";import{toHex as kt,getAddress as Tt,isHex as Ct,hashAuthorization as _t}from"viem/utils";import{trigger as St}from"@privy-io/popup";import{u as bt,p as Et,a as It,b as Pt,f as Wt,c as Ut,d as Nt,e as Ot,o as Rt,g as Mt,h as xt,i as Ft,j as Dt,k as Lt,l as jt,m as qt,n as zt,q as Ht,r as Bt,s as Vt,t as Kt,v as $t,w as Gt,x as Yt,y as Jt,z as Qt,A as Zt,B as Xt,C as en,D as tn,E as nn,F as rn,G as an,H as sn,I as on,J as ln,K as cn,L as dn,M as un,N as hn,O as pn,P as wn,Q as mn,R as yn,S as gn,T as fn,U as vn,V as An,W as kn,X as Tn,Y as Cn,Z as _n,_ as Sn,$ as bn,a0 as En,a1 as In,a2 as Pn,a3 as Wn,a4 as Un}from"./paths-3HW55qZg.mjs";import{o as Nn,p as On,d as Rn,r as Mn,b as xn,s as Fn,a as Dn,c as Ln,u as jn,S as qn,e as zn,f as Hn}from"./usePrivy-D9f62ILp.mjs";import{base64 as Bn}from"@scure/base";import{styled as Vn,createGlobalStyle as Kn,css as $n}from"styled-components";import{u as Gn,a as Yn,p as Jn,e as Qn,P as Zn}from"./events-context-CI0iqAXA.mjs";import{create as Xn}from"zustand";import{Transition as er,Dialog as tr,TransitionChild as nr,DialogPanel as rr}from"@headlessui/react";import{EthereumProvider as ar,OPTIONAL_METHODS as ir,OPTIONAL_EVENTS as sr}from"@walletconnect/ethereum-provider";import{constructURL as or}from"@privy-io/urls";import{toHex as lr,zeroAddress as cr,getAddress as dr,createWalletClient as ur,http as hr,parseSignature as pr}from"viem";import{u as wr,P as mr}from"./PrivyPluginContext-2QN2dVUw.mjs";import{D as yr}from"./getEmbeddedConnectedWallet-JzK4iD-L.mjs";import{g as gr,a as fr}from"./getPublicClient-B4uPLKn-.mjs";import{ofetch as vr}from"ofetch";import Ar from"js-cookie";import{F as kr}from"./frame-uzTmvtww.mjs";import{MfaAuthPasskeyVerify as Tr,MfaAuthPasskeyInit as Cr,MfaAuthTotpVerify as _r,MfaAuthPasskeyEnrollment as Sr,MfaAuthTotpUnenroll as br,MfaAuthTotpEnroll as Er,MfaAuthTotpInit as Ir}from"@privy-io/routes";import{selectPaymentRequirements as Pr,createPaymentHeader as Wr}from"x402/client";import{InvalidInputError as Ur}from"@privy-io/api-base";import{areAddressesEqual as Nr}from"@privy-io/are-addresses-equal";import{toAccount as Or}from"viem/accounts";import{u as Rr}from"./use-sign-with-user-signer-Do5Oi_rb.mjs";class Mr{static parse(e){try{return new Mr(e)}catch(e){return null}}static throwIfNotWellFormedJwt(e){return k.decodeJwt(e),e}get subject(){return this._decoded.sub}get expiration(){return this._decoded.exp}get issuer(){return this._decoded.iss}get audience(){return this._decoded.aud}isExpired(e=0){return Date.now()>=1e3*(this.expiration-e)}constructor(e){this.value=e,this._decoded=k.decodeJwt(e)}}class xr extends Mr{static parse(e){try{return new xr(e)}catch(e){return null}}get appId(){return this._decoded.aid?this._decoded.aid:this.audience}}const Fr=({style:n,...r})=>/*#__PURE__*/e("svg",{viewBox:"0 0 1024 1024",fill:"none",xmlns:"http://www.w3.org/2000/svg",style:{height:"28px",width:"28px",...n},...r,children:[/*#__PURE__*/t("rect",{width:"1024",height:"1024",fill:"#0052FF",rx:100,ry:100}),/*#__PURE__*/t("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M152 512C152 710.823 313.177 872 512 872C710.823 872 872 710.823 872 512C872 313.177 710.823 152 512 152C313.177 152 152 313.177 152 512ZM420 396C406.745 396 396 406.745 396 420V604C396 617.255 406.745 628 420 628H604C617.255 628 628 617.255 628 604V420C628 406.745 617.255 396 604 396H420Z",fill:"white"})]}),Dr="data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PScwIDAgMTAyNCAxMDI0JyBmaWxsPSdub25lJyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnIHN0eWxlPSdoZWlnaHQ6MjhweDt3aWR0aDoyOHB4Jz48cmVjdCB3aWR0aD0nMTAyNCcgaGVpZ2h0PScxMDI0JyBmaWxsPScjMDA1MkZGJyByeD0nMTAwJyByeT0nMTAwJz48L3JlY3Q+PHBhdGggZmlsbC1ydWxlPSdldmVub2RkJyBjbGlwLXJ1bGU9J2V2ZW5vZGQnIGQ9J00xNTIgNTEyQzE1MiA3MTAuODIzIDMxMy4xNzcgODcyIDUxMiA4NzJDNzEwLjgyMyA4NzIgODcyIDcxMC44MjMgODcyIDUxMkM4NzIgMzEzLjE3NyA3MTAuODIzIDE1MiA1MTIgMTUyQzMxMy4xNzcgMTUyIDE1MiAzMTMuMTc3IDE1MiA1MTJaTTQyMCAzOTZDNDA2Ljc0NSAzOTYgMzk2IDQwNi43NDUgMzk2IDQyMFY2MDRDMzk2IDYxNy4yNTUgNDA2Ljc0NSA2MjggNDIwIDYyOEg2MDRDNjE3LjI1NSA2MjggNjI4IDYxNy4yNTUgNjI4IDYwNFY0MjBDNjI4IDQwNi43NDUgNjE3LjI1NSAzOTYgNjA0IDM5Nkg0MjBaJyBmaWxsPSd3aGl0ZSc+PC9wYXRoPjwvc3ZnPg==",Lr="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADAAAAAwCAYAAABXAvmHAAAAAXNSR0IArs4c6QAAALZJREFUaEPtmjEOhDAMBNc/O14GvOzys3CAKK6eAlmaVGl2Zc+kTOU685vkc9/bnD2prZK5/TZY24z9P+g4F5hNh7/GdoG37WlAA5CATwgCxHENYISwQAMQII5rACOEBRqAAHFcAxghLNAABIjjGsAIYYEGIEAc1wBGCAs0AAHiuAYwQligAQgQxzWAEcICDUCAOK4BjBAWaAACxHENYISwQAMQII6fBjr+VHkW3+u+tfyxMpJaDgYzYxb/ALZVAAAAAElFTkSuQmCC";let jr,qr;class zr extends L{async initialize(){await this.importPromise,await this.syncAccounts(),this.initialized=!0,this.emit("initialized")}async connect(e){return e.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}disconnect(){this.proxyProvider.walletProvider.disconnect(),this.onDisconnect()}get walletBranding(){return{name:this.displayName,icon:Lr,id:"com.coinbase.wallet"}}async promptConnection(){try{await this.importPromise;let e=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!e||0===e.length||!e[0])throw new Ae("Unable to retrieve accounts");this.connected=!0,await this.syncAccounts([e[0]])}catch(e){throw Oe(e)}}constructor(e,t,n,r,a){super("base_account",e,t,n),this.connectorType="base_account",this.walletClientType="base_account",this.displayName="Base",this.setBaseAccountSdk=a,this.proxyProvider=new j(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.baseAccountConfig={...r,appChainIds:[t.id].concat(e.map((e=>e.id)))},jr?(this.proxyProvider.setWalletProvider(jr.getProvider()),this.setBaseAccountSdk(jr)):this.importPromise=import("@base-org/account").then((({createBaseAccountSDK:e})=>{jr=e(this.baseAccountConfig),this.proxyProvider.setWalletProvider(jr.getProvider()),this.setBaseAccountSdk(jr)})).catch(console.error)}}let Hr=[1,11155111,137,10,8453,84532,42161,7777777,43114,56];class Br extends L{async initialize(){await this.syncAccounts(),this.initialized=!0,this.emit("initialized")}async connect(e){return e.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}disconnect(){this.proxyProvider.walletProvider.disconnect(),this.onDisconnect()}get walletBranding(){return{name:this.displayName,icon:Dr,id:"com.coinbase.wallet"}}async promptConnection(){try{let e=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!e||0===e.length||!e[0])throw new Ae("Unable to retrieve accounts");this.connected=!0,await this.syncAccounts([e[0]])}catch(e){throw Oe(e)}}updateConnectionPreference(e){this.coinbaseWalletConfig={...this.coinbaseWalletConfig,preference:{...this.coinbaseWalletConfig.preference,options:e}},this.walletClientType="smartWalletOnly"===e?"coinbase_smart_wallet":"coinbase_wallet",qr=He({...this.coinbaseWalletConfig}),this.proxyProvider.setWalletProvider(qr.getProvider())}constructor(e,t,n,r){if(super("coinbase_wallet",e,t,n),this.connectorType="coinbase_wallet",this.displayName="Coinbase Wallet",this.proxyProvider=new j(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.coinbaseWalletConfig={...r,appChainIds:[t.id].concat(e.map((e=>e.id)))},this.walletClientType="smartWalletOnly"===this.coinbaseWalletConfig.preference?.options?"coinbase_smart_wallet":"coinbase_wallet","coinbase_smart_wallet"===this.walletClientType&&(this.displayName="Coinbase Smart Wallet"),!qr){let e="eoaOnly"!==this.coinbaseWalletConfig.preference?.options?(this.coinbaseWalletConfig.appChainIds??[]).filter((e=>!Hr.includes(e))):[];e.length>0&&!e.every((e=>w.has(e)))&&console.info(`The configured chains are not supported by Coinbase Smart Wallet: ${e.join(", ")}`),qr=He(this.coinbaseWalletConfig)}this.proxyProvider.setWalletProvider(qr.getProvider())}}const Vr=({...e})=>/*#__PURE__*/t("svg",{width:"15",height:"15",viewBox:"0 0 15 15",fill:"none",xmlns:"http://www.w3.org/2000/svg",...e,children:/*#__PURE__*/t("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M2.37126 11.0323C2.37126 12.696 3.90598 13.4421 5.40654 13.4468C8.91753 13.4468 12.8021 11.2897 12.7819 7.67984C12.7673 5.07728 10.3748 2.86167 7.54357 2.88296C4.8495 2.88296 2.21821 4.6411 2.21803 7.03628C2.21803 7.67951 2.58722 8.30178 3.55231 8.37184C2.74763 9.16826 2.37126 10.1225 2.37126 11.0323ZM7.55283 8.68012C8.11562 8.68012 8.57186 8.13217 8.57186 7.45624C8.57186 6.78032 8.11562 6.23237 7.55283 6.23237C6.99003 6.23237 6.53379 6.78032 6.53379 7.45624C6.53379 8.13217 6.99003 8.68012 7.55283 8.68012ZM10.4747 8.68012C11.0375 8.68012 11.4937 8.13217 11.4937 7.45625C11.4937 6.78032 11.0375 6.23237 10.4747 6.23237C9.91186 6.23237 9.45562 6.78032 9.45562 7.45625C9.45562 8.13217 9.91186 8.68012 10.4747 8.68012Z",fill:e.color||"var(--privy-color-foreground-3)"})});class Kr extends L{async initialize(){await this.syncAccounts(),this.initialized=!0,this.emit("initialized")}async connect(e){return await this.isConnected()?(await this.proxyProvider.request({method:"wallet_switchEthereumChain",params:[q(e?.chainId||"0x1")]}),this.getConnectedWallet()):null}get walletBranding(){return{name:"Privy Wallet",icon:Vr,id:"io.privy.wallet"}}disconnect(){this.connected=!1}async promptConnection(){}constructor({provider:e,chains:t,defaultChain:n,rpcConfig:r,imported:a,walletIndex:i}){super("privy",t,n,r),this.connectorType="embedded",this.proxyProvider=e,this.walletIndex=i,a&&(this.connectorType="embedded_imported"),this.subscribeListeners()}}async function $r(){let e=xs();return e?e.getAccessToken():Promise.resolve(Re.get(Ke)||Re.get($e)||null)}const Gr=["eth_sign","eth_populateTransactionRequest","eth_signTransaction","personal_sign","eth_signTypedData_v4","csw_signUserOperation","secp256k1_sign"];function Yr(e){return e?{"privy-ui":"t"}:void 0}class Jr{async authenticate(){if(!this.api)throw new ke("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new ke("Email and email code must be set prior to calling authenticate.");try{return await this.api.post(Et,{email:this.meta.email,code:this.meta.emailCode,mode:this.meta.disableSignup?"no-signup":"login-or-sign-up"})}catch(e){throw Te(e)}}async link(){if(!this.api)throw new ke("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new ke("Email and email code must be set prior to calling authenticate.");try{return await this.api.post(It,{email:this.meta.email,code:this.meta.emailCode})}catch(e){throw Te(e)}}async sendCodeEmail({email:e,captchaToken:t,withPrivyUi:n}){if(!this.api)throw new ke("Auth flow has no API instance");if(e&&(this.meta.email=e),t&&(this.meta.captchaToken=t),!this.meta.email)throw new ke("Email must be set when initialzing authentication.");let r=Yr(n);try{return await this.api.post(Pt,{email:this.meta.email,token:this.meta.captchaToken},{headers:{...r}})}catch(e){throw Te(e)}}constructor({email:e,captchaToken:t,disableSignup:n}){this.meta={email:e,captchaToken:t,disableSignup:n??!1}}}class Qr extends Jr{async link(){if(!this.api)throw new ke("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode||!this.meta.oldAddress)throw new ke("Email, email code, and an old email address must be set prior to calling update.");try{return await this.api.post(bt,{oldAddress:this.meta.oldAddress,newAddress:this.meta.email,code:this.meta.emailCode})}catch(e){throw Te(e)}}constructor(e,t,n){super({email:t,captchaToken:n}),this.meta={email:t,captchaToken:n,oldAddress:e,disableSignup:!1}}}class Zr{execute(e){return null===this.promise&&(this.promise=(async()=>{try{return await this.fn(e)}finally{this.promise=null}})()),this.promise}constructor(e){this.promise=null,this.fn=e}}class Xr{get meta(){return this._meta}async authenticate(){if(!this.api)throw new ke("Auth flow has no API instance");if(!this.meta.channelToken)throw new ke("Auth flow must be initialized first");try{let e=await this.api.post(Wt,{channel_token:this.meta.channelToken,message:this.message,signature:this.signature,fid:this.fid,mode:this.meta.disableSignup?"no-signup":"login-or-sign-up"});if(!e)throw new ke("No response from authentication");return e}catch(e){throw Te(e)}}async link(){if(!this.api)throw new ke("Auth flow has no API instance");try{return await this.api.post(Ut,{channel_token:this.meta.channelToken,message:this.message,signature:this.signature,fid:this.fid})}catch(e){throw Te(e)}}async _startChannelOnce(){if(!this.api)throw new ke("Auth flow has no API instance");let e=await this.api.post(Nt,{token:this.captchaToken});gt&&!ft&&e.connect_uri&&Nn(e.connect_uri,"_blank"),this._meta={...this._meta,connectUri:e.connect_uri,channelToken:e.channel_token}}async initializeFarcasterConnect(){if(!this.api)throw new ke("Auth flow has no API instance");await this.startChannelOnce.execute()}async _pollForReady(){if(!this.api)throw new ke("Auth flow has no API instance");if(!this.meta.channelToken)throw new ke("Auth flow must be initialized first");let e=await this.api.get(Ot,{headers:{"farcaster-channel-token":this.meta.channelToken}});return"completed"===e.state&&(this.message=e.message,this.signature=e.signature,this.fid=e.fid,!0)}constructor(e,t=!1){this._meta={disableSignup:!1},this.captchaToken=e,this.startChannelOnce=new Zr(this._startChannelOnce.bind(this)),this.pollForReady=new Zr(this._pollForReady.bind(this)),this._meta.disableSignup=t}}function ea(){return"undefined"!=typeof window&&"chrome-extension:"===window.location.protocol&&"chrome"in window}function ta(){if(!ea())return;let e=window.chrome;return e?.runtime?.id}function na(){if(!ea())return!1;let e=window.chrome;return"function"==typeof e?.identity?.launchWebAuthFlow}async function ra(e){return new Promise(((t,n)=>{na()?window.chrome.identity.launchWebAuthFlow({url:e,interactive:!0},(async e=>{try{let n=function(){if(!ea())return;let e=window.chrome;return e?.runtime?.lastError?.message}();if(n||!e){let e=`WebAuthFlow failed: ${n||"Response URI missing"}`;throw Error(e)}let r=new URL(e),a=ta();if(!a)throw Error("Invalid extension context");if("chrome-extension:"===r.protocol){if(r.hostname!==a)throw Error("Invalid responseUri origin")}else{if("https:"!==r.protocol)throw Error("Invalid responseUri protocol");{let e=r.hostname.split(".");if(3!==e.length||"chromiumapp"!==e[1]||"org"!==e[2]||e[0]!==a)throw Error("Invalid responseUri origin")}}let i=r.searchParams.get("privy_oauth_state"),s=r.searchParams.get("privy_oauth_code");if(!i||!s)throw Error("Invalid responseUri - missing required parameters");t({privyOAuthState:i,privyOAuthCode:s})}catch(e){n(e)}})):n(Error("Chrome identity API not available"))}))}function aa(e){return crypto.getRandomValues(new Uint8Array(e))}function ia(){return T.encode(aa(36))}function sa(){return ia()}async function oa(e,t="S256"){if("S256"!=t)return e;{let t=await async function(e){let t=(new TextEncoder).encode(e);return new Uint8Array(await crypto.subtle.digest("SHA-256",t))}(e);return T.encode(t)}}class la{addCaptchaToken(e){this.meta.captchaToken=e}isActive(){return!!(this.meta.authorizationCode&&this.meta.stateCode&&this.meta.provider)}async authenticate(){if(!this.api)throw new ke("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new ke("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling authenticate.");if("undefined"===this.meta.authorizationCode)throw new ke("User denied confirmation during OAuth flow");let e=function(){let e=Re.get(Ge);if(!e)throw new ke("Authentication error.");return e}();try{let t=await this.api.post(Rt,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode,code_verifier:e,mode:this.meta.disableSignup?"no-signup":"login-or-sign-up"});return Re.del(Ge),Re.del(Ye),Re.del(Je),t}catch(e){let t=Te(e);if(t.privyErrorCode)throw new ke(t.message||"Invalid code during OAuth flow.",void 0,t.privyErrorCode);if("User denied confirmation during OAuth flow"===t.message)throw new ke("Invalid code during oauth flow.",void 0,Ce.OAUTH_USER_DENIED);throw new ke("Invalid code during OAuth flow.",void 0,Ce.UNKNOWN_AUTH_ERROR)}}async link(){if(!this.api)throw new ke("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new ke("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling link.");if("undefined"===this.meta.authorizationCode)throw new ke("User denied confirmation during OAuth flow");let e=Re.get(Ge);if(!e)throw new ke("Authentication error.");try{let t=await this.api.post(Mt,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode,code_verifier:e});return Re.del(Ge),t}catch(e){throw Te(e)}}async getAuthorizationUrl(){if(!this.api)throw new ke("Auth flow has no API instance");if(!this.meta.provider)throw new ke("Provider must be set when initializing OAuth authentication.");let e=ia();Re.put(Ge,e);let t=sa();Re.put(Qe,t);let n=await oa(e);this.meta.withPrivyUi||Re.put(Ye,!0),this.meta.disableSignup?Re.put(Je,!0):Re.del(Je);let r=Yr(this.meta.withPrivyUi),a=window.location.href,i=function(){let e=ta();if(e)return`https://${e}.chromiumapp.org`}();i&&(a=i);try{return await this.api.post(xt,{provider:this.meta.provider,redirect_to:this.meta.customOAuthRedirectUrl||a,token:this.meta.captchaToken,code_challenge:n,state_code:t},{headers:{...r}})}catch(e){throw Te(e)}}constructor(e){this.meta=e}}function ca(){let e=new URLSearchParams(window.location.search),t=e.get("privy_oauth_code"),n=e.get("privy_oauth_state"),r=e.get("privy_oauth_provider");if(!t||!n||!r)return{inProgress:!1};let a=!1;try{a=!!window.opener.location.origin}catch{}return{inProgress:!0,authorizationCode:t,stateCode:n,provider:r,withPrivyUi:!Re.get(Ye),popupFlow:null!==window.opener&&a,disableSignup:!!Re.get(Je)}}function da(){let e=new URL(window.location.href);e.searchParams.delete("privy_oauth_code"),e.searchParams.delete("privy_oauth_provider"),e.searchParams.delete("privy_oauth_state"),Re.del(Qe),window.history.replaceState({},"",e)}class ua{async initRegisterFlow(e){if(!this.api)throw new ke("Auth flow has no API instance");this.authenticateForRegistration=!0,this.meta.initRegisterResponse=await this.initRegisterOnce.execute(e)}async initAuthenticationFlow(e){if(!this.api)throw new ke("Auth flow has no API instance");this.authenticateForRegistration=!1,this.meta.initAuthenticateResponse=await this.initAuthenticateOnce.execute(e)}async initLinkFlow(){if(!this.api)throw new ke("Auth flow has no API instance");this.meta.initLinkResponse=await this.initLinkOnce.execute()}async register(){let e=await import("@simplewebauthn/browser");if(!this.api)throw new ke("Auth flow has no API instance");if(!e.browserSupportsWebAuthn())throw new ke("WebAuthn is not supported in this browser");this.meta.initRegisterResponse||(this.meta.initRegisterResponse=await this.initRegisterOnce.execute());try{let t=this.meta.initRegisterResponse.options,n=await e.startRegistration({optionsJSON:this._transformInitLinkOptionsToCamelCase(t)});return this.meta.setPasskeyAuthState?.({status:"submitting-response"}),await this.api.post(Ft,{relying_party:this.meta.initRegisterResponse.relying_party,authenticator_response:this._transformRegistrationResponseToSnakeCase(n)})}catch(e){if("NotAllowedError"===e.name)throw new ke("Passkey request timed out or rejected by user.",void 0,Ce.PASSKEY_NOT_ALLOWED);throw Te(e)}}async authenticate(){if(this.authenticateForRegistration)return this.register();let e=await import("@simplewebauthn/browser");if(!this.api)throw new ke("Auth flow has no API instance");if(!e.browserSupportsWebAuthn())throw new ke("WebAuthn is not supported in this browser");this.meta.initAuthenticateResponse||(this.meta.initAuthenticateResponse=await this.initAuthenticateOnce.execute());let t=this.meta.allowedCredentialsIds?.map((e=>({type:"public-key",id:e})))??this.meta.initAuthenticateResponse.options.allow_credentials;try{let n=await e.startAuthentication({optionsJSON:this._transformInitAuthenticateOptionsToCamelCase({...this.meta.initAuthenticateResponse.options,allow_credentials:t})});return this.meta.setPasskeyAuthState?.({status:"submitting-response"}),await this.api.post(Dt,{relying_party:this.meta.initAuthenticateResponse.relying_party,challenge:this.meta.initAuthenticateResponse.options.challenge,authenticator_response:this._transformAuthenticationResponseToSnakeCase(n)})}catch(e){if("NotAllowedError"===e.name)throw new ke("Passkey request timed out or rejected by user.",void 0,Ce.PASSKEY_NOT_ALLOWED);throw Te(e)}}async link(){let e=await import("@simplewebauthn/browser");if(!this.api)throw new ke("Auth flow has no API instance");if(!e.browserSupportsWebAuthn())throw new ke("WebAuthn is not supported in this browser");this.meta.initLinkResponse||(this.meta.initLinkResponse=await this.initLinkOnce.execute());try{let t=this.meta.initLinkResponse.options,n=await e.startRegistration({optionsJSON:this._transformInitLinkOptionsToCamelCase(t)});return this.meta.setPasskeyAuthState?.({status:"submitting-response"}),await this.api.post(Lt,{relying_party:this.meta.initLinkResponse.relying_party,authenticator_response:this._transformRegistrationResponseToSnakeCase(n)})}catch(e){if("NotAllowedError"===e.name)throw new ke("Passkey request timed out or rejected by user.",void 0,Ce.PASSKEY_NOT_ALLOWED);throw Te(e)}}async _initRegisterOnce(e){if(!this.api)throw new ke("Auth flow has no API instance");let t=Yr(e);return await this.api.post(jt,{token:this.meta.captchaToken},{headers:{...t}})}async _initAuthenticateOnce(e){if(!this.api)throw new ke("Auth flow has no API instance");let t=Yr(e);return await this.api.post(qt,{token:this.meta.captchaToken},{headers:{...t}})}async _initLinkOnce(){if(!this.api)throw new ke("Auth flow has no API instance");return await this.api.post(zt,{})}_transformInitLinkOptionsToCamelCase(e){return{rp:e.rp,user:{id:e.user.id,name:e.user.name,displayName:e.user.display_name},challenge:e.challenge,pubKeyCredParams:e.pub_key_cred_params.map((e=>({type:e.type,alg:e.alg}))),timeout:e.timeout,excludeCredentials:e.exclude_credentials?.map((e=>({id:e.id,type:e.type,transports:e.transports}))),authenticatorSelection:{authenticatorAttachment:e.authenticator_selection?.authenticator_attachment,requireResidentKey:e.authenticator_selection?.require_resident_key,residentKey:e.authenticator_selection?.resident_key,userVerification:e.authenticator_selection?.user_verification},attestation:e.attestation,extensions:{appid:e.extensions?.app_id,credProps:e.extensions?.cred_props?.rk,hmacCreateSecret:e.extensions?.hmac_create_secret},hints:this.meta.hints}}_transformRegistrationResponseToSnakeCase(e){return{id:e.id,raw_id:e.rawId,response:{client_data_json:e.response.clientDataJSON,attestation_object:e.response.attestationObject,authenticator_data:e.response.authenticatorData},authenticator_attachment:e.authenticatorAttachment,client_extension_results:{app_id:e.clientExtensionResults.appid,cred_props:e.clientExtensionResults.credProps,hmac_create_secret:e.clientExtensionResults.hmacCreateSecret},type:e.type}}_transformInitAuthenticateOptionsToCamelCase(e){return{rpId:e.rp_id,challenge:e.challenge,allowCredentials:e.allow_credentials?.map((e=>({id:e.id,type:e.type,transports:e.transports})))||[],timeout:e.timeout,extensions:{appid:e.extensions?.app_id,credProps:e.extensions?.cred_props,hmacCreateSecret:e.extensions?.hmac_create_secret},userVerification:e.user_verification}}_transformAuthenticationResponseToSnakeCase(e){return{id:e.id,raw_id:e.rawId,response:{client_data_json:e.response.clientDataJSON,authenticator_data:e.response.authenticatorData,signature:e.response.signature,user_handle:e.response.userHandle},authenticator_attachment:e.authenticatorAttachment,client_extension_results:{app_id:e.clientExtensionResults.appid,cred_props:e.clientExtensionResults.credProps,hmac_create_secret:e.clientExtensionResults.hmacCreateSecret},type:e.type}}constructor({captchaToken:e,setPasskeyAuthState:t,hints:n}){this.authenticateForRegistration=!1,this.initRegisterOnce=new Zr(this._initRegisterOnce.bind(this)),this.initAuthenticateOnce=new Zr(this._initAuthenticateOnce.bind(this)),this.initLinkOnce=new Zr(this._initLinkOnce.bind(this)),this.meta={captchaToken:e,setPasskeyAuthState:t,hints:n}}}const ha=({address:e,chainId:t,nonce:n})=>`${window.location.host} wants you to sign in with your Ethereum account:\n${e}\n\nBy signing, you are proving you own this wallet and logging in. This does not initiate a transaction or cost any fees.\n\nURI: ${window.location.origin}\nVersion: 1\nChain ID: ${t}\nNonce: ${n}\nIssued At: ${(new Date).toISOString()}\nResources:\n- https://privy.io`;class pa{get meta(){return{connectorType:this.wallet?.connectorType,walletClientType:this.wallet?.walletClientType,chainId:this.wallet?.chainId,address:this.wallet?.address,disableSignup:this._meta.disableSignup}}async authenticate(){if(!this.client)throw new ke("SiweFlow has no client instance");try{if(this.preparedMessage&&this.signature)return await this.client.authenticateWithSiweInternal({message:this.preparedMessage,signature:this.signature,chainId:this.wallet?.chainId,walletClientType:this.walletClientType??this.wallet?.walletClientType,connectorType:this.connectorType??this.wallet?.connectorType,mode:this._meta.disableSignup?"no-signup":"login-or-sign-up"});if(!this.wallet)throw new ke("SiweFlow has no wallet instance");let{message:e,signature:t}=await this.sign();return await this.client.authenticateWithSiweInternal({message:e,signature:t,chainId:this.wallet.chainId,walletClientType:this.wallet.walletClientType,connectorType:this.wallet.connectorType,mode:this.meta.disableSignup?"no-signup":"login-or-sign-up"})}catch(e){throw Te(e)}}async link(){if(!this.client)throw new ke("SiweFlow has no client instance");try{if(!this.wallet)throw new ke("SiweFlow has no wallet instance");let{message:e,signature:t}=await this.sign();return await this.client.linkWithSiweInternal({message:e,signature:t,chainId:this.wallet.chainId,walletClientType:this.wallet.walletClientType,connectorType:this.wallet.connectorType})}catch(e){throw Te(e)}}async sign(){if(!this.client)throw new ke("SiweFlow has no client instance");if(await this.buildMessage(),!this.preparedMessage)throw new ke("Could not prepare SIWE message");if(!this.wallet)throw new ke("SiweFlow has no wallet instance");let e=await this.wallet.sign(this.preparedMessage);return{message:this.preparedMessage,signature:e}}async _getNonceOnce(){if(!this.client)throw new ke("SiweFlow has no client instance");if(!this.wallet)throw new ke("UI SiweFlow has no wallet instance");return await this.client.generateSiweNonce({address:this.wallet.address,captchaToken:this.captchaToken})}async buildMessage(){if(!this.client)throw new ke("SiweFlow has no client instance");if(!this.wallet)throw new ke("SiweFlow has no wallet instance");let e=this.wallet.address,t=this.wallet.chainId.replace("eip155:","");return this.nonce||(this.nonce=await this.getNonceOnce.execute()),this.preparedMessage=ha({address:e,chainId:t,nonce:this.nonce}),this.preparedMessage}constructor(e,t,n,r=!1,a){this._meta={disableSignup:!1},this.getNonceOnce=new Zr(this._getNonceOnce.bind(this)),this.wallet=t,this.captchaToken=n,this.client=e,this._meta.disableSignup=r,this.preparedMessage=a?.message,this.signature=a?.signature,this.walletClientType=a?.walletClientType,this.connectorType=a?.connectorType}}class wa{get meta(){return{connectorType:this.wallet.connectorType,walletClientType:this.wallet.walletClientType,disableSignup:this._meta.disableSignup,messageType:this._meta.messageType,address:this.wallet?.address}}set messageType(e){this._meta.messageType=e}async authenticate(){if(!this.client)throw new ke("SiwsFlow has no client instance");try{let{message:e,signature:t}=await this.sign();return await this.client.authenticateWithSiwsInternal({message:e,signature:t,walletClientType:this.wallet.walletClientType,connectorType:this.wallet.connectorType,mode:this.meta.disableSignup?"no-signup":"login-or-sign-up",messageType:this.meta.messageType})}catch(e){throw Te(e)}}async link(){if(!this.client)throw new ke("SiwsFlow has no client instance");try{let{message:e,signature:t}=await this.sign();return await this.client.linkWithSiwsInternal({message:e,signature:t,walletClientType:this.wallet.walletClientType,connectorType:this.wallet.connectorType,messageType:this.meta.messageType})}catch(e){throw Te(e)}}async sign(){let e,t;if(!this.client)throw new ke("SiwsFlow has no client instance");await this.buildMessage();let n="transaction"===this.meta.messageType;if(!this.preparedMessage)throw new ke("Could not prepare SIWS message");if(!n&&!this.wallet.provider.signMessage||n&&!this.wallet.provider.signTransaction)throw new ke("Wallet does not support the necessary signing methods");if(n&&this._plugin){let n=await this.wallet.provider.signTransaction({transaction:Bn.decode(this.preparedMessage)});e=Bn.encode(n.signedTransaction),t=this._plugin.getSignatureFromTransaction(n.signedTransaction,this.wallet.address)}else{e=this.preparedMessage;let n=await this.wallet.provider.signMessage({message:(new TextEncoder).encode(this.preparedMessage)});t=Bn.encode(n.signature)}return{message:e,signature:t}}async _getNonceOnce(){if(!this.client)throw new ke("SiwsFlow has no client instance");return await this.client.generateSiwsNonce({address:this.wallet.address,captchaToken:this.captchaToken})}async buildMessage(){if(!this.client)throw new ke("SiwsFlow has no client instance");let e=this.wallet.address;return this.nonce||(this.nonce=await this.getNonceOnce.execute()),"transaction"===this.meta.messageType&&this._plugin?this.preparedMessage=this._plugin.createSiwsMemoTransaction({address:e,nonce:this.nonce}):this.preparedMessage=On({address:e,nonce:this.nonce}),this.preparedMessage}constructor(e,t,n,r=!1,a="plain",i){this._meta={disableSignup:!1,messageType:"plain"},this.getNonceOnce=new Zr(this._getNonceOnce.bind(this)),this.wallet=e,this.captchaToken=n,this.client=t,this._meta.disableSignup=r,this._meta.messageType=a,this._plugin=i}}class ma{async authenticate(){if(!this.api)throw new ke("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new ke("phone number and sms code must be set prior to calling authenticate.");try{return await this.api.post(Ht,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode,mode:this.meta.disableSignup?"no-signup":"login-or-sign-up"})}catch(e){throw Te(e)}}async link(){if(!this.api)throw new ke("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new ke("phone number and sms code must be set prior to calling authenticate.");try{return await this.api.post(Bt,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode})}catch(e){throw Te(e)}}async sendSmsCode({phoneNumber:e,captchaToken:t,withPrivyUi:n}){if(!this.api)throw new ke("Auth flow has no API instance");if(e&&(this.meta.phoneNumber=e),t&&(this.meta.captchaToken=t),!this.meta.phoneNumber)throw new ke("phone nNumber must be set when initialzing authentication.");let r=Yr(n);try{return await this.api.post(Vt,{phoneNumber:this.meta.phoneNumber,token:this.meta.captchaToken},{headers:{...r}})}catch(e){throw Te(e)}}constructor({phoneNumber:e,captchaToken:t,disableSignup:n}){this.meta={phoneNumber:e,captchaToken:t,disableSignup:n??!1}}}class ya extends ma{async link(){if(!this.api)throw new ke("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode||!this.meta.oldPhoneNumber)throw new ke("Phone number, sms code, and an old phone number must be set prior to calling update.");try{return await this.api.post(Kt,{old_phone_number:this.meta.oldPhoneNumber,new_phone_number:this.meta.phoneNumber,code:this.meta.smsCode})}catch(e){throw Te(e)}}constructor(e,t,n){super({phoneNumber:t,captchaToken:n}),this.meta={phoneNumber:t,captchaToken:n,oldPhoneNumber:e,disableSignup:!1}}}const ga=/*#__PURE__*/i({enabled:!1,siteKey:"",provider:void 0,appId:void 0,token:void 0,error:void 0,status:"disabled",setToken:Se,setError:Se,setExecuting:Se,waitForResult:()=>Promise.resolve(""),ref:{current:null},remove:be,reset:Se,execute:Se});class fa extends _e{constructor(e,t,n){super(e||"Captcha failed"),this.type="Captcha",t instanceof Error&&(this.cause=t),this.privyErrorCode=n}}const va=({children:e,appId:n,captchaSiteKey:r,enabledCaptchaProvider:a})=>{let i=s(null),c=s(null),[d,u]=o(),[h,p]=o(),[w,m]=o(!1),y=l((()=>a?w||d||h?!w||d||h?d&&!h?{status:"success",token:d}:h?{status:"error",error:h}:{status:"ready"}:{status:"loading"}:{status:"ready"}:{status:"disabled"}),[a,d,h,w]),g=l((()=>a?"turnstile"===a?{remove:()=>{i.current?.remove(),m(!1),p(void 0),u(void 0)},reset:()=>{i.current?.reset(),m(!1),p(void 0),u(void 0)},execute:()=>{m(!0),i.current?.execute()},waitForResult:async()=>{try{return await z((()=>i.current?.getResponse()),{interval:200,timeout:2e4})}catch(e){throw new fa("Captcha failed",null,Ce.CAPTCHA_TIMEOUT)}}}:{remove:()=>{c.current?.removeCaptcha(),m(!1),p(void 0),u(void 0)},reset:()=>{c.current?.resetCaptcha(),m(!1),p(void 0),u(void 0)},execute:()=>{m(!0),c.current?.execute()},waitForResult:async()=>{try{return await z((()=>{let e=c.current?.getResponse();if(e)return e}),{interval:200,timeout:2e4})}catch(e){throw new fa("Captcha failed",null,Ce.CAPTCHA_TIMEOUT)}}}:null),[a]),f=l((()=>{if(!a||!g)return{...y,enabled:!1,siteKey:"",appId:n,setToken:Se,setError:Se,setExecuting:Se,waitForResult:()=>Promise.resolve(void 0),remove:be,reset:Se,execute:Se,provider:void 0,ref:{current:null}};let e={...y,enabled:!0,appId:n,setToken:u,setError:p,setExecuting:m};return"turnstile"===a?{...e,provider:"turnstile",ref:i,siteKey:r.split("t:")[1]??"",...g}:{...e,provider:"hcaptcha",ref:c,siteKey:r.split("h:")[1]??"",...g}}),[y,a,g,n,r]);/*#__PURE__*/return t(ga.Provider,{value:f,children:e})},Aa=()=>a(ga);async function ka(e){if(e.enabled){if("error"===e.status)throw new fa(e.error,null,Ce.CAPTCHA_FAILURE);return"success"===e.status?e.token:(e.execute(),await e.waitForResult())}}class Ta{async authenticate(){if(!this.api)throw new ke("Auth flow has no API instance");try{return await this.api.post($t,{captcha_token:this.meta.captchaToken,telegram_auth_result:this.meta.telegramAuthResult,telegram_web_app_data:this.meta.telegramWebAppData,mode:this.meta.disableSignup?"no-signup":"login-or-sign-up"})}catch(e){throw Te(e)}}async link(){if(!this.api)throw new ke("Auth flow has no API instance");try{return await this.api.post(Gt,{telegram_auth_result:this.meta.telegramAuthResult,telegram_web_app_data:this.meta.telegramWebAppData})}catch(e){throw Te(e)}}constructor(e,t=!1){this.meta={disableSignup:!1},this.meta={captchaToken:e,disableSignup:!1},this.meta.disableSignup=t}}function Ca(e){let t={detail:"",retryable:!1};return e?.privyErrorCode===Ce.LINKED_TO_ANOTHER_USER&&(t.detail="This account has already been linked to another user."),e?.privyErrorCode===Ce.DISALLOWED_LOGIN_METHOD&&(t.detail="Login with Telegram not allowed."),e?.privyErrorCode===Ce.INVALID_DATA&&(t.retryable=!0,t.detail="Something went wrong. Try again."),e?.privyErrorCode===Ce.CANNOT_LINK_MORE_OF_TYPE&&(t.retryable=!0,t.detail="Something went wrong. Try again."),e?.privyErrorCode===Ce.INVALID_CREDENTIALS&&(t.retryable=!0,t.detail="Something went wrong. Try again."),e?.privyErrorCode===Ce.TOO_MANY_REQUESTS&&(t.detail="Too many requests. Please wait before trying again."),e?.privyErrorCode===Ce.TOO_MANY_REQUESTS&&e.message.includes("rate limit")&&(t.detail="Request limit reached for Telegram. Please wait a moment and try again."),e instanceof fa&&(t.retryable=!0,t.detail="Something went wrong. Try again."),t}function _a(e){return Object.fromEntries(decodeURIComponent(e).split("&").map((e=>e.split("=").map(decodeURIComponent))))}function Sa(){let e=new URL(window.location.href);e.searchParams.delete("id"),e.searchParams.delete("hash"),e.searchParams.delete("auth_date"),e.searchParams.delete("first_name"),e.searchParams.delete("last_name"),e.searchParams.delete("username"),e.searchParams.delete("photo_url"),e.hash="",window.history.replaceState({},"",e)}let ba=/*#__PURE__*/u((()=>import("./TurnstileWrapper-Co-t5mTh.mjs"))),Ea=/*#__PURE__*/u((()=>import("./HCaptchaWrapper-CUi9LJsp.mjs")));const Ia=n=>{let r=Aa();return c((()=>r.remove),[r.remove]),r.enabled&&r.provider?/*#__PURE__*/t(d,{fallback:null,children:/*#__PURE__*/e("div",{className:"hidden h-0 w-0",children:["turnstile"===r.provider&&/*#__PURE__*/t(ba,{...n,captchaContext:r}),"hcaptcha"===r.provider&&/*#__PURE__*/t(Ea,{...n,captchaContext:r})]})}):null};var Pa=/*#__PURE__*/Object.freeze({__proto__:null,AccountNotFoundScreen:()=>import("./AccountNotFoundScreen-DzQ8Ded6.mjs"),AffirmativeConsentScreen:()=>import("./AffirmativeConsentScreen-CGLpvQm4.mjs"),AllowlistRejectionScreen:()=>import("./AllowlistRejectionScreen-0T0W1npW.mjs"),AuthenticateWithWalletScreen:()=>import("./AuthenticateWithWalletScreen-aIIbB44q.mjs"),AwaitingEvmToSolBridgingScreen:()=>import("./AwaitingEvmToSolBridgingScreen-Bcx6oRJE.mjs"),AwaitingExternalEthereumTransferScreen:()=>import("./AwaitingExternalEthereumTransferScreen-BlmM5W1W.mjs"),AwaitingPasswordlessCodeScreen:()=>import("./AwaitingPasswordlessCodeScreen-DxV44L8v.mjs"),AwaitingSolToEvmBridgingScreen:()=>import("./AwaitingSolToEvmBridgingScreen-C_VwI_Sw.mjs"),CaptchaScreen:()=>import("./CaptchaScreen-BeoBh2yB.mjs"),CoinbaseOnrampStatusScreen:()=>import("./CoinbaseOnrampStatusScreen-h359lw0u.mjs"),ConnectLedgerScreen:()=>import("./ConnectLedgerScreen-DlzVqbV7.mjs"),ConnectOnlyLandingScreen:()=>import("./ConnectOnlyLandingScreen-wbu-70B6.mjs"),ConnectOnlyStatusScreen:()=>import("./ConnectOnlyStatusScreen-CbWmfcm8.mjs"),ConnectOrCreateScreen:()=>import("./ConnectOrCreateScreen-CSKKpNhC.mjs"),ConnectionStatusScreen:()=>import("./ConnectionStatusScreen-BCZOSVuo.mjs"),CrossAppAuthScreen:()=>import("./CrossAppAuthScreen-C9Y8UmMT.mjs"),DelegatedActionsConsentScreen:()=>import("./DelegatedActionsConsentScreen-CRlv1sFS.mjs"),DelegatedActionsRevokeScreen:()=>import("./DelegatedActionsRevokeScreen-CfOOZLtD.mjs"),EmbeddedWalletConnectingScreen:()=>import("./EmbeddedWalletConnectingScreen-DuSxBQbx.mjs"),EmbeddedWalletCreatedScreen:()=>import("./EmbeddedWalletCreatedScreen--ZpH1G0k.mjs"),EmbeddedWalletKeyExportScreen:()=>import("./EmbeddedWalletKeyExportScreen-CSJq1Sik.mjs"),EmbeddedWalletOnAccountCreateScreen:()=>import("./EmbeddedWalletOnAccountCreateScreen-DOSya90v.mjs"),EmbeddedWalletPasswordCreateScreen:()=>import("./RecoveryPasswordCreateScreen--aWRhenB.mjs"),EmbeddedWalletPasswordUpdateScreen:()=>import("./EmbeddedWalletPasswordUpdateScreen-C_es2EpS.mjs"),EmbeddedWalletPasswordUpdateSplashScreen:()=>import("./EmbeddedWalletPasswordUpdateSplashScreen-DhwnqiCK.mjs"),ErrorScreen:()=>import("./ErrorScreen-DZ153hPv.mjs"),FarcasterConnectStatusScreen:()=>import("./FarcasterConnectStatusScreen-CwQhh_aC.mjs"),FarcasterSignerStatusScreen:()=>import("./FarcasterSignerStatusScreen-D1SKEl4x.mjs"),FundSolWalletWithExternalSolanaWallet:()=>import("./FundSolWalletWithExternalSolanaWallet-CH85fmbL.mjs"),FundWithBankDepositScreen:()=>import("./FundWithBankDepositScreen-BJk-wxSq.mjs"),FundingAmountEditScreen:()=>import("./FundingEditAmountScreen-C_YGQD1r.mjs"),FundingMethodSelectionScreen:()=>import("./FundingMethodSelectionScreen-gGZKP4LD.mjs"),InAppBrowserLoginNotPossible:()=>import("./InAppBrowserLoginNotPossible-BiwxWFju.mjs"),InstallWalletScreen:()=>import("./InstallWalletScreen-DHPONpNA.mjs"),LandingScreen:()=>import("./LandingScreen-DBZbonr_.mjs"),LinkConflictScreen:()=>import("./LinkConflictScreen-D0TlabXV.mjs"),LinkEmailScreen:()=>import("./LinkEmailScreen-D9zKrb4E.mjs"),LinkPasskeyScreen:()=>import("./LinkPasskeyScreen-3_thbT6t.mjs"),LinkPhoneScreen:()=>import("./LinkPhoneScreen-BwBdaLqt.mjs"),LoginFailedScreen:()=>import("./LoginFailedScreen-Dxi-7tx8.mjs"),ManualTransferScreen:()=>import("./ManualTransferScreen-e347H8JC.mjs"),MfaAuthEnrollmentFlowScreen:()=>import("./MfaAuthEnrollmentFlowScreen-BUF154dJ.mjs"),MfaAuthVerifyFlowScreen:()=>import("./MfaAuthVerifyFlowScreen-BJ4ZNRWe.mjs"),MfaEnrollmentFlowScreen:()=>import("./MfaEnrollmentFlowScreen-B5DfdOkM.mjs"),MoonpayStatusScreen:()=>import("./MoonpayStatusScreen-BeZtoeAo.mjs"),OAuthStatusScreen:()=>import("./OAuthStatusScreen-BVLexXQC.mjs"),PasskeySelectSignupOrLogin:()=>import("./PasskeySelectSignupOrLogin-CejGrqSb.mjs"),PasskeyStatusScreen:()=>import("./PasskeyStatusScreen-BrDLZfaA.mjs"),PasswordRecoveryScreen:()=>import("./PasswordRecoveryScreen-Bks4ITku.mjs"),RecoveryOAuthScreen:()=>import("./RecoveryOAuthStatusScreen-TsrFc2KU.mjs"),RecoverySelectionScreen:()=>import("./RecoverySelectionScreen-DJ33E1hd.mjs"),SendTransactionScreen:()=>import("./index-CIjObncO.mjs"),SetAutomaticRecoveryScreen:()=>import("./SetAutomaticRecoveryScreen-DelsQl1S.mjs"),SignRequestScreen:()=>import("./SignRequestScreen-C6XvfvXV.mjs"),StandardSignAndSendTransactionScreen:()=>import("./StandardSignAndSendTransactionScreen-FQcyAQoq.mjs"),TelegramAuthScreen:()=>import("./TelegramAuthScreen-LB2IdLqW.mjs"),TransferFromWalletScreen:()=>import("./TransferFromWalletScreen-BLLYNl1T.mjs"),UpdateEmailScreen:()=>import("./UpdateEmailScreen-DGAco54E.mjs"),UpdatePhoneScreen:()=>import("./UpdatePhoneScreen-CLCixHYj.mjs"),UserLimitReachedScreen:()=>import("./UserLimitReachedScreen-ClahBH0m.mjs"),WalletInterstitialScreen:()=>import("./WalletInterstitialScreen-CBzg1He2.mjs")});function Wa(e){Gn("configureMfa",e)}const Ua=Xn((()=>({inProgressMfaFlow:void 0})));const Na=Kn`
|
|
1
|
+
import{jsxs as e,jsx as t,Fragment as n}from"react/jsx-runtime";import r,{useContext as a,createContext as i,useRef as s,useState as o,useMemo as l,useEffect as c,Suspense as d,lazy as u,useCallback as h}from"react";import p,{DEFAULT_SUPPORTED_CHAIN_IDS as w,rpc as m,PrivyClientError as y,getWallet as g,updateWallet as f,generateAuthorizationSignature as v}from"@privy-io/js-sdk-core";import{v4 as A}from"uuid";import*as k from"jose";import{base64url as T}from"jose";import{u as C,a as _,g as S,i as b,b as E,c as I,d as P,e as W,f as U,P as N,M as O,h as R,j as M,k as x,l as F}from"./get-is-unified-wallet-Boa8DYrQ.mjs";import D from"eventemitter3";import{E as L,P as j,t as q,p as z,H,u as B,L as V,g as K,s as $,a as G,b as Y,c as J,i as Q,d as Z,e as X,R as ee,f as te,h as ne,j as re,k as ae,l as ie,m as se,n as oe,M as le,o as ce,q as de,S as ue,r as he,v as pe,w as we,x as me}from"./useActiveWallet-3RHPIBxJ.mjs";import{u as ye,t as ge,U as fe,g as ve}from"./useWallets-CR0z5IIt.mjs";import{P as Ae,a as ke,f as Te,b as Ce,c as _e,n as Se,d as be,u as Ee,e as Ie,I as Pe,g as We,h as Ue,i as Ne}from"./internal-context-Z-fyxadS.mjs";import{f as Oe,s as Re,W as Me,i as xe,a as Fe,P as De,e as Le,p as je,b as qe,l as ze}from"./use-export-wallet-CV4p7L0b.mjs";import{createCoinbaseWalletSDK as He}from"@coinbase/wallet-sdk";import{toViemTransactionSerializable as Be,STRING_TO_NUMBER_TXN_TYPE as Ve}from"@privy-io/ethereum";import{P as Ke,C as $e,a as Ge,H as Ye,O as Je,S as Qe,u as Ze,b as Xe,c as et,D as tt,d as nt,g as rt,V as at,R as it,e as st,f as ot,h as lt,i as ct,j as dt,I as ut,k as ht,l as pt,m as wt,W as mt}from"./context-WTldtXS8.mjs";import{createStore as yt}from"mipd";import{isMobile as gt,isIOS as ft,isAndroid as vt,isSafari as At}from"react-device-detect";import{toHex as kt,getAddress as Tt,isHex as Ct,hashAuthorization as _t}from"viem/utils";import{trigger as St}from"@privy-io/popup";import{u as bt,p as Et,a as It,b as Pt,f as Wt,c as Ut,d as Nt,e as Ot,o as Rt,g as Mt,h as xt,i as Ft,j as Dt,k as Lt,l as jt,m as qt,n as zt,q as Ht,r as Bt,s as Vt,t as Kt,v as $t,w as Gt,x as Yt,y as Jt,z as Qt,A as Zt,B as Xt,C as en,D as tn,E as nn,F as rn,G as an,H as sn,I as on,J as ln,K as cn,L as dn,M as un,N as hn,O as pn,P as wn,Q as mn,R as yn,S as gn,T as fn,U as vn,V as An,W as kn,X as Tn,Y as Cn,Z as _n,_ as Sn,$ as bn,a0 as En,a1 as In,a2 as Pn,a3 as Wn,a4 as Un}from"./paths-3HW55qZg.mjs";import{o as Nn,p as On,d as Rn,r as Mn,b as xn,s as Fn,a as Dn,c as Ln,u as jn,S as qn,e as zn,f as Hn}from"./usePrivy-6nkpbErN.mjs";import{base64 as Bn}from"@scure/base";import{styled as Vn,createGlobalStyle as Kn,css as $n}from"styled-components";import{u as Gn,a as Yn,p as Jn,e as Qn,P as Zn}from"./events-context-CI0iqAXA.mjs";import{create as Xn}from"zustand";import{Transition as er,Dialog as tr,TransitionChild as nr,DialogPanel as rr}from"@headlessui/react";import{EthereumProvider as ar,OPTIONAL_METHODS as ir,OPTIONAL_EVENTS as sr}from"@walletconnect/ethereum-provider";import{constructURL as or}from"@privy-io/urls";import{toHex as lr,zeroAddress as cr,getAddress as dr,createWalletClient as ur,http as hr,parseSignature as pr}from"viem";import{u as wr,P as mr}from"./PrivyPluginContext-2QN2dVUw.mjs";import{D as yr}from"./getEmbeddedConnectedWallet-JzK4iD-L.mjs";import{g as gr,a as fr}from"./getPublicClient-B4uPLKn-.mjs";import{ofetch as vr}from"ofetch";import Ar from"js-cookie";import{F as kr}from"./frame-uzTmvtww.mjs";import{MfaAuthPasskeyVerify as Tr,MfaAuthPasskeyInit as Cr,MfaAuthTotpVerify as _r,MfaAuthPasskeyEnrollment as Sr,MfaAuthTotpUnenroll as br,MfaAuthTotpEnroll as Er,MfaAuthTotpInit as Ir}from"@privy-io/routes";import{selectPaymentRequirements as Pr,createPaymentHeader as Wr}from"x402/client";import{InvalidInputError as Ur}from"@privy-io/api-base";import{areAddressesEqual as Nr}from"@privy-io/are-addresses-equal";import{toAccount as Or}from"viem/accounts";import{u as Rr}from"./use-sign-with-user-signer-Do5Oi_rb.mjs";class Mr{static parse(e){try{return new Mr(e)}catch(e){return null}}static throwIfNotWellFormedJwt(e){return k.decodeJwt(e),e}get subject(){return this._decoded.sub}get expiration(){return this._decoded.exp}get issuer(){return this._decoded.iss}get audience(){return this._decoded.aud}isExpired(e=0){return Date.now()>=1e3*(this.expiration-e)}constructor(e){this.value=e,this._decoded=k.decodeJwt(e)}}class xr extends Mr{static parse(e){try{return new xr(e)}catch(e){return null}}get appId(){return this._decoded.aid?this._decoded.aid:this.audience}}const Fr=({style:n,...r})=>/*#__PURE__*/e("svg",{viewBox:"0 0 1024 1024",fill:"none",xmlns:"http://www.w3.org/2000/svg",style:{height:"28px",width:"28px",...n},...r,children:[/*#__PURE__*/t("rect",{width:"1024",height:"1024",fill:"#0052FF",rx:100,ry:100}),/*#__PURE__*/t("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M152 512C152 710.823 313.177 872 512 872C710.823 872 872 710.823 872 512C872 313.177 710.823 152 512 152C313.177 152 152 313.177 152 512ZM420 396C406.745 396 396 406.745 396 420V604C396 617.255 406.745 628 420 628H604C617.255 628 628 617.255 628 604V420C628 406.745 617.255 396 604 396H420Z",fill:"white"})]}),Dr="data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PScwIDAgMTAyNCAxMDI0JyBmaWxsPSdub25lJyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnIHN0eWxlPSdoZWlnaHQ6MjhweDt3aWR0aDoyOHB4Jz48cmVjdCB3aWR0aD0nMTAyNCcgaGVpZ2h0PScxMDI0JyBmaWxsPScjMDA1MkZGJyByeD0nMTAwJyByeT0nMTAwJz48L3JlY3Q+PHBhdGggZmlsbC1ydWxlPSdldmVub2RkJyBjbGlwLXJ1bGU9J2V2ZW5vZGQnIGQ9J00xNTIgNTEyQzE1MiA3MTAuODIzIDMxMy4xNzcgODcyIDUxMiA4NzJDNzEwLjgyMyA4NzIgODcyIDcxMC44MjMgODcyIDUxMkM4NzIgMzEzLjE3NyA3MTAuODIzIDE1MiA1MTIgMTUyQzMxMy4xNzcgMTUyIDE1MiAzMTMuMTc3IDE1MiA1MTJaTTQyMCAzOTZDNDA2Ljc0NSAzOTYgMzk2IDQwNi43NDUgMzk2IDQyMFY2MDRDMzk2IDYxNy4yNTUgNDA2Ljc0NSA2MjggNDIwIDYyOEg2MDRDNjE3LjI1NSA2MjggNjI4IDYxNy4yNTUgNjI4IDYwNFY0MjBDNjI4IDQwNi43NDUgNjE3LjI1NSAzOTYgNjA0IDM5Nkg0MjBaJyBmaWxsPSd3aGl0ZSc+PC9wYXRoPjwvc3ZnPg==",Lr="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADAAAAAwCAYAAABXAvmHAAAAAXNSR0IArs4c6QAAALZJREFUaEPtmjEOhDAMBNc/O14GvOzys3CAKK6eAlmaVGl2Zc+kTOU685vkc9/bnD2prZK5/TZY24z9P+g4F5hNh7/GdoG37WlAA5CATwgCxHENYISwQAMQII5rACOEBRqAAHFcAxghLNAABIjjGsAIYYEGIEAc1wBGCAs0AAHiuAYwQligAQgQxzWAEcICDUCAOK4BjBAWaAACxHENYISwQAMQII6fBjr+VHkW3+u+tfyxMpJaDgYzYxb/ALZVAAAAAElFTkSuQmCC";let jr,qr;class zr extends L{async initialize(){await this.importPromise,await this.syncAccounts(),this.initialized=!0,this.emit("initialized")}async connect(e){return e.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}disconnect(){this.proxyProvider.walletProvider.disconnect(),this.onDisconnect()}get walletBranding(){return{name:this.displayName,icon:Lr,id:"com.coinbase.wallet"}}async promptConnection(){try{await this.importPromise;let e=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!e||0===e.length||!e[0])throw new Ae("Unable to retrieve accounts");this.connected=!0,await this.syncAccounts([e[0]])}catch(e){throw Oe(e)}}constructor(e,t,n,r,a){super("base_account",e,t,n),this.connectorType="base_account",this.walletClientType="base_account",this.displayName="Base",this.setBaseAccountSdk=a,this.proxyProvider=new j(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.baseAccountConfig={...r,appChainIds:[t.id].concat(e.map((e=>e.id)))},jr?(this.proxyProvider.setWalletProvider(jr.getProvider()),this.setBaseAccountSdk(jr)):this.importPromise=import("@base-org/account").then((({createBaseAccountSDK:e})=>{jr=e(this.baseAccountConfig),this.proxyProvider.setWalletProvider(jr.getProvider()),this.setBaseAccountSdk(jr)})).catch(console.error)}}let Hr=[1,11155111,137,10,8453,84532,42161,7777777,43114,56];class Br extends L{async initialize(){await this.syncAccounts(),this.initialized=!0,this.emit("initialized")}async connect(e){return e.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}disconnect(){this.proxyProvider.walletProvider.disconnect(),this.onDisconnect()}get walletBranding(){return{name:this.displayName,icon:Dr,id:"com.coinbase.wallet"}}async promptConnection(){try{let e=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!e||0===e.length||!e[0])throw new Ae("Unable to retrieve accounts");this.connected=!0,await this.syncAccounts([e[0]])}catch(e){throw Oe(e)}}updateConnectionPreference(e){this.coinbaseWalletConfig={...this.coinbaseWalletConfig,preference:{...this.coinbaseWalletConfig.preference,options:e}},this.walletClientType="smartWalletOnly"===e?"coinbase_smart_wallet":"coinbase_wallet",qr=He({...this.coinbaseWalletConfig}),this.proxyProvider.setWalletProvider(qr.getProvider())}constructor(e,t,n,r){if(super("coinbase_wallet",e,t,n),this.connectorType="coinbase_wallet",this.displayName="Coinbase Wallet",this.proxyProvider=new j(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.coinbaseWalletConfig={...r,appChainIds:[t.id].concat(e.map((e=>e.id)))},this.walletClientType="smartWalletOnly"===this.coinbaseWalletConfig.preference?.options?"coinbase_smart_wallet":"coinbase_wallet","coinbase_smart_wallet"===this.walletClientType&&(this.displayName="Coinbase Smart Wallet"),!qr){let e="eoaOnly"!==this.coinbaseWalletConfig.preference?.options?(this.coinbaseWalletConfig.appChainIds??[]).filter((e=>!Hr.includes(e))):[];e.length>0&&!e.every((e=>w.has(e)))&&console.info(`The configured chains are not supported by Coinbase Smart Wallet: ${e.join(", ")}`),qr=He(this.coinbaseWalletConfig)}this.proxyProvider.setWalletProvider(qr.getProvider())}}const Vr=({...e})=>/*#__PURE__*/t("svg",{width:"15",height:"15",viewBox:"0 0 15 15",fill:"none",xmlns:"http://www.w3.org/2000/svg",...e,children:/*#__PURE__*/t("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M2.37126 11.0323C2.37126 12.696 3.90598 13.4421 5.40654 13.4468C8.91753 13.4468 12.8021 11.2897 12.7819 7.67984C12.7673 5.07728 10.3748 2.86167 7.54357 2.88296C4.8495 2.88296 2.21821 4.6411 2.21803 7.03628C2.21803 7.67951 2.58722 8.30178 3.55231 8.37184C2.74763 9.16826 2.37126 10.1225 2.37126 11.0323ZM7.55283 8.68012C8.11562 8.68012 8.57186 8.13217 8.57186 7.45624C8.57186 6.78032 8.11562 6.23237 7.55283 6.23237C6.99003 6.23237 6.53379 6.78032 6.53379 7.45624C6.53379 8.13217 6.99003 8.68012 7.55283 8.68012ZM10.4747 8.68012C11.0375 8.68012 11.4937 8.13217 11.4937 7.45625C11.4937 6.78032 11.0375 6.23237 10.4747 6.23237C9.91186 6.23237 9.45562 6.78032 9.45562 7.45625C9.45562 8.13217 9.91186 8.68012 10.4747 8.68012Z",fill:e.color||"var(--privy-color-foreground-3)"})});class Kr extends L{async initialize(){await this.syncAccounts(),this.initialized=!0,this.emit("initialized")}async connect(e){return await this.isConnected()?(await this.proxyProvider.request({method:"wallet_switchEthereumChain",params:[q(e?.chainId||"0x1")]}),this.getConnectedWallet()):null}get walletBranding(){return{name:"Privy Wallet",icon:Vr,id:"io.privy.wallet"}}disconnect(){this.connected=!1}async promptConnection(){}constructor({provider:e,chains:t,defaultChain:n,rpcConfig:r,imported:a,walletIndex:i}){super("privy",t,n,r),this.connectorType="embedded",this.proxyProvider=e,this.walletIndex=i,a&&(this.connectorType="embedded_imported"),this.subscribeListeners()}}async function $r(){let e=xs();return e?e.getAccessToken():Promise.resolve(Re.get(Ke)||Re.get($e)||null)}const Gr=["eth_sign","eth_populateTransactionRequest","eth_signTransaction","personal_sign","eth_signTypedData_v4","csw_signUserOperation","secp256k1_sign"];function Yr(e){return e?{"privy-ui":"t"}:void 0}class Jr{async authenticate(){if(!this.api)throw new ke("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new ke("Email and email code must be set prior to calling authenticate.");try{return await this.api.post(Et,{email:this.meta.email,code:this.meta.emailCode,mode:this.meta.disableSignup?"no-signup":"login-or-sign-up"})}catch(e){throw Te(e)}}async link(){if(!this.api)throw new ke("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new ke("Email and email code must be set prior to calling authenticate.");try{return await this.api.post(It,{email:this.meta.email,code:this.meta.emailCode})}catch(e){throw Te(e)}}async sendCodeEmail({email:e,captchaToken:t,withPrivyUi:n}){if(!this.api)throw new ke("Auth flow has no API instance");if(e&&(this.meta.email=e),t&&(this.meta.captchaToken=t),!this.meta.email)throw new ke("Email must be set when initialzing authentication.");let r=Yr(n);try{return await this.api.post(Pt,{email:this.meta.email,token:this.meta.captchaToken},{headers:{...r}})}catch(e){throw Te(e)}}constructor({email:e,captchaToken:t,disableSignup:n}){this.meta={email:e,captchaToken:t,disableSignup:n??!1}}}class Qr extends Jr{async link(){if(!this.api)throw new ke("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode||!this.meta.oldAddress)throw new ke("Email, email code, and an old email address must be set prior to calling update.");try{return await this.api.post(bt,{oldAddress:this.meta.oldAddress,newAddress:this.meta.email,code:this.meta.emailCode})}catch(e){throw Te(e)}}constructor(e,t,n){super({email:t,captchaToken:n}),this.meta={email:t,captchaToken:n,oldAddress:e,disableSignup:!1}}}class Zr{execute(e){return null===this.promise&&(this.promise=(async()=>{try{return await this.fn(e)}finally{this.promise=null}})()),this.promise}constructor(e){this.promise=null,this.fn=e}}class Xr{get meta(){return this._meta}async authenticate(){if(!this.api)throw new ke("Auth flow has no API instance");if(!this.meta.channelToken)throw new ke("Auth flow must be initialized first");try{let e=await this.api.post(Wt,{channel_token:this.meta.channelToken,message:this.message,signature:this.signature,fid:this.fid,mode:this.meta.disableSignup?"no-signup":"login-or-sign-up"});if(!e)throw new ke("No response from authentication");return e}catch(e){throw Te(e)}}async link(){if(!this.api)throw new ke("Auth flow has no API instance");try{return await this.api.post(Ut,{channel_token:this.meta.channelToken,message:this.message,signature:this.signature,fid:this.fid})}catch(e){throw Te(e)}}async _startChannelOnce(){if(!this.api)throw new ke("Auth flow has no API instance");let e=await this.api.post(Nt,{token:this.captchaToken});gt&&!ft&&e.connect_uri&&Nn(e.connect_uri,"_blank"),this._meta={...this._meta,connectUri:e.connect_uri,channelToken:e.channel_token}}async initializeFarcasterConnect(){if(!this.api)throw new ke("Auth flow has no API instance");await this.startChannelOnce.execute()}async _pollForReady(){if(!this.api)throw new ke("Auth flow has no API instance");if(!this.meta.channelToken)throw new ke("Auth flow must be initialized first");let e=await this.api.get(Ot,{headers:{"farcaster-channel-token":this.meta.channelToken}});return"completed"===e.state&&(this.message=e.message,this.signature=e.signature,this.fid=e.fid,!0)}constructor(e,t=!1){this._meta={disableSignup:!1},this.captchaToken=e,this.startChannelOnce=new Zr(this._startChannelOnce.bind(this)),this.pollForReady=new Zr(this._pollForReady.bind(this)),this._meta.disableSignup=t}}function ea(){return"undefined"!=typeof window&&"chrome-extension:"===window.location.protocol&&"chrome"in window}function ta(){if(!ea())return;let e=window.chrome;return e?.runtime?.id}function na(){if(!ea())return!1;let e=window.chrome;return"function"==typeof e?.identity?.launchWebAuthFlow}async function ra(e){return new Promise(((t,n)=>{na()?window.chrome.identity.launchWebAuthFlow({url:e,interactive:!0},(async e=>{try{let n=function(){if(!ea())return;let e=window.chrome;return e?.runtime?.lastError?.message}();if(n||!e){let e=`WebAuthFlow failed: ${n||"Response URI missing"}`;throw Error(e)}let r=new URL(e),a=ta();if(!a)throw Error("Invalid extension context");if("chrome-extension:"===r.protocol){if(r.hostname!==a)throw Error("Invalid responseUri origin")}else{if("https:"!==r.protocol)throw Error("Invalid responseUri protocol");{let e=r.hostname.split(".");if(3!==e.length||"chromiumapp"!==e[1]||"org"!==e[2]||e[0]!==a)throw Error("Invalid responseUri origin")}}let i=r.searchParams.get("privy_oauth_state"),s=r.searchParams.get("privy_oauth_code");if(!i||!s)throw Error("Invalid responseUri - missing required parameters");t({privyOAuthState:i,privyOAuthCode:s})}catch(e){n(e)}})):n(Error("Chrome identity API not available"))}))}function aa(e){return crypto.getRandomValues(new Uint8Array(e))}function ia(){return T.encode(aa(36))}function sa(){return ia()}async function oa(e,t="S256"){if("S256"!=t)return e;{let t=await async function(e){let t=(new TextEncoder).encode(e);return new Uint8Array(await crypto.subtle.digest("SHA-256",t))}(e);return T.encode(t)}}class la{addCaptchaToken(e){this.meta.captchaToken=e}isActive(){return!!(this.meta.authorizationCode&&this.meta.stateCode&&this.meta.provider)}async authenticate(){if(!this.api)throw new ke("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new ke("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling authenticate.");if("undefined"===this.meta.authorizationCode)throw new ke("User denied confirmation during OAuth flow");let e=function(){let e=Re.get(Ge);if(!e)throw new ke("Authentication error.");return e}();try{let t=await this.api.post(Rt,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode,code_verifier:e,mode:this.meta.disableSignup?"no-signup":"login-or-sign-up"});return Re.del(Ge),Re.del(Ye),Re.del(Je),t}catch(e){let t=Te(e);if(t.privyErrorCode)throw new ke(t.message||"Invalid code during OAuth flow.",void 0,t.privyErrorCode);if("User denied confirmation during OAuth flow"===t.message)throw new ke("Invalid code during oauth flow.",void 0,Ce.OAUTH_USER_DENIED);throw new ke("Invalid code during OAuth flow.",void 0,Ce.UNKNOWN_AUTH_ERROR)}}async link(){if(!this.api)throw new ke("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new ke("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling link.");if("undefined"===this.meta.authorizationCode)throw new ke("User denied confirmation during OAuth flow");let e=Re.get(Ge);if(!e)throw new ke("Authentication error.");try{let t=await this.api.post(Mt,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode,code_verifier:e});return Re.del(Ge),t}catch(e){throw Te(e)}}async getAuthorizationUrl(){if(!this.api)throw new ke("Auth flow has no API instance");if(!this.meta.provider)throw new ke("Provider must be set when initializing OAuth authentication.");let e=ia();Re.put(Ge,e);let t=sa();Re.put(Qe,t);let n=await oa(e);this.meta.withPrivyUi||Re.put(Ye,!0),this.meta.disableSignup?Re.put(Je,!0):Re.del(Je);let r=Yr(this.meta.withPrivyUi),a=window.location.href,i=function(){let e=ta();if(e)return`https://${e}.chromiumapp.org`}();i&&(a=i);try{return await this.api.post(xt,{provider:this.meta.provider,redirect_to:this.meta.customOAuthRedirectUrl||a,token:this.meta.captchaToken,code_challenge:n,state_code:t},{headers:{...r}})}catch(e){throw Te(e)}}constructor(e){this.meta=e}}function ca(){let e=new URLSearchParams(window.location.search),t=e.get("privy_oauth_code"),n=e.get("privy_oauth_state"),r=e.get("privy_oauth_provider");if(!t||!n||!r)return{inProgress:!1};let a=!1;try{a=!!window.opener.location.origin}catch{}return{inProgress:!0,authorizationCode:t,stateCode:n,provider:r,withPrivyUi:!Re.get(Ye),popupFlow:null!==window.opener&&a,disableSignup:!!Re.get(Je)}}function da(){let e=new URL(window.location.href);e.searchParams.delete("privy_oauth_code"),e.searchParams.delete("privy_oauth_provider"),e.searchParams.delete("privy_oauth_state"),Re.del(Qe),window.history.replaceState({},"",e)}class ua{async initRegisterFlow(e){if(!this.api)throw new ke("Auth flow has no API instance");this.authenticateForRegistration=!0,this.meta.initRegisterResponse=await this.initRegisterOnce.execute(e)}async initAuthenticationFlow(e){if(!this.api)throw new ke("Auth flow has no API instance");this.authenticateForRegistration=!1,this.meta.initAuthenticateResponse=await this.initAuthenticateOnce.execute(e)}async initLinkFlow(){if(!this.api)throw new ke("Auth flow has no API instance");this.meta.initLinkResponse=await this.initLinkOnce.execute()}async register(){let e=await import("@simplewebauthn/browser");if(!this.api)throw new ke("Auth flow has no API instance");if(!e.browserSupportsWebAuthn())throw new ke("WebAuthn is not supported in this browser");this.meta.initRegisterResponse||(this.meta.initRegisterResponse=await this.initRegisterOnce.execute());try{let t=this.meta.initRegisterResponse.options,n=await e.startRegistration({optionsJSON:this._transformInitLinkOptionsToCamelCase(t)});return this.meta.setPasskeyAuthState?.({status:"submitting-response"}),await this.api.post(Ft,{relying_party:this.meta.initRegisterResponse.relying_party,authenticator_response:this._transformRegistrationResponseToSnakeCase(n)})}catch(e){if("NotAllowedError"===e.name)throw new ke("Passkey request timed out or rejected by user.",void 0,Ce.PASSKEY_NOT_ALLOWED);throw Te(e)}}async authenticate(){if(this.authenticateForRegistration)return this.register();let e=await import("@simplewebauthn/browser");if(!this.api)throw new ke("Auth flow has no API instance");if(!e.browserSupportsWebAuthn())throw new ke("WebAuthn is not supported in this browser");this.meta.initAuthenticateResponse||(this.meta.initAuthenticateResponse=await this.initAuthenticateOnce.execute());let t=this.meta.allowedCredentialsIds?.map((e=>({type:"public-key",id:e})))??this.meta.initAuthenticateResponse.options.allow_credentials;try{let n=await e.startAuthentication({optionsJSON:this._transformInitAuthenticateOptionsToCamelCase({...this.meta.initAuthenticateResponse.options,allow_credentials:t})});return this.meta.setPasskeyAuthState?.({status:"submitting-response"}),await this.api.post(Dt,{relying_party:this.meta.initAuthenticateResponse.relying_party,challenge:this.meta.initAuthenticateResponse.options.challenge,authenticator_response:this._transformAuthenticationResponseToSnakeCase(n)})}catch(e){if("NotAllowedError"===e.name)throw new ke("Passkey request timed out or rejected by user.",void 0,Ce.PASSKEY_NOT_ALLOWED);throw Te(e)}}async link(){let e=await import("@simplewebauthn/browser");if(!this.api)throw new ke("Auth flow has no API instance");if(!e.browserSupportsWebAuthn())throw new ke("WebAuthn is not supported in this browser");this.meta.initLinkResponse||(this.meta.initLinkResponse=await this.initLinkOnce.execute());try{let t=this.meta.initLinkResponse.options,n=await e.startRegistration({optionsJSON:this._transformInitLinkOptionsToCamelCase(t)});return this.meta.setPasskeyAuthState?.({status:"submitting-response"}),await this.api.post(Lt,{relying_party:this.meta.initLinkResponse.relying_party,authenticator_response:this._transformRegistrationResponseToSnakeCase(n)})}catch(e){if("NotAllowedError"===e.name)throw new ke("Passkey request timed out or rejected by user.",void 0,Ce.PASSKEY_NOT_ALLOWED);throw Te(e)}}async _initRegisterOnce(e){if(!this.api)throw new ke("Auth flow has no API instance");let t=Yr(e);return await this.api.post(jt,{token:this.meta.captchaToken},{headers:{...t}})}async _initAuthenticateOnce(e){if(!this.api)throw new ke("Auth flow has no API instance");let t=Yr(e);return await this.api.post(qt,{token:this.meta.captchaToken},{headers:{...t}})}async _initLinkOnce(){if(!this.api)throw new ke("Auth flow has no API instance");return await this.api.post(zt,{})}_transformInitLinkOptionsToCamelCase(e){return{rp:e.rp,user:{id:e.user.id,name:e.user.name,displayName:e.user.display_name},challenge:e.challenge,pubKeyCredParams:e.pub_key_cred_params.map((e=>({type:e.type,alg:e.alg}))),timeout:e.timeout,excludeCredentials:e.exclude_credentials?.map((e=>({id:e.id,type:e.type,transports:e.transports}))),authenticatorSelection:{authenticatorAttachment:e.authenticator_selection?.authenticator_attachment,requireResidentKey:e.authenticator_selection?.require_resident_key,residentKey:e.authenticator_selection?.resident_key,userVerification:e.authenticator_selection?.user_verification},attestation:e.attestation,extensions:{appid:e.extensions?.app_id,credProps:e.extensions?.cred_props?.rk,hmacCreateSecret:e.extensions?.hmac_create_secret},hints:this.meta.hints}}_transformRegistrationResponseToSnakeCase(e){return{id:e.id,raw_id:e.rawId,response:{client_data_json:e.response.clientDataJSON,attestation_object:e.response.attestationObject,authenticator_data:e.response.authenticatorData},authenticator_attachment:e.authenticatorAttachment,client_extension_results:{app_id:e.clientExtensionResults.appid,cred_props:e.clientExtensionResults.credProps,hmac_create_secret:e.clientExtensionResults.hmacCreateSecret},type:e.type}}_transformInitAuthenticateOptionsToCamelCase(e){return{rpId:e.rp_id,challenge:e.challenge,allowCredentials:e.allow_credentials?.map((e=>({id:e.id,type:e.type,transports:e.transports})))||[],timeout:e.timeout,extensions:{appid:e.extensions?.app_id,credProps:e.extensions?.cred_props,hmacCreateSecret:e.extensions?.hmac_create_secret},userVerification:e.user_verification}}_transformAuthenticationResponseToSnakeCase(e){return{id:e.id,raw_id:e.rawId,response:{client_data_json:e.response.clientDataJSON,authenticator_data:e.response.authenticatorData,signature:e.response.signature,user_handle:e.response.userHandle},authenticator_attachment:e.authenticatorAttachment,client_extension_results:{app_id:e.clientExtensionResults.appid,cred_props:e.clientExtensionResults.credProps,hmac_create_secret:e.clientExtensionResults.hmacCreateSecret},type:e.type}}constructor({captchaToken:e,setPasskeyAuthState:t,hints:n}){this.authenticateForRegistration=!1,this.initRegisterOnce=new Zr(this._initRegisterOnce.bind(this)),this.initAuthenticateOnce=new Zr(this._initAuthenticateOnce.bind(this)),this.initLinkOnce=new Zr(this._initLinkOnce.bind(this)),this.meta={captchaToken:e,setPasskeyAuthState:t,hints:n}}}const ha=({address:e,chainId:t,nonce:n})=>`${window.location.host} wants you to sign in with your Ethereum account:\n${e}\n\nBy signing, you are proving you own this wallet and logging in. This does not initiate a transaction or cost any fees.\n\nURI: ${window.location.origin}\nVersion: 1\nChain ID: ${t}\nNonce: ${n}\nIssued At: ${(new Date).toISOString()}\nResources:\n- https://privy.io`;class pa{get meta(){return{connectorType:this.wallet?.connectorType,walletClientType:this.wallet?.walletClientType,chainId:this.wallet?.chainId,address:this.wallet?.address,disableSignup:this._meta.disableSignup}}async authenticate(){if(!this.client)throw new ke("SiweFlow has no client instance");try{if(this.preparedMessage&&this.signature)return await this.client.authenticateWithSiweInternal({message:this.preparedMessage,signature:this.signature,chainId:this.wallet?.chainId,walletClientType:this.walletClientType??this.wallet?.walletClientType,connectorType:this.connectorType??this.wallet?.connectorType,mode:this._meta.disableSignup?"no-signup":"login-or-sign-up"});if(!this.wallet)throw new ke("SiweFlow has no wallet instance");let{message:e,signature:t}=await this.sign();return await this.client.authenticateWithSiweInternal({message:e,signature:t,chainId:this.wallet.chainId,walletClientType:this.wallet.walletClientType,connectorType:this.wallet.connectorType,mode:this.meta.disableSignup?"no-signup":"login-or-sign-up"})}catch(e){throw Te(e)}}async link(){if(!this.client)throw new ke("SiweFlow has no client instance");try{if(!this.wallet)throw new ke("SiweFlow has no wallet instance");let{message:e,signature:t}=await this.sign();return await this.client.linkWithSiweInternal({message:e,signature:t,chainId:this.wallet.chainId,walletClientType:this.wallet.walletClientType,connectorType:this.wallet.connectorType})}catch(e){throw Te(e)}}async sign(){if(!this.client)throw new ke("SiweFlow has no client instance");if(await this.buildMessage(),!this.preparedMessage)throw new ke("Could not prepare SIWE message");if(!this.wallet)throw new ke("SiweFlow has no wallet instance");let e=await this.wallet.sign(this.preparedMessage);return{message:this.preparedMessage,signature:e}}async _getNonceOnce(){if(!this.client)throw new ke("SiweFlow has no client instance");if(!this.wallet)throw new ke("UI SiweFlow has no wallet instance");return await this.client.generateSiweNonce({address:this.wallet.address,captchaToken:this.captchaToken})}async buildMessage(){if(!this.client)throw new ke("SiweFlow has no client instance");if(!this.wallet)throw new ke("SiweFlow has no wallet instance");let e=this.wallet.address,t=this.wallet.chainId.replace("eip155:","");return this.nonce||(this.nonce=await this.getNonceOnce.execute()),this.preparedMessage=ha({address:e,chainId:t,nonce:this.nonce}),this.preparedMessage}constructor(e,t,n,r=!1,a){this._meta={disableSignup:!1},this.getNonceOnce=new Zr(this._getNonceOnce.bind(this)),this.wallet=t,this.captchaToken=n,this.client=e,this._meta.disableSignup=r,this.preparedMessage=a?.message,this.signature=a?.signature,this.walletClientType=a?.walletClientType,this.connectorType=a?.connectorType}}class wa{get meta(){return{connectorType:this.wallet.connectorType,walletClientType:this.wallet.walletClientType,disableSignup:this._meta.disableSignup,messageType:this._meta.messageType,address:this.wallet?.address}}set messageType(e){this._meta.messageType=e}async authenticate(){if(!this.client)throw new ke("SiwsFlow has no client instance");try{let{message:e,signature:t}=await this.sign();return await this.client.authenticateWithSiwsInternal({message:e,signature:t,walletClientType:this.wallet.walletClientType,connectorType:this.wallet.connectorType,mode:this.meta.disableSignup?"no-signup":"login-or-sign-up",messageType:this.meta.messageType})}catch(e){throw Te(e)}}async link(){if(!this.client)throw new ke("SiwsFlow has no client instance");try{let{message:e,signature:t}=await this.sign();return await this.client.linkWithSiwsInternal({message:e,signature:t,walletClientType:this.wallet.walletClientType,connectorType:this.wallet.connectorType,messageType:this.meta.messageType})}catch(e){throw Te(e)}}async sign(){let e,t;if(!this.client)throw new ke("SiwsFlow has no client instance");await this.buildMessage();let n="transaction"===this.meta.messageType;if(!this.preparedMessage)throw new ke("Could not prepare SIWS message");if(!n&&!this.wallet.provider.signMessage||n&&!this.wallet.provider.signTransaction)throw new ke("Wallet does not support the necessary signing methods");if(n&&this._plugin){let n=await this.wallet.provider.signTransaction({transaction:Bn.decode(this.preparedMessage)});e=Bn.encode(n.signedTransaction),t=this._plugin.getSignatureFromTransaction(n.signedTransaction,this.wallet.address)}else{e=this.preparedMessage;let n=await this.wallet.provider.signMessage({message:(new TextEncoder).encode(this.preparedMessage)});t=Bn.encode(n.signature)}return{message:e,signature:t}}async _getNonceOnce(){if(!this.client)throw new ke("SiwsFlow has no client instance");return await this.client.generateSiwsNonce({address:this.wallet.address,captchaToken:this.captchaToken})}async buildMessage(){if(!this.client)throw new ke("SiwsFlow has no client instance");let e=this.wallet.address;return this.nonce||(this.nonce=await this.getNonceOnce.execute()),"transaction"===this.meta.messageType&&this._plugin?this.preparedMessage=this._plugin.createSiwsMemoTransaction({address:e,nonce:this.nonce}):this.preparedMessage=On({address:e,nonce:this.nonce}),this.preparedMessage}constructor(e,t,n,r=!1,a="plain",i){this._meta={disableSignup:!1,messageType:"plain"},this.getNonceOnce=new Zr(this._getNonceOnce.bind(this)),this.wallet=e,this.captchaToken=n,this.client=t,this._meta.disableSignup=r,this._meta.messageType=a,this._plugin=i}}class ma{async authenticate(){if(!this.api)throw new ke("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new ke("phone number and sms code must be set prior to calling authenticate.");try{return await this.api.post(Ht,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode,mode:this.meta.disableSignup?"no-signup":"login-or-sign-up"})}catch(e){throw Te(e)}}async link(){if(!this.api)throw new ke("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new ke("phone number and sms code must be set prior to calling authenticate.");try{return await this.api.post(Bt,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode})}catch(e){throw Te(e)}}async sendSmsCode({phoneNumber:e,captchaToken:t,withPrivyUi:n}){if(!this.api)throw new ke("Auth flow has no API instance");if(e&&(this.meta.phoneNumber=e),t&&(this.meta.captchaToken=t),!this.meta.phoneNumber)throw new ke("phone nNumber must be set when initialzing authentication.");let r=Yr(n);try{return await this.api.post(Vt,{phoneNumber:this.meta.phoneNumber,token:this.meta.captchaToken},{headers:{...r}})}catch(e){throw Te(e)}}constructor({phoneNumber:e,captchaToken:t,disableSignup:n}){this.meta={phoneNumber:e,captchaToken:t,disableSignup:n??!1}}}class ya extends ma{async link(){if(!this.api)throw new ke("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode||!this.meta.oldPhoneNumber)throw new ke("Phone number, sms code, and an old phone number must be set prior to calling update.");try{return await this.api.post(Kt,{old_phone_number:this.meta.oldPhoneNumber,new_phone_number:this.meta.phoneNumber,code:this.meta.smsCode})}catch(e){throw Te(e)}}constructor(e,t,n){super({phoneNumber:t,captchaToken:n}),this.meta={phoneNumber:t,captchaToken:n,oldPhoneNumber:e,disableSignup:!1}}}const ga=/*#__PURE__*/i({enabled:!1,siteKey:"",provider:void 0,appId:void 0,token:void 0,error:void 0,status:"disabled",setToken:Se,setError:Se,setExecuting:Se,waitForResult:()=>Promise.resolve(""),ref:{current:null},remove:be,reset:Se,execute:Se});class fa extends _e{constructor(e,t,n){super(e||"Captcha failed"),this.type="Captcha",t instanceof Error&&(this.cause=t),this.privyErrorCode=n}}const va=({children:e,appId:n,captchaSiteKey:r,enabledCaptchaProvider:a})=>{let i=s(null),c=s(null),[d,u]=o(),[h,p]=o(),[w,m]=o(!1),y=l((()=>a?w||d||h?!w||d||h?d&&!h?{status:"success",token:d}:h?{status:"error",error:h}:{status:"ready"}:{status:"loading"}:{status:"ready"}:{status:"disabled"}),[a,d,h,w]),g=l((()=>a?"turnstile"===a?{remove:()=>{i.current?.remove(),m(!1),p(void 0),u(void 0)},reset:()=>{i.current?.reset(),m(!1),p(void 0),u(void 0)},execute:()=>{m(!0),i.current?.execute()},waitForResult:async()=>{try{return await z((()=>i.current?.getResponse()),{interval:200,timeout:2e4})}catch(e){throw new fa("Captcha failed",null,Ce.CAPTCHA_TIMEOUT)}}}:{remove:()=>{c.current?.removeCaptcha(),m(!1),p(void 0),u(void 0)},reset:()=>{c.current?.resetCaptcha(),m(!1),p(void 0),u(void 0)},execute:()=>{m(!0),c.current?.execute()},waitForResult:async()=>{try{return await z((()=>{let e=c.current?.getResponse();if(e)return e}),{interval:200,timeout:2e4})}catch(e){throw new fa("Captcha failed",null,Ce.CAPTCHA_TIMEOUT)}}}:null),[a]),f=l((()=>{if(!a||!g)return{...y,enabled:!1,siteKey:"",appId:n,setToken:Se,setError:Se,setExecuting:Se,waitForResult:()=>Promise.resolve(void 0),remove:be,reset:Se,execute:Se,provider:void 0,ref:{current:null}};let e={...y,enabled:!0,appId:n,setToken:u,setError:p,setExecuting:m};return"turnstile"===a?{...e,provider:"turnstile",ref:i,siteKey:r.split("t:")[1]??"",...g}:{...e,provider:"hcaptcha",ref:c,siteKey:r.split("h:")[1]??"",...g}}),[y,a,g,n,r]);/*#__PURE__*/return t(ga.Provider,{value:f,children:e})},Aa=()=>a(ga);async function ka(e){if(e.enabled){if("error"===e.status)throw new fa(e.error,null,Ce.CAPTCHA_FAILURE);return"success"===e.status?e.token:(e.execute(),await e.waitForResult())}}class Ta{async authenticate(){if(!this.api)throw new ke("Auth flow has no API instance");try{return await this.api.post($t,{captcha_token:this.meta.captchaToken,telegram_auth_result:this.meta.telegramAuthResult,telegram_web_app_data:this.meta.telegramWebAppData,mode:this.meta.disableSignup?"no-signup":"login-or-sign-up"})}catch(e){throw Te(e)}}async link(){if(!this.api)throw new ke("Auth flow has no API instance");try{return await this.api.post(Gt,{telegram_auth_result:this.meta.telegramAuthResult,telegram_web_app_data:this.meta.telegramWebAppData})}catch(e){throw Te(e)}}constructor(e,t=!1){this.meta={disableSignup:!1},this.meta={captchaToken:e,disableSignup:!1},this.meta.disableSignup=t}}function Ca(e){let t={detail:"",retryable:!1};return e?.privyErrorCode===Ce.LINKED_TO_ANOTHER_USER&&(t.detail="This account has already been linked to another user."),e?.privyErrorCode===Ce.DISALLOWED_LOGIN_METHOD&&(t.detail="Login with Telegram not allowed."),e?.privyErrorCode===Ce.INVALID_DATA&&(t.retryable=!0,t.detail="Something went wrong. Try again."),e?.privyErrorCode===Ce.CANNOT_LINK_MORE_OF_TYPE&&(t.retryable=!0,t.detail="Something went wrong. Try again."),e?.privyErrorCode===Ce.INVALID_CREDENTIALS&&(t.retryable=!0,t.detail="Something went wrong. Try again."),e?.privyErrorCode===Ce.TOO_MANY_REQUESTS&&(t.detail="Too many requests. Please wait before trying again."),e?.privyErrorCode===Ce.TOO_MANY_REQUESTS&&e.message.includes("rate limit")&&(t.detail="Request limit reached for Telegram. Please wait a moment and try again."),e instanceof fa&&(t.retryable=!0,t.detail="Something went wrong. Try again."),t}function _a(e){return Object.fromEntries(decodeURIComponent(e).split("&").map((e=>e.split("=").map(decodeURIComponent))))}function Sa(){let e=new URL(window.location.href);e.searchParams.delete("id"),e.searchParams.delete("hash"),e.searchParams.delete("auth_date"),e.searchParams.delete("first_name"),e.searchParams.delete("last_name"),e.searchParams.delete("username"),e.searchParams.delete("photo_url"),e.hash="",window.history.replaceState({},"",e)}let ba=/*#__PURE__*/u((()=>import("./TurnstileWrapper-Co-t5mTh.mjs"))),Ea=/*#__PURE__*/u((()=>import("./HCaptchaWrapper-CUi9LJsp.mjs")));const Ia=n=>{let r=Aa();return c((()=>r.remove),[r.remove]),r.enabled&&r.provider?/*#__PURE__*/t(d,{fallback:null,children:/*#__PURE__*/e("div",{className:"hidden h-0 w-0",children:["turnstile"===r.provider&&/*#__PURE__*/t(ba,{...n,captchaContext:r}),"hcaptcha"===r.provider&&/*#__PURE__*/t(Ea,{...n,captchaContext:r})]})}):null};var Pa=/*#__PURE__*/Object.freeze({__proto__:null,AccountNotFoundScreen:()=>import("./AccountNotFoundScreen-C055cesr.mjs"),AffirmativeConsentScreen:()=>import("./AffirmativeConsentScreen-DXy2kEcy.mjs"),AllowlistRejectionScreen:()=>import("./AllowlistRejectionScreen-BIzWPeoe.mjs"),AuthenticateWithWalletScreen:()=>import("./AuthenticateWithWalletScreen-q3jQKiH6.mjs"),AwaitingEvmToSolBridgingScreen:()=>import("./AwaitingEvmToSolBridgingScreen-B4R4PEVm.mjs"),AwaitingExternalEthereumTransferScreen:()=>import("./AwaitingExternalEthereumTransferScreen-Dwy69FD1.mjs"),AwaitingPasswordlessCodeScreen:()=>import("./AwaitingPasswordlessCodeScreen-Ch_YXDTX.mjs"),AwaitingSolToEvmBridgingScreen:()=>import("./AwaitingSolToEvmBridgingScreen-spElnpUE.mjs"),CaptchaScreen:()=>import("./CaptchaScreen-BZy78GrD.mjs"),CoinbaseOnrampStatusScreen:()=>import("./CoinbaseOnrampStatusScreen-CTWZaE1o.mjs"),ConnectLedgerScreen:()=>import("./ConnectLedgerScreen-CIPOaq8e.mjs"),ConnectOnlyLandingScreen:()=>import("./ConnectOnlyLandingScreen-CbLV-cj4.mjs"),ConnectOnlyStatusScreen:()=>import("./ConnectOnlyStatusScreen-bmx1wwk1.mjs"),ConnectOrCreateScreen:()=>import("./ConnectOrCreateScreen-DXw5Y8gN.mjs"),ConnectionStatusScreen:()=>import("./ConnectionStatusScreen-D-9fLZfA.mjs"),CrossAppAuthScreen:()=>import("./CrossAppAuthScreen-Co723kT3.mjs"),DelegatedActionsConsentScreen:()=>import("./DelegatedActionsConsentScreen-CyQTJHgT.mjs"),DelegatedActionsRevokeScreen:()=>import("./DelegatedActionsRevokeScreen-CFm4F3CM.mjs"),EmbeddedWalletConnectingScreen:()=>import("./EmbeddedWalletConnectingScreen-DmTtzGwq.mjs"),EmbeddedWalletCreatedScreen:()=>import("./EmbeddedWalletCreatedScreen-Cj1c5KyP.mjs"),EmbeddedWalletKeyExportScreen:()=>import("./EmbeddedWalletKeyExportScreen-CsWRTEgd.mjs"),EmbeddedWalletOnAccountCreateScreen:()=>import("./EmbeddedWalletOnAccountCreateScreen-DBAmWm90.mjs"),EmbeddedWalletPasswordCreateScreen:()=>import("./RecoveryPasswordCreateScreen-Q1zuy9fu.mjs"),EmbeddedWalletPasswordUpdateScreen:()=>import("./EmbeddedWalletPasswordUpdateScreen-B5w6wtgf.mjs"),EmbeddedWalletPasswordUpdateSplashScreen:()=>import("./EmbeddedWalletPasswordUpdateSplashScreen-BvsscceO.mjs"),ErrorScreen:()=>import("./ErrorScreen-DtGc3Chy.mjs"),FarcasterConnectStatusScreen:()=>import("./FarcasterConnectStatusScreen-DGeCyr6b.mjs"),FarcasterSignerStatusScreen:()=>import("./FarcasterSignerStatusScreen-DASa1xq2.mjs"),FundSolWalletWithExternalSolanaWallet:()=>import("./FundSolWalletWithExternalSolanaWallet-0jNi_hvn.mjs"),FundWithBankDepositScreen:()=>import("./FundWithBankDepositScreen-D_uu3GEF.mjs"),FundingAmountEditScreen:()=>import("./FundingEditAmountScreen-vQUS-a80.mjs"),FundingMethodSelectionScreen:()=>import("./FundingMethodSelectionScreen-G8gkM1Mk.mjs"),InAppBrowserLoginNotPossible:()=>import("./InAppBrowserLoginNotPossible-C8mlSbYe.mjs"),InstallWalletScreen:()=>import("./InstallWalletScreen-D0kdHc5W.mjs"),LandingScreen:()=>import("./LandingScreen-0MlIkV3C.mjs"),LinkConflictScreen:()=>import("./LinkConflictScreen-DW31R5fr.mjs"),LinkEmailScreen:()=>import("./LinkEmailScreen-B10iXGH8.mjs"),LinkPasskeyScreen:()=>import("./LinkPasskeyScreen-OxaghvUl.mjs"),LinkPhoneScreen:()=>import("./LinkPhoneScreen-Cdg3eg7w.mjs"),LoginFailedScreen:()=>import("./LoginFailedScreen-BVOo2ycm.mjs"),ManualTransferScreen:()=>import("./ManualTransferScreen-_04Sq7zU.mjs"),MfaAuthEnrollmentFlowScreen:()=>import("./MfaAuthEnrollmentFlowScreen-DApO6DPY.mjs"),MfaAuthVerifyFlowScreen:()=>import("./MfaAuthVerifyFlowScreen-mdmdgWdO.mjs"),MfaEnrollmentFlowScreen:()=>import("./MfaEnrollmentFlowScreen-DRZTnt-I.mjs"),MoonpayStatusScreen:()=>import("./MoonpayStatusScreen-DDSK5dda.mjs"),OAuthStatusScreen:()=>import("./OAuthStatusScreen-DSAUQ_YN.mjs"),PasskeySelectSignupOrLogin:()=>import("./PasskeySelectSignupOrLogin-G19VpAdI.mjs"),PasskeyStatusScreen:()=>import("./PasskeyStatusScreen-TD2nYAnk.mjs"),PasswordRecoveryScreen:()=>import("./PasswordRecoveryScreen-C0oVVZYe.mjs"),RecoveryOAuthScreen:()=>import("./RecoveryOAuthStatusScreen-Ca9VYOrA.mjs"),RecoverySelectionScreen:()=>import("./RecoverySelectionScreen-scmqFA8Y.mjs"),SendTransactionScreen:()=>import("./index-BH9-XZRZ.mjs"),SetAutomaticRecoveryScreen:()=>import("./SetAutomaticRecoveryScreen-D-__1Pf7.mjs"),SignRequestScreen:()=>import("./SignRequestScreen-D6HSUOxx.mjs"),StandardSignAndSendTransactionScreen:()=>import("./StandardSignAndSendTransactionScreen-YlstFfkB.mjs"),TelegramAuthScreen:()=>import("./TelegramAuthScreen-DHCcieoC.mjs"),TransferFromWalletScreen:()=>import("./TransferFromWalletScreen-BG5Mj5tz.mjs"),UpdateEmailScreen:()=>import("./UpdateEmailScreen-ndRi1gY6.mjs"),UpdatePhoneScreen:()=>import("./UpdatePhoneScreen-DoH__glA.mjs"),UserLimitReachedScreen:()=>import("./UserLimitReachedScreen-BLzaOW7F.mjs"),WalletInterstitialScreen:()=>import("./WalletInterstitialScreen-BQ-ku50j.mjs")});function Wa(e){Gn("configureMfa",e)}const Ua=Xn((()=>({inProgressMfaFlow:void 0})));const Na=Kn`
|
|
2
2
|
:root {
|
|
3
3
|
${e=>Oa(e.palette)}
|
|
4
4
|
};
|
|
@@ -137,7 +137,7 @@ import{jsxs as e,jsx as t,Fragment as n}from"react/jsx-runtime";import r,{useCon
|
|
|
137
137
|
align-items: center;
|
|
138
138
|
justify-content: center;
|
|
139
139
|
height: 100%;
|
|
140
|
-
`;const ja=()=>{let{ready:e}=C(),{currentScreen:t}=_(),[n,r]=o(null),[a,i]=o(!1),l=function(e){let[t,n]=o(!1),r=s(null),a=s(null),i=s(null);return c((()=>{if(r.current&&(clearTimeout(r.current),r.current=null),a.current&&(clearTimeout(a.current),a.current=null),e)i.current=Date.now(),r.current=setTimeout((()=>{n(!0)}),150);else if(null!==i.current){let e=Date.now()-i.current;if(e>=150){let t=Math.max(0,400-(e-150));a.current=setTimeout((()=>{n(!1),i.current=null}),t)}else r.current&&(clearTimeout(r.current),r.current=null),n(!1),i.current=null}return()=>{r.current&&clearTimeout(r.current),a.current&&clearTimeout(a.current)}}),[e]),t}(a);return c((()=>{if(!t)return r(null),void i(!1);i(!0),Pa[t]().then((n=>{(!t||e||n.default.isShownBeforeReady)&&(r((()=>n.default.component)),i(!1))})).catch((()=>{r(null),i(!1)}))}),[t,e]),{component:n,isLoading:l}};let qa=/*#__PURE__*/u((()=>import("./MfaVerifyFlowScreen-
|
|
140
|
+
`;const ja=()=>{let{ready:e}=C(),{currentScreen:t}=_(),[n,r]=o(null),[a,i]=o(!1),l=function(e){let[t,n]=o(!1),r=s(null),a=s(null),i=s(null);return c((()=>{if(r.current&&(clearTimeout(r.current),r.current=null),a.current&&(clearTimeout(a.current),a.current=null),e)i.current=Date.now(),r.current=setTimeout((()=>{n(!0)}),150);else if(null!==i.current){let e=Date.now()-i.current;if(e>=150){let t=Math.max(0,400-(e-150));a.current=setTimeout((()=>{n(!1),i.current=null}),t)}else r.current&&(clearTimeout(r.current),r.current=null),n(!1),i.current=null}return()=>{r.current&&clearTimeout(r.current),a.current&&clearTimeout(a.current)}}),[e]),t}(a);return c((()=>{if(!t)return r(null),void i(!1);i(!0),Pa[t]().then((n=>{(!t||e||n.default.isShownBeforeReady)&&(r((()=>n.default.component)),i(!1))})).catch((()=>{r(null),i(!1)}))}),[t,e]),{component:n,isLoading:l}};let qa=/*#__PURE__*/u((()=>import("./MfaVerifyFlowScreen-mrf95cEs.mjs"))),za=/*#__PURE__*/u((()=>(e=>Pa[e]().then((e=>({default:e.default.component}))))("MfaAuthVerifyFlowScreen"))),Ha=()=>/*#__PURE__*/t(Ya,{children:/*#__PURE__*/t(V,{})}),Ba=()=>{let{currentScreen:r}=_(),a=Ua((e=>e.inProgressMfaFlow)),i=()=>Ua.setState({inProgressMfaFlow:void 0}),{component:s,isLoading:l}=ja();return function(){let{isModalOpen:e}=C(),{headless:t}=Ze(),{currentScreen:n}=_(),{status:r,execute:a,reset:i,enabled:s}=Aa(),[l,d]=o(!1);c((()=>{!e&&s&&i()}),[e,s,i]),c((()=>{n?Pa[n]().then((e=>{d(!!e.default.isCaptchaRequired)})).catch((()=>{d(!1)})):d(!1)}),[n]),c((()=>{e&&l&&!t&&"ready"===r&&s&&a()}),[e,l,t,r,s,a])}(),r||"txn"!==a?l?/*#__PURE__*/t(Ha,{}):s?
|
|
141
141
|
/*#__PURE__*/e(n,{children:[/*#__PURE__*/t(H,{$if:!!a,children:/*#__PURE__*/t(d,{children:/*#__PURE__*/t(s,{})})}),/*#__PURE__*/e(d,{children:["txn"===a&&/*#__PURE__*/t(qa,{onClose:i}),"auth"===a&&/*#__PURE__*/t(za,{})]})]}):null:/*#__PURE__*/t(d,{children:/*#__PURE__*/t(qa,{onClose:i})})},Va=()=>{let e=s(null);/*#__PURE__*/return t(Ga,{style:{height:B(e)},id:"privy-modal-content",children:/*#__PURE__*/t("div",{ref:e,children:/*#__PURE__*/t(Ba,{})})})};const Ka=({open:e})=>{let n=Ze(),{gracefulClosePrivyModal:r}=(()=>{let{closePrivyModal:e}=Ee(),{onUserCloseViaDialogOrKeybindRef:t}=_();return{gracefulClosePrivyModal:h((()=>{if(!t?.current)return e({shouldCallAuthOnSuccess:!1});t.current()}),[e])}})(),a=Ua((e=>e.inProgressMfaFlow));return Wa({onMfaRequired:()=>{n.mfa.noPromptOnMfaRequired||Ua.setState({inProgressMfaFlow:"txn"})}}),n.render.standalone?/*#__PURE__*/t(Ra,{children:/*#__PURE__*/t($a,{id:"privy-modal-content",children:/*#__PURE__*/t(Ba,{})})}):/*#__PURE__*/t(Ma,{open:!(!e&&!a),id:"privy-dialog","aria-label":"log in or sign up","aria-labelledby":"privy-dialog-title",onClick:()=>r(),children:/*#__PURE__*/t(Ra,{children:/*#__PURE__*/t(Va,{})})})};let $a=Vn.div`
|
|
142
142
|
display: flex;
|
|
143
143
|
flex-direction: column;
|
|
@@ -171,4 +171,4 @@ import{jsxs as e,jsx as t,Fragment as n}from"react/jsx-runtime";import r,{useCon
|
|
|
171
171
|
padding: 2rem;
|
|
172
172
|
`;function Ja(e){let n=s(null),r=s();return c((()=>{r.current?.remove(),r.current=function({botUsername:e,scriptHost:t}){let n=document.createElement("script"),{origin:r}=new URL(t);return n.async=!0,n.src=`${r}/js/telegram-login.js`,n.setAttribute("data-telegram-login",e),n.setAttribute("data-request-access","write"),n.setAttribute("data-lang","en"),n}(e),n.current?.after(r.current)}),[e]),/*#__PURE__*/t("div",{ref:n,hidden:!0})}const Qa=()=>{let{ready:e}=ye(),{client:t}=Ee();return c((()=>{let n=()=>{if(!t.connectors||!e)return;let n=t.connectors.wallets.map((e=>({address:e.address,connectorType:e.connectorType,walletClientType:e.walletClientType,connectedAt:e.connectedAt,id:e.meta.id})));Re.put(Xe,n)};return t.connectors?.on("walletsUpdated",n),()=>{t.connectors?.off("walletsUpdated",n)}}),[e,t.connectors]),null};class Za extends L{async initialize(){let e=await this.createProvider();this.provider=e,this.proxyProvider.setWalletProvider(e),this.subscribeListeners(),e.session&&(this.walletProvider?.session?.peer.metadata.url&&(this.walletEntry=K(this.walletProvider?.session?.peer.metadata.url),this.walletClientType=this.walletEntry?.slug||"unknown"),this.connected=!0,await this.syncAccounts()),this.initialized=!0,this.emit("initialized")}async connect(e){return e.showPrompt&&await this.promptConnection(),this.getConnectedWallet()}async isConnected(){return!!this.walletProvider?.connected}get walletBranding(){let e=this.walletProvider?.session?.peer.metadata.icons?.[0];return{name:$(this.walletProvider?.session?.peer.metadata.name||"")||"WalletConnect",icon:"string"==typeof e?e:Me,id:this.walletProvider?.session?.peer.metadata.name.toLowerCase()||"wallet_connect_v2"}}async resetConnection(e){this.walletProvider&&this.walletProvider.connected&&(await this.walletProvider.disconnect(),this.walletProvider.signer.session=void 0,this.walletClientType=e,this.redirectUri=void 0,this.fallbackUniversalRedirectUri=void 0,Rn(),this.onDisconnect())}async promptConnection(){if(this.provider)return new Promise(((e,t)=>{(async()=>{let t="",n=await Promise.race([this.walletProvider?.enable(),this.proxyProvider.walletTimeout()]);if(n?.length&&(t=n[0]),!t||""===t)throw new Ae("Unable to retrieve address");this.walletProvider?.session?.peer.metadata.url&&(this.walletEntry=K(this.walletProvider?.session?.peer.metadata.url),this.walletClientType=this.walletEntry?.slug||"unknown",this.proxyProvider.rpcTimeoutDuration=J(this.rpcConfig,this.walletClientType)),this.connected=!0,await this.syncAccounts(n),e()})().catch((e=>{t(e?Oe(e):new Ae("Unknown error during connection"))}))}))}disconnect(){this.walletProvider?.disconnect().then((()=>this.onDisconnect())).catch((()=>console.warn("Unable to disconnect WalletConnect provider")))}get walletProvider(){return this.proxyProvider.walletProvider}setWalletProvider(e){this.proxyProvider.setWalletProvider(e)}async createProvider(){let e={};for(let t of this.chains){let n=G(t.id,this.chains,this.rpcConfig,this.privyAppId);n&&(e[t.id]=n)}let t=this.shouldEnforceDefaultChainOnConnect?[this.defaultChain.id]:[],n=this.chains.map((e=>e.id)),r=await ar.init({projectId:this.walletConnectCloudProjectId,chains:t,optionalChains:n,optionalEvents:sr,optionalMethods:ir,rpcMap:e,showQrModal:!1,metadata:{description:this.privyAppName,name:this.privyAppName,url:window.location.origin,icons:[]}});return r.on("display_uri",(e=>{if(r.signer.abortPairingAttempt(),Mn(),!this.showPrivyQrModal)throw new Ae("WalletConnect modal not available - Privy handles wallet connections through its own UI");if(gt&&this.walletEntry){let{redirect:t,href:n}=xn(e,this.walletEntry);Nn(t,"_self"),Fn({href:n,name:this.walletEntry.metadata?.shortName||this.walletEntry.name});let r=Dn(e,this.walletEntry);return this.redirectUri=t,this.fallbackUniversalRedirectUri=r?.redirect,this.showPrivyQrModal({native:t,universal:t})}if(this.redirectUri=void 0,this.walletEntry){let t=Dn(e,this.walletEntry);this.fallbackUniversalRedirectUri=t?.redirect}this.showPrivyQrModal({native:e,universal:void 0})})),r.on("connect",(()=>{r.session?.peer.metadata.url&&(this.walletEntry=K(r.session?.peer.metadata.url),this.walletClientType=this.walletEntry?.slug||"unknown")})),r}async enableProvider(){return this.walletProvider?.connected?Promise.resolve(this.walletProvider.accounts):await(this.walletProvider?.enable())}setWalletEntry(e,t){this.walletEntry=e,this.showPrivyQrModal=t}constructor({walletConnectCloudProjectId:e,rpcConfig:t,chains:n,defaultChain:r,shouldEnforceDefaultChainOnConnect:a,privyAppId:i,privyAppName:s,walletClientType:o}){super(o||"unknown",n,r,t),this.connectorType="wallet_connect_v2",this.privyAppId=i,this.privyAppName=s,this.walletConnectCloudProjectId=e,this.rpcConfig=t,this.shouldEnforceDefaultChainOnConnect=a,this.proxyProvider=new j(void 0,this.rpcTimeoutDuration),o&&(this.walletEntry=Y(o),this.walletClientType=o)}}const Xa=["error","invalid_request_arguments","wallet_not_on_device","invalid_recovery_pin","insufficient_funds","missing_or_invalid_mfa","mfa_verification_max_attempts_reached","mfa_timeout","twilio_verification_failed"];class ei extends Error{constructor(e,t){super(t),this.type=e}}function ti(e){let t=e.type;return"string"==typeof t&&Xa.includes(t)}function ni(e){return ti(e)&&"wallet_not_on_device"===e.type}function ri(e){return ti(e)&&("invalid_recovery_pin"===e.type||"invalid_request_arguments"===e.type)}function ai(e){return!!ti(e)&&"mfa_timeout"===e.type}function ii(e){return!!ti(e)&&"missing_or_invalid_mfa"===e.type}function si(e){return!!ti(e)&&"mfa_verification_max_attempts_reached"===e.type}function oi(e){return!(!ti(e)||!e.message.includes("code 429"))}function li(e){return!!function(e){let t=e.type;return"string"==typeof t&&"client_error"===t}(e)&&"MFA canceled"===e.message}async function ci(e,t,n,r,a,i=!1){let s=i,o=async o=>{if(s&&t&&t.length>0){o===(i?0:1)?a("configureMfa","onMfaRequired",{mfaMethods:t}):r.current?.reject(new ei("missing_or_invalid_mfa","MFA verification failed, retry."));let s=await new Promise(((e,t)=>{n.current={resolve:e,reject:t},setTimeout((()=>{let e=new ei("mfa_timeout","Timed out waiting for MFA code");r.current?.reject(e),t(e)}),3e5)}));return await e(s)}return await e()},l=null;for(let e=0;e<4;e++)try{l=await o(e),r.current?.resolve(void 0);break}catch(e){if("missing_or_invalid_mfa"!==e.type)throw r.current?.resolve(void 0),e;s=!0}if(null===l){let e=new ei("mfa_verification_max_attempts_reached","Max MFA verification attempts reached");throw r.current?.reject(e),e}return l}var di;let ui=(di=0,()=>"id-"+di++);function hi(e){return void 0!==e.error}let pi=new class{enqueue(e,t){this.callbacks[e]=t}dequeue(e,t){let n=this.callbacks[t];if(!n)throw Error(`cannot dequeue ${e} event: no event found for id ${t}`);switch(delete this.callbacks[t],e){case"privy:iframe:ready":case"privy:user-signer:sign":case"privy:wallets:add":case"privy:wallets:import":case"privy:wallets:set-recovery":case"privy:wallets:connect":case"privy:wallets:recover":case"privy:wallets:rpc":case"privy:wallet:create":case"privy:mfa:verify":case"privy:mfa:init-enrollment":case"privy:mfa:submit-enrollment":case"privy:mfa:unenroll":case"privy:mfa:clear":case"privy:auth:unlink-passkey":case"privy:farcaster:init-signer":case"privy:farcaster:sign":case"privy:solana-wallet:create":case"privy:delegated-actions:consent":return n;default:throw Error(`invalid wallet event type ${e}`)}}constructor(){this.callbacks={}}},wi=new Map,mi=(e,t)=>"bigint"==typeof t?t.toString():t;function yi(e,t,n,r){let a=n.contentWindow;if(!a)throw Error("iframe not initialized");let i=((e,t)=>`${e}${JSON.stringify(t,mi)}`)(e,t);if("privy:wallet:create"===e||"privy:wallets:add"===e||"privy:solana-wallet:create"===e){let e=wi.get(i);if(e)return e}let s=new Promise(((n,i)=>{let s=ui();pi.enqueue(s,{resolve:n,reject:i}),a.postMessage({id:s,event:e,data:t},r)})).finally((()=>{wi.delete(i)}));return wi.set(i,s),s}function gi(e){let n=et(),r=s(null),a=s(e.mfaMethods),i=Yn(),[l,d]=o(!1);return c((()=>{a.current=e.mfaMethods}),[e.mfaMethods]),c((()=>{if(!l)return;let t=r.current;if(!t)return;function n(t){var n;t&&t.origin===e.origin&&"string"==typeof(n=t.data).event&&/^privy:.+/.test(n.event)&&function(e){switch(e.event){case"privy:iframe:ready":let t=pi.dequeue(e.event,e.id);return hi(e)?t.reject(new ei(e.error.type,e.error.message)):t.resolve(e.data);case"privy:user-signer:sign":{let t=pi.dequeue(e.event,e.id);return hi(e)?t.reject(new ei(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:wallets:add":{let t=pi.dequeue(e.event,e.id);return hi(e)?t.reject(new ei(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:wallets:set-recovery":{let t=pi.dequeue(e.event,e.id);return hi(e)?t.reject(new ei(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:wallets:connect":{let t=pi.dequeue(e.event,e.id);return hi(e)?t.reject(new ei(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:wallets:recover":{let t=pi.dequeue(e.event,e.id);return hi(e)?t.reject(new ei(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:wallets:rpc":{let t=pi.dequeue(e.event,e.id);return hi(e)?t.reject(new ei(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:wallet:create":let n=pi.dequeue(e.event,e.id);return hi(e)?n.reject(new ei(e.error.type,e.error.message)):n.resolve(e.data);case"privy:wallets:import":let r=pi.dequeue(e.event,e.id);return hi(e)?r.reject(new ei(e.error.type,e.error.message)):r.resolve(e.data);case"privy:mfa:verify":let a=pi.dequeue(e.event,e.id);return hi(e)?a.reject(new ei(e.error.type,e.error.message)):a.resolve(e.data);case"privy:mfa:init-enrollment":{let t=pi.dequeue(e.event,e.id);return hi(e)?t.reject(new ei(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:mfa:submit-enrollment":{let t=pi.dequeue(e.event,e.id);return hi(e)?t.reject(new ei(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:mfa:unenroll":{let t=pi.dequeue(e.event,e.id);return hi(e)?t.reject(new ei(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:mfa:clear":{let t=pi.dequeue(e.event,e.id);return hi(e)?t.reject(new ei(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:auth:unlink-passkey":{let t=pi.dequeue(e.event,e.id);return hi(e)?t.reject(new ei(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:solana-wallet:create":let i=pi.dequeue(e.event,e.id);return hi(e)?i.reject(new ei(e.error.type,e.error.message)):i.resolve(e.data);case"privy:farcaster:init-signer":{let t=pi.dequeue(e.event,e.id);return hi(e)?t.reject(new ei(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:farcaster:sign":{let t=pi.dequeue(e.event,e.id);return hi(e)?t.reject(new ei(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:delegated-actions:consent":{let t=pi.dequeue(e.event,e.id);return hi(e)?t.reject(new ei(e.error.type,e.error.message)):t.resolve(e.data)}default:console.warn("Unsupported wallet proxy method:",e)}}(t.data)}let s={signWithUserSigner:n=>ci((r=>yi("privy:user-signer:sign",{...n,...r},t,e.origin)),a.current,e.mfaPromise,e.mfaSubmitPromise,i),addWallet:n=>ci((r=>yi("privy:wallets:add",{...n,...r},t,e.origin)),a.current,e.mfaPromise,e.mfaSubmitPromise,i),setRecovery:n=>ci((r=>yi("privy:wallets:set-recovery",{...n,...r},t,e.origin)),a.current,e.mfaPromise,e.mfaSubmitPromise,i),connect:n=>ci((r=>yi("privy:wallets:connect",{...n,...r},t,e.origin)),a.current,e.mfaPromise,e.mfaSubmitPromise,i),recover:n=>ci((r=>yi("privy:wallets:recover",{...n,...r},t,e.origin)),a.current,e.mfaPromise,e.mfaSubmitPromise,i,!n.recoveryAccessToken&&!n.recoveryPassword&&!n.recoverySecretOverride),rpc:n=>ci((r=>yi("privy:wallets:rpc",{...n,...r},t,e.origin)),a.current,e.mfaPromise,e.mfaSubmitPromise,i),create:n=>yi("privy:wallet:create",n,t,e.origin),importWallet:n=>yi("privy:wallets:import",n,t,e.origin),createSolana:n=>ci((r=>yi("privy:solana-wallet:create",{...n,...r},t,e.origin)),a.current,e.mfaPromise,e.mfaSubmitPromise,i),createDelegatedAction:n=>yi("privy:delegated-actions:consent",n,t,e.origin),verifyMfa:n=>ci((r=>yi("privy:mfa:verify",{...n,...r},t,e.origin)),a.current,e.mfaPromise,e.mfaSubmitPromise,i,!0),initEnrollMfa:n=>ci((r=>yi("privy:mfa:init-enrollment",{...n,...r},t,e.origin)),a.current,e.mfaPromise,e.mfaSubmitPromise,i),submitEnrollMfa:n=>ci((r=>yi("privy:mfa:submit-enrollment",{...n,...r},t,e.origin)),a.current,e.mfaPromise,e.mfaSubmitPromise,i),unenrollMfa:n=>ci((r=>yi("privy:mfa:unenroll",{...n,...r},t,e.origin)),a.current,e.mfaPromise,e.mfaSubmitPromise,i),clearMfa:n=>yi("privy:mfa:clear",n,t,e.origin),unlinkPasskeyAccount:n=>ci((r=>yi("privy:auth:unlink-passkey",{...n,...r},t,e.origin)),a.current,e.mfaPromise,e.mfaSubmitPromise,i),initFarcasterSigner:n=>yi("privy:farcaster:init-signer",n,t,e.origin),signFarcasterMessage:n=>yi("privy:farcaster:sign",n,t,e.origin)};window.addEventListener("message",n);let o=new AbortController;return Q((()=>yi("privy:iframe:ready",{},t,e.origin)),{abortSignal:o.signal}).then((()=>e.onLoad(s)),((...t)=>{console.warn("Privy iframe failed to load: ",...t),e.onLoadFailed()})),()=>{window.removeEventListener("message",n),o.abort()}}),[l]),n?
|
|
173
173
|
/*#__PURE__*/t("iframe",{ref:r,width:"0",height:"0",style:{display:"none",height:"0px",width:"0px"},onLoad:()=>d(!0),src:or({origin:e.origin,path:`/apps/${e.appId}/embedded-wallets`,query:{caid:e.clientAnalyticsId,client_id:e.appClientId}})}):null}const fi=({address:e,user:t})=>{let n=t.linkedAccounts.find((t=>"wallet"===t.type&&"privy"===t.walletClientType&&t.address===e));if(!n)throw new ke("Address to delegate is not associated with current user.");if(!xe(n))throw new ke(`useDelegatedActions is not supported for ${n.chainType} wallets. Use the useSessionSigners hook to provision server side access on behalf of your users.`);return{address:n.address,chainType:n.chainType,walletIndex:n.walletIndex??0}},vi=({address:e,user:t})=>{let n=t.linkedAccounts.find((t=>"wallet"===t.type&&"privy"===t.walletClientType&&t.address===e));if(!n)throw new ke("Address to delegate is not associated with current user.");let r=n.imported?n:S(t);if(!r)throw new ke("Unable to determine root address for delegated address.");if(!xe(r))throw new ke(`useDelegatedActions is not supported for ${r.chainType} wallets. Use the useSessionSigners hook to provision server side access on behalf of your users.`);return{address:r.address,chainType:r.chainType,imported:r.imported}},Ai=e=>e.linkedAccounts.filter((e=>"wallet"===e.type&&"privy"===e.walletClientType&&e.delegated));const ki="popup-privy-oauth",Ti="PRIVY_OAUTH_USE_BROADCAST_CHANNEL";class Ci{async authenticate(){if(!this.api)throw new ke("Auth flow has no API instance");try{return await this.api.post(Rt,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode,code_verifier:this.meta.codeVerifier,provider:this.meta.provider,mode:this.meta.disableSignup?"no-signup":"login-or-sign-up"})}catch(e){throw Te(e)}}async link(){if(!this.api)throw new ke("Auth flow has no API instance");try{return await this.api.post(Mt,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode,code_verifier:this.meta.codeVerifier,provider:this.meta.provider})}catch(e){throw Te(e)}}constructor(e){this.meta=e}}async function _i({api:e,requesterAppId:t,providerAppId:n}){let r=(await e.get(`/api/v1/apps/${t}/cross-app/connections`)).connections.find((e=>e.provider_app_id===n));if(!r)throw new ke("Invalid connected app");return{name:r.provider_app_name,logoUrl:r.provider_app_icon_url||void 0,apiUrl:r.provider_app_custom_api_url,readOnly:r.read_only,customAuthAuthorizeUrl:r.provider_app_custom_auth_authorize_url,customAuthTransactUrl:r.provider_app_custom_auth_transact_url}}const Si=async({user:e,address:t,client:n,request:r,requesterAppId:a,reconnect:i})=>{n.createAnalyticsEvent({eventName:"cross_app_request_started",payload:{address:t,method:r.method}});let s=e?.linkedAccounts.find((e=>"cross_app"===e.type&&(e.embeddedWallets.some((e=>e.address===t))||e.smartWallets.some((e=>e.address===t)))));if(!e||!s)throw n.createAnalyticsEvent({eventName:"cross_app_request_error",payload:{error:"Cannot request a signature with this wallet address",address:t}}),new ke("Cannot request a signature with this wallet address");let o=n.getProviderAccessToken(s.providerApp.id),l=await _i({api:n.api,requesterAppId:a,providerAppId:s.providerApp.id});if(!o){if(l.readOnly)throw console.error("cannot transact against a read-only provider app"),new ke("Cannot transact against a read-only provider app");await i({appId:s.providerApp.id,action:"link"})&&(o=n.getProviderAccessToken(s.providerApp.id))}if(!o)throw n.createAnalyticsEvent({eventName:"cross_app_request_error",payload:{error:"Transactions require a valid token",address:t}}),new ke("Transactions require a valid token");let c=new URL(l.customAuthTransactUrl||`${l.apiUrl}/oauth/transact`);c.searchParams.set("token",o||""),c.searchParams.set("request",bi(r));let d=St({location:c.href});if(!d)throw n.createAnalyticsEvent({eventName:"cross_app_request_error",payload:{error:"Missing token",address:t}}),new ke("Failed to initialize signature request");return new Promise(((e,a)=>{let i=setTimeout((()=>{c(),a(new ke("Request timeout")),n.createAnalyticsEvent({eventName:"cross_app_request_error",payload:{error:"Request timeout",address:t}})}),12e4),o=setInterval((()=>{d.closed&&(c(),a(new ke("User rejected request")),n.createAnalyticsEvent({eventName:"cross_app_request_error",payload:{error:"User rejected request",address:t}}))}),300),l=i=>{i.data&&("set"===i.data.token?.action&&void 0!==i.data.token?.value?n.storeProviderAccessToken(s.providerApp.id,i.data.token.value):"clear"===i.data.token?.action&&n.storeProviderAccessToken(s.providerApp.id,null),"PRIVY_CROSS_APP_ACTION_RESPONSE"===i.data.type&&i.data.result&&(c(),e(i.data.result),n.createAnalyticsEvent({eventName:"cross_app_request_success",payload:{address:t,method:r.method}})),"PRIVY_CROSS_APP_ACTION_ERROR"===i.data.type&&i.data.error&&(c(),a(i.data.error),n.createAnalyticsEvent({eventName:"cross_app_request_error",payload:{error:i.data.error,address:t}})))};window.addEventListener("message",l);let c=()=>{d.close(),clearInterval(o),clearTimeout(i),window.removeEventListener("message",l)}}))};let bi=e=>JSON.stringify({content:{request:{request:Ei(e,lr)}},timestamp:Date.now(),callbackUrl:window.origin});const Ei=(e,t)=>"bigint"==typeof e?t(e):Array.isArray(e)?e.map((e=>Ei(e,t))):e&&"object"==typeof e?Object.fromEntries(Object.entries(e).map((([e,n])=>[e,Ei(n,t)]))):e;function Ii({isCreatingWallet:e,skipSplashScreen:t}){return e?"EmbeddedWalletPasswordCreateScreen":t?"EmbeddedWalletPasswordUpdateScreen":"EmbeddedWalletPasswordUpdateSplashScreen"}function Pi({walletAction:e,availableRecoveryMethods:t,legacySetWalletPasswordFlow:n,isResettingPassword:r,showAutomaticRecovery:a}){return a?"SetAutomaticRecoveryScreen":n||1===t.length?Ii({isCreatingWallet:"create"===e,skipSplashScreen:r}):"RecoverySelectionScreen"}function Wi(e){switch(e){case"user-passcode":return"PasswordRecoveryScreen";case"google-drive":case"icloud":return"RecoveryOAuthScreen";default:throw Error("Recovery method not supported")}}function Ui(e,t){if(e.onComplete)switch(t){case"external":e.fundingResult?e.onComplete({...e.fundingResult,fundingMethod:t}):e.onComplete({status:"cancelled",address:e.address,fundingMethod:t,amount:e.amount});break;case null:e.onComplete({status:"cancelled",address:e.address,fundingMethod:void 0,amount:e.amount});break;default:e.onComplete({status:"completed",address:e.address,fundingMethod:t,amount:e.amount})}}function Ni(e,t,n,r,a,i,s){return{...e,funding:e?.funding?{...e.funding,fundingResult:{status:t,address:e.funding.address,fundingMethod:void 0,transactionHash:n,amount:e.funding.amount,assetType:a?i?.symbol||"ETH":s.nativeCurrency.symbol||"ETH",metadata:{walletClientType:r}}}:void 0,solanaFundingData:e?.solanaFundingData,sendTransaction:e?.sendTransaction}}const Oi=new Map([["FundingMethodSelectionScreen",null],["TransferFromWalletScreen","external"],["FundingAmountEditScreen","external"],["ConnectOnlyLandingScreen","external"],["ConnectOnlyStatusScreen","external"],["AwaitingExternalEthereumTransferScreen","external"],["AwaitingEvmToSolBridgingScreen","external"],["AwaitingSolToEvmBridgingScreen","external"],["ManualTransferScreen","manual"],["MoonpayStatusScreen","moonpay"]]);function Ri(e){let t=e.toLowerCase();return!!window?.webkit?.messageHandlers?.ReactNativeWebView||!!window?.ReactNativeWebView||["fbav","fban","instagram","snapchat","linkedinapp"].some((e=>t.includes(e)))}async function Mi({rpc:e,address:t}){return(await e.getBalance(t,{commitment:"confirmed"}).send()).value??0n}let xi={apple_oauth:"apple",custom_auth:"custom",discord_oauth:"discord",email:"email",farcaster:"farcaster",github_oauth:"github",google_oauth:"google",instagram_oauth:"instagram",linkedin_oauth:"linkedin",passkey:"passkey",phone:"sms",spotify_oauth:"spotify",telegram:"telegram",tiktok_oauth:"tiktok",line_oauth:"line",twitch_oauth:"twitch",twitter_oauth:"twitter",wallet:"siwe",smart_wallet:"siwe",cross_app:"privy:"};const Fi=e=>{if(b(e))return{displayName:e.replace("custom:",""),loginMethod:"custom"};let t=xi[e];return"wallet"===e||"phone"===e?{displayName:e,loginMethod:t}:{displayName:t,loginMethod:t}};async function Di(e,t,n,r){let a=Be(e),{chain:i,...s}=await(async()=>r?await r():await t.prepareTransactionRequest({...a,account:{address:n,type:"json-rpc"}}))();return{...s,type:Ve[s.type]}}const Li=()=>{let e=Ze(),{user:t}=C(),{client:n,refreshSessionAndUser:r,walletProxy:a}=Ee();return{migrate:h((async()=>{if("legacy-embedded-wallets-only"===e.embeddedWallets.mode)return{success:!0,migrated:!1};if(!t)throw new ke("User must be authenticated before migrating wallets",Ce.MUST_BE_AUTHENTICATED);if(!a)throw new ke("Cannot connect to wallet proxy");let i=await n.getAccessToken();if(!i)throw new ke("User must be authenticated before migrating wallets",Ce.MUST_BE_AUTHENTICATED);let s=t.linkedAccounts.filter((e=>"wallet"===e.type&&"privy"===e.walletClientType&&xe(e)&&!E(e)));if(0===s.length)return{success:!0,migrated:!1};let o=s.filter((e=>e.imported)),l=s.filter((e=>!e.imported));if(l.length>0){let e=l.find((e=>"ethereum"===e.chainType&&0===e.walletIndex))??l.find((e=>"solana"===e.chainType&&0===e.walletIndex))??null;if(!e)throw new ke("Primary wallet not found");let{entropyId:t,entropyIdVerifier:n}=ge(e);try{await a.connect({accessToken:i,entropyId:t,entropyIdVerifier:n})}catch(r){if(!ni(r)||"privy"!==e.recoveryMethod)throw r;await a.recover({accessToken:i,entropyId:t,entropyIdVerifier:n})}await a.createDelegatedAction({accessToken:i,rootWallet:{address:e.address,chainType:e.chainType,imported:!1},delegatedWallets:l.map((e=>({address:e.address,chainType:e.chainType,walletIndex:e.walletIndex??0})))})}for(let e of o){let{entropyId:t,entropyIdVerifier:n}=ge(e);try{await a.connect({accessToken:i,entropyId:t,entropyIdVerifier:n})}catch(o){if(!ni(o)||"privy"!==e.recoveryMethod)throw o;await a.recover({accessToken:i,entropyId:t,entropyIdVerifier:n})}await a.createDelegatedAction({accessToken:i,rootWallet:{address:e.address,chainType:e.chainType,imported:!0},delegatedWallets:[{address:e.address,chainType:e.chainType,walletIndex:e.walletIndex??0}]})}return await r(),{success:!0,migrated:!0}}),[e.embeddedWallets.mode,t,a,n,r])}},ji=({disabled:e})=>{let{migrate:t}=Li(),{user:n}=C(),{walletProxy:r}=Ee(),a=s(!1),i=s(0);return c((()=>{e||i.current>2||a.current||!n||!r||(a.current=!0,i.current++,t().catch((e=>{console.debug("Unable to migrate wallets: ",e)})).finally((()=>{a.current=!1})))}),[n,r,e,t]),null},qi=e=>({id:e.id,raw_id:e.rawId,response:{client_data_json:e.response.clientDataJSON,authenticator_data:e.response.authenticatorData,signature:e.response.signature,user_handle:e.response.userHandle},authenticator_attachment:e.authenticatorAttachment,client_extension_results:{app_id:e.clientExtensionResults.appid,cred_props:e.clientExtensionResults.credProps,hmac_create_secret:e.clientExtensionResults.hmacCreateSecret},type:e.type}),zi=Xn((()=>({ethereum:[]}))),Hi=()=>zi.getState().ethereum,Bi=Xn((()=>({user:null,authenticated:!1}))),Vi=e=>Bi.setState({user:e}),Ki=e=>Bi.setState({authenticated:e});class $i{async authenticate(){if(!this.api)throw new ke("Auth flow has no API instance");try{return await this.api.post(Yt,{token:this.meta.token})}catch(e){throw Te(e)}}async link(){if(!this.api)throw new ke("Auth flow has no API instance");try{return await this.api.post(Jt,{token:this.meta.token})}catch(e){throw Te(e)}}constructor(e){this.meta={token:e}}}const Gi=(e,t)=>!I(e)&&("all-users"===t||"users-without-wallets"===t&&!Yi(e).length);let Yi=e=>e.linkedAccounts.filter((e=>"wallet"===e.type&&"ethereum"===e.chainType));const Ji=(e,t)=>!P(e)&&("all-users"===t||"users-without-wallets"===t&&!Qi(e).length);let Qi=e=>e.linkedAccounts.filter((e=>"wallet"===e.type&&"solana"===e.chainType));const Zi=()=>{let{walletProxy:e,recoverEmbeddedWallet:t,setUser:n,refreshSessionAndUser:r,privy:a,client:i}=Ee(),s=Ze();return{create:async({walletIndex:o,chainType:l,latestUser:c,recoveryMethod:d,recoveryPassword:u,recoveryAccessToken:h,idempotencyKey:p})=>{let w=c;w||(w=await r());let m=await i.getAccessToken();if(!w||!m||!e)throw Error("User must be authenticated before creating a Privy wallet");return await Ln({appConfig:s,user:w,refreshSessionAndUser:r,privy:a,accessToken:m,proxy:e,recoverEmbeddedWallet:t,setUser:n,walletIndex:o,chainType:l,recoveryMethod:d,recoveryPassword:u,recoveryAccessToken:h,idempotencyKey:p})}}};function Xi({subscribe:e,getExternalJwt:t,enabled:n=!0,onAuthenticated:r,onUnauthenticated:a,onError:i}){let{client:l,setAuthenticated:d,setUser:u,setIsNewUser:h}=Ee(),{logout:p,authenticated:w,ready:m}=jn(),{create:y}=Zi(),g=Ze();if(!l)throw new ke("`useSyncJwtBasedAuthState` must be used within a `PrivyProvider`");let[f,v]=o({status:"initial"}),A=s(),k=s(!1),T=s(t);c((()=>{T.current=t}),[t]);let C=s(r);c((()=>{C.current=r}),[r]);let _=s(a);c((()=>{_.current=a}),[a]);let S=s(i);c((()=>{S.current=i}),[i]);let b=s(y);c((()=>{b.current=y}),[y]);let E=s(g.embeddedWallets.ethereum.createOnLogin);c((()=>{E.current=g.embeddedWallets.ethereum.createOnLogin}),[g.embeddedWallets.ethereum.createOnLogin]);let I=s(g.embeddedWallets.solana.createOnLogin);c((()=>{I.current=g.embeddedWallets.solana.createOnLogin}),[g.embeddedWallets.solana.createOnLogin]);let P=s(u);c((()=>{P.current=u}),[u]);let W=s(h);c((()=>{W.current=h}),[h]);let U=s(d);return c((()=>{U.current=d}),[d]),c((()=>{if(!n||!m)return;let t=async()=>{if(!k.current){k.current=!0;try{v({status:"loading"});let e=await T.current();if(void 0!==A.current&&A.current===e)return void v({status:"done"});if(!e)return w&&(await p(),_.current?.()),A.current=e,void v({status:"done"});l.startAuthFlow(new $i(e));let{user:t,isNewUser:n=!1}=await l.authenticate();if(!t)throw new ke("Failed to sync with custom auth provider");C.current?.({user:t,isNewUser:n}),P.current(t),W.current(n),U.current(!0);let r=Gi(t,E.current),a=Ji(t,I.current);if(r&&a){let e=await b.current({chainType:"ethereum",walletIndex:0,latestUser:t});await b.current({chainType:"solana",walletIndex:0,latestUser:e.user})}else a?await b.current({chainType:"solana",walletIndex:0,latestUser:t}):r&&await b.current({chainType:"ethereum",walletIndex:0,latestUser:t});A.current=e,v({status:"done"})}catch(e){if(console.warn(e),await p().catch((()=>{})),_.current?.(),e instanceof Ie&&e.privyErrorCode===Ce.LINKED_TO_ANOTHER_USER)return v({status:"initial"}),void setTimeout((()=>{t()}),0);S.current?.(e),v({status:"error",error:e})}finally{k.current=!1}}};return t(),e(t)}),[e,l,w,p,n,m]),n?{state:f}:{state:{status:"not-enabled"}}}let es=Xn((()=>({jwtAuthFlowState:{status:"not-enabled"}})));function ts({customAuth:e}){let{jwtAuthFlowState:t}=function({customAuth:e}){let t=Yn(),n=s(),r=h((e=>(n.current=e,()=>{n.current=void 0})),[]),a=e?.getCustomAccessToken??(()=>Promise.resolve(void 0)),{state:i}=Xi({enabled:!0===e?.enabled,subscribe:r,getExternalJwt:a,onAuthenticated:({user:e,isNewUser:n})=>{t("login","onComplete",{user:e,isNewUser:n,wasAlreadyAuthenticated:!1,loginMethod:"custom",loginAccount:null}),t("customAuth","onAuthenticated",{user:e})},onUnauthenticated:()=>{t("customAuth","onUnauthenticated")},onError:e=>{t("login","onError",e.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR)}});return c((()=>{(async()=>{e&&!e.isLoading&&n.current?.()})()}),[e?.enabled,e?.getCustomAccessToken,e?.isLoading]),{jwtAuthFlowState:i}}({customAuth:e});return c((()=>{es.setState({jwtAuthFlowState:t})}),[t]),null}const ns=/*#__PURE__*/i(!1);let rs,as,is,ss,os;const ls=n=>{let r=n.client,a=n.privy,i=wr(),d=Ze();Z(X(d?.appearance.walletList??[]));let[u,p]=o(!1),w=Ua((e=>e.inProgressMfaFlow)),[y,g]=o(!1),f=Bi((e=>e.user)),v=zi((e=>e.ethereum)),[A,k]=o(void 0),[T,C]=o(!1),[_,b]=o(null),[P,F]=o(!1),[D,L]=o({status:"disconnected",connectedWallet:null,connectError:null,connector:null,connectRetry:Se}),[j,q]=o({status:"initial"}),[z,B]=o({status:"initial"}),[V,K]=o({status:"initial"}),[$,G]=o({status:"initial"}),[Y,J]=o({status:"initial"}),[Q,le]=o({status:"initial"}),[ce,de]=o(null),ue=et(),[he,pe]=o({}),[we,me]=o(null),ye=s(null),[ge,be]=o(!1),Ee=s(null),Ie=s(null),Ue=s(Jn),[Ne,Oe]=o(!1),Me=Bi((e=>e.authenticated)),xe=h((e=>{Ki(e),!e&&_&&Pa[_]().then((e=>{e.default.isUnauthenticatedScreem&&b(null)}))}),[_]);r.onStoreCustomerAccessToken=e=>{e&&Qn(Ue,"accessToken","onAccessTokenGranted",{accessToken:e})},r.onDeleteCustomerAccessToken=()=>{Vi(null),xe(!1),Qn(Ue,"accessToken","onAccessTokenRemoved")};let ze=s(null),He=s(null),Be=s(!1),Ve=({showWalletUIs:e})=>Be.current?Be.current:void 0!==e?!e:!d.embeddedWallets.showWalletUIs,Ke=e=>{b(e),setTimeout((()=>{p(!0)}),15)};c((()=>{if(!f)return void r.connectors?.removeEmbeddedWalletConnectors();let e=I(f),t=W(f),i=U(f);e&&t.length||r.connectors?.removeEmbeddedWalletConnectors(),i.length||r.connectors?.removeImportedWalletConnectors(),r.connectors?ce?(e&&r.connectors.addEmbeddedWalletConnectors({walletProxy:ce,user:f,embeddedWallets:t,defaultChain:d.defaultChain,appId:n.appId,privyClient:a}),i.forEach((e=>r.connectors?.addImportedWalletConnector(ce,e.address,d.defaultChain,n.appId)))):console.debug("Failed to add embedded wallet connector: Wallet proxy not initialized"):console.debug("Failed to add embedded wallet connector: Client connectors not initialized")}),[ce,f]),c((()=>{ce&&ye.current?.(ce)}),[ce]),c((()=>{if(d.externalWallets.solana.connectors)return d.externalWallets.solana.connectors.onMount(),()=>d.externalWallets.solana.connectors?.onUnmount()}),[d.externalWallets.solana.connectors]),c((()=>{!y&&ue&&async function(){let e,t=$e(),n=Ge(),a=yt();r.initializeConnectorManager({walletConnectCloudProjectId:d.walletConnectCloudProjectId,rpcConfig:d.rpcConfig,chains:d.chains,defaultChain:d.defaultChain,store:a,walletList:d.appearance.walletList,shouldEnforceDefaultChainOnConnect:d.shouldEnforceDefaultChainOnConnect,externalWalletConfig:d.externalWallets,appName:d.name??"Privy",walletChainType:d.appearance.walletChainType,setBaseAccountSdk:k}),r.connectors?.on("connectorInitialized",(()=>{e&&clearTimeout(e);let t=r.connectors.walletConnectors.length,n=r.connectors.walletConnectors.reduce(((e,t)=>e+(t.initialized?1:0)),0);n===t?Oe(!0):e=setTimeout((()=>{console.debug({message:"Unable to initialize all expected connectors before timeout",initialized:n,expected:t}),Oe(!0)}),1500)})),r.connectors?.initialize().then((()=>{ot()}));let i=await r.getAuthenticatedUser(),s=!!i;d.legal.requireUsersAcceptTerms&&i&&!i.hasAcceptedTerms?(await r.logout(),_t.setReadyToTrue(!0),Qn(Ue,"logout","onSuccess")):(d.customAuth?.enabled||(xe(!!i),i&&Qn(Ue,"login","onComplete",{user:i,isNewUser:!1,wasAlreadyAuthenticated:!0,loginMethod:null,loginAccount:null}),Vi(i)),t?He.current=s?"link":"login":n&&!s?(He.current="login",pe({telegramAuthModalData:{seamlessAuth:!0}}),Ke("TelegramAuthScreen")):_t.setReadyToTrue(!!i))}()}),[r,we,y,ue]),c((()=>{if(y){if(!f||!f.linkedAccounts.find((e=>"wallet"===e.type&&"privy"===e.walletClientType)))return void be(!!ce);if([...v].some((e=>"privy"===e.walletClientType)))return void be(!0);be(!!ce)}}),[y,f,v,ce]),c((()=>{r.connectors?.setWalletList(d.appearance.walletList)}),[d.appearance.walletList.join()]);let $e=()=>{let e=ca();return e.inProgress&&e.popupFlow?window.opener.location.origin!==window.location.origin?void window.opener.postMessage({type:"PRIVY_OAUTH_ERROR",error:"Origins between parent and child windows do not match."}):"error"===e.authorizationCode?void window.opener.postMessage({type:"PRIVY_OAUTH_ERROR",error:"Something went wrong. Try again."}):void window.opener.postMessage({type:"PRIVY_OAUTH_RESPONSE",stateCode:e.stateCode,authorizationCode:e.authorizationCode}):(e.inProgress&&e.provider.startsWith("privy:")&&!e.popupFlow&&(new BroadcastChannel(ki).postMessage({type:"PRIVY_OAUTH_RESPONSE",stateCode:e.stateCode,authorizationCode:e.authorizationCode}),window.close()),!!e.inProgress&&!!e.withPrivyUi&&(r.startAuthFlow(new la({...e,customOAuthRedirectUrl:d.customOAuthRedirectUrl})),Ke("OAuthStatusScreen"),!0))},Ge=()=>{let e=function(){let e;return(e=function(){let e=new URLSearchParams(window.location.search),t=Number(e.get("id")||""),n=e.get("hash"),r=Number(e.get("auth_date")||""),a=e.get("first_name");if(t&&a&&r&&n)return Object.fromEntries(e.entries())}())?(Sa(),{flowType:"login-url",authData:e}):(e=function(){let e=window.location.hash;if(!e||!e.startsWith("#tgWebAppData"))return;let t=_a(e.replace("#tgWebAppData=","")),{user:n,auth_date:r,hash:a}=t;return n&&r&&a?t:void 0}())?(Sa(),{flowType:"web-app",authData:e}):void 0}();if(!e||!d.loginMethods.telegram||!d.loginConfig.telegramAuthConfiguration?.seamlessAuthEnabled)return;let t=new Ta;return r.startAuthFlow(t),"login-url"===e.flowType&&(t.meta.telegramWebAppData=void 0,t.meta.telegramAuthResult=e.authData),"web-app"===e.flowType&&(t.meta.telegramAuthResult=void 0,t.meta.telegramWebAppData=e.authData),!0},Xe=async(e,t,n,a)=>{if("solana_adapter"!==e)at(await(r.connectors?.createEthereumWalletConnector({connectorType:e,walletClientType:t}))||null,t,n,a);else{let e=r.connectors?.findSolanaWalletConnector(t);if(!e)return;at(e,t,n,a)}};async function at(e,t,n,r){if(!e)return L({status:"disconnected",connectedWallet:null,connectError:new Ae("Unable to connect to wallet."),connector:null,connectRetry:Se}),r?.(null,n);L({status:"disconnected",connectedWallet:null,connectError:null,connector:e,connectRetry:Se}),e instanceof Za&&t&&await e.resetConnection(t),L({connector:e,status:"connecting",connectedWallet:null,connectError:null,connectRetry:()=>at(e,t,n,r)});try{let t=await e.connect({showPrompt:!0});if((!t||te(t))&&d.shouldEnforceDefaultChainOnConnect&&!d.chains.find((e=>e.id===Number(t?.chainId.replace("eip155:",""))))&&("wallet_connect_v2"!==t?.connectorType||"metamask"!==t?.walletClientType)){L((t=>({...t,connector:e,status:"switching_to_supported_chain",connectedWallet:null,connectError:null,connectRetry:Se})));try{await(t?.switchChain(d.defaultChain.id)),t&&(t.chainId=ie(kt(d.defaultChain.id)))}catch{console.warn(`Unable to switch to default chain: ${d.defaultChain.id}`)}}return L((e=>({...e,status:"connected",connectedWallet:t,connectError:null,connectRetry:Se}))),t&&Qn(Ue,"connectWallet","onSuccess",{wallet:t}),r?.(t,n)}catch(e){return e instanceof _e?(console.warn(e.cause?e.cause:e.message),Qn(Ue,"connectWallet","onError",e.privyErrorCode||Ce.GENERIC_CONNECT_WALLET_ERROR)):(console.warn(e),Qn(Ue,"connectWallet","onError",Ce.UNKNOWN_CONNECT_WALLET_ERROR)),L((t=>({...t,status:"disconnected",connectedWallet:null,connectError:e}))),r?.(null,n)}}let it=async(e,t,n)=>{if(null===e||!te(e))return;let a=new pa(r,e,t,n);r.startAuthFlow(a)},st=async(e,t,n,a="plain")=>{let s=i(zn);if("transaction"===a&&!s)throw new ke("useSolanaLedger plugin hook must be mounted");if(null===e||!oe(e))return;let o=new wa(e,r,t,n,a,s);r.startAuthFlow(o)},ot=async()=>{let e=new URLSearchParams(window.location.search),t=e.get("privy_connector"),n=e.get("privy_wallet_client"),a="true"===e.get("privy_connect_only");if(!t||!n)return;let i=se({connectorType:t,walletClientType:n});if(!i||!i.isInstalled)return Ke("LoginFailedScreen");if(!r.connectors)throw new ke("Connector not initialized");await Ke(a?"ConnectOnlyStatusScreen":"ConnectionStatusScreen");let s=new URL(window.location.href);s.searchParams.delete("privy_connector"),s.searchParams.delete("privy_wallet_client"),s.searchParams.delete("privy_connect_only"),window.history.pushState({},"",s),Xe(t,n,void 0,a?void 0:"solana_adapter"===t?st:it)};c((()=>{y&&Me&&null===f&&r.getAuthenticatedUser().then(Vi)}),[y,Me,f,r]);let lt=e=>{if(!Me)throw Qn(Ue,"linkAccount","onError",Ce.MUST_BE_AUTHENTICATED,{linkMethod:e}),new ke("User must be authenticated before linking an account.")},ct=e=>{if(!Me||!f)return!1;if("privy"===e.walletClientType)return!0;for(let t of f.linkedAccounts)if("wallet"===t.type&&t.address===e.address&&"privy"!==t.walletClientType)return!0;return!1},dt=()=>{zi.setState((e=>{let t=r.connectors?.wallets.filter(te).map((e=>({...e,linked:ct(e),loginOrLink:async()=>{if(!await e.isConnected())throw new ke("Wallet is not connected");if("embedded"===e.connectorType&&"privy"===e.walletClientType)throw new ke("Cannot link or login with embedded wallet");(async e=>{let t;if(!r.connectors)throw new ke("Connector not initialized");t="ethereum"===e.type?r.connectors.findWalletConnector(e.connectorType,e.walletClientType)||null:r.connectors.findSolanaWalletConnector(e.walletClientType)||null,L((n=>({...n,connector:t,status:"connected",connectedWallet:e,connectError:null,connectRetry:Se}))),d.captcha.enabledProvider&&!Me?(pe({captchaModalData:{callback:t=>te(e)?it(e,t):st(e,t),userIntentRequired:!1,onSuccessNavigateTo:"ConnectionStatusScreen",onErrorNavigateTo:"ErrorScreen"}}),await Ke("CaptchaScreen")):(te(e)?await it(e):await st(e),await Ke("ConnectionStatusScreen"))})(e)},fund:async t=>{await _t.fundWallet(e.address,t)},unlink:async()=>{if(!Me)throw new ke("User is not authenticated.");if("embedded"===e.connectorType&&"privy"===e.walletClientType)throw new ke("Cannot unlink an embedded wallet");Vi(await r.unlinkEthereumWallet(e.address))}})))||[];return ne(e.ethereum,t)?{}:{ethereum:t}}))};c((()=>{dt()}),[f?.linkedAccounts,Me,y]),c((()=>{if(y){if(!r.connectors)throw new ke("Connector not initialized");dt(),r.connectors.on("walletsUpdated",dt)}}),[y]),c((()=>{[...d.loginMethodsAndOrder?.primary??[],...d.loginMethodsAndOrder?.overflow??[]].filter((e=>e.startsWith("privy:"))).forEach((e=>r.getCrossAppProviderDetails(e.replace("privy:",""))))}),[!!r]);let ut=({transaction:e,sponsor:t,uiOptions:s,fundWalletConfig:o,address:l,signOnly:c})=>new Promise((async(u,h)=>{let{requesterAppId:p}=s||{},w=c?"signTransaction":"sendTransaction",y=l?R(f,l):I(f);if(!y&&l){let n=M(Hi(),l);if(n){if(t)throw new ke("Cannot sponsor transactions for externally connected wallet.");try{let t=await n.getEthereumProvider(),r=e.data,a=i(yr);a&&(r=a.appendDataSuffix({data:r}));let s={...e,from:l,chainId:e.chainId||Number(n.chainId.replace("eip155:","")),value:void 0!==e.value?kt(e.value):void 0,data:r},o=await t.request({method:"sendTransaction"===w?"eth_sendTransaction":"eth_signTransaction",params:[s]});return Qn(Ue,w,"onSuccess",{hash:o}),void u({hash:o})}catch(e){return Qn(Ue,w,"onError",Ce.TRANSACTION_FAILURE),void h(e??new De("Unable to "+w+e))}}}if(!y)return Qn(Ue,w,"onError",Ce.EMBEDDED_WALLET_NOT_FOUND),void h(new ke("No embedded or connected wallet found for address."));if(!Me||!f)return Qn(Ue,w,"onError",Ce.MUST_BE_AUTHENTICATED),void h(Error("User must be authenticated before signing with a Privy wallet"));let g=y.address,v=y.walletIndex??0,{entropyId:A,entropyIdVerifier:k}=ve(f,y),T=bt.wallets.find((e=>"privy"===e.walletClientType&&Tt(e.address)===Tt(g)));if(!T)return Qn(Ue,w,"onError",Ce.EMBEDDED_WALLET_NOT_FOUND),void h(Error("Must have a Privy wallet before signing"));let C=await T.getEthereumProvider(),_=await C.request({method:"eth_chainId"}),S=e.chainId?Number(e.chainId):Le(_);(e=>{if(!d.chains.map((e=>e.id)).includes(e))throw new Ae(`Chain ID ${e} is not supported. It must be added to the config.supportedChains property of the PrivyProvider.`,Ce.UNSUPPORTED_CHAIN_ID)})(S);let b=e.data,P=i(yr);P&&(b=P.appendDataSuffix({data:b}));let W={...e,from:e.from??g,chainId:S,data:b},U=await $r();if(!U||!ce)return Qn(Ue,w,"onError",Ce.EMBEDDED_WALLET_NOT_FOUND),void h(Error("Must have valid access token and Privy wallet to send transaction"));let N=gr(W.chainId,d.chains,d.rpcConfig,{appId:n.appId}),O=E(y),x=async({transactionRequest:e})=>{try{let n;if(!await _t.recoverEmbeddedWallet({address:g}))throw Qn(Ue,w,"onError",Ce.UNKNOWN_CONNECT_WALLET_ERROR),h(Error("Unable to connect to wallet")),Error("Unable to connect to wallet");if(t){let t=await(async({transactionRequest:e})=>{if(!O)throw new ke("Sponsoring is only supported for wallets on the TEE stack");if(c)throw new ke("Cannot sponsor a sign transaction request");let t=e=>null==e?void 0:kt(e),n=await m(a,(async({message:e})=>await ce.signWithUserSigner({accessToken:U,requesterAppId:p,message:e})),{chain_type:"ethereum",method:"eth_sendTransaction",caip2:ie(kt(e.chainId)),sponsor:!0,params:{transaction:{from:e.from,to:e.to,chain_id:t(e.chainId),data:Ct(e.data)?e.data?e.data:kt(Uint8Array.from(e.data)):void 0,value:t(e.value)}},wallet_id:y.id});if(n.data&&"hash"in n.data)return n.data.hash;throw new De("Unable to sign transaction")})({transactionRequest:e});return Qn(Ue,"sendTransaction","onSuccess",{hash:t}),t}if(O){let t=e=>null==e?void 0:kt(e),r=await m(a,(async({message:e})=>await ce.signWithUserSigner({accessToken:U,requesterAppId:p,message:e})),{chain_type:"ethereum",method:"eth_signTransaction",params:{transaction:{from:e.from,to:e.to,nonce:t(e.nonce),chain_id:t(e.chainId),data:Ct(e.data)?e.data?e.data:kt(Uint8Array.from(e.data)):void 0,value:t(e.value),type:e.type,gas_limit:t(e.gasLimit??e.gas),gas_price:t(e.gasPrice??e.gas),max_fee_per_gas:t(e.maxFeePerGas),max_priority_fee_per_gas:t(e.maxPriorityFeePerGas)}},wallet_id:y.id});if(!r.data||!("signed_transaction"in r.data))throw new De("Unable to sign transaction");n=r.data.signed_transaction}else n=await async function({accessToken:e,entropyId:t,entropyIdVerifier:n,transactingWalletIndex:r,walletProxy:a,transactionRequest:i,requesterAppId:s}){return(await a.rpc({entropyId:t,entropyIdVerifier:n,hdWalletIndex:r??0,chainType:"ethereum",accessToken:e,requesterAppId:s,request:{method:"eth_signTransaction",params:[i]}})).response.data}({accessToken:U,entropyId:A,entropyIdVerifier:k,transactingWalletIndex:v,walletProxy:ce,transactionRequest:e,requesterAppId:p});if(c)return Qn(Ue,"signTransaction","onSuccess",{signature:n}),n;{let e=await N.sendRawTransaction({serializedTransaction:n});return Qn(Ue,"sendTransaction","onSuccess",{hash:e}),e}}catch(e){throw Qn(Ue,w,"onError",Ce.TRANSACTION_FAILURE),e}};if(Ve({showWalletUIs:s?.showWalletUIs})){let e=c||t?W:await Di(W,N,W.from);try{let t=await x({transactionRequest:e});c?Qn(Ue,"signTransaction","onSuccess",{signature:t}):Qn(Ue,"sendTransaction","onSuccess",{hash:t}),u({hash:t})}catch(e){Qn(Ue,w,"onError",Ce.TRANSACTION_FAILURE),h(e)}}else{let e={connectingWalletAddress:g,recoveryMethod:y.recoveryMethod,entropyId:A,entropyIdVerifier:k,onCompleteNavigateTo:"SendTransactionScreen",isUnifiedWallet:O,onFailure:e=>{Qn(Ue,w,"onError",Ce.UNKNOWN_CONNECT_WALLET_ERROR),h(e)}},n=(e=>!!e.fundingConfig&&Fe(e.fundingConfig.options).length>=1)(d)?je({address:g,appConfig:d,fundWalletConfig:o,methodScreen:"FundingMethodSelectionScreen",chainIdOverride:W.chainId,comingFromSendTransactionScreen:!0}):void 0;pe({connectWallet:e,sendTransaction:{transactionRequest:W,transactingWalletIndex:v,transactingWalletAddress:g,entropyId:A,entropyIdVerifier:k,signOnly:c,scanTransaction:async()=>{let e=await Di(W,N,W.from);return await r.scanTransaction({metadata:{domain:d.embeddedWallets.transactionScanning.domain},chain_id:e.chainId.toString(),request:{method:"eth_sendTransaction",params:[{from:e.from,to:e.to,value:e.value?.toString(),gas:e.gas?.toString(),gasPrice:e.gasPrice?.toString(),nonce:e.nonce?.toString(),data:e.data}]}})},getIsSponsored:async()=>!!t,onConfirm:({transactionRequest:e})=>x({transactionRequest:e}),onSuccess:e=>{c?Qn(Ue,"signTransaction","onSuccess",{signature:e.hash}):Qn(Ue,"sendTransaction","onSuccess",{hash:e.hash}),u(e)},onFailure:e=>{Qn(Ue,w,"onError",Ce.TRANSACTION_FAILURE),h(e)},uiOptions:s||{},fundWalletConfig:o,requesterAppId:p},funding:n}),Ke("EmbeddedWalletConnectingScreen")}}));function ht(){return new Promise((async(e,t)=>{let n=await $r();if(!n||!ce)throw Error("Must have valid access token to enroll in MFA");try{await ce.verifyMfa({accessToken:n}),e()}catch(e){t(e)}}))}let pt=e=>e?.linkedAccounts.filter((e=>null!==e.latestVerifiedAt&&!("wallet"===e.type&&"privy"===e.walletClientType))).sort(((e,t)=>t.latestVerifiedAt.getTime()-e.latestVerifiedAt.getTime()))[0],wt=e=>{let t=f?.linkedAccounts.filter((t=>t.type===e)).length??0,{displayName:n,loginMethod:r}=Fi(e);if("passkey"===e&&t>=5||"passkey"!==e&&t>=1)throw Qn(Ue,"linkAccount","onError",Ce.CANNOT_LINK_MORE_OF_TYPE,{linkMethod:r}),new ke(`User already has an account of type ${n} linked.`)};async function mt({showAutomaticRecovery:e=!1,legacySetWalletPasswordFlow:t=!1}){b(null);let n=t?"setWalletPassword":"setWalletRecovery";if(!Me||!f)throw Qn(Ue,n,"onError",Ce.MUST_BE_AUTHENTICATED),Error("User must be authenticated before adding recovery method to Privy wallet");let r=S(f);if(!r||!ce)throw Qn(Ue,n,"onError",Ce.EMBEDDED_WALLET_NOT_FOUND),Error("Must have a Privy wallet to add a recovery method");let a=E(r);if(a)throw Qn(Ue,n,"onError",Ce.UNSUPPORTED_WALLET_TYPE),new ke("User owned wallet recovery is only supported for on-device execution and this app uses TEE execution. Learn more https://docs.privy.io/recipes/tee-wallet-migration-guide");try{await ht()}catch(e){throw Qn(Ue,n,"onError",Ce.MISSING_MFA_CREDENTIALS),e}return new Promise(((i,s)=>{let o="user-passcode"===r.recoveryMethod,l=Pi({walletAction:"update",availableRecoveryMethods:d.embeddedWallets.userOwnedRecoveryOptions,legacySetWalletPasswordFlow:t,isResettingPassword:o,showAutomaticRecovery:e}),{entropyId:c,entropyIdVerifier:u}=ve(f),h={recoveryMethod:r.recoveryMethod,connectingWalletAddress:r.address,onCompleteNavigateTo:l,shouldForceMFA:!1,entropyId:c,isUnifiedWallet:a,entropyIdVerifier:u,onFailure:e=>{Qn(Ue,n,"onError",Ce.UNKNOWN_CONNECT_WALLET_ERROR),s(e)}};pe({setWalletPassword:{onSuccess:e=>{Qn(Ue,n,"onSuccess",{method:"user-passcode",wallet:e}),i(e)},onFailure:e=>{Qn(Ue,n,"onError",Ce.USER_EXITED_SET_PASSWORD_FLOW),s(e)},callAuthOnSuccessOnClose:!1},recoverWallet:{entropyId:c,entropyIdVerifier:u,onFailure:s},connectWallet:h,recoverySelection:{isInAccountCreateFlow:!1,isResettingPassword:o,shouldCreateEth:!1,shouldCreateSol:!1}}),Ke("EmbeddedWalletConnectingScreen")}))}async function gt({appId:e,action:t,disableSignup:n}){let a=await $r();if("link"===t&&!a)throw Qn(Ue,"linkAccount","onError",Ce.MUST_BE_AUTHENTICATED,{linkMethod:`privy:${e}`}),new ke("User must be authenticated before linking an account.");if("login"===t&&a)throw Qn(Ue,"login","onError",Ce.UNKNOWN_AUTH_ERROR),new ke("Attempted to log in, but user is already logged in. Use a `link` helper instead.");ze.current=`privy:${e}`,He.current=t;let i=St();return r.createAnalyticsEvent({eventName:"cross_app_auth_started",payload:{providerAppId:e}}),new Promise((async(a,s)=>{let{name:o,logoUrl:l}=await _i({api:r.api,providerAppId:e,requesterAppId:d.id});pe({crossAppAuth:{appId:e,name:o,logoUrl:l,action:t,popup:i,disableSignup:n,onSuccess:a,onError:s}}),Ke("CrossAppAuthScreen")}))}let ft={ready:y,authenticated:Me,user:f,walletConnectors:r.connectors||null,connectWallet:e=>{e&&"target"in e&&e&&(e=void 0),pe({externalConnectWallet:{walletList:e?.walletList&&e?.walletList.length>0?e.walletList:void 0,walletChainType:e?.walletChainType,description:e?.description,hideHeader:e?.hideHeader}}),Ke("ConnectOnlyLandingScreen")},linkWallet:e=>(e&&"target"in e&&e&&(e=void 0),lt("siwe"),ze.current="siwe",He.current="link",pe({...he,externalConnectWallet:{...he.externalConnectWallet,walletList:e?.walletList,walletChainType:e?.walletChainType,description:e?.description||`Link a wallet to your ${d?.name} account`}}),Ke("AuthenticateWithWalletScreen")),startCrossAppAuthFlow:gt,linkEmail:()=>{lt("email"),wt("email"),ze.current="email",He.current="link",Ke("LinkEmailScreen")},linkPhone:()=>{lt("sms"),wt("phone"),ze.current="sms",He.current="link",Ke("LinkPhoneScreen")},linkGoogle:async()=>{lt("google"),wt("google_oauth"),He.current="link",await _t.initLoginWithOAuth("google")},linkTwitter:async()=>{lt("twitter"),wt("twitter_oauth"),He.current="link",await _t.initLoginWithOAuth("twitter")},linkTwitch:async()=>{lt("twitch"),wt("twitch_oauth"),He.current="link",await _t.initLoginWithOAuth("twitch")},linkDiscord:async()=>{lt("discord"),wt("discord_oauth"),He.current="link",await _t.initLoginWithOAuth("discord")},linkGithub:async()=>{lt("github"),wt("github_oauth"),He.current="link",await _t.initLoginWithOAuth("github")},linkSpotify:async()=>{lt("spotify"),wt("spotify_oauth"),He.current="link",await _t.initLoginWithOAuth("spotify")},linkInstagram:async()=>{lt("instagram"),wt("instagram_oauth"),He.current="link",await _t.initLoginWithOAuth("instagram")},linkTiktok:async()=>{lt("tiktok"),wt("tiktok_oauth"),He.current="link",await _t.initLoginWithOAuth("tiktok")},linkLine:async()=>{lt("line"),wt("line_oauth"),He.current="link",await _t.initLoginWithOAuth("line")},linkLinkedIn:async()=>{lt("linkedin"),wt("linkedin_oauth"),He.current="link",await _t.initLoginWithOAuth("linkedin")},linkApple:async()=>{lt("apple"),wt("apple_oauth"),He.current="link",await _t.initLoginWithOAuth("apple")},linkPasskey:async()=>{lt("passkey"),wt("passkey"),await _t.initLinkWithPasskey(),Ke("LinkPasskeyScreen")},linkTelegram:async e=>{if(lt("telegram"),wt("telegram"),He.current="link",ze.current="telegram",e?.launchParams)if(e.launchParams.initDataRaw){let t=new Ta;r.startAuthFlow(t),t.meta.telegramAuthResult=void 0,t.meta.telegramWebAppData=_a(e.launchParams.initDataRaw),pe({telegramAuthModalData:{seamlessAuth:!0}}),Ke("TelegramAuthScreen")}else Qn(Ue,"linkAccount","onError",Ce.INVALID_DATA,{linkMethod:"telegram"});else await _t.initLoginWithTelegram();Ke("TelegramAuthScreen")},linkFarcaster:async()=>{lt("farcaster"),wt("farcaster"),await _t.initLoginWithFarcaster(),He.current="link",ze.current="farcaster",Ke("FarcasterConnectStatusScreen")},updateEmail:()=>{if(lt("email"),!f?.email)throw new ke("User does not have an email linked to their account.");He.current="update",ze.current="email",Ke("UpdateEmailScreen")},updatePhone:()=>{if(lt("sms"),!f?.phone)throw new ke("User does not have a phone number linked to their account.");He.current="update",ze.current="sms",Ke("UpdatePhoneScreen")},login:async e=>{e&&"target"in e&&e&&(e=void 0);let t="Attempted to log in, but user is already logged in. Use a `link` helper instead.";if(!y){let e=await new Promise((e=>{me((t=>e.bind(t)))}));if(me(null),e)return void console.warn(t)}!f||f.isGuest?(He.current="login",pe({login:e}),Ke("LandingScreen")):console.warn(t)},connectOrCreateWallet:async()=>{y||(await new Promise((e=>{me((()=>e))})),me(null)),Me?console.warn("User must be unauthenticated to `connectOrCreateWallet`"):(He.current="connect-or-create",Ke("ConnectOrCreateScreen"))},logout:async()=>{if(He.current=null,ze.current=null,f&&r.clearProviderAcccessTokens(f),b(null),await r.logout(),f&&ce)try{await ce.clearMfa({userId:f.id})}catch(e){}Vi(null),xe(!1),B({status:"initial"}),K({status:"initial"}),q({status:"initial"}),G({status:"initial"}),J({status:"initial"}),le({status:"initial"}),Qn(Ue,"logout","onSuccess"),p(!1),Re.del(nt),Re.del(rt(d.id))},getAccessToken:h((async()=>{let e=await r.getCustomerAccessToken();return e&&!Me&&xe(!0),e}),[r,Me]),unlinkWallet:async e=>{let t;return Vi(t=e.startsWith("0x")?await r.unlinkEthereumWallet(e):await r.unlinkSolanaWallet(e)),t},unlinkEmail:async e=>{let t=await r.unlinkEmail(e);return Vi(t),t},unlinkPhone:async e=>{let t=await r.unlinkPhone(e);return Vi(t),t},unlinkGoogle:async e=>{let t=await r.unlinkOAuth("google",e);return Vi(t),t},unlinkTwitter:async e=>{let t=await r.unlinkOAuth("twitter",e);return Vi(t),t},unlinkTwitch:async e=>{let t=await r.unlinkOAuth("twitch",e);return Vi(t),t},unlinkDiscord:async e=>{let t=await r.unlinkOAuth("discord",e);return Vi(t),t},unlinkGithub:async e=>{let t=await r.unlinkOAuth("github",e);return Vi(t),t},unlinkSpotify:async e=>{let t=await r.unlinkOAuth("spotify",e);return Vi(t),t},unlinkInstagram:async e=>{let t=await r.unlinkOAuth("instagram",e);return Vi(t),t},unlinkTiktok:async e=>{let t=await r.unlinkOAuth("tiktok",e);return Vi(t),t},unlinkLine:async e=>{let t=await r.unlinkOAuth("line",e);return Vi(t),t},unlinkLinkedIn:async e=>{let t=await r.unlinkOAuth("linkedin",e);return Vi(t),t},unlinkApple:async e=>{let t=await r.unlinkOAuth("apple",e);return Vi(t),t},unlinkFarcaster:async e=>{let t=await r.unlinkFarcaster(e);return Vi(t),t},unlinkTelegram:async e=>{let t=await r.unlinkTelegram(e);return Vi(t),t},unlinkPasskey:async e=>{let t=await $r();if(!t)throw Error("Must have valid access token to enroll in MFA");if(!ce)throw Error("Wallet proxy not initialized.");let n=d.passkeys.shouldUnenrollMfaOnUnlink;await ce.unlinkPasskeyAccount({credentialId:e,accessToken:t,removeAsMfa:n});let a=await r.getAuthenticatedUser();return Vi(a),a},unlinkCrossAppAccount:async({subject:e})=>{let t=f?.linkedAccounts.find((t=>"cross_app"===t.type&&t.subject===e))?.providerApp;if(!t)throw new ke("Invalid subject");r.storeProviderAccessToken(t.id,null);let n=await r.unlinkOAuth(`privy:${t.id}`,e);return Vi(n),n},setWalletRecovery:async e=>mt({legacySetWalletPasswordFlow:!1,showAutomaticRecovery:e?.showAutomaticRecovery??!1}),setWalletPassword:async()=>mt({legacySetWalletPasswordFlow:!0,showAutomaticRecovery:!1}),signMessage:(e,t)=>new Promise((async(n,i)=>{let{requesterAppId:s}=t?.uiOptions||{},o=e.message,l=t?.address?R(f,t.address):I(f);if(!l&&void 0!==t?.address){let e=M(Hi(),t.address);if(e)try{let t=await e.getEthereumProvider(),r=await t.request({method:"personal_sign",params:[o,e.address]});return Qn(Ue,"signMessage","onSuccess",{signature:r}),void n({signature:r})}catch(e){return Qn(Ue,"signMessage","onError",Ce.UNABLE_TO_SIGN),void i(e??new De("Unable to sign message"))}}if(!l)throw new ke("No embedded or connected wallet found for address.");if(!Me||!f)return Qn(Ue,"signMessage","onError",Ce.MUST_BE_AUTHENTICATED),void i(Error("User must be authenticated before signing with a Privy wallet"));let c=l.address,d=l.walletIndex??0,{entropyId:u,entropyIdVerifier:h}=ve(f,l),p=E(l);if("string"!=typeof o||o.length<1)return Qn(Ue,"signMessage","onError",Ce.INVALID_MESSAGE),void i(Error("Message must be a non-empty string"));let w=async()=>{let t;if(!Me)throw Error("User must be authenticated before signing with a Privy wallet");let n=await $r();if(!ce||!n||!await _t.recoverEmbeddedWallet({address:c}))throw Error("Unable to connect to wallet");if(r.createAnalyticsEvent({eventName:"embedded_wallet_sign_message_started",payload:{walletAddress:c,requesterAppId:s}}),p){let r=Ct(e.message,{strict:!0}),i=await m(a,(async({message:e})=>await ce.signWithUserSigner({accessToken:n,requesterAppId:s,message:e})),{chain_type:"ethereum",method:"personal_sign",params:r?{message:o.slice(2),encoding:"hex"}:{message:o,encoding:"utf-8"},wallet_id:l.id});if(!i.data||!("signature"in i.data))throw new De("Unable to sign message");t=i.data.signature}else{let{response:e}=await ce.rpc({accessToken:n,entropyId:u,entropyIdVerifier:h,chainType:"ethereum",hdWalletIndex:d,requesterAppId:s,request:{method:"personal_sign",params:[o,c]}});t=e.data}return r.createAnalyticsEvent({eventName:"embedded_wallet_sign_message_completed",payload:{walletAddress:c,requesterAppId:s}}),t};if(Ve({showWalletUIs:t?.uiOptions?.showWalletUIs}))try{let e=await w();Qn(Ue,"signMessage","onSuccess",{signature:e}),n({signature:e})}catch(e){Qn(Ue,"signMessage","onError",Ce.UNABLE_TO_SIGN),i(e??new De("Unable to sign message"))}else pe({signMessage:{method:"personal_sign",data:o,confirmAndSign:w,onSuccess:e=>{Qn(Ue,"signMessage","onSuccess",{signature:e}),n({signature:e})},onFailure:e=>{Qn(Ue,"signMessage","onError",Ce.UNABLE_TO_SIGN),i(e)},uiOptions:t?.uiOptions||{}},connectWallet:{recoveryMethod:l.recoveryMethod,connectingWalletAddress:c,entropyId:u,entropyIdVerifier:h,onCompleteNavigateTo:"SignRequestScreen",isUnifiedWallet:p,onFailure:e=>{Qn(Ue,"signMessage","onError",Ce.UNKNOWN_CONNECT_WALLET_ERROR),i(e)}}}),Ke("EmbeddedWalletConnectingScreen")})),signTypedData:(e,t)=>new Promise((async(n,i)=>{let{requesterAppId:s}=t?.uiOptions||{},o=t?.address?R(f,t.address):I(f);if(!o&&t?.address){let r=M(Hi(),t.address);if(r)try{let t=await r.getEthereumProvider(),a=re(e),i=await t.request({method:"eth_signTypedData_v4",params:[r.address,a]});return Qn(Ue,"signTypedData","onSuccess",{signature:i}),void n({signature:i})}catch(e){return Qn(Ue,"signTypedData","onError",Ce.UNABLE_TO_SIGN),void i(e??new De("Unable to sign typed data "+e))}}if(!o)throw new ke("No embedded or connected wallet found for address.");if(!Me||!f)return Qn(Ue,"signTypedData","onError",Ce.MUST_BE_AUTHENTICATED),void i(Error("User must be authenticated before signing with a Privy wallet"));let l=o.address,c=o.walletIndex??0,{entropyId:d,entropyIdVerifier:u}=ve(f,o),h=E(o),p=re(e),w=async()=>{let e;if(!Me)throw Error("User must be authenticated before signing with a Privy wallet");let t=await $r();if(!ce||!t||!await _t.recoverEmbeddedWallet({address:l}))throw Error("Unable to connect to wallet");if(r.createAnalyticsEvent({eventName:"embedded_wallet_sign_typed_data_started",payload:{walletAddress:l,requesterAppId:s}}),h){let{domain:n,types:r,primaryType:i,message:l}=p,c=await m(a,(async({message:e})=>await ce.signWithUserSigner({accessToken:t,requesterAppId:s,message:e})),{chain_type:"ethereum",method:"eth_signTypedData_v4",params:{typed_data:{domain:n,types:r,primary_type:i,message:l}},wallet_id:o.id});if(!c.data||!("signature"in c.data))throw new De("Unable to sign message");e=c.data.signature}else{let{response:n}=await ce.rpc({accessToken:t,entropyId:d,entropyIdVerifier:u,chainType:"ethereum",hdWalletIndex:c,requesterAppId:s,request:{method:"eth_signTypedData_v4",params:[l,p]}});e=n.data}return r.createAnalyticsEvent({eventName:"embedded_wallet_sign_typed_data_completed",payload:{walletAddress:l,requesterAppId:s}}),e};if(Ve({showWalletUIs:t?.uiOptions?.showWalletUIs}))try{let e=await w();Qn(Ue,"signTypedData","onSuccess",{signature:e}),n({signature:e})}catch(e){Qn(Ue,"signTypedData","onError",Ce.UNABLE_TO_SIGN),i(e??new De("Unable to sign message"))}else pe({signMessage:{method:"eth_signTypedData_v4",data:p,confirmAndSign:w,onSuccess:e=>{Qn(Ue,"signTypedData","onSuccess",{signature:e}),n({signature:e})},onFailure:e=>{Qn(Ue,"signTypedData","onError",Ce.UNABLE_TO_SIGN),i(e)},uiOptions:t?.uiOptions||{}},connectWallet:{recoveryMethod:o.recoveryMethod,connectingWalletAddress:o.address,entropyId:d,isUnifiedWallet:h,entropyIdVerifier:u,onCompleteNavigateTo:"SignRequestScreen",onFailure:e=>{Qn(Ue,"signMessage","onError",Ce.UNKNOWN_CONNECT_WALLET_ERROR),i(e)}}}),Ke("EmbeddedWalletConnectingScreen")})),sendTransaction:async(e,t)=>await ut({transaction:e,sponsor:t?.sponsor,uiOptions:t?.uiOptions,fundWalletConfig:t?.fundWalletConfig,address:t?.address,signOnly:!1}),signTransaction:async(e,t)=>({signature:(await ut({transaction:e,uiOptions:t?.uiOptions,address:t?.address,signOnly:!0})).hash}),promptMfa:ht,async init(e){switch(e){case"sms":return void await r.initMfaSmsVerification();case"passkey":return await r.initMfaPasskeyVerification();case"totp":return;default:throw Error(`Unsupported MFA method: ${e}`)}},async submit(e,t){switch(e){case"totp":case"sms":if("string"!=typeof t)throw new ke("Invalid MFA code");Ee.current?.resolve({mfaMethod:e,mfaCode:t,relyingParty:window.origin}),await new Promise(((e,t)=>{Ie.current={resolve:e,reject:t}}));break;case"passkey":if("string"==typeof t)throw new ke("Invalid authenticator response");let n=await import("@simplewebauthn/browser"),r=qi(await n.startAuthentication({optionsJSON:t}));Ee.current?.resolve({mfaMethod:e,mfaCode:r,relyingParty:window.origin}),await new Promise(((e,t)=>{Ie.current={resolve:e,reject:t}}));break;default:throw Ee.current?.reject(new ke("Unsupported MFA method")),new ke(`Unsupported MFA method: ${e}`)}},cancel(){Ee.current?.reject(new ke("MFA canceled"))},async initEnrollmentWithSms(e){let t=await $r();if(!t||!ce)throw Error("Must have valid access token to enroll in MFA");await ce.initEnrollMfa({method:"sms",accessToken:t,phoneNumber:e.phoneNumber})},enrollInMfa:e=>new Promise(((t,n)=>{if(!e)return _t.closePrivyModal(),void t();d.mfa.noPromptOnMfaRequired&&console.warn("[Privy Warning] Triggering the 'showMfaEnrollmentModal' function when 'noPromptOnMfaRequired' is set to true is unexpected. If this is intentional, ensure that you are building custom UIs for MFA verification."),pe({mfaEnrollmentFlow:{mfaMethods:d.mfa.methods,shouldUnlinkOnUnenrollMfa:d.passkeys.shouldUnlinkOnUnenrollMfa,onSuccess:t,onFailure:n}}),Ke("MfaEnrollmentFlowScreen")})),async initEnrollmentWithTotp(){let e=await $r();if(!e||!ce)throw Error("Must have valid access token to enroll in MFA");let t=await ce.initEnrollMfa({method:"totp",accessToken:e});return{secret:t.secret,authUrl:t.authUrl}},async submitEnrollmentWithSms(e){let t=await $r();if(!t||!ce)throw Error("Must have valid access token to enroll in MFA");await ce.submitEnrollMfa({method:"sms",accessToken:t,phoneNumber:e.phoneNumber,code:e.mfaCode}),Vi(await r.getAuthenticatedUser())},async submitEnrollmentWithTotp(e){let t=await $r();if(!t||!ce)throw Error("Must have valid access token to enroll in MFA");await ce.submitEnrollMfa({method:"totp",accessToken:t,code:e.mfaCode}),Vi(await r.getAuthenticatedUser())},async initEnrollmentWithPasskey(){},async submitEnrollmentWithPasskey({credentialIds:e},t={}){let n=await $r();if(!n||!ce)throw Error("Must have valid access token to enroll in MFA");await ce.submitEnrollMfa({method:"passkey",accessToken:n,credentialIds:e,removeForLogin:t.removeForLogin}),Vi(await r.getAuthenticatedUser())},async unenroll(e,t={}){let n=await $r();if(!n||!ce)throw Error("Must have valid access token to remove MFA");"passkey"===e?await ce.submitEnrollMfa({method:"passkey",accessToken:n,credentialIds:[],removeForLogin:t.removeForLogin}):await ce.unenrollMfa({method:e,accessToken:n}),Vi(await r.getAuthenticatedUser())},requestFarcasterSignerFromWarpcast:async()=>{let e=await $r(),t=f?.linkedAccounts.find((e=>"wallet"===e.type&&"privy"===e.walletClientType));if(!e)throw Error("Must have valid access token to connect with Farcaster");if(!ce||!t)throw Error("Must have an embedded wallet to use Farcaster signers");if(E(t))throw new ke("Farcaster signers are only supported for on-device execution and this app uses TEE execution. Learn more at https://docs.privy.io/recipes/tee-wallet-migration-guide");if(!f?.farcaster?.fid)throw Error("Must have Farcaster account to use Farcaster signers");if(!await _t.recoverEmbeddedWallet({address:t.address}))throw Error("Unable to connect to wallet");let n=await ce.initFarcasterSigner({address:t.address,hdWalletIndex:null,accessToken:e,mfaCode:null,mfaMethod:null,relyingParty:window.origin});"approved"===n.status&&Vi(await r.getAuthenticatedUser()||f||null),pe({farcasterSigner:n}),Ke("FarcasterSignerStatusScreen")},getFarcasterSignerPublicKey:async()=>{let e,t=await $r(),n=f?.linkedAccounts.find((e=>"wallet"===e.type&&"privy"===e.walletClientType));if(!t)throw Error("Must have valid access token to connect with Farcaster");if(!ce||!n)throw Error("Must have an embedded wallet to use Farcaster signers");if(E(n))throw new ke("Farcaster signers are only supported for on-device execution and this app uses TEE execution. Learn more at https://docs.privy.io/recipes/tee-wallet-migration-guide");if(!f?.farcaster?.fid)throw Error("Must have Farcaster account to use Farcaster signers");if(!await _t.recoverEmbeddedWallet({address:n.address}))throw Error("Unable to connect to wallet");if(!f.farcaster?.signerPublicKey)throw Error("Must have a Farcaster signer public key to sign");return e=f.farcaster.signerPublicKey.slice(2),Uint8Array.from(e.match(/.{1,2}/g).map((e=>parseInt(e,16))))},signFarcasterMessage:async e=>{let t=await $r(),n=f?.linkedAccounts.find((e=>"wallet"===e.type&&"privy"===e.walletClientType));if(!t)throw Error("Must have valid access token to connect with Farcaster");if(!ce||!n)throw Error("Must have an embedded wallet to use Farcaster signers");if(E(n))throw new ke("Farcaster signers are only supported for on-device execution and this app uses TEE execution. Learn more at https://docs.privy.io/recipes/tee-wallet-migration-guide");if(!f?.farcaster?.fid)throw Error("Must have Farcaster account to use Farcaster signers");if(!await _t.recoverEmbeddedWallet({address:n.address}))throw Error("Unable to connect to wallet");if(!f.farcaster?.signerPublicKey)throw Error("Must have a Farcaster signer public key to sign");let r=await import("@simplewebauthn/browser"),a=await ce.signFarcasterMessage({address:n.address,hdWalletIndex:null,accessToken:t,mfaCode:null,mfaMethod:null,payload:{hash:r.bufferToBase64URLString(e)},fid:BigInt(f.farcaster.fid),relyingParty:window.origin});return new Uint8Array(r.base64URLStringToBuffer(a.signature))},signMessageWithCrossAppWallet(e,{address:t,chainId:n}){let a=f?.linkedAccounts.some((e=>"cross_app"===e.type&&e.smartWallets.some((e=>e.address===t))));return Si({user:f,client:r,address:t,requesterAppId:d.id,request:{method:a?"privy_signSmartWalletMessage":"personal_sign",params:[e,t],chainId:n},reconnect:gt})},signTypedDataWithCrossAppWallet(e,{address:t,chainId:n}){let a=f?.linkedAccounts.some((e=>"cross_app"===e.type&&e.smartWallets.some((e=>e.address===t)))),i=re(e);return Si({user:f,client:r,address:t,requesterAppId:d.id,request:{method:a?"privy_signSmartWalletTypedData":"eth_signTypedData_v4",params:[t,i],chainId:n},reconnect:gt})},sendTransactionWithCrossAppWallet(e,{address:t}){let n=f?.linkedAccounts.some((e=>"cross_app"===e.type&&e.smartWallets.some((e=>e.address===t))));return Si({user:f,client:r,address:t,requesterAppId:d.id,request:{method:n?"privy_sendSmartWalletTx":"eth_sendTransaction",params:[e],chainId:e.chainId},reconnect:gt})},signTransactionWithCrossAppWallet(e,{address:t}){let n=f?.linkedAccounts.some((e=>"cross_app"===e.type&&e.smartWallets.some((e=>e.address===t))));return Si({user:f,client:r,address:t,requesterAppId:d.id,request:{method:n?"privy_signSmartWalletTx":"eth_signTransaction",params:[e],chainId:e.chainId},reconnect:gt})},isModalOpen:u||!!w,mfaMethods:d.mfa.methods};rs=ft.signMessage,as=ft.signTypedData,ss=async(e,t)=>await ut({transaction:e,...t,signOnly:!1}),is=async(e,t)=>({signature:(await ut({transaction:e,...t,signOnly:!0})).hash});let At=async e=>{let t,n,a;F(!0),J({status:"loading"}),r.startAuthFlow(new la({...e,customOAuthRedirectUrl:d.customOAuthRedirectUrl}));let i=Re.get(Qe),s=e.stateCode;if(i!==s)throw r.createAnalyticsEvent({eventName:"possible_phishing_attempt",payload:{provider:e.provider,storedStateCode:i??"",returnedStateCode:s??""}}),F(!1),new ke("Unexpected auth flow. This may be a phishing attempt.",void 0,Ce.OAUTH_UNEXPECTED);if(null!==await r.getAccessToken())try{({user:t,oAuthTokens:a}=await r.link()),ze.current=e.provider;let n=pt(t);t&&n&&Qn(Ue,"linkAccount","onSuccess",{user:t,linkMethod:ze.current,linkedAccount:n})}catch(t){throw F(!1),Qn(Ue,"linkAccount","onError",t.privyErrorCode||Ce.FAILED_TO_LINK_ACCOUNT,{linkMethod:e.provider}),t}else try{({user:t,isNewUser:n,oAuthTokens:a}=await r.authenticate()),ze.current=e.provider;let i=pt(t);t&&i&&void 0!==n&&Qn(Ue,"login","onComplete",{user:t,isNewUser:n,wasAlreadyAuthenticated:!1,loginMethod:ze.current,loginAccount:i})}catch(e){throw F(!1),J({status:"error",error:e}),Qn(Ue,"login","onError",e.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),e}return Vi(t),C(n||!1),xe(!0),F(!1),J({status:"done"}),a&&t&&Qn(Ue,"oAuthAuthorization","onOAuthTokenGrant",{oAuthTokens:a,user:t}),t??void 0},_t={privy:a,setAuthenticated:xe,setUser:Vi,setIsNewUser:C,isNewUserThisSession:T,pendingTransaction:null,walletConnectionStatus:D,setWalletConnectionStatus:L,connectors:r.connectors?.walletConnectors??[],rpcConfig:d.rpcConfig,chains:d.chains,appId:n.appId,showFiatPrices:"native-token"!==d.embeddedWallets.priceDisplay.primary,clientAnalyticsId:r.clientAnalyticsId,hideWalletUIs:Be,isHeadlessSigning:h(Ve,[d.embeddedWallets.showWalletUIs]),emailOtpState:z,setEmailOtpState:B,smsOtpState:V,setSmsOtpState:K,oAuthState:Y,setOAuthState:J,telegramAuthState:Q,setTelegramAuthState:le,siweState:$,setSiweState:G,isHeadlessOAuthLoading:P,baseAccountSdk:A,setBaseAccountSdk:k,nativeTokenSymbolForChainId:e=>d.chains.find((t=>t.id===Number(e)))?.nativeCurrency.symbol,initializeWalletProxy:async e=>{if(ce)return ce;let t=new Promise((e=>{ye.current=e})),n=new Promise((t=>setTimeout((()=>t(null)),e))),r=await Promise.race([t,n]);return ye.current=null,r},getAuthFlow:()=>r.authFlow,getAuthMeta:()=>r.authFlow?.meta,client:r,closePrivyModal:async(e={shouldCallAuthOnSuccess:!0,isSuccess:!1})=>{let t,a=y&&Me&&f;if(a&&ze.current&&(t=pt(f)),"login"===He.current)e.shouldCallAuthOnSuccess&&a&&ze.current?Qn(Ue,"login","onComplete",{user:f,isNewUser:T,wasAlreadyAuthenticated:!1,loginMethod:ze.current,loginAccount:t??null}):Qn(Ue,"login","onError",Ce.USER_EXITED_AUTH_FLOW);else if("link"===He.current&&t)e.isSuccess&&a&&ze.current?Qn(Ue,"linkAccount","onSuccess",{user:f,linkMethod:ze.current,linkedAccount:t}):ze.current&&Qn(Ue,"linkAccount","onError",Ce.USER_EXITED_LINK_FLOW,{linkMethod:ze.current});else if("update"===He.current&&t)e.isSuccess&&a&&ze.current?Qn(Ue,"update","onSuccess",{user:f,updateMethod:ze.current,updatedAccount:t}):ze.current&&Qn(Ue,"update","onError",Ce.USER_EXITED_UPDATE_FLOW,{linkMethod:ze.current});else if("connect-or-create"===He.current){let e=Hi();e[0]?Qn(Ue,"connectOrCreateWallet","onSuccess",{wallet:e[0]}):Qn(Ue,"connectOrCreateWallet","onError",Ce.USER_EXITED_AUTH_FLOW)}let s=_&&Oi.has(_),o="ErrorScreen"===_&&he.errorModalData&&Oi.has(he.errorModalData.previousScreen);if((s||o)&&he.funding){let e,t=Oi.get(_)??null;if(o&&he.funding?.onError){let e=he.errorModalData?.error,t=e?.privyErrorCode||Ce.UNKNOWN_FUNDING_ERROR,n=new ke(e?.message||"Funding failed",e,t);he.funding?.onError?.(n)}if("solana"===he.funding.chainType){let n=d.solanaRpcs[he.funding.chain];if(!n)return console.warn("Unable to load solana rpc, skipping balance"),Qn(Ue,"fundSolanaWallet","onUserExited",{address:he.funding.address,fundingMethod:t,chain:he.funding.chain,balance:e}),p(!1),void Ui(he.funding,t);if(i(qn))try{e=await Mi({rpc:n.rpc,address:he.funding.address})}catch{console.error("Unable to pull wallet balance")}else console.warn("Unable to load solana plugin, skipping balance");Qn(Ue,"fundSolanaWallet","onUserExited",{address:he.funding.address,fundingMethod:t,chain:he.funding.chain,balance:e})}else{let r=gr(he.funding.chain.id,d.chains,d.rpcConfig,{appId:n.appId});try{e=await r.getBalance({address:he.funding.address})}catch{console.error("Unable to pull wallet balance")}Qn(Ue,"fundWallet","onUserExited",{address:he.funding.address,chain:he.funding.chain,fundingMethod:t,balance:e}),Ui(he.funding,t)}}pe((e=>({...e,externalConnectWallet:{}}))),He.current=null,ze.current=null,C(!1),p(!1),L({status:"disconnected",connectedWallet:null,connector:null,connectError:null,connectRetry:()=>{}}),setTimeout((()=>{r.authFlow=void 0}),200)},openPrivyModal:Ke,connectWallet:at,initLoginWithWallet:async(e,t,n,r)=>{te(e)?(ze.current="siwe",it(e,t,n)):(ze.current="siws",st(e,t,n,r))},loginWithWallet:async()=>{let e,t,n;if(!y)throw new We;if(r.authFlow instanceof pa?e="siwe":r.authFlow instanceof wa&&(e="siws"),!e)throw new ke("Must initialize SIWE/SIWS flow first.");if(null!==await r.getAccessToken())try{({user:t}=await r.link()),ze.current=e}catch(t){throw Qn(Ue,"linkAccount","onError",t.privyErrorCode||Ce.FAILED_TO_LINK_ACCOUNT,{linkMethod:e}),t}else try{({user:t,isNewUser:n}=await r.authenticate()),ze.current=e}catch(e){throw Qn(Ue,"login","onError",e.privyErrorCode||Ce.GENERIC_CONNECT_WALLET_ERROR),e}Vi(t||f||null),C(n||!1),xe(!0)},delegateWallet:async({address:e,chainType:t,showDelegationUIs:n})=>new Promise((async(r,a)=>{let i=await $r();if(!Me||!f||!i)throw new ke("User must be authenticated and have an embedded wallet to delegate actions.");if("solana"!==t&&"ethereum"!==t)throw new ke("Only Solana and Ethereum embedded wallets are supported for delegation and revocation.");let s=_t.walletProxy??await _t.initializeWalletProxy(15e3);if(!s)throw new ke("Wallet proxy not initialized.");if((({address:e,user:t})=>!!Ai(t).find((t=>t.address===e)))({address:e,user:f}))return r();let o=R(f,e);if(!o)throw new ke("Address to delegate is not associated with current user.");if(E(o))throw new ke("useDelegatedActions is only supported for on-device execution and this app uses TEE execution. Use the useSessionSigners hook to provision server side access on behalf of your users. Learn more at https://docs.privy.io/recipes/tee-wallet-migration-guide");let l=fi({address:e,user:f}),c=vi({address:e,user:f}),d=async()=>{await s.createDelegatedAction({accessToken:i,rootWallet:c,delegatedWallets:[l]}),await _t.refreshSessionAndUser()};if(await _t.recoverEmbeddedWallet({address:e}),n)pe({delegatedActions:{consent:{address:e,onDelegate:d,onSuccess:async()=>{r()},onError:async e=>{a(e)}}}}),Ke("DelegatedActionsConsentScreen");else try{await d(),r()}catch(e){a(e)}})),revokeDelegatedWallets:async({showDelegationUIs:e})=>new Promise((async(t,n)=>{if(!Me||!f)throw new ke("User must be authenticated and have an embedded wallet to revoke a delegated wallet.");let a=Ai(f);if(0===a.length)throw new ke("User has no delegated wallets to revoke.");if(a.some(E))throw new ke("useDelegatedActions is only supported for on-device execution and this app uses TEE execution. Use the useSessionSigners hook to provision server side access on behalf of your users. Learn more at https://docs.privy.io/recipes/tee-wallet-migration-guide");let i=async()=>{await r.revokeDelegatedWallet(),await _t.refreshSessionAndUser()};if(e)pe({delegatedActions:{revoke:{onRevoke:i,onSuccess:async()=>{t()},onError:async e=>{n(e)}}}}),Ke("DelegatedActionsRevokeScreen");else try{await i(),t()}catch(e){n(e)}})),initLoginWithFarcaster:async(e,t)=>{let n=new Xr(e,t);r.startAuthFlow(n);try{ze.current="farcaster",await n.initializeFarcasterConnect()}catch(e){throw"login"===He.current?Qn(Ue,"login","onError",e.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR):"link"===He.current&&Qn(Ue,"linkAccount","onError",e.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR,{linkMethod:"farcaster"}),e}},loginWithFarcaster:async()=>{let e,t;if(!y)throw new We;if(!(r.authFlow instanceof Xr))throw new ke("Must initialize Farcaster flow first.");if(null!==await r.getAccessToken())try{({user:e}=await r.link()),ze.current="farcaster"}catch(e){throw Qn(Ue,"linkAccount","onError",e.privyErrorCode||Ce.FAILED_TO_LINK_ACCOUNT,{linkMethod:"farcaster"}),e}else try{({user:e,isNewUser:t}=await r.authenticate()),ze.current="farcaster"}catch(e){throw Qn(Ue,"login","onError",e.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),e}Vi(e||null),C(t||!1),xe(!0)},async crossAppAuthFlow({appId:e,popup:t,action:n,disableSignup:a}){let i=`privy:${e}`;ze.current=i;let{url:s,stateCode:o,codeVerifier:l}=await async function({api:e,appId:t}){let n=ia(),r=sa(),a=await oa(n);try{let{url:i}=await e.post(xt,{provider:`privy:${t}`,redirect_to:window.location.href,code_challenge:a,state_code:r});return{url:i,stateCode:r,codeVerifier:n}}catch(e){throw Te(e)}}({api:r.api,appId:e});if(!s)throw r.createAnalyticsEvent({eventName:"cross_app_auth_error",payload:{error:"Unable to open cross-app auth popup",appId:e}}),new ke("No authorization URL returned for cross-app auth.");try{let c=await async function({url:e,popup:t}){return t.location=e,new Promise(((e,n)=>{let r,a=setTimeout((()=>{n(new ke("Authorization request timed out after 2 minutes.")),i()}),12e4);function i(){t?.close(),window.removeEventListener("message",o)}let s=setInterval((()=>{t?.closed&&!r&&(i(),clearInterval(s),clearTimeout(a),n(new ke("User rejected request")))}),300);function o(t){t.data&&("PRIVY_OAUTH_RESPONSE"===t.data.type&&t.data.stateCode&&t.data.authorizationCode&&(clearTimeout(a),e(t.data),i()),"PRIVY_OAUTH_ERROR"===t.data.type&&(clearTimeout(a),n(new ke(t.data.error)),i()),t.data.type===Ti&&((r=new BroadcastChannel(ki)).onmessage=o))}window.addEventListener("message",o)}))}({url:s,popup:t,provider:i}),d=c.stateCode,u=c.authorizationCode;if(d!==o)throw r.createAnalyticsEvent({eventName:"possible_phishing_attempt",payload:{provider:i,storedStateCode:o??"",returnedStateCode:d??""}}),new ke("Unexpected auth flow. This may be a phishing attempt.",void 0,Ce.OAUTH_UNEXPECTED);let h=await async function({appId:e,stateCode:t,codeVerifier:n,authorizationCode:r,action:a,client:i,disableSignup:s}){if(!r||!t)throw new ke("[Cross-App AuthFlow] Authorization and state codes code must be set prior to calling authenicate.");if("undefined"===r)throw new ke("User denied confirmation during cross-app auth flow");try{let o=new Ci({authorizationCode:r,stateCode:t,codeVerifier:n,provider:`privy:${e}`,disableSignup:!!s});i.startAuthFlow(o);let l="link"===a?await i.link():await i.authenticate(),c=l.oAuthTokens?.accessToken;return console.debug(),c}catch(e){let t=Te(e);if(t.privyErrorCode===Ce.ACCOUNT_TRANSFER_REQUIRED)throw t;if(t.privyErrorCode)throw new ke(t.message||"Invalid code during cross-app auth flow.",void 0,t.privyErrorCode);if("User denied confirmation during cross-app auth flow"===t.message)throw new ke("Invalid code during cross-app auth flow.",void 0,Ce.OAUTH_USER_DENIED);throw new ke("Invalid code during cross-app auth flow.",void 0,Ce.UNKNOWN_AUTH_ERROR)}}({appId:e,codeVerifier:l,stateCode:d,authorizationCode:u,action:n,client:r,disableSignup:a});h&&r.storeProviderAccessToken(e,h);let p=await _t.refreshSessionAndUser();if(!p)throw new ke("Unable to update user");return r.createAnalyticsEvent({eventName:"cross_app_auth_completed",payload:{providerAppId:e}}),p}catch(e){throw r.createAnalyticsEvent({eventName:"cross_app_auth_error",payload:{error:e.toString(),provider:i}}),e}},async initLoginWithOAuth(e,t,n){if(ze.current=e,!qe())return void Ke("InAppBrowserLoginNotPossible");if("google"===e&&!d.allowOAuthInEmbeddedBrowsers&&Ri(window.navigator.userAgent))return void Ke("InAppBrowserLoginNotPossible");"twitter"===e&&window.opener&&window.opener.postMessage({type:Ti},"*"),Re.del(Ye),Re.del(Je);let a=new la({provider:e,disableSignup:!!n,withPrivyUi:!0,customOAuthRedirectUrl:d.customOAuthRedirectUrl});t&&a.addCaptchaToken(t),r.startAuthFlow(a);let i=await r.authFlow.getAuthorizationUrl();if(i&&i.url)if("twitter"===e&&vt&&(i.url=i.url.replace("x.com","twitter.com")),"chrome-extension:"===window.location.protocol&&na())try{let{privyOAuthCode:e,privyOAuthState:t}=await ra(i.url);Ke("OAuthStatusScreen"),a.meta.stateCode=t,a.meta.authorizationCode=e}catch(e){throw console.error("OAuth in chrome extension flow failed:",e),e}else window.location.assign(i.url)},async initLoginWithTelegram(e,t){if(!y)throw new We;ze.current="telegram";let n=new Ta(e,t);r.startAuthFlow(n),le({status:"loading"}),n.meta.telegramWebAppData=void 0,n.meta.telegramAuthResult=await new Promise(((e,t)=>d.loginConfig.telegramAuthConfiguration?window.Telegram?void window.Telegram.Login.auth({bot_id:d.loginConfig.telegramAuthConfiguration.botId,request_access:!0},(n=>n?e(n):("link"===He.current?Qn(Ue,"linkAccount","onError",Ce.FAILED_TO_LINK_ACCOUNT,{linkMethod:"telegram"}):"login"===He.current?Qn(Ue,"login","onError",Ce.INVALID_CREDENTIALS):"update"===He.current&&Qn(Ue,"login","onError",Ce.FAILED_TO_UPDATE_ACCOUNT),t(new ke("Telegram auth failed or was canceled by the client"))))):t(new ke("Telegram was not initialized")):t(new ke("Telegram Auth configuration is not loaded"))))},async loginWithTelegram(e){let t,n;if(!(r.authFlow instanceof Ta))throw new ke("Must initialize Telegram flow before calling loginWithTelegram");r.authFlow.meta.captchaToken||=e?.captchaToken;let a=await $r(),i=e?.intent||He.current;if("login"===i)try{let e=await r.authenticate();t=e.user,n=e.isNewUser,ze.current="telegram"}catch(e){throw Qn(Ue,"login","onError",e.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),e}else{if("link"!==i)throw new ke("Unknown auth intent");try{t=(await r.link()).user,ze.current="telegram"}catch(e){throw Qn(Ue,"linkAccount","onError",e.privyErrorCode||Ce.FAILED_TO_LINK_ACCOUNT,{linkMethod:"telegram"}),e}}Vi(t),C(n||!1),xe(!0),le({status:"done"});let s=t?.linkedAccounts.find((({type:e})=>"telegram"===e))||null;return{user:t,isNewUser:n||!1,wasAlreadyAuthenticated:!!a,loginAccount:s}},async loginWithOAuth(e){let t,n,a;if(!(r.authFlow instanceof la))throw new ke("Must initialize OAuth flow before calling loginWithOAuth");let i=Re.get(Qe),s=r.authFlow.meta.stateCode;if(i!==s)throw r.createAnalyticsEvent({eventName:"possible_phishing_attempt",payload:{provider:e,storedStateCode:i??"",returnedStateCode:s??""}}),new ke("Unexpected auth flow. This may be a phishing attempt.",void 0,Ce.OAUTH_UNEXPECTED);if(null!==await r.getAccessToken())try{let n=await r.link();t=n.user,a=n.oAuthTokens,ze.current=e}catch(t){throw Qn(Ue,"linkAccount","onError",t.privyErrorCode||Ce.FAILED_TO_LINK_ACCOUNT,{linkMethod:e}),t}else try{let i=await r.authenticate();t=i.user,n=i.isNewUser,a=i.oAuthTokens,ze.current=e}catch(t){throw"login"===He.current?Qn(Ue,"login","onError",t.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR):"link"===He.current&&Qn(Ue,"linkAccount","onError",t.privyErrorCode||Ce.FAILED_TO_LINK_ACCOUNT,{linkMethod:e}),t}return Vi(t),C(n||!1),xe(!0),a&&t&&Qn(Ue,"oAuthAuthorization","onOAuthTokenGrant",{oAuthTokens:a,user:t}),a},passkeyAuthState:j,setPasskeyAuthState:q,async initSignupWithPasskey({captchaToken:e,withPrivyUi:t}){let n=new ua({captchaToken:e,setPasskeyAuthState:q,hints:d.passkeys.registration?.hints});r.startAuthFlow(n),He.current="login";try{ze.current="passkey",q({status:"generating-challenge"}),await n.initRegisterFlow(t),q({status:"awaiting-passkey"})}catch(e){throw q({status:"error",error:e}),Qn(Ue,"login","onError",e.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),e}},async signupWithPasskey(){let e,t;if(!y)throw new We;if(!(r.authFlow instanceof ua))throw new ke("Must initialize Passkey flow first.");if("passkey"!==ze.current){let e=new ke("Must init login with Passkey flow first.");throw q({status:"error",error:e}),e}let n=await $r();try{ze.current="passkey",q({status:"awaiting-passkey"}),({user:e,isNewUser:t}=await r.authenticate())}catch(e){throw q({status:"error",error:e}),Qn(Ue,"login","onError",e.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),e}Vi(e),C(t||!1),xe(!0),q({status:"done"});let a=e?.linkedAccounts.find((({type:e})=>"passkey"===e))||null;return{user:e,isNewUser:t||!1,wasAlreadyAuthenticated:!!n,loginAccount:a}},async initLoginWithPasskey({captchaToken:e,withPrivyUi:t}){let n=new ua({captchaToken:e,setPasskeyAuthState:q,hints:void 0});r.startAuthFlow(n),He.current="login";try{ze.current="passkey",q({status:"generating-challenge"}),await n.initAuthenticationFlow(t),q({status:"awaiting-passkey"})}catch(e){throw q({status:"error",error:e}),Qn(Ue,"login","onError",e.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),e}},async loginWithPasskey(e){let t,n;if(!y)throw new We;if(!(r.authFlow instanceof ua))throw new ke("Must initialize Passkey flow first.");if(e?.credentialIds&&(r.authFlow.meta.allowedCredentialsIds=e.credentialIds),"passkey"!==ze.current){let e=new ke("Must init login with Passkey flow first.");throw q({status:"error",error:e}),e}let a=await $r();try{ze.current="passkey",q({status:"awaiting-passkey"}),({user:t,isNewUser:n}=await r.authenticate())}catch(e){throw q({status:"error",error:e}),Qn(Ue,"login","onError",e.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),e}Vi(t),C(n||!1),xe(!0),q({status:"done"});let i=t?.linkedAccounts.find((({type:e})=>"passkey"===e))||null;return{user:t,isNewUser:n||!1,wasAlreadyAuthenticated:!!a,loginAccount:i}},async initLinkWithPasskey(e){let t=new ua({captchaToken:e,hints:d.passkeys.registration?.hints});r.startAuthFlow(t),He.current="link",ze.current="passkey",q({status:"generating-challenge"});try{await t.initLinkFlow(),q({status:"awaiting-passkey"})}catch(e){throw Qn(Ue,"linkAccount","onError",e.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR,{linkMethod:"passkey"}),q({status:"error",error:e}),e}},async linkWithPasskey(){let e;if(!y)throw new We;if(!(r.authFlow instanceof ua))throw new ke("Must initialize Passkey flow first.");if("passkey"!==ze.current)throw new ke("Must init login with Passkey flow first.");try{ze.current="passkey",({user:e}=await r.link())}catch(e){throw Qn(Ue,"linkAccount","onError",e.privyErrorCode||Ce.FAILED_TO_LINK_ACCOUNT,{linkMethod:"passkey"}),e}return Vi(e||f||null),q({status:"done"}),e},async initLoginWithHeadlessOAuth(e,t,n){if(!qe())throw Error("It looks like you're using an in-app browser. To log in, please try again using an external browser.");if("google"===e&&!d.allowOAuthInEmbeddedBrowsers&&Ri(window.navigator.userAgent))throw Error("It looks like you're using an in-app browser. To log in, please try again using an external browser.");let a=new la({provider:e,withPrivyUi:!1,disableSignup:n??!1,customOAuthRedirectUrl:d.customOAuthRedirectUrl});t&&a.addCaptchaToken(t),J({status:"loading"});let i=await r.startAuthFlow(a).getAuthorizationUrl();if(i?.url)if("chrome-extension:"===window.location.protocol&&na())try{let{privyOAuthCode:e,privyOAuthState:t}=await ra(i.url);a.meta.stateCode=t,a.meta.authorizationCode=e,await At(a.meta)}catch(e){throw J({status:"error",error:e}),e}else window.location.assign(i.url)},loginWithHeadlessOAuth:At,initLoginWithEmail:async({email:e,captchaToken:t,disableSignup:n,withPrivyUi:a})=>{let i=new Jr({email:e,captchaToken:t,disableSignup:n});r.startAuthFlow(i);try{ze.current="email",B({status:"sending-code"});let e=await i.sendCodeEmail({withPrivyUi:a});if(e?.ssoRedirectUrl)return window.location.href=e.ssoRedirectUrl,void await ae(1e4);B({status:"awaiting-code-input"})}catch(e){throw B({status:"error",error:e}),"login"===He.current?Qn(Ue,"login","onError",e.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR):"link"===He.current&&Qn(Ue,"linkAccount","onError",e.privyErrorCode||Ce.FAILED_TO_LINK_ACCOUNT,{linkMethod:"email"}),e}},initUpdateEmail:async({oldAddress:e,newAddress:t,captchaToken:n})=>{let a=new Qr(e,t,n);r.startAuthFlow(a);try{await a.sendCodeEmail({withPrivyUi:!0})}catch(e){throw Qn(Ue,"update","onError",e.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR,{linkMethod:ze.current}),e}},initUpdatePhone:async(e,t,n)=>{let a=new ya(e,t,n);r.startAuthFlow(a);try{await a.sendSmsCode({withPrivyUi:!0})}catch(e){Qn(Ue,"update","onError",e.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR,{linkMethod:ze.current})}},initLoginWithSms:async({phoneNumber:e,captchaToken:t,disableSignup:n,withPrivyUi:a})=>{K({status:"sending-code"});let i=new ma({phoneNumber:e,captchaToken:t,disableSignup:n});r.startAuthFlow(i);try{ze.current="sms",await i.sendSmsCode({withPrivyUi:a}),K({status:"awaiting-code-input"})}catch(e){throw K({status:"error",error:e}),"login"===He.current?Qn(Ue,"login","onError",e.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR):"link"===He.current&&Qn(Ue,"linkAccount","onError",e.privyErrorCode||Ce.FAILED_TO_LINK_ACCOUNT,{linkMethod:"sms"}),e}},resendEmailCode:async()=>{await(r.authFlow?.sendCodeEmail({withPrivyUi:!0}))},resendSmsCode:async()=>{await(r.authFlow?.sendSmsCode({withPrivyUi:!0}))},loginWithCode:async e=>{let t,n;function a(e){r.authFlow instanceof Jr?B(e):r.authFlow instanceof ma&&K(e)}if(a({status:"submitting-code"}),!y){let e=new We;throw a({status:"error",error:e}),e}if(r.authFlow instanceof Jr)r.authFlow.meta.emailCode=e.trim();else{if(!(r.authFlow instanceof ma)){let e=new ke("Must initialize a passwordless code flow first");throw a({status:"error",error:e}),e}r.authFlow.meta.smsCode=e.trim()}let i=await $r();if("link"===He.current)try{({user:t}=await r.link())}catch(e){throw a({status:"error",error:e}),Qn(Ue,"linkAccount","onError",e.privyErrorCode||Ce.FAILED_TO_LINK_ACCOUNT,{linkMethod:ze.current}),e}else if("update"===He.current)try{({user:t}=await r.link())}catch(e){throw a({status:"error",error:e}),Qn(Ue,"update","onError",e.privyErrorCode||Ce.FAILED_TO_UPDATE_ACCOUNT,{linkMethod:ze.current}),e}else try{({user:t,isNewUser:n}=await r.authenticate())}catch(e){throw a({status:"error",error:e}),Qn(Ue,"login","onError",e.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),e}let s=t||f;Vi(s||null),C(n||!1),xe(!0),a({status:"done"});let o=null;return r.authFlow instanceof Jr?o=s?.linkedAccounts.find((({type:e})=>"email"===e))||null:r.authFlow instanceof ma&&(o=s?.linkedAccounts.find((({type:e})=>"phone"===e))||null),{user:s,isNewUser:n||!1,wasAlreadyAuthenticated:!!i,linkedAccount:o}},generateSiweMessage:async({address:e,chainId:t,captchaToken:n})=>{He.current=Me?"link":"login",ze.current="siwe",G({status:"generating-message"});let a=await r.generateSiweNonce({address:e,captchaToken:n});return G({status:"awaiting-signature"}),ha({address:e,chainId:t.replace("eip155:",""),nonce:a})},generateSiweMessageForSmartWallet:async({address:e,chainId:t})=>{let n=await r.generateSiweNonce({address:e});return ha({address:e,chainId:t.replace("eip155:",""),nonce:n})},linkSmartWallet:async({message:e,signature:t,smartWalletType:n,smartWalletVersion:a})=>{let i;i=await r.linkSmartWallet({message:e,signature:t,smartWalletType:n,smartWalletVersion:a}),Vi((i=await _t.refreshSessionAndUser()??i)||f||null)},loginWithSiwe:async({message:e,signature:t,captchaToken:n,disableSignup:a,walletClientType:i,connectorType:s})=>{let o,l=null;try{if(f)throw Error("User already authenticated");let c=new pa(r,void 0,n,a,{message:e,signature:t,walletClientType:i,connectorType:s});r.startAuthFlow(c),ze.current="siwe",He.current="login",G({status:"submitting-signature"});let d=await r.authenticate();if(({user:l,isNewUser:o}=d),!l)throw Error("Authentication failed - no user returned")}catch(e){throw Qn(Ue,"login","onError",e.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),G({status:"error",error:e}),e}return Vi(l),C(o||!1),xe(!0),G({status:"done"}),He.current=null,ze.current=null,{user:l,isNewUser:o||!1}},linkWithSiwe:async({message:e,signature:t,chainId:n,walletClientType:a,connectorType:i})=>{let s;lt("siwe");let o=null;try{G({status:"submitting-signature"}),s=await r.linkWithSiwe({message:e,signature:t,chainId:n,walletClientType:a,connectorType:i}),s=await _t.refreshSessionAndUser()??s,G({status:"done"}),(o=pt(s)||null)&&Qn(Ue,"linkAccount","onSuccess",{user:s,linkMethod:"siwe",linkedAccount:o})}catch(e){throw Qn(Ue,"linkAccount","onError",e.privyErrorCode||Ce.FAILED_TO_LINK_ACCOUNT,{linkMethod:"siwe"}),He.current=null,ze.current=null,G({status:"error",error:e}),e}let l=s||f;return Vi(l||null),He.current=null,ze.current=null,{user:l,linkedAccount:o}},refreshSessionAndUser:async()=>{let e=await r.getAuthenticatedUser();return xe(!!e),Vi(e),e},walletProxy:ce,createAnalyticsEvent:({eventName:e,payload:t,timestamp:n})=>r.createAnalyticsEvent({eventName:e,payload:t,timestamp:n}),acceptTerms:async()=>{let e=await r.acceptTerms();return Vi(e),e},getUsdTokenPrice:e=>r.getUsdTokenPrice(e),getUsdPriceForSol:()=>r.getUsdPriceForSol(),getSplTokenMetadata:e=>r.getSplTokenMetadata(e),recoverEmbeddedWallet:async e=>new Promise((async(t,n)=>{if(!f)return void t(!0);let a=e?.address?R(f,e.address):S(f)||U(f).at(0)||x(f).at(0);if(!a||E(a))return void t(!0);let i=await $r();if(!i||!ce||!a)return void n(Error("Must have valid access token and Privy wallet to recover wallet"));let{entropyId:s,entropyIdVerifier:o}=ve(f,a);try{await ce.connect({accessToken:i,entropyId:s,entropyIdVerifier:o}),t(!0)}catch(e){if(ni(e)&&"privy"===a.recoveryMethod){let e;r.createAnalyticsEvent({eventName:"embedded_wallet_pinless_recovery_started",payload:{walletAddress:a.address}});try{e=await ce.recover({entropyId:s,entropyIdVerifier:o,accessToken:i})}catch(e){return void n(e)}e.entropyId||n(Error("Unable to recover wallet")),r.createAnalyticsEvent({eventName:"embedded_wallet_recovery_completed",payload:{walletAddress:a.address}}),t(!0)}else ni(e)&&"privy"!==a.recoveryMethod&&"privy-v2"!==a.recoveryMethod?(pe((e=>({...e,recoverWallet:{entropyId:s,entropyIdVerifier:o,onFailure:n,onSuccess:()=>{t(!0)},onCompleteNavigateTo:e.createWallet?"EmbeddedWalletOnAccountCreateScreen":void 0},recoveryOAuthStatus:{provider:a.recoveryMethod,action:"recover",shouldCreateEth:!1,shouldCreateSol:!1,isInAccountCreateFlow:!!e.createWallet}}))),Ke(Wi(a.recoveryMethod))):n(e)}})),setReadyToTrue:e=>{g(!0),we?.(e)},updateWallets:()=>dt(),fundWallet:async(e,t)=>{let n="FundingMethodSelectionScreen";return new Promise(((r,a)=>{pe({funding:{...je({address:e,appConfig:d,fundWalletConfig:t,methodScreen:n,onComplete:r,onError:a})}}),Ke(n)}))},openModal:Ke,requestFarcasterSignerStatus:async e=>{let t=await $r(),n=f?.linkedAccounts.find((e=>"wallet"===e.type&&"privy"===e.walletClientType));if(!t)throw Error("Must have valid access token to connect with Farcaster");if(!ce||!n)throw Error("Must have an embedded wallet to use Farcaster signers");if(!f?.farcaster?.fid)throw Error("Must have Farcaster account to use Farcaster signers");let a=await r.requestFarcasterSignerStatus(e);return"approved"===a.status&&Vi(await r.getAuthenticatedUser()||f||null),a},connectCoinbaseSmartWallet:async()=>{d.externalWallets.coinbaseWallet.config.preference={...d.externalWallets.coinbaseWallet.config.preference,options:"smartWalletOnly"};let e=r.connectors?.findWalletConnector("coinbase_wallet","coinbase_smart_wallet")||r.connectors?.findWalletConnector("coinbase_wallet","coinbase_wallet");if(e)return e.updateConnectionPreference("smartWalletOnly"),at(e);await Xe("coinbase_wallet","coinbase_smart_wallet")},connectBaseAccount:async()=>{let e=r.connectors?.findWalletConnector("base_account","base_account");if(e)return at(e);await Xe("base_account","base_account")},initiateAccountTransfer:async({nonce:e,account:t,accountType:n,externalWalletMetadata:a,telegramAuthResult:i,telegramWebAppData:s,farcasterEmbeddedAddress:o,oAuthUserInfo:l})=>{let c=await r.sendAccountTransferRequest({nonce:e,account:t,accountType:n,externalWalletMetadata:a,telegramAuthResult:i,telegramWebAppData:s,farcasterEmbeddedAddress:o,oAuthUserInfo:l});return Vi(c),c},inProgressAuthFlowRef:He,inProgressLoginOrLinkMethodRef:ze};os=_t.recoverEmbeddedWallet,_t.recoverEmbeddedWallet;let bt=l((()=>({wallets:v,ready:ge&&Ne})),[v,ge,Ne]),Et=r.authFlow instanceof Ta,{siteKey:It,enabledProvider:Pt}=d.captcha,Wt=!d.headless&&Pt&&!Me&&(y||Et);/*#__PURE__*/return t(ns.Provider,{value:!0,children:/*#__PURE__*/t(N.Provider,{value:ft,children:/*#__PURE__*/t(Zn.Provider,{value:Ue,children:/*#__PURE__*/t(fe.Provider,{value:bt,children:/*#__PURE__*/t(va,{appId:d.id,captchaSiteKey:It,enabledCaptchaProvider:Pt,children:/*#__PURE__*/e(Pe.Provider,{value:_t,children:[/*#__PURE__*/t(ee,{children:/*#__PURE__*/e(O,{data:he,setModalData:pe,setInitialScreen:b,initialScreen:_,authenticated:Me,open:u,children:[n.children,/*#__PURE__*/t(ts,{customAuth:d.customAuth}),Wt&&/*#__PURE__*/t(Ia,{delayedExecution:!1}),/*#__PURE__*/t(Qa,{}),/*#__PURE__*/t(ji,{disabled:d.embeddedWallets.disableAutomaticMigration}),/*#__PURE__*/t(Na,{palette:d.appearance.palette||{}}),!d.render.standalone&&/*#__PURE__*/t(Ka,{open:u})]})}),/*#__PURE__*/t(gi,{appId:n.appId,appClientId:n.clientId,clientAnalyticsId:r.clientAnalyticsId,origin:r.apiUrl,mfaMethods:f?.mfaMethods,mfaPromise:Ee,mfaSubmitPromise:Ie,onLoad:de,onLoadFailed:()=>null}),d.loginConfig.telegramAuthConfiguration&&
|
|
174
|
-
/*#__PURE__*/t(H,{$if:!0,children:/*#__PURE__*/t(Ja,{scriptHost:n.apiUrl||tt,botUsername:d.loginConfig.telegramAuthConfiguration.botName})})]})})})})})})};class cs extends Error{constructor(e,t,n){super(e),this.code=t,this.data=n}}class ds extends D{async handleSendTransaction(e){if(!e.params||!Array.isArray(e.params))throw new cs(`Invalid params for ${e.method}`,4200);let t=e.params[0];if(!await $r()||!this.address)throw new cs("Disconnected",4900);let{hash:n}=await((e,t)=>ss(e,t))(t,{address:this.address});return n}async handleSignTransaction(e){if(!e.params||!Array.isArray(e.params))throw new cs(`Invalid params for ${e.method}`,4200);let t=e.params[0];if(!await $r()||!this.address)throw new cs("Disconnected",4900);let{signature:n}=await((e,t)=>is(e,t))(t,{address:this.address});return n}handleSwitchEthereumChain(e){let t;if(!e.params||!Array.isArray(e.params))throw new cs(`Invalid params for ${e.method}`,4200);if("string"==typeof e.params[0])t=e.params[0];else{if(!("chainId"in e.params[0])||"string"!=typeof e.params[0].chainId)throw new cs(`Invalid params for ${e.method}`,4200);t=e.params[0].chainId}this.chainId=Number(t),this.publicClient=gr(this.chainId,this.chains,this.rpcConfig,{appId:this.appId}),this.emit("chainChanged",t)}async handlePersonalSign(e){if(!e.params||!Array.isArray(e.params))throw Error("Invalid params for personal_sign");let t=e.params[0],n=e.params[1],{signature:r}=await((e,t)=>rs(e,t))({message:t},{address:n});return r}async handleSignedTypedData(e){if(!e.params||!Array.isArray(e.params))throw Error("Invalid params for eth_signTypedData_v4");let t=e.params[0],n="string"==typeof e.params[1]?JSON.parse(e.params[1]):e.params[1],{signature:r}=await((e,t)=>as(e,t))(re(n),{address:t});return r}async handleEstimateGas(e){if(!e.params||!Array.isArray(e.params))throw Error("Invalid params for eth_estimateGas");delete e.params[0].gasPrice,delete e.params[0].maxFeePerGas,delete e.params[0].maxPriorityFeePerGas;let t={...e.params[0],chainId:q(this.chainId)};return await this.publicClient.estimateGas({account:t.from??this.address,...Be(t)})}async request(e){switch(console.debug("Embedded1193Provider.request() called with args",e),e.method){case"eth_accounts":case"eth_requestAccounts":return this.address?[this.address]:[];case"eth_chainId":return q(this.chainId);case"eth_estimateGas":return this.handleEstimateGas(e);case"eth_sendTransaction":return this.handleSendTransaction(e);case"eth_signTransaction":return this.handleSignTransaction(e);case"wallet_switchEthereumChain":return this.handleSwitchEthereumChain(e);case"personal_sign":return this.handlePersonalSign(e);case"eth_signTypedData_v4":return this.handleSignedTypedData(e)}if(!(e=>Gr.includes(e))(e.method))return this.publicClient.request({method:e.method,params:e.params});{let t=await $r();if(await(e=>os(e))({address:this.address}),!t||!this.address)throw new cs("Disconnected",4900);try{let n={method:e.method,params:e.params},r=this.walletAccount;return r&&E(r)?this.handleWalletApiRequest(n,r,t):(await this.walletProxy.rpc({accessToken:t,entropyId:this.entropyId,entropyIdVerifier:this.entropyIdVerifier,chainType:"ethereum",hdWalletIndex:this.walletIndex,request:n})).response.data}catch(e){throw console.error(e),new cs("Disconnected",4900)}}}async handleWalletApiRequest(e,t,n){let r=this.privyClient;if(!r)throw new cs("Disconnected",4900);if("secp256k1_sign"===e.method){let a=await m(r,(async({message:e})=>this.walletProxy.signWithUserSigner({accessToken:n,message:e})),{chain_type:"ethereum",method:"secp256k1_sign",wallet_id:t.id,params:{hash:e.params[0]}});if("secp256k1_sign"!==a.method)throw new cs(`Invalid params for ${e.method}`,4200);return a.data.signature}throw new cs(`Method not supported: ${e.method}`,4200)}constructor({walletProxy:e,address:t,entropyId:n,entropyIdVerifier:r,rpcConfig:a,chains:i,appId:s,chainId:o=1,walletIndex:l,privyClient:c,walletAccount:d}){super(),this.walletProxy=e,this.address=t,this.entropyId=n,this.entropyIdVerifier=r,this.chainId=o,this.rpcConfig=a,this.chains=i,this.publicClient=gr(o,this.chains,a,{appId:s}),this.rpcTimeoutDuration=J(a,"privy"),this.appId=s,this.walletIndex=l,this.privyClient=c,this.walletAccount=d}}const us=({style:e,...n})=>/*#__PURE__*/t("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",stroke:"currentColor",strokeWidth:1.5,viewBox:"0 0 24 24",style:{...e},...n,children:/*#__PURE__*/t("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M9 17.25v1.007a3 3 0 01-.879 2.122L7.5 21h9l-.621-.621A3 3 0 0115 18.257V17.25m6-12V15a2.25 2.25 0 01-2.25 2.25H5.25A2.25 2.25 0 013 15V5.25m18 0A2.25 2.25 0 0018.75 3H5.25A2.25 2.25 0 003 5.25m18 0V12a2.25 2.25 0 01-2.25 2.25H5.25A2.25 2.25 0 013 12V5.25"})}),hs=({style:n,...r})=>/*#__PURE__*/e("svg",{xmlns:"http://www.w3.org/2000/svg",width:"108",height:"108",viewBox:"0 0 108 108",fill:"none",style:{height:"28px",width:"28px",...n},...r,children:[/*#__PURE__*/t("rect",{width:"108",height:"108",rx:"23",fill:"#AB9FF2"}),/*#__PURE__*/t("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M46.5267 69.9229C42.0054 76.8509 34.4292 85.6182 24.348 85.6182C19.5824 85.6182 15 83.6563 15 75.1342C15 53.4305 44.6326 19.8327 72.1268 19.8327C87.768 19.8327 94 30.6846 94 43.0079C94 58.8258 83.7355 76.9122 73.5321 76.9122C70.2939 76.9122 68.7053 75.1342 68.7053 72.314C68.7053 71.5783 68.8275 70.7812 69.0719 69.9229C65.5893 75.8699 58.8685 81.3878 52.5754 81.3878C47.993 81.3878 45.6713 78.5063 45.6713 74.4598C45.6713 72.9884 45.9768 71.4556 46.5267 69.9229ZM83.6761 42.5794C83.6761 46.1704 81.5575 47.9658 79.1875 47.9658C76.7816 47.9658 74.6989 46.1704 74.6989 42.5794C74.6989 38.9885 76.7816 37.1931 79.1875 37.1931C81.5575 37.1931 83.6761 38.9885 83.6761 42.5794ZM70.2103 42.5795C70.2103 46.1704 68.0916 47.9658 65.7216 47.9658C63.3157 47.9658 61.233 46.1704 61.233 42.5795C61.233 38.9885 63.3157 37.1931 65.7216 37.1931C68.0916 37.1931 70.2103 38.9885 70.2103 42.5795Z",fill:"#FFFDF8"})]});function ps(e,t){if(!Object.prototype.hasOwnProperty.call(e,t))throw TypeError("attempted to use private field on non-instance");return e}var ws=0;class ms extends L{async initialize(){await this.syncAccounts(),this.initialized=!0,this.emit("initialized")}async connect(e){return e.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}get walletBranding(){return{name:this.providerDetail.info.name,icon:this.providerDetail.info.icon,id:this.providerDetail.info.rdns}}disconnect(){console.warn(`Programmatic disconnect with ${this.providerDetail.info.name} is not yet supported.`)}async promptConnection(){try{let e=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!e||0===e.length||!e[0])throw new Ae("Unable to retrieve accounts");await this.syncAccounts([e[0]])}catch(e){throw Oe(e)}}constructor(e,t,n,r,a){super(a||"unknown",e,t,n),this.connectorType="injected",this.proxyProvider=new j(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.providerDetail=r;let i=r.provider;this.proxyProvider.setWalletProvider(i)}}var ys="__private_"+ws+++"__walletBranding";class gs extends L{async initialize(){await this.syncAccounts(),this.initialized=!0,this.emit("initialized")}async connect(e){return e.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}get walletBranding(){return ps(this,ys)[ys]??{name:"Browser Extension",icon:us,id:"extension"}}disconnect(){console.warn("Programmatic disconnect with browser wallets is not yet supported.")}async promptConnection(){try{let e=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!e||0===e.length||!e[0])throw new Ae("Unable to retrieve accounts");await this.syncAccounts([e[0]])}catch(e){throw Oe(e)}}constructor(e,t,n,r,a){super(a??"unknown",e,t,n),Object.defineProperty(this,ys,{writable:!0,value:void 0}),this.connectorType="injected",this.proxyProvider=new j(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.proxyProvider.setWalletProvider(r),"metamask"===a?ps(this,ys)[ys]={name:"MetaMask",icon:le,id:"io.metamask"}:"phantom"===a&&(ps(this,ys)[ys]={name:"Phantom",icon:hs,id:"phantom"})}}class fs extends ms{disconnect(){console.warn("MetaMask does not support programmatic disconnect.")}async promptConnection(){try{gt||await this.proxyProvider.request({method:"wallet_requestPermissions",params:[{eth_accounts:{}}]});let e=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!e||0===e.length||!e[0])throw new Ae("Unable to retrieve accounts");await this.syncAccounts([e[0]])}catch(e){throw Oe(e)}}}class vs extends D{get wallets(){let e=new Set;return this.walletConnectors.flatMap((e=>e.wallets)).sort(((e,t)=>e.connectedAt&&t.connectedAt?t.connectedAt-e.connectedAt:0)).filter((t=>{let n=`${t.address}${t.walletClientType}${t.connectorType}${t.meta.id}`;return!e.has(n)&&(e.add(n),!0)}))}async initialize(e){if(this.initialized&&!e||(e&&this.removeAllConnectors(),this.externalWalletConfig.disableAllExternalWallets))return;let t=ce({store:this.store,walletList:this.walletList,externalWalletConfig:this.externalWalletConfig,walletChainType:this.walletChainType}).then((e=>{e.forEach((({type:e,eip6963InjectedProvider:t,legacyInjectedProvider:n})=>{this.createEthereumWalletConnector({connectorType:"injected",walletClientType:e,providers:{eip6963InjectedProvider:t,legacyInjectedProvider:n}})}))}));for(let e of(this.walletList.includes("coinbase_wallet")&&this.createEthereumWalletConnector({connectorType:"coinbase_wallet",walletClientType:"coinbase_wallet"}),this.walletList.includes("base_account")&&this.createEthereumWalletConnector({connectorType:"base_account",walletClientType:"base_account"}),Object.values(de)))!e.isInstalled&&this.walletList.includes(e.client)&&(["ethereum-only","ethereum-and-solana"].includes(this.walletChainType)&&e.chainTypes.includes("ethereum")&&this.createEthereumWalletConnector({connectorType:"null",walletClientType:e.client,walletConfig:e}),["ethereum-and-solana","solana-only"].includes(this.walletChainType)&&e.chainTypes.includes("solana")&&this.addSolanaWalletConnector(new ue({id:e.client,name:e.name})));this.externalWalletConfig.walletConnect.enabled&&(this.walletList.includes("wallet_connect_qr")||X(this.walletList))&&"solana-only"!==this.walletChainType&&this.createEthereumWalletConnector({connectorType:"wallet_connect_v2",walletClientType:"unknown"});let n=this.walletList.includes("wallet_connect_qr_solana")||X(this.walletList)&&"ethereum-only"!==this.walletChainType,r=this.externalWalletConfig.solana.connectors?.get()||[],a=async e=>{if(!n)return;let t=e.find((e=>"walletconnect_solana"===e.walletBranding?.id));t&&t.wallet&&await t.wallet.initialize({walletConnectCloudProjectId:this.walletConnectCloudProjectId,privyAppName:this.privyAppName})};a(r),r.filter((e=>n||"walletconnect_solana"!==e.walletBranding?.id)).forEach(this.addSolanaWalletConnector),this.externalWalletConfig.solana.connectors?._setOnConnectorsUpdated?.((e=>{a(e),e?.filter((e=>n||"walletconnect_solana"!==e.walletBranding?.id)).forEach(this.addSolanaWalletConnector)})),await t,this.initialized=!0}findWalletConnector(e,t,n){return"wallet_connect_v2"===e?this.walletConnectors.filter(he).find((t=>t.connectorType===e&&(!n||t.wallets.some((e=>e.address===n)))))??null:this.walletConnectors.filter(he).find((r=>r.connectorType===e&&r.walletClientType===t&&(!n||r.wallets.some((e=>e.address===n)))))??null}findSolanaWalletConnector(e){return this.walletConnectors.filter(pe).find((t=>"unknown"===t.walletClientType?t.walletBranding.id===e:t.walletClientType===e))??null}findEmbeddedWalletConnectors(){return this.walletConnectors.filter((e=>"embedded"===e.connectorType))}findImportedWalletConnectors(){return this.walletConnectors.filter((e=>"embedded_imported"===e.connectorType))}onInitialized(e){e.wallets.forEach((e=>{let t=this.storedConnections.find((t=>t.address===e.address&&t.connectorType===e.connectorType&&("solana"===e.type&&"unknown"===t.walletClientType&&"unknown"===e.walletClientType?e.meta.id===t.id:t.walletClientType===e.walletClientType)));t&&(e.connectedAt=t.connectedAt)})),this.emit("walletsUpdated"),this.emit("connectorInitialized")}onWalletsUpdated(e){e.initialized&&this.emit("walletsUpdated")}addEmbeddedWalletConnectors({walletProxy:e,user:t,embeddedWallets:n,defaultChain:r,appId:a,privyClient:i}){let{entropyId:s,entropyIdVerifier:o}=ve(t);for(let t of n){let n=this.findEmbeddedWalletConnectors().find((e=>e.walletIndex===t.walletIndex));if(n&&he(n))n.proxyProvider.walletProxy=e;else{let n=new Kr({provider:new ds({walletProxy:e,address:t.address,entropyId:s,entropyIdVerifier:o,rpcConfig:this.rpcConfig,chains:this.chains,appId:a,chainId:r.id,walletIndex:t.walletIndex,privyClient:i,walletAccount:t}),chains:this.chains,defaultChain:r,rpcConfig:this.rpcConfig,imported:!1,walletIndex:t.walletIndex});this.addWalletConnector(n)}}}addImportedWalletConnector(e,t,n,r){let a=this.findWalletConnector("embedded_imported","privy",t);if(a&&he(a))a.proxyProvider.walletProxy=e;else{let a=new Kr({provider:new ds({walletProxy:e,address:t,entropyId:t,entropyIdVerifier:"ethereum-address-verifier",walletIndex:0,rpcConfig:this.rpcConfig,chains:this.chains,appId:r,chainId:n.id}),chains:this.chains,walletIndex:0,defaultChain:n,rpcConfig:this.rpcConfig,imported:!0});this.addWalletConnector(a)}}removeEmbeddedWalletConnectors(){this.walletConnectors=this.walletConnectors.filter((e=>"embedded"!==e.connectorType)),this.storedConnections=ze(),this.emit("walletsUpdated")}removeImportedWalletConnectors(){let e=this.findImportedWalletConnectors();e.length&&(e.forEach((e=>{let t=this.walletConnectors.indexOf(e);this.walletConnectors.splice(t,1)})),this.storedConnections=ze(),this.emit("walletsUpdated"))}async createEthereumWalletConnector({connectorType:e,walletClientType:t,providers:n,walletConfig:r}){let a=this.findWalletConnector(e,t);if(a&&he(a))return a instanceof Za&&a.resetConnection(t),a;let i=(()=>"injected"!==e?"coinbase_wallet"===e?new Br(this.chains,this.defaultChain,this.rpcConfig,this.externalWalletConfig.coinbaseWallet.config):"base_account"===e?new zr(this.chains,this.defaultChain,this.rpcConfig,this.externalWalletConfig.baseAccount.config,this.setBaseAccountSdk):"null"!==e?new Za({walletConnectCloudProjectId:this.walletConnectCloudProjectId,rpcConfig:this.rpcConfig,chains:this.chains,defaultChain:this.defaultChain,shouldEnforceDefaultChainOnConnect:this.shouldEnforceDefaultChainOnConnect,privyAppId:this.privyAppId,privyAppName:this.privyAppName,walletClientType:t}):r?new we({id:r.client,name:r.name,defaultChain:this.defaultChain,walletClientType:r.client}):null:"metamask"===t&&n?.eip6963InjectedProvider?new fs(this.chains,this.defaultChain,this.rpcConfig,n?.eip6963InjectedProvider,"metamask"):"metamask"===t&&n?.legacyInjectedProvider?new gs(this.chains,this.defaultChain,this.rpcConfig,n?.legacyInjectedProvider,"metamask"):"phantom"===t&&n?.legacyInjectedProvider?new gs(this.chains,this.defaultChain,this.rpcConfig,n?.legacyInjectedProvider,"phantom"):n?.legacyInjectedProvider&&"unknown_browser_extension"===t?new gs(this.chains,this.defaultChain,this.rpcConfig,n?.legacyInjectedProvider):n?.eip6963InjectedProvider?new ms(this.chains,this.defaultChain,this.rpcConfig,n?.eip6963InjectedProvider,t):void 0)();return i&&this.addWalletConnector(i),i||null}addWalletConnector(e){this.walletConnectors.push(e),e.on("initialized",(()=>this.onInitialized(e))),e.on("walletsUpdated",(()=>this.onWalletsUpdated(e))),e.initialize().catch((e=>{console.debug("Failed to initialize connector",e)}))}setWalletList(e){this.walletList=e,this.initialized&&this.initialize(!0).catch(console.error)}removeAllConnectors(){for(let e of this.walletConnectors)e.removeAllListeners();this.walletConnectors=[]}constructor(e,t,n,r,a,i,s,o,l,c,d,u){super(),this.addSolanaWalletConnector=async e=>{let t=this.findSolanaWalletConnector(e.walletClientType);if(!t||"null"===t.connectorType){if("null"===t?.connectorType){let e=this.walletConnectors.indexOf(t);this.walletConnectors.splice(e,1)}this.addWalletConnector(e)}},this.privyAppId=e,this.walletConnectCloudProjectId=t,this.rpcConfig=n,this.chains=r,this.defaultChain=a,this.walletConnectors=[],this.initialized=!1,this.store=i,this.walletList=s,this.shouldEnforceDefaultChainOnConnect=o,this.externalWalletConfig=l,this.privyAppName=c,this.walletChainType=u||"ethereum-only",this.setBaseAccountSdk=d,this.storedConnections=ze()}}const As=Xn((()=>({identityToken:null})));function ks(){let{identityToken:e}=As();return{identityToken:e}}let Ts=[Qt,Zt,Xt];class Cs{async get(e,t){try{return await this.baseFetch(e,t)}catch(e){throw Te(e)}}async post(e,t,n){try{return await this.baseFetch(e,{method:"POST",...t?{body:t}:{},...n})}catch(e){throw Te(e)}}async delete(e,t){try{return await this.baseFetch(e,{method:"DELETE",...t})}catch(e){throw Te(e)}}constructor({appId:e,appClientId:t,client:n,defaults:r}){this.appId=e,this.appClientId=t,this.clientAnalyticsId=n.clientAnalyticsId,this.sdkVersion=at,this.client=n,this.defaults=r,this.fallbackApiUrl=n.fallbackApiUrl,this.baseFetch=vr.create({baseURL:this.defaults.baseURL,timeout:this.defaults.timeout,retry:3,retryDelay:500,retryStatusCodes:[408,409,425,500,502,503,504],credentials:"include",onRequest:async({request:e,options:t})=>{let n=new Headers(t.headers);n.set("privy-app-id",this.appId),this.appClientId&&n.set("privy-client-id",this.appClientId),n.set("privy-ca-id",this.clientAnalyticsId||""),n.set("privy-client",`react-auth:${this.sdkVersion}`);let r=Ts.includes(e.toString());if(!n.has("authorization")){let e=await this.client.getAccessToken({disableAutoRefresh:r});null!==e&&n.set("authorization",`Bearer ${e}`)}t.headers=n,t.retryDelay&&"number"==typeof t.retryDelay&&(t.retryDelay=3*t.retryDelay)},onRequestError:({error:e})=>{if(e instanceof DOMException&&"AbortError"===e.name)throw new Ue}})}}const _s=e=>({rpId:e.rp_id,challenge:e.challenge,allowCredentials:e.allow_credentials?.map((e=>({id:e.id,type:e.type,transports:e.transports})))||[],timeout:e.timeout,extensions:{appid:e.extensions?.app_id,credProps:e.extensions?.cred_props,hmacCreateSecret:e.extensions?.hmac_create_secret},userVerification:e.user_verification});class Ss{getOrCreateGuestCredential(e){let t=rt(e);if(qe()){if(Re.get(t))return Re.get(t);{let e=T.encode(aa(32));return Re.put(t,e),e}}return T.encode(aa(32))}async authenticate(){if(!this.api)throw new ke("Auth flow has no API instance");try{return await this.api.post(en,{guest_credential:this.meta.guestCredential})}catch(e){throw Te(e)}}async link(){throw Error("Linking is not supported for the guest flow")}constructor(e){this.meta={guestCredential:this.getOrCreateGuestCredential(e)}}}function bs(){return!(At&&window.location.origin.startsWith("http://localhost"))}var Es,Is=((Es={}).PRIVY="privy_access_token",Es.CUSTOMER="customer_access_token",Es);class Ps{get token(){return this.privyAccessToken||this.customerAccessToken}getToken(e){return"privy_access_token"===e?this.privyAccessToken:this.customerAccessToken}get customerAccessToken(){return this._getToken($e)}get privyAccessToken(){return this._getToken(Ke)}_getToken(e){try{let t=Re.get(e);return"string"==typeof t?Mr.throwIfNotWellFormedJwt(t):null}catch(e){return console.error(e),this.destroyLocalState(),null}}get refreshToken(){try{let e=Re.get(it);return"string"==typeof e?e:null}catch(e){return console.error(e),this.destroyLocalState(),null}}getProviderAccessToken(e){try{let t=Re.get(st(e));if("string"!=typeof t)return null;{let n=new Mr(t);return n.isExpired()?(Re.del(st(e)),null):n.value}}catch(e){return console.error(e),null}}get mightHaveServerCookies(){try{let e=Ar.get(ot);return void 0!==e&&e.length>0}catch(e){console.error(e)}return!1}hasRefreshCredentials(e="privy_access_token"){let t="string"==typeof this.getToken(e),n="string"==typeof this.refreshToken&&this.refreshToken!==lt;return this.mightHaveServerCookies||t&&n}hasActiveAccessToken(e){let t=Mr.parse(this.getToken(e));return null!==t&&!t.isExpired(30)}authenticate(e){return this.authenticateOnce.execute(e)}link(e){return this.linkOnce.execute(e)}refresh(){return this.refreshOnce.execute()}destroy(){return this.destroyOnce.execute()}storeProviderAccessToken(e,t){"string"==typeof t?Re.put(st(e),t):Re.del(st(e))}updateIdentityToken(e){"string"==typeof e?this.storeIdentityToken(e):this.clearIdentityToken()}async _authenticate(e){try{let t=await e.authenticate(),{user:n,is_new_user:r,oauth_tokens:a}=t;this.handleTokenResponse(t);let i=a?{provider:a.provider,accessToken:a.access_token,accessTokenExpiresInSeconds:a.access_token_expires_in_seconds,refreshToken:a.refresh_token,refreshTokenExpiresInSeconds:a.refresh_token_expires_in_seconds,scopes:a.scopes}:void 0;return this._trackAuthenticateEvents(e,r),{user:F(n),isNewUser:r,oAuthTokens:i}}catch(e){throw console.warn("Error authenticating session"),Ne(e)}}_trackAuthenticateEvents(e,t){let n=function(e){return e instanceof Jr?"email":e instanceof ma?"sms":e instanceof pa?"siwe":e instanceof Ss?"guest":e instanceof $i?"custom_auth":e instanceof la?e.meta.provider:null}(e);n&&this.client&&this.client.createAnalyticsEvent({eventName:"sdk_authenticate",payload:{method:n,isNewUser:t}}),"siwe"===n&&this.client&&this.client.createAnalyticsEvent({eventName:"sdk_authenticate_siwe",payload:{connectorType:e.meta.connectorType,walletClientType:e.meta.walletClientType}})}async _link(e){try{let t=await e.link(),n=t.oauth_tokens,r=n?{provider:n.provider,accessToken:n.access_token,accessTokenExpiresInSeconds:n.access_token_expires_in_seconds,refreshToken:n.refresh_token,refreshTokenExpiresInSeconds:n.refresh_token_expires_in_seconds,scopes:n.scopes}:void 0;return{user:F(t),oAuthTokens:r}}catch(e){throw console.warn("Error linking account"),Ne(e)}}async _refresh(){if(!this.api)throw new ke("Session has no API instance");if(!this.client)throw new ke("Session has no PrivyClient instance");await this.client.getAccessToken({disableAutoRefresh:!0});let e=this.token,t=this.refreshToken;if(this.client.useServerCookies&&!this.mightHaveServerCookies&&this.token&&window.location.origin===this.client.apiUrl)return this.destroyLocalState(),null;try{let n;if(!(e&&t||this.mightHaveServerCookies))return null;{let r={};e&&(r.authorization=`Bearer ${e}`),n=await this.api.post(Qt,t?{refresh_token:t}:{},{headers:r})}return this.handleTokenResponse(n),F(n.user)}catch(e){if(e instanceof Ie&&e.privyErrorCode===Ce.MISSING_OR_INVALID_TOKEN)return console.warn("Unable to refresh tokens - token is missing or no longer valid"),this.destroyLocalState(),null;throw Ne(e)}}handleTokenResponse(e){e.session_update_action&&"set"!==e.session_update_action?"clear"===e.session_update_action?this.destroyLocalState():"ignore"===e.session_update_action&&(e.token&&(this.storeCustomerAccessToken(e.token),this.storePrivyAccessToken(e.privy_access_token)),e.identity_token&&this.storeIdentityToken(e.identity_token)):this._storeAllTokens(e)}_storeAllTokens(e){this.storeRefreshToken(e.refresh_token),this.storeCustomerAccessToken(e.token),this.storePrivyAccessToken(e.privy_access_token),e.identity_token&&this.storeIdentityToken(e.identity_token)}async _destroy(){try{await(this.api?.post(Zt,{refresh_token:this.refreshToken}))}catch(e){console.warn("Error destroying session")}this.destroyLocalState()}destroyLocalState(){this.storeRefreshToken(null),this.storeCustomerAccessToken(null),this.storePrivyAccessToken(null),this.clearIdentityToken()}storeCustomerAccessToken(e){if("string"==typeof e){let t=Re.get($e);if(Re.put($e,e),!this.client?.useServerCookies){let t=Mr.parse(e)?.expiration;Ar.set(ct,e,{sameSite:"Strict",secure:bs(),expires:t?new Date(1e3*t):void 0})}t!==e&&this.client?.onStoreCustomerAccessToken?.(e)}else Re.del($e),Ar.remove(ct),this.client?.onDeleteCustomerAccessToken?.()}storeRefreshToken(e){"string"==typeof e?(Re.put(it,e),this.client?.useServerCookies||Ar.set(ot,"t",{sameSite:"Strict",secure:bs(),expires:30})):(Re.del(it),Ar.remove(dt),Ar.remove(ot))}storePrivyAccessToken(e){"string"==typeof e?Re.put(Ke,e):Re.del(Ke)}storeIdentityToken(e){if(As.setState({identityToken:e}),this.client?.useServerCookies)return;Re.put(ut,e);let t=Mr.parse(e)?.expiration;Ar.set(ht,e,{sameSite:"Strict",secure:bs(),expires:t?new Date(1e3*t):void 0})}clearIdentityToken(){Re.del(ut),As.setState({identityToken:null}),Ar.remove(ht)}constructor(){this.authenticateOnce=new Zr((async e=>this._authenticate(e))),this.linkOnce=new Zr((async e=>this._link(e))),this.refreshOnce=new Zr(this._refresh.bind(this)),this.destroyOnce=new Zr(this._destroy.bind(this))}}let Ws,Us;var Ns=0,Os="__private_"+Ns+++"__getOrGenerateClientAnalyticsId";class Rs{getAppId(){return this.appId}initializeConnectorManager({walletConnectCloudProjectId:e,rpcConfig:t,chains:n,defaultChain:r,store:a,walletList:i,shouldEnforceDefaultChainOnConnect:s,externalWalletConfig:o,appName:l,walletChainType:c,setBaseAccountSdk:d}){this.connectors||(this.connectors=new vs(this.appId,e,t,n,r,a,i,s,o,l,d,c))}generateApi(){let e=new Cs({appId:this.appId,appClientId:this.appClientId,client:this,defaults:{baseURL:this.apiUrl,timeout:this.timeout}});return this.session.api=e,e}updateApiUrl(e){this.apiUrl=e||this.fallbackApiUrl,this.api=this.generateApi(),e&&(this.useServerCookies=!0)}authenticate(){if(!this.authFlow)throw new ke("No auth flow in progress.");return this.session.authenticate(this.authFlow)}async link(){if(!this.authFlow)throw new ke("No auth flow in progress.");let{oAuthTokens:e}=await this.session.link(this.authFlow);return{user:await this.getAuthenticatedUser(),oAuthTokens:e}}storeProviderAccessToken(e,t){this.session.storeProviderAccessToken(e,t)}getProviderAccessToken(e){return this.session.getProviderAccessToken(e)}async logout(){await this.session.destroy(),this.authFlow=void 0}clearProviderAcccessTokens(e){e.linkedAccounts.filter((e=>"cross_app"===e.type)).forEach((e=>{this.storeProviderAccessToken(e.providerApp.id,null)}))}startAuthFlow(e){return e.api=this.api,this.authFlow=e,this.authFlow}async initMfaSmsVerification(){try{await this.api.post(tn,{action:"verify"})}catch(e){throw Te(e)}}async initMfaPasskeyVerification(){try{let e=await this.api.post(nn,{});return _s(e.options)}catch(e){throw Te(e)}}async getCrossAppProviderDetails(e){try{return this._cachedProviderAppDetails[e]||(this._cachedProviderAppDetails[e]=await this.api.get(`/api/v1/apps/${e}/cross-app/details`)),this._cachedProviderAppDetails[e]}catch(e){console.error("Error fetching cross app provider details",e)}}async acceptTerms(){try{let e=await this.api.post(rn,{});return F(e)}catch(e){throw Ne(e)}}async unlinkEmail(e){try{let t=await this.api.post(an,{address:e});return await this.getAuthenticatedUser()??F(t)}catch(e){throw Ne(e)}}async unlinkPhone(e){try{let t=await this.api.post(sn,{phoneNumber:e});return await this.getAuthenticatedUser()??F(t)}catch(e){throw Ne(e)}}async unlinkEthereumWallet(e){try{let t=await this.api.post(on,{address:e});return await this.getAuthenticatedUser()??F(t)}catch(e){throw Ne(e)}}async unlinkSolanaWallet(e){try{let t=await this.api.post(ln,{address:e});return await this.getAuthenticatedUser()??F(t)}catch(e){throw Ne(e)}}async unlinkOAuth(e,t){try{let n=await this.api.post(cn,{provider:e,subject:t});return await this.getAuthenticatedUser()??F(n)}catch(e){throw Ne(e)}}async unlinkFarcaster(e){try{let t=await this.api.post(dn,{fid:e});return await this.getAuthenticatedUser()??F(t)}catch(e){throw Ne(e)}}async unlinkTelegram(e){try{let t=await this.api.post(un,{telegram_user_id:e});return await this.getAuthenticatedUser()??F(t)}catch(e){throw Ne(e)}}async revokeDelegatedWallet(){try{await this.api.post(hn,{})}catch(e){throw Ne(e)}}async createAnalyticsEvent({eventName:e,payload:t,timestamp:n,options:r}){if("undefined"!=typeof window)try{this.clientAnalyticsId||console.warn("No client analytics id set, refusing to send analytics event"),await this.api.post(Xt,{event_name:e,client_id:this.clientAnalyticsId,payload:{...t||{},clientTimestamp:n?n.toISOString():(new Date).toISOString()}},{retry:-1,keepalive:r?.keepAlive??!1})}catch(e){console.log("Unable to submit event. This is not an issue.")}}async signMoonpayOnRampUrl(e){try{return this.api.post(pn,e)}catch(e){throw Ne(e)}}async initCoinbaseOnRamp(e){try{return this.api.post(wn,e)}catch(e){throw Ne(e)}}async getCoinbaseOnRampStatus({partnerUserId:e}){try{return this.api.get(`${mn}?partnerUserId=${e}`)}catch(e){throw Ne(e)}}async getAuthenticatedUser(){return this.session.hasRefreshCredentials()?this.session.refresh():null}async getAccessToken(e){return await this.getPrivyAccessToken(e)||await this.getCustomerAccessToken(e)}async getCustomerAccessToken(e){return await this._getToken(Is.CUSTOMER,e)}async getPrivyAccessToken(e){return await this._getToken(Is.PRIVY,e)}async _getToken(e,t){return this.session.getToken(e)?this.session.hasActiveAccessToken(e)?this.session.hasRefreshCredentials(e)?xr.parse(this.session.getToken(e))?.appId!==this.appId?(await this.logout(),null):this.session.getToken(e):(this.session.destroyLocalState(),null):!t?.disableAutoRefresh&&this.session.hasRefreshCredentials(e)?(await this.session.refresh(),this.session.getToken(e)):null:null}async getUsdTokenPrice(e){try{return(await this.api.get(`/api/v1/token_price?chainId=${e.id}&tokenSymbol=${e.nativeCurrency.symbol}`)).usd}catch(t){return void console.error(`Unable to fetch token price for chain with id ${e.id}`)}}async getUsdPriceForSol(){try{return(await this.api.get("/api/v1/token_price?chainId=0&tokenSymbol=SOL")).usd}catch(e){return void console.error("Unable to fetch token price for SOL")}}async getSplTokenMetadata({mintAddress:e,cluster:t}){try{return await this.api.get(`/api/v1/spl_token_info?mint_address=${e}&cluster=${t}`)}catch(n){return void console.error(`Unable to fetch token metadata for ${t}:${e}`)}}async requestFarcasterSignerStatus(e){try{return await this.api.post("/api/v1/farcaster/signer/status",{ed25519_public_key:e})}catch(e){throw console.error("Unable to fetch Farcaster signer status"),e}}async generateSiweNonce({address:e,captchaToken:t}){try{return(await this.api.post(yn,{address:e,token:t})).nonce}catch(e){throw Ne(e)}}async authenticateWithSiweInternal({message:e,signature:t,chainId:n,walletClientType:r,connectorType:a,mode:i}){return await this.api.post(gn,{message:e,signature:t,chainId:n,walletClientType:r,connectorType:a,mode:i})}async linkWithSiweInternal({message:e,signature:t,chainId:n,walletClientType:r,connectorType:a}){return await this.api.post(fn,{message:e,signature:t,chainId:n,walletClientType:r,connectorType:a})}async linkSmartWallet({message:e,signature:t,smartWalletType:n,smartWalletVersion:r}){try{let a=await this.api.post(vn,{message:e,signature:t,smart_wallet_type:n,smart_wallet_version:r});return F(a)}catch(e){throw Ne(e)}}async linkWithSiwe({message:e,signature:t,chainId:n,walletClientType:r,connectorType:a}){try{let i=await this.linkWithSiweInternal({message:e,signature:t,chainId:n,walletClientType:r,connectorType:a});return F(i)}catch(e){throw Ne(e)}}async generateSiwsNonce({address:e,captchaToken:t}){try{return(await this.api.post(An,{address:e,token:t})).nonce}catch(e){throw Ne(e)}}async authenticateWithSiwsInternal({message:e,signature:t,walletClientType:n,connectorType:r,mode:a,messageType:i="plain"}){return await this.api.post(kn,{message:e,signature:t,walletClientType:n,connectorType:r,mode:a,message_type:i})}async authenticateWithSiws({message:e,signature:t,walletClientType:n,connectorType:r,mode:a,messageType:i="plain"}){let s=await this.authenticateWithSiwsInternal({message:e,signature:t,walletClientType:n,connectorType:r,mode:a,messageType:i});this.session.handleTokenResponse(s);let o=F(s.user);if(!o)throw Error("Authentication failed - no user returned");return{user:o,isNewUser:s.is_new_user||!1}}async sendAccountTransferRequest({nonce:e,account:t,accountType:n,externalWalletMetadata:r,telegramAuthResult:a,telegramWebAppData:i,farcasterEmbeddedAddress:s,oAuthUserInfo:o}){try{let l,c;switch(n){case"email":l=In,c={nonce:e,email:t};break;case"sms":l=En,c={nonce:e,phoneNumber:t};break;case"siwe":if(l=bn,!r)throw Error("Wallet parameters must be defined");c={nonce:e,address:t,...r};break;case"farcaster":l=Sn,c={nonce:e,farcaster_id:t,farcaster_embedded_address:s};break;case"telegram":l=_n,c={nonce:e,telegram_auth_result:a,telegram_web_app_data:i};break;case"siws":l=Cn,c={nonce:e,address:t,...r};break;case"custom":case"guest":case"passkey":throw Error("Invalid transfer account type");default:l=Tn,c={nonce:e,userInfo:o}}let d=await this.api.post(l,c);return await this.getAuthenticatedUser()??F(d)}catch(e){throw Ne(e)}}async linkWithSiwsInternal({message:e,signature:t,walletClientType:n,connectorType:r,messageType:a="plain"}){return await this.api.post(Pn,{message:e,signature:t,walletClientType:n,connectorType:r,message_type:a})}async linkWithSiws({message:e,signature:t,walletClientType:n,connectorType:r,messageType:a="plain"}){try{let i=await this.linkWithSiwsInternal({message:e,signature:t,walletClientType:n,connectorType:r,messageType:a});return F(i)}catch(e){throw Ne(e)}}async updateUserAndIdToken(){try{let e=await this.api.get(Wn);return this.session.updateIdentityToken(e.identity_token),F(e.user)}catch(e){throw Ne(e)}}async scanTransaction(e){try{return await this.api.post(Un,e)}catch(e){throw Ne(e)}}constructor({apiUrl:e=tt,appId:t,appClientId:n,timeout:r=pt}){Object.defineProperty(this,Os,{value:Ms}),this._cachedProviderAppDetails={},this.apiUrl=e,this.fallbackApiUrl=this.apiUrl,this.useServerCookies=e!==tt&&e.startsWith("https://privy."),this.timeout=r,this.appId=t,this.appClientId=n,this.clientAnalyticsId=function(e,t){if(!Object.prototype.hasOwnProperty.call(e,t))throw TypeError("attempted to use private field on non-instance");return e}(this,Os)[Os](),Ws||(Ws=new Ps),this.session=Ws,this.api=this.generateApi(),this.session.client=this}}function Ms(){if("undefined"==typeof window)return null;try{let e=Re.get(nt);if("string"==typeof e&&e.length>0)return e}catch(e){}let e=A();try{return Re.put(nt,e),e}catch(t){return e}}function xs(){if(!Us)throw new ke("No global PrivyClient instance found. Please ensure you have initialized the PrivyProvider.");return Us}async function Fs(){return await(Us?.updateUserAndIdToken()),Us?.useServerCookies?As.getState().identityToken:Promise.resolve(Re.get(ut)||null)}const Ds=({config:e,...n})=>{(()=>{if(a(ns))throw new ke("Multiple PrivyProvider instances found","Found multiple instances of PrivyProvider, ensure there is only one mounted in your application tree.")})(),function(){if("undefined"==typeof window)return;let e=["localhost","127.0.0.1"].includes(window.location.hostname),t="https:"===window.location.protocol||"chrome-extension:"===window.location.protocol;if(!e&&!t)throw new ke("Embedded wallet is only available over HTTPS")}(),function(e){if("string"!=typeof e||25!==e.length)throw new ke("Cannot initialize the Privy provider with an invalid Privy app ID")}(n.appId),function(e){Us||(Us=new Rs({appId:e.appId,appClientId:e.clientId,apiUrl:e.apiUrl}))}(n);let r=l((()=>new p({appId:n.appId,clientId:n.clientId,storage:Re,baseUrl:n.apiUrl,sdkVersion:"react-auth:3.14.0"})),[]),i=xs(),s=Object.assign({},e);/*#__PURE__*/return t(wt,{client:r,legacyClient:i,appClientId:n.clientId,clientConfig:s,children:/*#__PURE__*/t(mr,{configPlugins:e?.plugins,children:/*#__PURE__*/t(ls,{...n,client:i,privy:r})})})},Ls=Symbol("cross-tab-user-sync-plugin");let js=null,qs=null,zs=!1;function Hs(e){if(!e.channelId)throw Error("[Privy] Cross-tab sync plugin requires a channelId.");return"undefined"==typeof BroadcastChannel||js||((js=new BroadcastChannel(`PRIVY_CROSS_TAB_CHANNEL:${e.channelId}`)).onmessage=e=>{e.data.eventId!==qs&&(qs=e.data.eventId,zs=!0,Vi(e.data.user),Ki(!!e.data.user),zs=!1)},Bi.subscribe(((e,t)=>{if(e.user===t.user||zs)return;let n=A();qs=n,js?.postMessage({user:e.user,eventId:n})}))),{id:Ls}}const Bs=()=>{let{user:e}=C(),{walletProxy:t}=Ee();return{recover:h((async n=>{if(!t)throw Error("Wallet proxy is not ready");let r=await $r();if(!e||!r)throw new ke("User must be logged in before attempting to modify the recovery method.");let{entropyId:a,entropyIdVerifier:i}=ve(e);try{await t.recover({entropyId:a,entropyIdVerifier:i,accessToken:r,...n})}catch{throw new ke("Unable to recover wallets")}}),[t,e])}};function Vs(){let{promptMfa:e,init:t,submit:n,cancel:r,mfaMethods:i}=a(N);return{promptMfa:e,init:t,submit:n,cancel:r,mfaMethods:i}}function Ks(){let{initEnrollmentWithSms:e,initEnrollmentWithTotp:t,initEnrollmentWithPasskey:n,submitEnrollmentWithSms:r,submitEnrollmentWithTotp:i,submitEnrollmentWithPasskey:s,unenroll:o,enrollInMfa:l}=a(N);return{initEnrollmentWithSms:e,initEnrollmentWithTotp:t,initEnrollmentWithPasskey:n,submitEnrollmentWithSms:r,submitEnrollmentWithTotp:i,submitEnrollmentWithPasskey:s,unenrollWithSms:()=>o("sms"),unenrollWithTotp:()=>o("totp"),unenrollWithPasskey:e=>o("passkey",e),showMfaEnrollmentModal:()=>l(!0),closeMfaEnrollmentModal:()=>l(!1)}}function $s(){let e=xs();return e?e.getCustomerAccessToken():Promise.resolve(Re.get($e)||null)}const Gs=()=>{let{client:e,setAuthenticated:t,setUser:n}=Ee();return l((()=>({init:async()=>{if(!e)throw new ke("Must initialize Privy client first.");let t=new kr;return e.startAuthFlow(t),await t.init()},login:async({fid:r,message:a,signature:i})=>{if(!e)throw new ke("Must initialize Privy client first.");if(!(e.authFlow instanceof kr))throw new ke("Must initialize Farcaster Mini App flow first.");e.authFlow.setAuthData({message:a,signature:i,fid:r});let{user:s}=await e.authenticate();if(!s)throw new ke("Failed to login with Farcaster V2");return n(s),t(!0),{user:s}}})),[e,n,t])},Ys=()=>l((()=>({getAccessTokenForProvider:({appId:e})=>{try{let t=Re.get(st(e));if("string"!=typeof t)return{token:null};{let n=new Mr(t);return n.isExpired()?(Re.del(st(e)),{token:null}):{token:n.value}}}catch(e){return console.error(e),{token:null}}}})),[]),Js=e=>{Gn("login",e);let t=Aa(),n=et(),{ready:r,user:a}=C(),{initLoginWithHeadlessOAuth:i,loginWithHeadlessOAuth:s,oAuthState:o,setOAuthState:l,isHeadlessOAuthLoading:d}=Ee(),u=h((async e=>{try{if(t.enabled&&"success"!==t.status)throw new fa(t.error,null,Ce.CAPTCHA_FAILURE);return await i(e.provider,t.token,e.disableSignup)}catch(e){throw l({status:"error",error:e}),e}}),[i,t]),p=h((async()=>{let e=ca();try{if(!e.inProgress)throw Error("Cannot login with OAuth because no OAuth flow is in progress");let t=e.provider;if(b(t)){if(a&&a.linkedAccounts.some((e=>e.type===t)))return console.warn("User is already logged in with this OAuth provider"),a}else if(a&&t in a&&a[t])return console.warn("User is already logged in with this OAuth provider"),a;if(e.popupFlow)return}catch(e){throw l({status:"error",error:e}),e}try{return await s(e)}catch(e){throw l({status:"error",error:e}),e}finally{da()}}),[s]);return c((()=>{let e=ca();r&&n&&e.inProgress&&!e.withPrivyUi&&!e.popupFlow&&p().catch((()=>{}))}),[r,n]),{initOAuth:u,loading:d,state:o}},Qs=e=>{let t=Aa(),{emailOtpState:n,setEmailOtpState:r,initLoginWithEmail:a,loginWithCode:i}=Ee();return{sendCode:h((async({email:n,disableSignup:i})=>{try{if(!n)throw Error("Email required to send OTP code");let e=await ka(t);return await a({email:n,captchaToken:e,disableSignup:i,withPrivyUi:!1})}catch(n){throw r({status:"error",error:n}),e?.onError?.(n.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),n}}),[a,t]),loginWithCode:h((async({code:t})=>{try{let{user:n,isNewUser:r,wasAlreadyAuthenticated:a,linkedAccount:s}=await i(t);e?.onComplete?.({user:n,isNewUser:r,wasAlreadyAuthenticated:a,loginMethod:"email",loginAccount:s})}catch(t){throw r({status:"error",error:t}),e?.onError?.(t.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),t}}),[i]),state:n}},Zs=e=>{let t=Aa(),{initSignupWithPasskey:n,signupWithPasskey:r,passkeyAuthState:a,setPasskeyAuthState:i}=Ee();return{signupWithPasskey:h((async()=>{try{let a=await ka(t);await n({captchaToken:a,withPrivyUi:!1});let{user:i,isNewUser:s,wasAlreadyAuthenticated:o,loginAccount:l}=await r();e?.onComplete?.({user:i,isNewUser:s,wasAlreadyAuthenticated:o,loginMethod:"passkey",loginAccount:l})}catch(t){throw i({status:"error",error:t}),e?.onError?.(t.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),t}}),[r,t]),state:a}},Xs=e=>{let t=Aa(),{initLoginWithPasskey:n,loginWithPasskey:r,passkeyAuthState:a,setPasskeyAuthState:i}=Ee();return{loginWithPasskey:h((async a=>{try{let i=await ka(t);await n({captchaToken:i,withPrivyUi:!1});let{user:s,isNewUser:o,wasAlreadyAuthenticated:l,loginAccount:c}=await r(a);e?.onComplete?.({user:s,isNewUser:o,wasAlreadyAuthenticated:l,loginMethod:"passkey",loginAccount:c})}catch(a){throw i({status:"error",error:a}),e?.onError?.(a.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),a}}),[r,t]),state:a}},eo=e=>{let{initLinkWithPasskey:t,linkWithPasskey:n,passkeyAuthState:r,setPasskeyAuthState:a}=Ee();return{linkWithPasskey:h((async()=>{try{await t();let r=await n();if(!r)throw Error("Error, user not found");let a=r.linkedAccounts.filter((e=>"passkey"===e.type)).sort(((e,t)=>t.latestVerifiedAt.getTime()-e.latestVerifiedAt.getTime()))[0];e?.onSuccess?.({user:r,linkMethod:"passkey",linkedAccount:a})}catch(t){throw a({status:"error",error:t}),e?.onError?.(t.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR,{linkMethod:"passkey"}),t}}),[n]),state:r}},to=e=>{let t=Aa(),{smsOtpState:n,setSmsOtpState:r,initLoginWithSms:a,loginWithCode:i}=Ee();return{sendCode:h((async({phoneNumber:n,disableSignup:i})=>{try{if(!n)throw Error("SMS required to send OTP code");let e=await ka(t);return await a({phoneNumber:n,captchaToken:e,disableSignup:i,withPrivyUi:!1})}catch(n){throw r({status:"error",error:n}),e?.onError?.(n.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),n}}),[a,t]),loginWithCode:h((async({code:t})=>{try{let{user:n,isNewUser:r,wasAlreadyAuthenticated:a,linkedAccount:s}=await i(t);e?.onComplete?.({user:n,isNewUser:r,wasAlreadyAuthenticated:a,loginMethod:"sms",loginAccount:s})}catch(t){throw r({status:"error",error:t}),e?.onError?.(t.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),t}}),[i]),state:n}},no=e=>{let{connectOrCreateWallet:t}=C();return Gn("connectOrCreateWallet",e),{connectOrCreateWallet:t}},ro=e=>{let t=Aa(),{siweState:n,setSiweState:r,linkWithSiwe:a,generateSiweMessage:i}=Ee();return{generateSiweMessage:h((async({address:t,chainId:n})=>{try{if(!t||!n)throw Error("wallet address and chainId required to generate nonce");return await i({address:t,chainId:n}).then((e=>e))}catch(t){throw r({status:"error",error:t}),e?.onError?.(t.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR,{linkMethod:"siwe"}),t}}),[i]),linkWithSiwe:h((async({signature:n,message:i,chainId:s,walletClientType:o,connectorType:l})=>{try{if(t.enabled&&"success"!==t.status)throw new fa(t.error,null,Ce.CAPTCHA_FAILURE);let{user:r,linkedAccount:c}=await a({message:i,signature:n,chainId:s,walletClientType:o,connectorType:l});c&&e?.onSuccess?.({user:r,linkMethod:"siwe",linkedAccount:c})}catch(n){throw r({status:"error",error:n}),e?.onError?.(n.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR,{linkMethod:"siwe"}),n}}),[a,t.status]),state:n}},ao=e=>{let t=Aa(),{siweState:n,setSiweState:r,client:a,generateSiweMessage:i,loginWithSiwe:s}=Ee();return{generateSiweNonce:h((async n=>{try{let e=await ka(t);r({status:"generating-message"});let i=await a.generateSiweNonce({address:n?.address,captchaToken:e});return r({status:"awaiting-signature"}),i}catch(n){throw r({status:"error",error:n}),e?.onError?.(n.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),n}}),[a,t]),generateSiweMessage:h((async({address:n,chainId:a})=>{try{let e=await ka(t);return await i({address:n,chainId:a,captchaToken:e})}catch(n){throw r({status:"error",error:n}),e?.onError?.(n.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),n}}),[i,t]),loginWithSiwe:h((async({message:n,signature:a,disableSignup:i,walletClientType:o,connectorType:l})=>{try{let r=await ka(t),{user:c,isNewUser:d}=await s({message:n,signature:a,captchaToken:r,disableSignup:i,walletClientType:o,connectorType:l});return e?.onComplete?.({user:c,isNewUser:d,wasAlreadyAuthenticated:!1,loginMethod:"siwe",loginAccount:null}),c}catch(n){throw r({status:"error",error:n}),e?.onError?.(n.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),n}}),[s,t]),state:n}},io=()=>{let e=Aa(),{client:t,setAuthenticated:n,setUser:r,setIsNewUser:a}=Ee(),{authenticated:i}=jn();return{generateSiwsMessage:h((async({address:n})=>{let r=await ka(e),a=await t.generateSiwsNonce({address:n,captchaToken:r});return On({address:n,nonce:a})}),[e,t]),loginWithSiws:h((async({message:e,signature:s,disableSignup:o,walletClientType:l,connectorType:c})=>{if(i)throw Error("User already authenticated");let{user:d,isNewUser:u}=await t.authenticateWithSiws({message:e,signature:s,walletClientType:l,connectorType:c,mode:o?"no-signup":"login-or-sign-up",messageType:"plain"});if(!d)throw Error("Authentication failed - no user returned");return r(d),a(u||!1),n(!0),d}),[i,t,n,r,a])}},so=()=>{let e=Aa(),{client:t,setUser:n,refreshSessionAndUser:r}=Ee(),{authenticated:a}=jn();return{generateSiwsMessage:h((async({address:n})=>{let r=await ka(e),a=await t.generateSiwsNonce({address:n,captchaToken:r});return On({address:n,nonce:a})}),[e,t]),linkWithSiws:h((async({signature:i,message:s,walletClientType:o,connectorType:l})=>{if(!a)throw Error("User must be authenticated before linking");await ka(e);let c=await t.linkWithSiws({message:s,signature:i,walletClientType:o,connectorType:l,messageType:"plain"}),d=(e=>{if(!e)return;let t=e.linkedAccounts;return t&&0!==t.length?t[t.length-1]:void 0})(c=await r()??c)||null;return n(c||null),{user:c,linkedAccount:d}}),[a,e,t,r,n])}};function oo(){let{signTransaction:e}=a(N);return{signTransaction:e}}function lo(e){let{linkEmail:t,linkPhone:n,linkWallet:r,linkGoogle:i,linkApple:s,linkTwitter:o,linkTwitch:l,linkDiscord:c,linkGithub:d,linkLinkedIn:u,linkTiktok:h,linkLine:p,linkSpotify:w,linkInstagram:m,linkTelegram:y,linkFarcaster:g,linkPasskey:f}=a(N);return Gn("linkAccount",e),{linkEmail:t,linkPhone:n,linkWallet:r,linkGoogle:i,linkApple:s,linkTwitter:o,linkTwitch:l,linkDiscord:c,linkGithub:d,linkLinkedIn:u,linkTiktok:h,linkLine:p,linkSpotify:w,linkInstagram:m,linkFarcaster:g,linkTelegram:y,linkPasskey:f}}function co(e){let{updateEmail:t,updatePhone:n}=a(N);return Gn("update",e),{updateEmail:t,updatePhone:n}}const uo=e=>{let{user:t}=C(),{loginWithCode:n,emailOtpState:r,setEmailOtpState:a,client:i,inProgressAuthFlowRef:s,inProgressLoginOrLinkMethodRef:o}=Ee();return{state:r,sendCode:h((async({newEmailAddress:n})=>{try{if(!t?.email)throw Error("User is required to have an email address to update it.");let e=new Qr(t.email.address,n);i.startAuthFlow(e),await e.sendCodeEmail({withPrivyUi:!1})}catch(n){a({status:"error",error:n}),e?.onError?.(n.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR,{linkMethod:"email"})}}),[t?.email]),verifyCode:h((async({code:r})=>{try{if(!t?.email)throw Error("User is required to have an email address to update it.");s.current="update",o.current="email";let{user:a,linkedAccount:i}=await n(r);return e?.onSuccess?.({user:a,updateMethod:"email",updatedAccount:i}),{user:a}}catch(r){a({status:"error",error:r}),e?.onError?.(r.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR,{linkMethod:"email"})}}),[t?.email])}},ho=()=>{let{openModal:e,closePrivyModal:t,privy:n}=Ee(),{setModalData:r}=_();return l((()=>({fund:a=>new Promise(((i,s)=>{r({FundWithBankDepositScreen:{onSuccess:async()=>{await t({shouldCallAuthOnSuccess:!1,isSuccess:!0}),i({})},onFailure:async e=>{await t({shouldCallAuthOnSuccess:!1,isSuccess:!1}),s(e)},getCustomer:async({kycRedirectUrl:e})=>{let t={provider:a.provider};return e&&(t.kyc_redirect_url=e),await n.fetchPrivyRoute({path:"/api/v1/fiat/customer",method:"GET"},{query:t})},createOrUpdateCustomer:async({hasAcceptedTerms:e,kycRedirectUrl:t})=>await n.fetchPrivyRoute({path:"/api/v1/fiat/customer",method:"PUT"},{body:{provider:a.provider,has_accepted_terms:e,kyc_redirect_url:t}}),getOrCreateVirtualAccount:async e=>await n.fetchPrivyRoute({path:"/api/v1/fiat/customer/virtual_accounts",method:"PUT"},{body:{...e,provider:a.provider}}),opts:a}}),e("FundWithBankDepositScreen")}))})),[])},po=()=>{let{connectCoinbaseSmartWallet:e}=Ee();return{connectCoinbaseSmartWallet:e}},wo=()=>{let{connectBaseAccount:e}=Ee();return{connectBaseAccount:e}},mo=()=>{let{baseAccountSdk:e}=Ee();return{baseAccountSdk:e}},yo=()=>{let{setModalData:e}=_(),{openModal:t,privy:n,closePrivyModal:r}=Ee(),{user:a}=C();return l((()=>({verify:async({standalone:i=!0}={standalone:!0})=>new Promise(((s,o)=>a?0===a.mfaMethods.length?s():(e((e=>({...e,mfaVerify:{onSuccess:async()=>{i?await r({shouldCallAuthOnSuccess:!1,isSuccess:!0}):Ua.setState({inProgressMfaFlow:void 0}),s()},onFailure:async e=>{i?await r({shouldCallAuthOnSuccess:!1,isSuccess:!1}):Ua.setState({inProgressMfaFlow:void 0}),o(e)},sendSmsCode:async()=>{throw Error("Not enabled")},verifySmsCode:async()=>{throw Error("Not enabled")},verifyTotpCode:async e=>{await n.fetchPrivyRoute(_r,{body:{code:e}})},generateOptions:async()=>_s((await n.fetchPrivyRoute(Cr,{body:{}})).options),verifyPasskey:async e=>{let t=await import("@simplewebauthn/browser"),r=await t.startAuthentication({optionsJSON:e});await n.fetchPrivyRoute(Tr,{body:{authenticator_response:qi(r)}})}}}))),void(i?t("MfaAuthVerifyFlowScreen"):Ua.setState({inProgressMfaFlow:"auth"}))):o(Error("Must be logged in to verify MFA"))))})),[n,e,t,r])},go=()=>{let e=Ze(),{setModalData:t}=_(),{verify:n}=yo(),{openModal:r,privy:a,closePrivyModal:i,refreshSessionAndUser:s,setUser:o}=Ee();return l((()=>({enroll:async l=>new Promise(((c,d)=>{t({mfaEnroll:{onSuccess:async e=>{await i({shouldCallAuthOnSuccess:!1,isSuccess:!0}),c(e)},onFailure:async e=>{await i({shouldCallAuthOnSuccess:!1,isSuccess:!1}),d(e)},onBack:l?.onBack?async()=>{await i({shouldCallAuthOnSuccess:!1,isSuccess:!1}),d(Error("User canceled MFA enrollment flow.")),l.onBack?.()}:void 0,verify:()=>n({standalone:!1}),shouldUnlinkOnUnenrollMfa:!0,mfaMethods:e.mfa.methods,sendSmsCode:async()=>{throw Error("Not enabled")},enrollSms:async()=>{throw Error("Not enabled")},unenrollSms:async()=>{throw Error("Not enabled")},generateTotpSecret:async()=>await a.fetchPrivyRoute(Ir,{body:{}}),enrollTotp:async e=>{await a.fetchPrivyRoute(Er,{body:{code:e}});let t=await s();return o(t),t},unenrollTotp:async()=>{await a.fetchPrivyRoute(br,{body:{}});let e=await s();return o(e),e},enrollPasskey:async e=>{await a.fetchPrivyRoute(Sr,{body:{credential_ids:e,remove_for_login:!0}});let t=await s();return o(t),t}}}),r("MfaAuthEnrollmentFlowScreen")}))})),[a,t,r,i])},fo=()=>{let{startCrossAppAuthFlow:e,unlinkCrossAppAccount:t,signMessageWithCrossAppWallet:n,signTypedDataWithCrossAppWallet:r,sendTransactionWithCrossAppWallet:a,signTransactionWithCrossAppWallet:i}=C();return{loginWithCrossAppAccount:({appId:t})=>e({appId:t,action:"login"}),linkCrossAppAccount:({appId:t})=>e({appId:t,action:"link"}),unlinkCrossAppAccount:t,signMessage:n,signTypedData:r,sendTransaction:a,signTransaction:i}};function vo(e){let{sendTransaction:t}=a(N);return Gn("sendTransaction",e),{sendTransaction:t}}function Ao(){let e=Ze(),t=Yn(),{client:n,setUser:r,setAuthenticated:a,setIsNewUser:i,initializeWalletProxy:s}=Ee(),{create:o}=Hn();return{createGuestAccount:async()=>{if(!e.id||!n)throw Error("SDK not yet ready");n.startAuthFlow(new Ss(e.id));try{let l=await n.authenticate(),c=l.user,d=l.isNewUser??!1;if(!c)throw new ke("Unable to authenticate guest account");let u=await n.getAccessToken(),h=await s(mt);if(u&&h)try{let t=Gi(c,e.embeddedWallets.ethereum.createOnLogin),n=Ji(c,e.embeddedWallets.solana.createOnLogin);t&&n?(c=(await o({chainType:"ethereum",latestUser:c})).user,c=(await o({chainType:"solana",latestUser:c})).user):n?c=(await o({chainType:"solana",latestUser:c})).user:t?c=(await o({chainType:"ethereum",latestUser:c})).user:r(c)}catch(e){r(c),console.warn("Unable to create embedded wallet for guest account")}return i(d),a(!0),t("login","onComplete",{user:c,isNewUser:d,wasAlreadyAuthenticated:!1,loginMethod:"guest",loginAccount:null}),c}catch(e){throw t("login","onError",e.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),e}}}}function ko(e){let{setWalletRecovery:t}=a(N);return Gn("setWalletRecovery",e),{setWalletRecovery:t}}function To(e){let{signMessage:t}=a(N);return Gn("signMessage",e),{signMessage:t}}const Co=()=>{let{ready:e,wallets:t}=ye(),{user:n}=C(),{rpcConfig:r,chains:a,appId:i}=Ee();return{signAuthorization:h((async(s,o)=>{let l;if(!n)throw Error("User must be authenticated before signing with a Privy wallet");if(!e)throw Error("Wallets are not ready");let c=o?.address??I(n)?.address??cr,d=t.find((e=>dr(e.address)===dr(c)));if(!d)throw Error("Signing wallet not found.");let u=s.chainId??Number(d.chainId.split(":")[1]);if(0===u)l={chainId:0,address:s.contractAddress,nonce:s.nonce??0};else{let e=a.find((e=>e.id===u));if(!e)throw Error("Error, chain not configured in PrivyProvider config");let t=ur({account:c,chain:e,transport:hr(fr(e,r,i))});l=await t.prepareAuthorization({...s})}let h=await d.getEthereumProvider(),p=await h.request({method:"secp256k1_sign",params:[_t(l)]});return{...l,...pr(p)}}),[e,t,n,a])}};function _o(e){let{signTypedData:t}=a(N);return Gn("signTypedData",e),{signTypedData:t}}const So=async({wallet:e})=>{let t=await e.getEthereumProvider();return Or({address:e.address,sign:async({hash:n})=>{if("privy"!==e.walletClientType)throw new y({error:"Unprefixed signing is not supported by external wallets.",code:"unsupported_wallet_type"});return await t.request({method:"secp256k1_sign",params:[n]})},signMessage:async({message:n})=>{let r;if("string"==typeof n)r=n;else{if("string"!=typeof n.raw)throw new y({error:"signMessage only supports string messages or {raw: Hex} format",code:"invalid_input"});r=n.raw}return await t.request({method:"personal_sign",params:[r,e.address]})},signTypedData:async n=>await t.request({method:"eth_signTypedData_v4",params:[e.address,n]}),signTransaction:async e=>await t.request({method:"eth_signTransaction",params:[e]}),signAuthorization:async n=>{if("privy"!==e.walletClientType)throw new y({error:"EIP-7702 authorization signing is not supported by external wallets.",code:"unsupported_wallet_type"});let r={chainId:n.chainId,address:n.contractAddress??n.address,nonce:n.nonce},a=_t(r),i=pr(await t.request({method:"secp256k1_sign",params:[a]}));return{...r,...i}}})},bo=()=>{let{wallets:e}=ye();return l((()=>({wrapFetchWithPayment:({walletAddress:t,fetch:n,maxValue:r=BigInt(1e5),paymentRequirementsSelector:a=Pr,config:i})=>{let s=t||e[0]?.address;if(!s)throw new Ur("No wallet available for payment");let o=e.find((e=>Nr(e.address,s)));if(!o)throw new Ur(`Wallet ${s} not found in connected wallets`);return async(e,t)=>{let s=await n(e,t);if(402!==s.status)return s;if(t?.__is402Retry)throw Error("Payment already attempted for this request");let{x402Version:l,accepts:c}=await s.json(),d=a(c,void 0,"exact");if(BigInt(d.maxAmountRequired)>r)throw new Ur("Payment amount exceeds maximum allowed");let u=await So({wallet:o}),h=await Wr(u,l,d,i),p={...t,headers:{...t?.headers||{},"X-PAYMENT":h,"Access-Control-Expose-Headers":"X-PAYMENT-RESPONSE"},__is402Retry:!0};return await n(e,p)}}})),[e])},Eo=()=>{let{isModalOpen:e}=a(N);return{isOpen:e}};function Io(e){let{getAccessToken:t}=a(N);return Gn("accessToken",e),{getAccessToken:t}}function Po(e){let{authenticated:t,user:n}=C(),{initLoginWithOAuth:r}=Ee(),a=Yn();return Gn("oAuthAuthorization",e),{reauthorize:e=>Wo(t,n,r,a,e.provider)}}let Wo=async(e,t,n,r,a)=>{if(!e)throw r("linkAccount","onError",Ce.MUST_BE_AUTHENTICATED,{linkMethod:a}),new ke("User must be authenticated before linking an account.");if(!t?.linkedAccounts.some((e=>e.type.includes(a))))throw new ke(`OAuth account of type ${a} not linked to the account.`);await n(a)};function Uo(e){let{client:t}=Ee(),[n,r]=o({status:"initial"});return{linkWithCustomJwt:h((async n=>{try{r({status:"initial"}),t.startAuthFlow(new $i(n)),r({status:"loading"});let{user:a}=await t.link();if(!a)throw Error("Error, user not found");let i=a.linkedAccounts.filter((e=>"custom_auth"===e.type)).sort(((e,t)=>t.latestVerifiedAt.getTime()-e.latestVerifiedAt.getTime())).at(0);return r({status:"done"}),e?.onSuccess?.({user:a,linkMethod:"custom",linkedAccount:i}),{user:a}}catch(n){throw r({status:"error",error:n}),e?.onError?.(n.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR,{linkMethod:"custom"}),n}}),[t.startAuthFlow,t.link]),state:n}}const No=e=>{let t=es((e=>e.jwtAuthFlowState));return Gn("customAuth",e),{status:t}};function Oo({isAuthenticated:e,isLoading:t,...n}){let r=s();c((()=>{t||r.current?.()}),[e,t]);let a=h((e=>(r.current=e,()=>{r.current=void 0})),[]);return Xi({...n,subscribe:a})}function Ro(){let{getFarcasterSignerPublicKey:e,signFarcasterMessage:t,requestFarcasterSignerFromWarpcast:n}=C();return{getFarcasterSignerPublicKey:e,signFarcasterMessage:t,requestFarcasterSignerFromWarpcast:n}}const Mo=()=>{let{revokeDelegatedWallets:e,delegateWallet:t}=Ee();return{delegateWallet:async({address:e,chainType:n})=>await t({address:e,chainType:n,showDelegationUIs:!0}),revokeWallets:async()=>await e({showDelegationUIs:!0})}},xo=()=>{let{user:e}=C(),t=Ee(),{signWithUserSigner:n}=Rr(),r=async({wallet:r,additional_signers:a})=>{let i=await t.client.getAccessToken();if(!e||!i)throw new ke("User must be authenticated and have an embedded wallet to delegate actions.");if(!r.id)throw new ke("Wallet to add signers to must have ID on server");if(!t.walletProxy)throw new ke("Wallet proxy not initialized.");await f(t.privy,{wallet_id:r.id},n,{additional_signers:a})};return{addSessionSignersInternal:async({address:n,signers:a})=>{let i=await t.client.getAccessToken();if(!e||!i)throw new ke("User must be authenticated and have an embedded wallet to add a session signer.");let s=t.walletProxy??await t.initializeWalletProxy(15e3);if(!s)throw new ke("Wallet proxy not initialized.");let o=R(e,n);if(!o)throw new ke("Address to add signers too is not associated with current user.");if(E(o)){if(0===a.length)throw new ke("Must specify at least one signer to add.");let e=[...(await g(t.privy,{wallet_id:o.id})).additional_signers,...me(a)];await r({wallet:o,additional_signers:e})}else{if(o.delegated)return{user:e};if(a.length>0)throw new ke("Specifying signers in addSessionSigners is only supported for TEE execution and this app uses On-device execution. Pass an empty array for signers instead. Learn more https://docs.privy.io/recipes/tee-wallet-migration-guide");let r=fi({address:n,user:e}),l=vi({address:n,user:e});await t.recoverEmbeddedWallet({address:n}),await s.createDelegatedAction({accessToken:i,rootWallet:l,delegatedWallets:[r]})}let l=await t.refreshSessionAndUser();if(!l)throw Error("Could not refresh user");return{user:l}},removeSessionSignersInternal:async({address:n})=>{let a=await t.client.getAccessToken();if(!e||!a)throw new ke("User must be authenticated and have an embedded wallet to delegate actions.");if(!(t.walletProxy??await t.initializeWalletProxy(15e3)))throw new ke("Wallet proxy not initialized.");let i=R(e,n);if(!i)throw new ke("Address to remove signers from is not associated with current user.");E(i)?await r({wallet:i,additional_signers:[]}):await t.client.revokeDelegatedWallet();let s=await t.refreshSessionAndUser();if(!s)throw Error("Could not refresh user");return{user:s}}}},Fo=()=>{let{addSessionSignersInternal:e,removeSessionSignersInternal:t}=xo();return{addSessionSigners:async({address:t,signers:n})=>e({address:t,signers:n}),removeSessionSigners:async({address:e})=>t({address:e})}},Do=()=>{let{addSessionSignersInternal:e,removeSessionSignersInternal:t}=xo();return{addSigners:async({address:t,signers:n})=>e({address:t,signers:n}),removeSigners:async({address:e})=>t({address:e})}},Lo=()=>{let{signWithUserSigner:e}=Rr();return l((()=>({async generateAuthorizationSignature(t){let{targetAppId:n,...r}=t,{signature:a}=await v((async({message:t})=>e({message:t,targetAppId:n})),r);return{signature:a}}})),[e])},jo=()=>{let{setUser:e,client:t}=a(Pe),{user:n}=a(N);return{user:n,refreshUser:h((async()=>{let n=await(t?.updateUserAndIdToken());return e(n??null),n}),[t,e])}};function qo(){let{user:e}=C(),{client:t}=Ee(),n=Ze(),r=h((async({address:r,recipientPublicKey:a})=>{if(!e)throw new ke("User must be authenticated before exporting their wallet");let i=await t.getAccessToken();if(!i)throw new ke("Must have valid access token");let s=R(e,r);if(!s)throw new ke("User does not have a wallet with this address");if(!E(s))throw new ke("Client export is only supported for unified stack wallets. On-device wallets are not supported.");return function(e,t,n){let r=document.createElement("iframe");return r.style.display="none",r.src=e,document.body.appendChild(r),new Promise(((e,a)=>{let i=null,s=()=>{null!==i&&(clearTimeout(i),i=null),window.removeEventListener("message",o),r.parentNode&&r.parentNode.removeChild(r)},o=t=>{var r;t.origin===n&&"object"==typeof(r=t.data)&&null!==r&&"type"in r&&("CLIENT_EXPORT_RESPONSE"===r.type||"CLIENT_EXPORT_ERROR"===r.type)&&(s(),"CLIENT_EXPORT_ERROR"===t.data.type?a(new ke(t.data.error)):e({ciphertext:t.data.ciphertext,encapsulatedKey:t.data.encapsulatedKey,chainType:t.data.chainType}))};window.addEventListener("message",o),r.onload=()=>{r.contentWindow?.postMessage({type:"CLIENT_EXPORT_REQUEST",recipientPublicKey:t},n)},i=setTimeout((()=>{s(),a(new ke("Wallet export timed out"))}),3e4)}))}(or({origin:t.apiUrl,path:`/apps/${n.id}/embedded-wallets/export`,query:{v:"1-unified",wallet_id:s.id,client_id:n.appClientId,mode:"client-export"},hash:{token:i}}),a,t.apiUrl)}),[e,t,n.id,n.appClientId]);return l((()=>({getWalletPrivateKey:r})),[r])}const zo=e=>{let t=Aa(),{initLoginWithTelegram:n,loginWithTelegram:r,telegramAuthState:a,setTelegramAuthState:i}=Ee();return{login:h((async a=>{try{if(t.enabled&&"success"!==t.status)throw new fa(t.error,null,Ce.CAPTCHA_FAILURE);await n(t.token,a?.disableSignup);let{user:i,isNewUser:s,loginAccount:o,wasAlreadyAuthenticated:l}=await r({intent:"login"});e?.onComplete?.({user:i,isNewUser:s,wasAlreadyAuthenticated:l,loginMethod:"telegram",loginAccount:o})}catch(a){throw i({status:"error",error:a}),e?.onError?.(a.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),a}}),[n,r,t]),state:a}},Ho=()=>{let{revokeDelegatedWallets:e,delegateWallet:t}=Ee();return{delegateWallet:async({address:e,chainType:n})=>await t({address:e,chainType:n,showDelegationUIs:!1}),revokeWallets:async()=>await e({showDelegationUIs:!1})}},Bo=Ka;export{eo as $,Ri as A,us as B,fa as C,Dr as D,Lr as E,Pi as F,hs as G,Fr as H,Ds as I,Hs as J,Ia as K,vs as L,Bs as M,Rs as N,Fs as O,ei as P,$s as Q,Zr as R,wa as S,Gs as T,ks as U,Ys as V,Za as W,Js as X,Qs as Y,Zs as Z,Xs as _,Aa as a,to as a0,no as a1,ro as a2,ao as a3,io as a4,so as a5,oo as a6,Wa as a7,lo as a8,co as a9,Lo as aA,jo as aB,qo as aC,zo as aD,Ho as aE,Bo as aF,Ka as aG,So as aH,Li as aI,uo as aa,ho as ab,po as ac,wo as ad,mo as ae,yo as af,go as ag,fo as ah,vo as ai,Ao as aj,ko as ak,To as al,Co as am,_o as an,bo as ao,Eo as ap,Io as aq,Po as ar,Uo as as,No as at,Xi as au,Oo as av,Ro as aw,Mo as ax,Fo as ay,Do as az,pa as b,Wi as c,Ks as d,ni as e,oi as f,ii as g,ai as h,li as i,si as j,Ji as k,da as l,Ca as m,ri as n,ia as o,Di as p,sa as q,oa as r,Gi as s,Fi as t,Vs as u,Zi as v,Ii as w,Mi as x,Ni as y,Vr as z};
|
|
174
|
+
/*#__PURE__*/t(H,{$if:!0,children:/*#__PURE__*/t(Ja,{scriptHost:n.apiUrl||tt,botUsername:d.loginConfig.telegramAuthConfiguration.botName})})]})})})})})})};class cs extends Error{constructor(e,t,n){super(e),this.code=t,this.data=n}}class ds extends D{async handleSendTransaction(e){if(!e.params||!Array.isArray(e.params))throw new cs(`Invalid params for ${e.method}`,4200);let t=e.params[0];if(!await $r()||!this.address)throw new cs("Disconnected",4900);let{hash:n}=await((e,t)=>ss(e,t))(t,{address:this.address});return n}async handleSignTransaction(e){if(!e.params||!Array.isArray(e.params))throw new cs(`Invalid params for ${e.method}`,4200);let t=e.params[0];if(!await $r()||!this.address)throw new cs("Disconnected",4900);let{signature:n}=await((e,t)=>is(e,t))(t,{address:this.address});return n}handleSwitchEthereumChain(e){let t;if(!e.params||!Array.isArray(e.params))throw new cs(`Invalid params for ${e.method}`,4200);if("string"==typeof e.params[0])t=e.params[0];else{if(!("chainId"in e.params[0])||"string"!=typeof e.params[0].chainId)throw new cs(`Invalid params for ${e.method}`,4200);t=e.params[0].chainId}this.chainId=Number(t),this.publicClient=gr(this.chainId,this.chains,this.rpcConfig,{appId:this.appId}),this.emit("chainChanged",t)}async handlePersonalSign(e){if(!e.params||!Array.isArray(e.params))throw Error("Invalid params for personal_sign");let t=e.params[0],n=e.params[1],{signature:r}=await((e,t)=>rs(e,t))({message:t},{address:n});return r}async handleSignedTypedData(e){if(!e.params||!Array.isArray(e.params))throw Error("Invalid params for eth_signTypedData_v4");let t=e.params[0],n="string"==typeof e.params[1]?JSON.parse(e.params[1]):e.params[1],{signature:r}=await((e,t)=>as(e,t))(re(n),{address:t});return r}async handleEstimateGas(e){if(!e.params||!Array.isArray(e.params))throw Error("Invalid params for eth_estimateGas");delete e.params[0].gasPrice,delete e.params[0].maxFeePerGas,delete e.params[0].maxPriorityFeePerGas;let t={...e.params[0],chainId:q(this.chainId)};return await this.publicClient.estimateGas({account:t.from??this.address,...Be(t)})}async request(e){switch(console.debug("Embedded1193Provider.request() called with args",e),e.method){case"eth_accounts":case"eth_requestAccounts":return this.address?[this.address]:[];case"eth_chainId":return q(this.chainId);case"eth_estimateGas":return this.handleEstimateGas(e);case"eth_sendTransaction":return this.handleSendTransaction(e);case"eth_signTransaction":return this.handleSignTransaction(e);case"wallet_switchEthereumChain":return this.handleSwitchEthereumChain(e);case"personal_sign":return this.handlePersonalSign(e);case"eth_signTypedData_v4":return this.handleSignedTypedData(e)}if(!(e=>Gr.includes(e))(e.method))return this.publicClient.request({method:e.method,params:e.params});{let t=await $r();if(await(e=>os(e))({address:this.address}),!t||!this.address)throw new cs("Disconnected",4900);try{let n={method:e.method,params:e.params},r=this.walletAccount;return r&&E(r)?this.handleWalletApiRequest(n,r,t):(await this.walletProxy.rpc({accessToken:t,entropyId:this.entropyId,entropyIdVerifier:this.entropyIdVerifier,chainType:"ethereum",hdWalletIndex:this.walletIndex,request:n})).response.data}catch(e){throw console.error(e),new cs("Disconnected",4900)}}}async handleWalletApiRequest(e,t,n){let r=this.privyClient;if(!r)throw new cs("Disconnected",4900);if("secp256k1_sign"===e.method){let a=await m(r,(async({message:e})=>this.walletProxy.signWithUserSigner({accessToken:n,message:e})),{chain_type:"ethereum",method:"secp256k1_sign",wallet_id:t.id,params:{hash:e.params[0]}});if("secp256k1_sign"!==a.method)throw new cs(`Invalid params for ${e.method}`,4200);return a.data.signature}throw new cs(`Method not supported: ${e.method}`,4200)}constructor({walletProxy:e,address:t,entropyId:n,entropyIdVerifier:r,rpcConfig:a,chains:i,appId:s,chainId:o=1,walletIndex:l,privyClient:c,walletAccount:d}){super(),this.walletProxy=e,this.address=t,this.entropyId=n,this.entropyIdVerifier=r,this.chainId=o,this.rpcConfig=a,this.chains=i,this.publicClient=gr(o,this.chains,a,{appId:s}),this.rpcTimeoutDuration=J(a,"privy"),this.appId=s,this.walletIndex=l,this.privyClient=c,this.walletAccount=d}}const us=({style:e,...n})=>/*#__PURE__*/t("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",stroke:"currentColor",strokeWidth:1.5,viewBox:"0 0 24 24",style:{...e},...n,children:/*#__PURE__*/t("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M9 17.25v1.007a3 3 0 01-.879 2.122L7.5 21h9l-.621-.621A3 3 0 0115 18.257V17.25m6-12V15a2.25 2.25 0 01-2.25 2.25H5.25A2.25 2.25 0 013 15V5.25m18 0A2.25 2.25 0 0018.75 3H5.25A2.25 2.25 0 003 5.25m18 0V12a2.25 2.25 0 01-2.25 2.25H5.25A2.25 2.25 0 013 12V5.25"})}),hs=({style:n,...r})=>/*#__PURE__*/e("svg",{xmlns:"http://www.w3.org/2000/svg",width:"108",height:"108",viewBox:"0 0 108 108",fill:"none",style:{height:"28px",width:"28px",...n},...r,children:[/*#__PURE__*/t("rect",{width:"108",height:"108",rx:"23",fill:"#AB9FF2"}),/*#__PURE__*/t("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M46.5267 69.9229C42.0054 76.8509 34.4292 85.6182 24.348 85.6182C19.5824 85.6182 15 83.6563 15 75.1342C15 53.4305 44.6326 19.8327 72.1268 19.8327C87.768 19.8327 94 30.6846 94 43.0079C94 58.8258 83.7355 76.9122 73.5321 76.9122C70.2939 76.9122 68.7053 75.1342 68.7053 72.314C68.7053 71.5783 68.8275 70.7812 69.0719 69.9229C65.5893 75.8699 58.8685 81.3878 52.5754 81.3878C47.993 81.3878 45.6713 78.5063 45.6713 74.4598C45.6713 72.9884 45.9768 71.4556 46.5267 69.9229ZM83.6761 42.5794C83.6761 46.1704 81.5575 47.9658 79.1875 47.9658C76.7816 47.9658 74.6989 46.1704 74.6989 42.5794C74.6989 38.9885 76.7816 37.1931 79.1875 37.1931C81.5575 37.1931 83.6761 38.9885 83.6761 42.5794ZM70.2103 42.5795C70.2103 46.1704 68.0916 47.9658 65.7216 47.9658C63.3157 47.9658 61.233 46.1704 61.233 42.5795C61.233 38.9885 63.3157 37.1931 65.7216 37.1931C68.0916 37.1931 70.2103 38.9885 70.2103 42.5795Z",fill:"#FFFDF8"})]});function ps(e,t){if(!Object.prototype.hasOwnProperty.call(e,t))throw TypeError("attempted to use private field on non-instance");return e}var ws=0;class ms extends L{async initialize(){await this.syncAccounts(),this.initialized=!0,this.emit("initialized")}async connect(e){return e.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}get walletBranding(){return{name:this.providerDetail.info.name,icon:this.providerDetail.info.icon,id:this.providerDetail.info.rdns}}disconnect(){console.warn(`Programmatic disconnect with ${this.providerDetail.info.name} is not yet supported.`)}async promptConnection(){try{let e=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!e||0===e.length||!e[0])throw new Ae("Unable to retrieve accounts");await this.syncAccounts([e[0]])}catch(e){throw Oe(e)}}constructor(e,t,n,r,a){super(a||"unknown",e,t,n),this.connectorType="injected",this.proxyProvider=new j(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.providerDetail=r;let i=r.provider;this.proxyProvider.setWalletProvider(i)}}var ys="__private_"+ws+++"__walletBranding";class gs extends L{async initialize(){await this.syncAccounts(),this.initialized=!0,this.emit("initialized")}async connect(e){return e.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}get walletBranding(){return ps(this,ys)[ys]??{name:"Browser Extension",icon:us,id:"extension"}}disconnect(){console.warn("Programmatic disconnect with browser wallets is not yet supported.")}async promptConnection(){try{let e=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!e||0===e.length||!e[0])throw new Ae("Unable to retrieve accounts");await this.syncAccounts([e[0]])}catch(e){throw Oe(e)}}constructor(e,t,n,r,a){super(a??"unknown",e,t,n),Object.defineProperty(this,ys,{writable:!0,value:void 0}),this.connectorType="injected",this.proxyProvider=new j(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.proxyProvider.setWalletProvider(r),"metamask"===a?ps(this,ys)[ys]={name:"MetaMask",icon:le,id:"io.metamask"}:"phantom"===a&&(ps(this,ys)[ys]={name:"Phantom",icon:hs,id:"phantom"})}}class fs extends ms{disconnect(){console.warn("MetaMask does not support programmatic disconnect.")}async promptConnection(){try{gt||await this.proxyProvider.request({method:"wallet_requestPermissions",params:[{eth_accounts:{}}]});let e=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!e||0===e.length||!e[0])throw new Ae("Unable to retrieve accounts");await this.syncAccounts([e[0]])}catch(e){throw Oe(e)}}}class vs extends D{get wallets(){let e=new Set;return this.walletConnectors.flatMap((e=>e.wallets)).sort(((e,t)=>e.connectedAt&&t.connectedAt?t.connectedAt-e.connectedAt:0)).filter((t=>{let n=`${t.address}${t.walletClientType}${t.connectorType}${t.meta.id}`;return!e.has(n)&&(e.add(n),!0)}))}async initialize(e){if(this.initialized&&!e||(e&&this.removeAllConnectors(),this.externalWalletConfig.disableAllExternalWallets))return;let t=ce({store:this.store,walletList:this.walletList,externalWalletConfig:this.externalWalletConfig,walletChainType:this.walletChainType}).then((e=>{e.forEach((({type:e,eip6963InjectedProvider:t,legacyInjectedProvider:n})=>{this.createEthereumWalletConnector({connectorType:"injected",walletClientType:e,providers:{eip6963InjectedProvider:t,legacyInjectedProvider:n}})}))}));for(let e of(this.walletList.includes("coinbase_wallet")&&this.createEthereumWalletConnector({connectorType:"coinbase_wallet",walletClientType:"coinbase_wallet"}),this.walletList.includes("base_account")&&this.createEthereumWalletConnector({connectorType:"base_account",walletClientType:"base_account"}),Object.values(de)))!e.isInstalled&&this.walletList.includes(e.client)&&(["ethereum-only","ethereum-and-solana"].includes(this.walletChainType)&&e.chainTypes.includes("ethereum")&&this.createEthereumWalletConnector({connectorType:"null",walletClientType:e.client,walletConfig:e}),["ethereum-and-solana","solana-only"].includes(this.walletChainType)&&e.chainTypes.includes("solana")&&this.addSolanaWalletConnector(new ue({id:e.client,name:e.name})));this.externalWalletConfig.walletConnect.enabled&&(this.walletList.includes("wallet_connect_qr")||X(this.walletList))&&"solana-only"!==this.walletChainType&&this.createEthereumWalletConnector({connectorType:"wallet_connect_v2",walletClientType:"unknown"});let n=this.walletList.includes("wallet_connect_qr_solana")||X(this.walletList)&&"ethereum-only"!==this.walletChainType,r=this.externalWalletConfig.solana.connectors?.get()||[],a=async e=>{if(!n)return;let t=e.find((e=>"walletconnect_solana"===e.walletBranding?.id));t&&t.wallet&&await t.wallet.initialize({walletConnectCloudProjectId:this.walletConnectCloudProjectId,privyAppName:this.privyAppName})};a(r),r.filter((e=>n||"walletconnect_solana"!==e.walletBranding?.id)).forEach(this.addSolanaWalletConnector),this.externalWalletConfig.solana.connectors?._setOnConnectorsUpdated?.((e=>{a(e),e?.filter((e=>n||"walletconnect_solana"!==e.walletBranding?.id)).forEach(this.addSolanaWalletConnector)})),await t,this.initialized=!0}findWalletConnector(e,t,n){return"wallet_connect_v2"===e?this.walletConnectors.filter(he).find((t=>t.connectorType===e&&(!n||t.wallets.some((e=>e.address===n)))))??null:this.walletConnectors.filter(he).find((r=>r.connectorType===e&&r.walletClientType===t&&(!n||r.wallets.some((e=>e.address===n)))))??null}findSolanaWalletConnector(e){return this.walletConnectors.filter(pe).find((t=>"unknown"===t.walletClientType?t.walletBranding.id===e:t.walletClientType===e))??null}findEmbeddedWalletConnectors(){return this.walletConnectors.filter((e=>"embedded"===e.connectorType))}findImportedWalletConnectors(){return this.walletConnectors.filter((e=>"embedded_imported"===e.connectorType))}onInitialized(e){e.wallets.forEach((e=>{let t=this.storedConnections.find((t=>t.address===e.address&&t.connectorType===e.connectorType&&("solana"===e.type&&"unknown"===t.walletClientType&&"unknown"===e.walletClientType?e.meta.id===t.id:t.walletClientType===e.walletClientType)));t&&(e.connectedAt=t.connectedAt)})),this.emit("walletsUpdated"),this.emit("connectorInitialized")}onWalletsUpdated(e){e.initialized&&this.emit("walletsUpdated")}addEmbeddedWalletConnectors({walletProxy:e,user:t,embeddedWallets:n,defaultChain:r,appId:a,privyClient:i}){let{entropyId:s,entropyIdVerifier:o}=ve(t);for(let t of n){let n=this.findEmbeddedWalletConnectors().find((e=>e.walletIndex===t.walletIndex));if(n&&he(n))n.proxyProvider.walletProxy=e;else{let n=new Kr({provider:new ds({walletProxy:e,address:t.address,entropyId:s,entropyIdVerifier:o,rpcConfig:this.rpcConfig,chains:this.chains,appId:a,chainId:r.id,walletIndex:t.walletIndex,privyClient:i,walletAccount:t}),chains:this.chains,defaultChain:r,rpcConfig:this.rpcConfig,imported:!1,walletIndex:t.walletIndex});this.addWalletConnector(n)}}}addImportedWalletConnector(e,t,n,r){let a=this.findWalletConnector("embedded_imported","privy",t);if(a&&he(a))a.proxyProvider.walletProxy=e;else{let a=new Kr({provider:new ds({walletProxy:e,address:t,entropyId:t,entropyIdVerifier:"ethereum-address-verifier",walletIndex:0,rpcConfig:this.rpcConfig,chains:this.chains,appId:r,chainId:n.id}),chains:this.chains,walletIndex:0,defaultChain:n,rpcConfig:this.rpcConfig,imported:!0});this.addWalletConnector(a)}}removeEmbeddedWalletConnectors(){this.walletConnectors=this.walletConnectors.filter((e=>"embedded"!==e.connectorType)),this.storedConnections=ze(),this.emit("walletsUpdated")}removeImportedWalletConnectors(){let e=this.findImportedWalletConnectors();e.length&&(e.forEach((e=>{let t=this.walletConnectors.indexOf(e);this.walletConnectors.splice(t,1)})),this.storedConnections=ze(),this.emit("walletsUpdated"))}async createEthereumWalletConnector({connectorType:e,walletClientType:t,providers:n,walletConfig:r}){let a=this.findWalletConnector(e,t);if(a&&he(a))return a instanceof Za&&a.resetConnection(t),a;let i=(()=>"injected"!==e?"coinbase_wallet"===e?new Br(this.chains,this.defaultChain,this.rpcConfig,this.externalWalletConfig.coinbaseWallet.config):"base_account"===e?new zr(this.chains,this.defaultChain,this.rpcConfig,this.externalWalletConfig.baseAccount.config,this.setBaseAccountSdk):"null"!==e?new Za({walletConnectCloudProjectId:this.walletConnectCloudProjectId,rpcConfig:this.rpcConfig,chains:this.chains,defaultChain:this.defaultChain,shouldEnforceDefaultChainOnConnect:this.shouldEnforceDefaultChainOnConnect,privyAppId:this.privyAppId,privyAppName:this.privyAppName,walletClientType:t}):r?new we({id:r.client,name:r.name,defaultChain:this.defaultChain,walletClientType:r.client}):null:"metamask"===t&&n?.eip6963InjectedProvider?new fs(this.chains,this.defaultChain,this.rpcConfig,n?.eip6963InjectedProvider,"metamask"):"metamask"===t&&n?.legacyInjectedProvider?new gs(this.chains,this.defaultChain,this.rpcConfig,n?.legacyInjectedProvider,"metamask"):"phantom"===t&&n?.legacyInjectedProvider?new gs(this.chains,this.defaultChain,this.rpcConfig,n?.legacyInjectedProvider,"phantom"):n?.legacyInjectedProvider&&"unknown_browser_extension"===t?new gs(this.chains,this.defaultChain,this.rpcConfig,n?.legacyInjectedProvider):n?.eip6963InjectedProvider?new ms(this.chains,this.defaultChain,this.rpcConfig,n?.eip6963InjectedProvider,t):void 0)();return i&&this.addWalletConnector(i),i||null}addWalletConnector(e){this.walletConnectors.push(e),e.on("initialized",(()=>this.onInitialized(e))),e.on("walletsUpdated",(()=>this.onWalletsUpdated(e))),e.initialize().catch((e=>{console.debug("Failed to initialize connector",e)}))}setWalletList(e){this.walletList=e,this.initialized&&this.initialize(!0).catch(console.error)}removeAllConnectors(){for(let e of this.walletConnectors)e.removeAllListeners();this.walletConnectors=[]}constructor(e,t,n,r,a,i,s,o,l,c,d,u){super(),this.addSolanaWalletConnector=async e=>{let t=this.findSolanaWalletConnector(e.walletClientType);if(!t||"null"===t.connectorType){if("null"===t?.connectorType){let e=this.walletConnectors.indexOf(t);this.walletConnectors.splice(e,1)}this.addWalletConnector(e)}},this.privyAppId=e,this.walletConnectCloudProjectId=t,this.rpcConfig=n,this.chains=r,this.defaultChain=a,this.walletConnectors=[],this.initialized=!1,this.store=i,this.walletList=s,this.shouldEnforceDefaultChainOnConnect=o,this.externalWalletConfig=l,this.privyAppName=c,this.walletChainType=u||"ethereum-only",this.setBaseAccountSdk=d,this.storedConnections=ze()}}const As=Xn((()=>({identityToken:null})));function ks(){let{identityToken:e}=As();return{identityToken:e}}let Ts=[Qt,Zt,Xt];class Cs{async get(e,t){try{return await this.baseFetch(e,t)}catch(e){throw Te(e)}}async post(e,t,n){try{return await this.baseFetch(e,{method:"POST",...t?{body:t}:{},...n})}catch(e){throw Te(e)}}async delete(e,t){try{return await this.baseFetch(e,{method:"DELETE",...t})}catch(e){throw Te(e)}}constructor({appId:e,appClientId:t,client:n,defaults:r}){this.appId=e,this.appClientId=t,this.clientAnalyticsId=n.clientAnalyticsId,this.sdkVersion=at,this.client=n,this.defaults=r,this.fallbackApiUrl=n.fallbackApiUrl,this.baseFetch=vr.create({baseURL:this.defaults.baseURL,timeout:this.defaults.timeout,retry:3,retryDelay:500,retryStatusCodes:[408,409,425,500,502,503,504],credentials:"include",onRequest:async({request:e,options:t})=>{let n=new Headers(t.headers);n.set("privy-app-id",this.appId),this.appClientId&&n.set("privy-client-id",this.appClientId),n.set("privy-ca-id",this.clientAnalyticsId||""),n.set("privy-client",`react-auth:${this.sdkVersion}`);let r=Ts.includes(e.toString());if(!n.has("authorization")){let e=await this.client.getAccessToken({disableAutoRefresh:r});null!==e&&n.set("authorization",`Bearer ${e}`)}t.headers=n,t.retryDelay&&"number"==typeof t.retryDelay&&(t.retryDelay=3*t.retryDelay)},onRequestError:({error:e})=>{if(e instanceof DOMException&&"AbortError"===e.name)throw new Ue}})}}const _s=e=>({rpId:e.rp_id,challenge:e.challenge,allowCredentials:e.allow_credentials?.map((e=>({id:e.id,type:e.type,transports:e.transports})))||[],timeout:e.timeout,extensions:{appid:e.extensions?.app_id,credProps:e.extensions?.cred_props,hmacCreateSecret:e.extensions?.hmac_create_secret},userVerification:e.user_verification});class Ss{getOrCreateGuestCredential(e){let t=rt(e);if(qe()){if(Re.get(t))return Re.get(t);{let e=T.encode(aa(32));return Re.put(t,e),e}}return T.encode(aa(32))}async authenticate(){if(!this.api)throw new ke("Auth flow has no API instance");try{return await this.api.post(en,{guest_credential:this.meta.guestCredential})}catch(e){throw Te(e)}}async link(){throw Error("Linking is not supported for the guest flow")}constructor(e){this.meta={guestCredential:this.getOrCreateGuestCredential(e)}}}function bs(){return!(At&&window.location.origin.startsWith("http://localhost"))}var Es,Is=((Es={}).PRIVY="privy_access_token",Es.CUSTOMER="customer_access_token",Es);class Ps{get token(){return this.privyAccessToken||this.customerAccessToken}getToken(e){return"privy_access_token"===e?this.privyAccessToken:this.customerAccessToken}get customerAccessToken(){return this._getToken($e)}get privyAccessToken(){return this._getToken(Ke)}_getToken(e){try{let t=Re.get(e);return"string"==typeof t?Mr.throwIfNotWellFormedJwt(t):null}catch(e){return console.error(e),this.destroyLocalState(),null}}get refreshToken(){try{let e=Re.get(it);return"string"==typeof e?e:null}catch(e){return console.error(e),this.destroyLocalState(),null}}getProviderAccessToken(e){try{let t=Re.get(st(e));if("string"!=typeof t)return null;{let n=new Mr(t);return n.isExpired()?(Re.del(st(e)),null):n.value}}catch(e){return console.error(e),null}}get mightHaveServerCookies(){try{let e=Ar.get(ot);return void 0!==e&&e.length>0}catch(e){console.error(e)}return!1}hasRefreshCredentials(e="privy_access_token"){let t="string"==typeof this.getToken(e),n="string"==typeof this.refreshToken&&this.refreshToken!==lt;return this.mightHaveServerCookies||t&&n}hasActiveAccessToken(e){let t=Mr.parse(this.getToken(e));return null!==t&&!t.isExpired(30)}authenticate(e){return this.authenticateOnce.execute(e)}link(e){return this.linkOnce.execute(e)}refresh(){return this.refreshOnce.execute()}destroy(){return this.destroyOnce.execute()}storeProviderAccessToken(e,t){"string"==typeof t?Re.put(st(e),t):Re.del(st(e))}updateIdentityToken(e){"string"==typeof e?this.storeIdentityToken(e):this.clearIdentityToken()}async _authenticate(e){try{let t=await e.authenticate(),{user:n,is_new_user:r,oauth_tokens:a}=t;this.handleTokenResponse(t);let i=a?{provider:a.provider,accessToken:a.access_token,accessTokenExpiresInSeconds:a.access_token_expires_in_seconds,refreshToken:a.refresh_token,refreshTokenExpiresInSeconds:a.refresh_token_expires_in_seconds,scopes:a.scopes}:void 0;return this._trackAuthenticateEvents(e,r),{user:F(n),isNewUser:r,oAuthTokens:i}}catch(e){throw console.warn("Error authenticating session"),Ne(e)}}_trackAuthenticateEvents(e,t){let n=function(e){return e instanceof Jr?"email":e instanceof ma?"sms":e instanceof pa?"siwe":e instanceof Ss?"guest":e instanceof $i?"custom_auth":e instanceof la?e.meta.provider:null}(e);n&&this.client&&this.client.createAnalyticsEvent({eventName:"sdk_authenticate",payload:{method:n,isNewUser:t}}),"siwe"===n&&this.client&&this.client.createAnalyticsEvent({eventName:"sdk_authenticate_siwe",payload:{connectorType:e.meta.connectorType,walletClientType:e.meta.walletClientType}})}async _link(e){try{let t=await e.link(),n=t.oauth_tokens,r=n?{provider:n.provider,accessToken:n.access_token,accessTokenExpiresInSeconds:n.access_token_expires_in_seconds,refreshToken:n.refresh_token,refreshTokenExpiresInSeconds:n.refresh_token_expires_in_seconds,scopes:n.scopes}:void 0;return{user:F(t),oAuthTokens:r}}catch(e){throw console.warn("Error linking account"),Ne(e)}}async _refresh(){if(!this.api)throw new ke("Session has no API instance");if(!this.client)throw new ke("Session has no PrivyClient instance");await this.client.getAccessToken({disableAutoRefresh:!0});let e=this.token,t=this.refreshToken;if(this.client.useServerCookies&&!this.mightHaveServerCookies&&this.token&&window.location.origin===this.client.apiUrl)return this.destroyLocalState(),null;try{let n;if(!(e&&t||this.mightHaveServerCookies))return null;{let r={};e&&(r.authorization=`Bearer ${e}`),n=await this.api.post(Qt,t?{refresh_token:t}:{},{headers:r})}return this.handleTokenResponse(n),F(n.user)}catch(e){if(e instanceof Ie&&e.privyErrorCode===Ce.MISSING_OR_INVALID_TOKEN)return console.warn("Unable to refresh tokens - token is missing or no longer valid"),this.destroyLocalState(),null;throw Ne(e)}}handleTokenResponse(e){e.session_update_action&&"set"!==e.session_update_action?"clear"===e.session_update_action?this.destroyLocalState():"ignore"===e.session_update_action&&(e.token&&(this.storeCustomerAccessToken(e.token),this.storePrivyAccessToken(e.privy_access_token)),e.identity_token&&this.storeIdentityToken(e.identity_token)):this._storeAllTokens(e)}_storeAllTokens(e){this.storeRefreshToken(e.refresh_token),this.storeCustomerAccessToken(e.token),this.storePrivyAccessToken(e.privy_access_token),e.identity_token&&this.storeIdentityToken(e.identity_token)}async _destroy(){try{await(this.api?.post(Zt,{refresh_token:this.refreshToken}))}catch(e){console.warn("Error destroying session")}this.destroyLocalState()}destroyLocalState(){this.storeRefreshToken(null),this.storeCustomerAccessToken(null),this.storePrivyAccessToken(null),this.clearIdentityToken()}storeCustomerAccessToken(e){if("string"==typeof e){let t=Re.get($e);if(Re.put($e,e),!this.client?.useServerCookies){let t=Mr.parse(e)?.expiration;Ar.set(ct,e,{sameSite:"Strict",secure:bs(),expires:t?new Date(1e3*t):void 0})}t!==e&&this.client?.onStoreCustomerAccessToken?.(e)}else Re.del($e),Ar.remove(ct),this.client?.onDeleteCustomerAccessToken?.()}storeRefreshToken(e){"string"==typeof e?(Re.put(it,e),this.client?.useServerCookies||Ar.set(ot,"t",{sameSite:"Strict",secure:bs(),expires:30})):(Re.del(it),Ar.remove(dt),Ar.remove(ot))}storePrivyAccessToken(e){"string"==typeof e?Re.put(Ke,e):Re.del(Ke)}storeIdentityToken(e){if(As.setState({identityToken:e}),this.client?.useServerCookies)return;Re.put(ut,e);let t=Mr.parse(e)?.expiration;Ar.set(ht,e,{sameSite:"Strict",secure:bs(),expires:t?new Date(1e3*t):void 0})}clearIdentityToken(){Re.del(ut),As.setState({identityToken:null}),Ar.remove(ht)}constructor(){this.authenticateOnce=new Zr((async e=>this._authenticate(e))),this.linkOnce=new Zr((async e=>this._link(e))),this.refreshOnce=new Zr(this._refresh.bind(this)),this.destroyOnce=new Zr(this._destroy.bind(this))}}let Ws,Us;var Ns=0,Os="__private_"+Ns+++"__getOrGenerateClientAnalyticsId";class Rs{getAppId(){return this.appId}initializeConnectorManager({walletConnectCloudProjectId:e,rpcConfig:t,chains:n,defaultChain:r,store:a,walletList:i,shouldEnforceDefaultChainOnConnect:s,externalWalletConfig:o,appName:l,walletChainType:c,setBaseAccountSdk:d}){this.connectors||(this.connectors=new vs(this.appId,e,t,n,r,a,i,s,o,l,d,c))}generateApi(){let e=new Cs({appId:this.appId,appClientId:this.appClientId,client:this,defaults:{baseURL:this.apiUrl,timeout:this.timeout}});return this.session.api=e,e}updateApiUrl(e){this.apiUrl=e||this.fallbackApiUrl,this.api=this.generateApi(),e&&(this.useServerCookies=!0)}authenticate(){if(!this.authFlow)throw new ke("No auth flow in progress.");return this.session.authenticate(this.authFlow)}async link(){if(!this.authFlow)throw new ke("No auth flow in progress.");let{oAuthTokens:e}=await this.session.link(this.authFlow);return{user:await this.getAuthenticatedUser(),oAuthTokens:e}}storeProviderAccessToken(e,t){this.session.storeProviderAccessToken(e,t)}getProviderAccessToken(e){return this.session.getProviderAccessToken(e)}async logout(){await this.session.destroy(),this.authFlow=void 0}clearProviderAcccessTokens(e){e.linkedAccounts.filter((e=>"cross_app"===e.type)).forEach((e=>{this.storeProviderAccessToken(e.providerApp.id,null)}))}startAuthFlow(e){return e.api=this.api,this.authFlow=e,this.authFlow}async initMfaSmsVerification(){try{await this.api.post(tn,{action:"verify"})}catch(e){throw Te(e)}}async initMfaPasskeyVerification(){try{let e=await this.api.post(nn,{});return _s(e.options)}catch(e){throw Te(e)}}async getCrossAppProviderDetails(e){try{return this._cachedProviderAppDetails[e]||(this._cachedProviderAppDetails[e]=await this.api.get(`/api/v1/apps/${e}/cross-app/details`)),this._cachedProviderAppDetails[e]}catch(e){console.error("Error fetching cross app provider details",e)}}async acceptTerms(){try{let e=await this.api.post(rn,{});return F(e)}catch(e){throw Ne(e)}}async unlinkEmail(e){try{let t=await this.api.post(an,{address:e});return await this.getAuthenticatedUser()??F(t)}catch(e){throw Ne(e)}}async unlinkPhone(e){try{let t=await this.api.post(sn,{phoneNumber:e});return await this.getAuthenticatedUser()??F(t)}catch(e){throw Ne(e)}}async unlinkEthereumWallet(e){try{let t=await this.api.post(on,{address:e});return await this.getAuthenticatedUser()??F(t)}catch(e){throw Ne(e)}}async unlinkSolanaWallet(e){try{let t=await this.api.post(ln,{address:e});return await this.getAuthenticatedUser()??F(t)}catch(e){throw Ne(e)}}async unlinkOAuth(e,t){try{let n=await this.api.post(cn,{provider:e,subject:t});return await this.getAuthenticatedUser()??F(n)}catch(e){throw Ne(e)}}async unlinkFarcaster(e){try{let t=await this.api.post(dn,{fid:e});return await this.getAuthenticatedUser()??F(t)}catch(e){throw Ne(e)}}async unlinkTelegram(e){try{let t=await this.api.post(un,{telegram_user_id:e});return await this.getAuthenticatedUser()??F(t)}catch(e){throw Ne(e)}}async revokeDelegatedWallet(){try{await this.api.post(hn,{})}catch(e){throw Ne(e)}}async createAnalyticsEvent({eventName:e,payload:t,timestamp:n,options:r}){if("undefined"!=typeof window)try{this.clientAnalyticsId||console.warn("No client analytics id set, refusing to send analytics event"),await this.api.post(Xt,{event_name:e,client_id:this.clientAnalyticsId,payload:{...t||{},clientTimestamp:n?n.toISOString():(new Date).toISOString()}},{retry:-1,keepalive:r?.keepAlive??!1})}catch(e){console.log("Unable to submit event. This is not an issue.")}}async signMoonpayOnRampUrl(e){try{return this.api.post(pn,e)}catch(e){throw Ne(e)}}async initCoinbaseOnRamp(e){try{return this.api.post(wn,e)}catch(e){throw Ne(e)}}async getCoinbaseOnRampStatus({partnerUserId:e}){try{return this.api.get(`${mn}?partnerUserId=${e}`)}catch(e){throw Ne(e)}}async getAuthenticatedUser(){return this.session.hasRefreshCredentials()?this.session.refresh():null}async getAccessToken(e){return await this.getPrivyAccessToken(e)||await this.getCustomerAccessToken(e)}async getCustomerAccessToken(e){return await this._getToken(Is.CUSTOMER,e)}async getPrivyAccessToken(e){return await this._getToken(Is.PRIVY,e)}async _getToken(e,t){return this.session.getToken(e)?this.session.hasActiveAccessToken(e)?this.session.hasRefreshCredentials(e)?xr.parse(this.session.getToken(e))?.appId!==this.appId?(await this.logout(),null):this.session.getToken(e):(this.session.destroyLocalState(),null):!t?.disableAutoRefresh&&this.session.hasRefreshCredentials(e)?(await this.session.refresh(),this.session.getToken(e)):null:null}async getUsdTokenPrice(e){try{return(await this.api.get(`/api/v1/token_price?chainId=${e.id}&tokenSymbol=${e.nativeCurrency.symbol}`)).usd}catch(t){return void console.error(`Unable to fetch token price for chain with id ${e.id}`)}}async getUsdPriceForSol(){try{return(await this.api.get("/api/v1/token_price?chainId=0&tokenSymbol=SOL")).usd}catch(e){return void console.error("Unable to fetch token price for SOL")}}async getSplTokenMetadata({mintAddress:e,cluster:t}){try{return await this.api.get(`/api/v1/spl_token_info?mint_address=${e}&cluster=${t}`)}catch(n){return void console.error(`Unable to fetch token metadata for ${t}:${e}`)}}async requestFarcasterSignerStatus(e){try{return await this.api.post("/api/v1/farcaster/signer/status",{ed25519_public_key:e})}catch(e){throw console.error("Unable to fetch Farcaster signer status"),e}}async generateSiweNonce({address:e,captchaToken:t}){try{return(await this.api.post(yn,{address:e,token:t})).nonce}catch(e){throw Ne(e)}}async authenticateWithSiweInternal({message:e,signature:t,chainId:n,walletClientType:r,connectorType:a,mode:i}){return await this.api.post(gn,{message:e,signature:t,chainId:n,walletClientType:r,connectorType:a,mode:i})}async linkWithSiweInternal({message:e,signature:t,chainId:n,walletClientType:r,connectorType:a}){return await this.api.post(fn,{message:e,signature:t,chainId:n,walletClientType:r,connectorType:a})}async linkSmartWallet({message:e,signature:t,smartWalletType:n,smartWalletVersion:r}){try{let a=await this.api.post(vn,{message:e,signature:t,smart_wallet_type:n,smart_wallet_version:r});return F(a)}catch(e){throw Ne(e)}}async linkWithSiwe({message:e,signature:t,chainId:n,walletClientType:r,connectorType:a}){try{let i=await this.linkWithSiweInternal({message:e,signature:t,chainId:n,walletClientType:r,connectorType:a});return F(i)}catch(e){throw Ne(e)}}async generateSiwsNonce({address:e,captchaToken:t}){try{return(await this.api.post(An,{address:e,token:t})).nonce}catch(e){throw Ne(e)}}async authenticateWithSiwsInternal({message:e,signature:t,walletClientType:n,connectorType:r,mode:a,messageType:i="plain"}){return await this.api.post(kn,{message:e,signature:t,walletClientType:n,connectorType:r,mode:a,message_type:i})}async authenticateWithSiws({message:e,signature:t,walletClientType:n,connectorType:r,mode:a,messageType:i="plain"}){let s=await this.authenticateWithSiwsInternal({message:e,signature:t,walletClientType:n,connectorType:r,mode:a,messageType:i});this.session.handleTokenResponse(s);let o=F(s.user);if(!o)throw Error("Authentication failed - no user returned");return{user:o,isNewUser:s.is_new_user||!1}}async sendAccountTransferRequest({nonce:e,account:t,accountType:n,externalWalletMetadata:r,telegramAuthResult:a,telegramWebAppData:i,farcasterEmbeddedAddress:s,oAuthUserInfo:o}){try{let l,c;switch(n){case"email":l=In,c={nonce:e,email:t};break;case"sms":l=En,c={nonce:e,phoneNumber:t};break;case"siwe":if(l=bn,!r)throw Error("Wallet parameters must be defined");c={nonce:e,address:t,...r};break;case"farcaster":l=Sn,c={nonce:e,farcaster_id:t,farcaster_embedded_address:s};break;case"telegram":l=_n,c={nonce:e,telegram_auth_result:a,telegram_web_app_data:i};break;case"siws":l=Cn,c={nonce:e,address:t,...r};break;case"custom":case"guest":case"passkey":throw Error("Invalid transfer account type");default:l=Tn,c={nonce:e,userInfo:o}}let d=await this.api.post(l,c);return await this.getAuthenticatedUser()??F(d)}catch(e){throw Ne(e)}}async linkWithSiwsInternal({message:e,signature:t,walletClientType:n,connectorType:r,messageType:a="plain"}){return await this.api.post(Pn,{message:e,signature:t,walletClientType:n,connectorType:r,message_type:a})}async linkWithSiws({message:e,signature:t,walletClientType:n,connectorType:r,messageType:a="plain"}){try{let i=await this.linkWithSiwsInternal({message:e,signature:t,walletClientType:n,connectorType:r,messageType:a});return F(i)}catch(e){throw Ne(e)}}async updateUserAndIdToken(){try{let e=await this.api.get(Wn);return this.session.updateIdentityToken(e.identity_token),F(e.user)}catch(e){throw Ne(e)}}async scanTransaction(e){try{return await this.api.post(Un,e)}catch(e){throw Ne(e)}}constructor({apiUrl:e=tt,appId:t,appClientId:n,timeout:r=pt}){Object.defineProperty(this,Os,{value:Ms}),this._cachedProviderAppDetails={},this.apiUrl=e,this.fallbackApiUrl=this.apiUrl,this.useServerCookies=e!==tt&&e.startsWith("https://privy."),this.timeout=r,this.appId=t,this.appClientId=n,this.clientAnalyticsId=function(e,t){if(!Object.prototype.hasOwnProperty.call(e,t))throw TypeError("attempted to use private field on non-instance");return e}(this,Os)[Os](),Ws||(Ws=new Ps),this.session=Ws,this.api=this.generateApi(),this.session.client=this}}function Ms(){if("undefined"==typeof window)return null;try{let e=Re.get(nt);if("string"==typeof e&&e.length>0)return e}catch(e){}let e=A();try{return Re.put(nt,e),e}catch(t){return e}}function xs(){if(!Us)throw new ke("No global PrivyClient instance found. Please ensure you have initialized the PrivyProvider.");return Us}async function Fs(){return await(Us?.updateUserAndIdToken()),Us?.useServerCookies?As.getState().identityToken:Promise.resolve(Re.get(ut)||null)}const Ds=({config:e,...n})=>{(()=>{if(a(ns))throw new ke("Multiple PrivyProvider instances found","Found multiple instances of PrivyProvider, ensure there is only one mounted in your application tree.")})(),function(){if("undefined"==typeof window)return;let e=["localhost","127.0.0.1"].includes(window.location.hostname),t="https:"===window.location.protocol||"chrome-extension:"===window.location.protocol;if(!e&&!t)throw new ke("Embedded wallet is only available over HTTPS")}(),function(e){if("string"!=typeof e||25!==e.length)throw new ke("Cannot initialize the Privy provider with an invalid Privy app ID")}(n.appId),function(e){Us||(Us=new Rs({appId:e.appId,appClientId:e.clientId,apiUrl:e.apiUrl}))}(n);let r=l((()=>new p({appId:n.appId,clientId:n.clientId,storage:Re,baseUrl:n.apiUrl,sdkVersion:"react-auth:3.14.1"})),[]),i=xs(),s=Object.assign({},e);/*#__PURE__*/return t(wt,{client:r,legacyClient:i,appClientId:n.clientId,clientConfig:s,children:/*#__PURE__*/t(mr,{configPlugins:e?.plugins,children:/*#__PURE__*/t(ls,{...n,client:i,privy:r})})})},Ls=Symbol("cross-tab-user-sync-plugin");let js=null,qs=null,zs=!1;function Hs(e){if(!e.channelId)throw Error("[Privy] Cross-tab sync plugin requires a channelId.");return"undefined"==typeof BroadcastChannel||js||((js=new BroadcastChannel(`PRIVY_CROSS_TAB_CHANNEL:${e.channelId}`)).onmessage=e=>{e.data.eventId!==qs&&(qs=e.data.eventId,zs=!0,Vi(e.data.user),Ki(!!e.data.user),zs=!1)},Bi.subscribe(((e,t)=>{if(e.user===t.user||zs)return;let n=A();qs=n,js?.postMessage({user:e.user,eventId:n})}))),{id:Ls}}const Bs=()=>{let{user:e}=C(),{walletProxy:t}=Ee();return{recover:h((async n=>{if(!t)throw Error("Wallet proxy is not ready");let r=await $r();if(!e||!r)throw new ke("User must be logged in before attempting to modify the recovery method.");let{entropyId:a,entropyIdVerifier:i}=ve(e);try{await t.recover({entropyId:a,entropyIdVerifier:i,accessToken:r,...n})}catch{throw new ke("Unable to recover wallets")}}),[t,e])}};function Vs(){let{promptMfa:e,init:t,submit:n,cancel:r,mfaMethods:i}=a(N);return{promptMfa:e,init:t,submit:n,cancel:r,mfaMethods:i}}function Ks(){let{initEnrollmentWithSms:e,initEnrollmentWithTotp:t,initEnrollmentWithPasskey:n,submitEnrollmentWithSms:r,submitEnrollmentWithTotp:i,submitEnrollmentWithPasskey:s,unenroll:o,enrollInMfa:l}=a(N);return{initEnrollmentWithSms:e,initEnrollmentWithTotp:t,initEnrollmentWithPasskey:n,submitEnrollmentWithSms:r,submitEnrollmentWithTotp:i,submitEnrollmentWithPasskey:s,unenrollWithSms:()=>o("sms"),unenrollWithTotp:()=>o("totp"),unenrollWithPasskey:e=>o("passkey",e),showMfaEnrollmentModal:()=>l(!0),closeMfaEnrollmentModal:()=>l(!1)}}function $s(){let e=xs();return e?e.getCustomerAccessToken():Promise.resolve(Re.get($e)||null)}const Gs=()=>{let{client:e,setAuthenticated:t,setUser:n}=Ee();return l((()=>({init:async()=>{if(!e)throw new ke("Must initialize Privy client first.");let t=new kr;return e.startAuthFlow(t),await t.init()},login:async({fid:r,message:a,signature:i})=>{if(!e)throw new ke("Must initialize Privy client first.");if(!(e.authFlow instanceof kr))throw new ke("Must initialize Farcaster Mini App flow first.");e.authFlow.setAuthData({message:a,signature:i,fid:r});let{user:s}=await e.authenticate();if(!s)throw new ke("Failed to login with Farcaster V2");return n(s),t(!0),{user:s}}})),[e,n,t])},Ys=()=>l((()=>({getAccessTokenForProvider:({appId:e})=>{try{let t=Re.get(st(e));if("string"!=typeof t)return{token:null};{let n=new Mr(t);return n.isExpired()?(Re.del(st(e)),{token:null}):{token:n.value}}}catch(e){return console.error(e),{token:null}}}})),[]),Js=e=>{Gn("login",e);let t=Aa(),n=et(),{ready:r,user:a}=C(),{initLoginWithHeadlessOAuth:i,loginWithHeadlessOAuth:s,oAuthState:o,setOAuthState:l,isHeadlessOAuthLoading:d}=Ee(),u=h((async e=>{try{if(t.enabled&&"success"!==t.status)throw new fa(t.error,null,Ce.CAPTCHA_FAILURE);return await i(e.provider,t.token,e.disableSignup)}catch(e){throw l({status:"error",error:e}),e}}),[i,t]),p=h((async()=>{let e=ca();try{if(!e.inProgress)throw Error("Cannot login with OAuth because no OAuth flow is in progress");let t=e.provider;if(b(t)){if(a&&a.linkedAccounts.some((e=>e.type===t)))return console.warn("User is already logged in with this OAuth provider"),a}else if(a&&t in a&&a[t])return console.warn("User is already logged in with this OAuth provider"),a;if(e.popupFlow)return}catch(e){throw l({status:"error",error:e}),e}try{return await s(e)}catch(e){throw l({status:"error",error:e}),e}finally{da()}}),[s]);return c((()=>{let e=ca();r&&n&&e.inProgress&&!e.withPrivyUi&&!e.popupFlow&&p().catch((()=>{}))}),[r,n]),{initOAuth:u,loading:d,state:o}},Qs=e=>{let t=Aa(),{emailOtpState:n,setEmailOtpState:r,initLoginWithEmail:a,loginWithCode:i}=Ee();return{sendCode:h((async({email:n,disableSignup:i})=>{try{if(!n)throw Error("Email required to send OTP code");let e=await ka(t);return await a({email:n,captchaToken:e,disableSignup:i,withPrivyUi:!1})}catch(n){throw r({status:"error",error:n}),e?.onError?.(n.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),n}}),[a,t]),loginWithCode:h((async({code:t})=>{try{let{user:n,isNewUser:r,wasAlreadyAuthenticated:a,linkedAccount:s}=await i(t);e?.onComplete?.({user:n,isNewUser:r,wasAlreadyAuthenticated:a,loginMethod:"email",loginAccount:s})}catch(t){throw r({status:"error",error:t}),e?.onError?.(t.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),t}}),[i]),state:n}},Zs=e=>{let t=Aa(),{initSignupWithPasskey:n,signupWithPasskey:r,passkeyAuthState:a,setPasskeyAuthState:i}=Ee();return{signupWithPasskey:h((async()=>{try{let a=await ka(t);await n({captchaToken:a,withPrivyUi:!1});let{user:i,isNewUser:s,wasAlreadyAuthenticated:o,loginAccount:l}=await r();e?.onComplete?.({user:i,isNewUser:s,wasAlreadyAuthenticated:o,loginMethod:"passkey",loginAccount:l})}catch(t){throw i({status:"error",error:t}),e?.onError?.(t.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),t}}),[r,t]),state:a}},Xs=e=>{let t=Aa(),{initLoginWithPasskey:n,loginWithPasskey:r,passkeyAuthState:a,setPasskeyAuthState:i}=Ee();return{loginWithPasskey:h((async a=>{try{let i=await ka(t);await n({captchaToken:i,withPrivyUi:!1});let{user:s,isNewUser:o,wasAlreadyAuthenticated:l,loginAccount:c}=await r(a);e?.onComplete?.({user:s,isNewUser:o,wasAlreadyAuthenticated:l,loginMethod:"passkey",loginAccount:c})}catch(a){throw i({status:"error",error:a}),e?.onError?.(a.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),a}}),[r,t]),state:a}},eo=e=>{let{initLinkWithPasskey:t,linkWithPasskey:n,passkeyAuthState:r,setPasskeyAuthState:a}=Ee();return{linkWithPasskey:h((async()=>{try{await t();let r=await n();if(!r)throw Error("Error, user not found");let a=r.linkedAccounts.filter((e=>"passkey"===e.type)).sort(((e,t)=>t.latestVerifiedAt.getTime()-e.latestVerifiedAt.getTime()))[0];e?.onSuccess?.({user:r,linkMethod:"passkey",linkedAccount:a})}catch(t){throw a({status:"error",error:t}),e?.onError?.(t.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR,{linkMethod:"passkey"}),t}}),[n]),state:r}},to=e=>{let t=Aa(),{smsOtpState:n,setSmsOtpState:r,initLoginWithSms:a,loginWithCode:i}=Ee();return{sendCode:h((async({phoneNumber:n,disableSignup:i})=>{try{if(!n)throw Error("SMS required to send OTP code");let e=await ka(t);return await a({phoneNumber:n,captchaToken:e,disableSignup:i,withPrivyUi:!1})}catch(n){throw r({status:"error",error:n}),e?.onError?.(n.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),n}}),[a,t]),loginWithCode:h((async({code:t})=>{try{let{user:n,isNewUser:r,wasAlreadyAuthenticated:a,linkedAccount:s}=await i(t);e?.onComplete?.({user:n,isNewUser:r,wasAlreadyAuthenticated:a,loginMethod:"sms",loginAccount:s})}catch(t){throw r({status:"error",error:t}),e?.onError?.(t.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),t}}),[i]),state:n}},no=e=>{let{connectOrCreateWallet:t}=C();return Gn("connectOrCreateWallet",e),{connectOrCreateWallet:t}},ro=e=>{let t=Aa(),{siweState:n,setSiweState:r,linkWithSiwe:a,generateSiweMessage:i}=Ee();return{generateSiweMessage:h((async({address:t,chainId:n})=>{try{if(!t||!n)throw Error("wallet address and chainId required to generate nonce");return await i({address:t,chainId:n}).then((e=>e))}catch(t){throw r({status:"error",error:t}),e?.onError?.(t.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR,{linkMethod:"siwe"}),t}}),[i]),linkWithSiwe:h((async({signature:n,message:i,chainId:s,walletClientType:o,connectorType:l})=>{try{if(t.enabled&&"success"!==t.status)throw new fa(t.error,null,Ce.CAPTCHA_FAILURE);let{user:r,linkedAccount:c}=await a({message:i,signature:n,chainId:s,walletClientType:o,connectorType:l});c&&e?.onSuccess?.({user:r,linkMethod:"siwe",linkedAccount:c})}catch(n){throw r({status:"error",error:n}),e?.onError?.(n.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR,{linkMethod:"siwe"}),n}}),[a,t.status]),state:n}},ao=e=>{let t=Aa(),{siweState:n,setSiweState:r,client:a,generateSiweMessage:i,loginWithSiwe:s}=Ee();return{generateSiweNonce:h((async n=>{try{let e=await ka(t);r({status:"generating-message"});let i=await a.generateSiweNonce({address:n?.address,captchaToken:e});return r({status:"awaiting-signature"}),i}catch(n){throw r({status:"error",error:n}),e?.onError?.(n.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),n}}),[a,t]),generateSiweMessage:h((async({address:n,chainId:a})=>{try{let e=await ka(t);return await i({address:n,chainId:a,captchaToken:e})}catch(n){throw r({status:"error",error:n}),e?.onError?.(n.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),n}}),[i,t]),loginWithSiwe:h((async({message:n,signature:a,disableSignup:i,walletClientType:o,connectorType:l})=>{try{let r=await ka(t),{user:c,isNewUser:d}=await s({message:n,signature:a,captchaToken:r,disableSignup:i,walletClientType:o,connectorType:l});return e?.onComplete?.({user:c,isNewUser:d,wasAlreadyAuthenticated:!1,loginMethod:"siwe",loginAccount:null}),c}catch(n){throw r({status:"error",error:n}),e?.onError?.(n.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),n}}),[s,t]),state:n}},io=()=>{let e=Aa(),{client:t,setAuthenticated:n,setUser:r,setIsNewUser:a}=Ee(),{authenticated:i}=jn();return{generateSiwsMessage:h((async({address:n})=>{let r=await ka(e),a=await t.generateSiwsNonce({address:n,captchaToken:r});return On({address:n,nonce:a})}),[e,t]),loginWithSiws:h((async({message:e,signature:s,disableSignup:o,walletClientType:l,connectorType:c})=>{if(i)throw Error("User already authenticated");let{user:d,isNewUser:u}=await t.authenticateWithSiws({message:e,signature:s,walletClientType:l,connectorType:c,mode:o?"no-signup":"login-or-sign-up",messageType:"plain"});if(!d)throw Error("Authentication failed - no user returned");return r(d),a(u||!1),n(!0),d}),[i,t,n,r,a])}},so=()=>{let e=Aa(),{client:t,setUser:n,refreshSessionAndUser:r}=Ee(),{authenticated:a}=jn();return{generateSiwsMessage:h((async({address:n})=>{let r=await ka(e),a=await t.generateSiwsNonce({address:n,captchaToken:r});return On({address:n,nonce:a})}),[e,t]),linkWithSiws:h((async({signature:i,message:s,walletClientType:o,connectorType:l})=>{if(!a)throw Error("User must be authenticated before linking");await ka(e);let c=await t.linkWithSiws({message:s,signature:i,walletClientType:o,connectorType:l,messageType:"plain"}),d=(e=>{if(!e)return;let t=e.linkedAccounts;return t&&0!==t.length?t[t.length-1]:void 0})(c=await r()??c)||null;return n(c||null),{user:c,linkedAccount:d}}),[a,e,t,r,n])}};function oo(){let{signTransaction:e}=a(N);return{signTransaction:e}}function lo(e){let{linkEmail:t,linkPhone:n,linkWallet:r,linkGoogle:i,linkApple:s,linkTwitter:o,linkTwitch:l,linkDiscord:c,linkGithub:d,linkLinkedIn:u,linkTiktok:h,linkLine:p,linkSpotify:w,linkInstagram:m,linkTelegram:y,linkFarcaster:g,linkPasskey:f}=a(N);return Gn("linkAccount",e),{linkEmail:t,linkPhone:n,linkWallet:r,linkGoogle:i,linkApple:s,linkTwitter:o,linkTwitch:l,linkDiscord:c,linkGithub:d,linkLinkedIn:u,linkTiktok:h,linkLine:p,linkSpotify:w,linkInstagram:m,linkFarcaster:g,linkTelegram:y,linkPasskey:f}}function co(e){let{updateEmail:t,updatePhone:n}=a(N);return Gn("update",e),{updateEmail:t,updatePhone:n}}const uo=e=>{let{user:t}=C(),{loginWithCode:n,emailOtpState:r,setEmailOtpState:a,client:i,inProgressAuthFlowRef:s,inProgressLoginOrLinkMethodRef:o}=Ee();return{state:r,sendCode:h((async({newEmailAddress:n})=>{try{if(!t?.email)throw Error("User is required to have an email address to update it.");let e=new Qr(t.email.address,n);i.startAuthFlow(e),await e.sendCodeEmail({withPrivyUi:!1})}catch(n){a({status:"error",error:n}),e?.onError?.(n.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR,{linkMethod:"email"})}}),[t?.email]),verifyCode:h((async({code:r})=>{try{if(!t?.email)throw Error("User is required to have an email address to update it.");s.current="update",o.current="email";let{user:a,linkedAccount:i}=await n(r);return e?.onSuccess?.({user:a,updateMethod:"email",updatedAccount:i}),{user:a}}catch(r){a({status:"error",error:r}),e?.onError?.(r.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR,{linkMethod:"email"})}}),[t?.email])}},ho=()=>{let{openModal:e,closePrivyModal:t,privy:n}=Ee(),{setModalData:r}=_();return l((()=>({fund:a=>new Promise(((i,s)=>{r({FundWithBankDepositScreen:{onSuccess:async()=>{await t({shouldCallAuthOnSuccess:!1,isSuccess:!0}),i({})},onFailure:async e=>{await t({shouldCallAuthOnSuccess:!1,isSuccess:!1}),s(e)},getCustomer:async({kycRedirectUrl:e})=>{let t={provider:a.provider};return e&&(t.kyc_redirect_url=e),await n.fetchPrivyRoute({path:"/api/v1/fiat/customer",method:"GET"},{query:t})},createOrUpdateCustomer:async({hasAcceptedTerms:e,kycRedirectUrl:t})=>await n.fetchPrivyRoute({path:"/api/v1/fiat/customer",method:"PUT"},{body:{provider:a.provider,has_accepted_terms:e,kyc_redirect_url:t}}),getOrCreateVirtualAccount:async e=>await n.fetchPrivyRoute({path:"/api/v1/fiat/customer/virtual_accounts",method:"PUT"},{body:e}),opts:a}}),e("FundWithBankDepositScreen")}))})),[])},po=()=>{let{connectCoinbaseSmartWallet:e}=Ee();return{connectCoinbaseSmartWallet:e}},wo=()=>{let{connectBaseAccount:e}=Ee();return{connectBaseAccount:e}},mo=()=>{let{baseAccountSdk:e}=Ee();return{baseAccountSdk:e}},yo=()=>{let{setModalData:e}=_(),{openModal:t,privy:n,closePrivyModal:r}=Ee(),{user:a}=C();return l((()=>({verify:async({standalone:i=!0}={standalone:!0})=>new Promise(((s,o)=>a?0===a.mfaMethods.length?s():(e((e=>({...e,mfaVerify:{onSuccess:async()=>{i?await r({shouldCallAuthOnSuccess:!1,isSuccess:!0}):Ua.setState({inProgressMfaFlow:void 0}),s()},onFailure:async e=>{i?await r({shouldCallAuthOnSuccess:!1,isSuccess:!1}):Ua.setState({inProgressMfaFlow:void 0}),o(e)},sendSmsCode:async()=>{throw Error("Not enabled")},verifySmsCode:async()=>{throw Error("Not enabled")},verifyTotpCode:async e=>{await n.fetchPrivyRoute(_r,{body:{code:e}})},generateOptions:async()=>_s((await n.fetchPrivyRoute(Cr,{body:{}})).options),verifyPasskey:async e=>{let t=await import("@simplewebauthn/browser"),r=await t.startAuthentication({optionsJSON:e});await n.fetchPrivyRoute(Tr,{body:{authenticator_response:qi(r)}})}}}))),void(i?t("MfaAuthVerifyFlowScreen"):Ua.setState({inProgressMfaFlow:"auth"}))):o(Error("Must be logged in to verify MFA"))))})),[n,e,t,r])},go=()=>{let e=Ze(),{setModalData:t}=_(),{verify:n}=yo(),{openModal:r,privy:a,closePrivyModal:i,refreshSessionAndUser:s,setUser:o}=Ee();return l((()=>({enroll:async l=>new Promise(((c,d)=>{t({mfaEnroll:{onSuccess:async e=>{await i({shouldCallAuthOnSuccess:!1,isSuccess:!0}),c(e)},onFailure:async e=>{await i({shouldCallAuthOnSuccess:!1,isSuccess:!1}),d(e)},onBack:l?.onBack?async()=>{await i({shouldCallAuthOnSuccess:!1,isSuccess:!1}),d(Error("User canceled MFA enrollment flow.")),l.onBack?.()}:void 0,verify:()=>n({standalone:!1}),shouldUnlinkOnUnenrollMfa:!0,mfaMethods:e.mfa.methods,sendSmsCode:async()=>{throw Error("Not enabled")},enrollSms:async()=>{throw Error("Not enabled")},unenrollSms:async()=>{throw Error("Not enabled")},generateTotpSecret:async()=>await a.fetchPrivyRoute(Ir,{body:{}}),enrollTotp:async e=>{await a.fetchPrivyRoute(Er,{body:{code:e}});let t=await s();return o(t),t},unenrollTotp:async()=>{await a.fetchPrivyRoute(br,{body:{}});let e=await s();return o(e),e},enrollPasskey:async e=>{await a.fetchPrivyRoute(Sr,{body:{credential_ids:e,remove_for_login:!0}});let t=await s();return o(t),t}}}),r("MfaAuthEnrollmentFlowScreen")}))})),[a,t,r,i])},fo=()=>{let{startCrossAppAuthFlow:e,unlinkCrossAppAccount:t,signMessageWithCrossAppWallet:n,signTypedDataWithCrossAppWallet:r,sendTransactionWithCrossAppWallet:a,signTransactionWithCrossAppWallet:i}=C();return{loginWithCrossAppAccount:({appId:t})=>e({appId:t,action:"login"}),linkCrossAppAccount:({appId:t})=>e({appId:t,action:"link"}),unlinkCrossAppAccount:t,signMessage:n,signTypedData:r,sendTransaction:a,signTransaction:i}};function vo(e){let{sendTransaction:t}=a(N);return Gn("sendTransaction",e),{sendTransaction:t}}function Ao(){let e=Ze(),t=Yn(),{client:n,setUser:r,setAuthenticated:a,setIsNewUser:i,initializeWalletProxy:s}=Ee(),{create:o}=Hn();return{createGuestAccount:async()=>{if(!e.id||!n)throw Error("SDK not yet ready");n.startAuthFlow(new Ss(e.id));try{let l=await n.authenticate(),c=l.user,d=l.isNewUser??!1;if(!c)throw new ke("Unable to authenticate guest account");let u=await n.getAccessToken(),h=await s(mt);if(u&&h)try{let t=Gi(c,e.embeddedWallets.ethereum.createOnLogin),n=Ji(c,e.embeddedWallets.solana.createOnLogin);t&&n?(c=(await o({chainType:"ethereum",latestUser:c})).user,c=(await o({chainType:"solana",latestUser:c})).user):n?c=(await o({chainType:"solana",latestUser:c})).user:t?c=(await o({chainType:"ethereum",latestUser:c})).user:r(c)}catch(e){r(c),console.warn("Unable to create embedded wallet for guest account")}return i(d),a(!0),t("login","onComplete",{user:c,isNewUser:d,wasAlreadyAuthenticated:!1,loginMethod:"guest",loginAccount:null}),c}catch(e){throw t("login","onError",e.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),e}}}}function ko(e){let{setWalletRecovery:t}=a(N);return Gn("setWalletRecovery",e),{setWalletRecovery:t}}function To(e){let{signMessage:t}=a(N);return Gn("signMessage",e),{signMessage:t}}const Co=()=>{let{ready:e,wallets:t}=ye(),{user:n}=C(),{rpcConfig:r,chains:a,appId:i}=Ee();return{signAuthorization:h((async(s,o)=>{let l;if(!n)throw Error("User must be authenticated before signing with a Privy wallet");if(!e)throw Error("Wallets are not ready");let c=o?.address??I(n)?.address??cr,d=t.find((e=>dr(e.address)===dr(c)));if(!d)throw Error("Signing wallet not found.");let u=s.chainId??Number(d.chainId.split(":")[1]);if(0===u)l={chainId:0,address:s.contractAddress,nonce:s.nonce??0};else{let e=a.find((e=>e.id===u));if(!e)throw Error("Error, chain not configured in PrivyProvider config");let t=ur({account:c,chain:e,transport:hr(fr(e,r,i))});l=await t.prepareAuthorization({...s})}let h=await d.getEthereumProvider(),p=await h.request({method:"secp256k1_sign",params:[_t(l)]});return{...l,...pr(p)}}),[e,t,n,a])}};function _o(e){let{signTypedData:t}=a(N);return Gn("signTypedData",e),{signTypedData:t}}const So=async({wallet:e})=>{let t=await e.getEthereumProvider();return Or({address:e.address,sign:async({hash:n})=>{if("privy"!==e.walletClientType)throw new y({error:"Unprefixed signing is not supported by external wallets.",code:"unsupported_wallet_type"});return await t.request({method:"secp256k1_sign",params:[n]})},signMessage:async({message:n})=>{let r;if("string"==typeof n)r=n;else{if("string"!=typeof n.raw)throw new y({error:"signMessage only supports string messages or {raw: Hex} format",code:"invalid_input"});r=n.raw}return await t.request({method:"personal_sign",params:[r,e.address]})},signTypedData:async n=>await t.request({method:"eth_signTypedData_v4",params:[e.address,n]}),signTransaction:async e=>await t.request({method:"eth_signTransaction",params:[e]}),signAuthorization:async n=>{if("privy"!==e.walletClientType)throw new y({error:"EIP-7702 authorization signing is not supported by external wallets.",code:"unsupported_wallet_type"});let r={chainId:n.chainId,address:n.contractAddress??n.address,nonce:n.nonce},a=_t(r),i=pr(await t.request({method:"secp256k1_sign",params:[a]}));return{...r,...i}}})},bo=()=>{let{wallets:e}=ye();return l((()=>({wrapFetchWithPayment:({walletAddress:t,fetch:n,maxValue:r=BigInt(1e5),paymentRequirementsSelector:a=Pr,config:i})=>{let s=t||e[0]?.address;if(!s)throw new Ur("No wallet available for payment");let o=e.find((e=>Nr(e.address,s)));if(!o)throw new Ur(`Wallet ${s} not found in connected wallets`);return async(e,t)=>{let s=await n(e,t);if(402!==s.status)return s;if(t?.__is402Retry)throw Error("Payment already attempted for this request");let{x402Version:l,accepts:c}=await s.json(),d=a(c,void 0,"exact");if(BigInt(d.maxAmountRequired)>r)throw new Ur("Payment amount exceeds maximum allowed");let u=await So({wallet:o}),h=await Wr(u,l,d,i),p={...t,headers:{...t?.headers||{},"X-PAYMENT":h,"Access-Control-Expose-Headers":"X-PAYMENT-RESPONSE"},__is402Retry:!0};return await n(e,p)}}})),[e])},Eo=()=>{let{isModalOpen:e}=a(N);return{isOpen:e}};function Io(e){let{getAccessToken:t}=a(N);return Gn("accessToken",e),{getAccessToken:t}}function Po(e){let{authenticated:t,user:n}=C(),{initLoginWithOAuth:r}=Ee(),a=Yn();return Gn("oAuthAuthorization",e),{reauthorize:e=>Wo(t,n,r,a,e.provider)}}let Wo=async(e,t,n,r,a)=>{if(!e)throw r("linkAccount","onError",Ce.MUST_BE_AUTHENTICATED,{linkMethod:a}),new ke("User must be authenticated before linking an account.");if(!t?.linkedAccounts.some((e=>e.type.includes(a))))throw new ke(`OAuth account of type ${a} not linked to the account.`);await n(a)};function Uo(e){let{client:t}=Ee(),[n,r]=o({status:"initial"});return{linkWithCustomJwt:h((async n=>{try{r({status:"initial"}),t.startAuthFlow(new $i(n)),r({status:"loading"});let{user:a}=await t.link();if(!a)throw Error("Error, user not found");let i=a.linkedAccounts.filter((e=>"custom_auth"===e.type)).sort(((e,t)=>t.latestVerifiedAt.getTime()-e.latestVerifiedAt.getTime())).at(0);return r({status:"done"}),e?.onSuccess?.({user:a,linkMethod:"custom",linkedAccount:i}),{user:a}}catch(n){throw r({status:"error",error:n}),e?.onError?.(n.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR,{linkMethod:"custom"}),n}}),[t.startAuthFlow,t.link]),state:n}}const No=e=>{let t=es((e=>e.jwtAuthFlowState));return Gn("customAuth",e),{status:t}};function Oo({isAuthenticated:e,isLoading:t,...n}){let r=s();c((()=>{t||r.current?.()}),[e,t]);let a=h((e=>(r.current=e,()=>{r.current=void 0})),[]);return Xi({...n,subscribe:a})}function Ro(){let{getFarcasterSignerPublicKey:e,signFarcasterMessage:t,requestFarcasterSignerFromWarpcast:n}=C();return{getFarcasterSignerPublicKey:e,signFarcasterMessage:t,requestFarcasterSignerFromWarpcast:n}}const Mo=()=>{let{revokeDelegatedWallets:e,delegateWallet:t}=Ee();return{delegateWallet:async({address:e,chainType:n})=>await t({address:e,chainType:n,showDelegationUIs:!0}),revokeWallets:async()=>await e({showDelegationUIs:!0})}},xo=()=>{let{user:e}=C(),t=Ee(),{signWithUserSigner:n}=Rr(),r=async({wallet:r,additional_signers:a})=>{let i=await t.client.getAccessToken();if(!e||!i)throw new ke("User must be authenticated and have an embedded wallet to delegate actions.");if(!r.id)throw new ke("Wallet to add signers to must have ID on server");if(!t.walletProxy)throw new ke("Wallet proxy not initialized.");await f(t.privy,{wallet_id:r.id},n,{additional_signers:a})};return{addSessionSignersInternal:async({address:n,signers:a})=>{let i=await t.client.getAccessToken();if(!e||!i)throw new ke("User must be authenticated and have an embedded wallet to add a session signer.");let s=t.walletProxy??await t.initializeWalletProxy(15e3);if(!s)throw new ke("Wallet proxy not initialized.");let o=R(e,n);if(!o)throw new ke("Address to add signers too is not associated with current user.");if(E(o)){if(0===a.length)throw new ke("Must specify at least one signer to add.");let e=[...(await g(t.privy,{wallet_id:o.id})).additional_signers,...me(a)];await r({wallet:o,additional_signers:e})}else{if(o.delegated)return{user:e};if(a.length>0)throw new ke("Specifying signers in addSessionSigners is only supported for TEE execution and this app uses On-device execution. Pass an empty array for signers instead. Learn more https://docs.privy.io/recipes/tee-wallet-migration-guide");let r=fi({address:n,user:e}),l=vi({address:n,user:e});await t.recoverEmbeddedWallet({address:n}),await s.createDelegatedAction({accessToken:i,rootWallet:l,delegatedWallets:[r]})}let l=await t.refreshSessionAndUser();if(!l)throw Error("Could not refresh user");return{user:l}},removeSessionSignersInternal:async({address:n})=>{let a=await t.client.getAccessToken();if(!e||!a)throw new ke("User must be authenticated and have an embedded wallet to delegate actions.");if(!(t.walletProxy??await t.initializeWalletProxy(15e3)))throw new ke("Wallet proxy not initialized.");let i=R(e,n);if(!i)throw new ke("Address to remove signers from is not associated with current user.");E(i)?await r({wallet:i,additional_signers:[]}):await t.client.revokeDelegatedWallet();let s=await t.refreshSessionAndUser();if(!s)throw Error("Could not refresh user");return{user:s}}}},Fo=()=>{let{addSessionSignersInternal:e,removeSessionSignersInternal:t}=xo();return{addSessionSigners:async({address:t,signers:n})=>e({address:t,signers:n}),removeSessionSigners:async({address:e})=>t({address:e})}},Do=()=>{let{addSessionSignersInternal:e,removeSessionSignersInternal:t}=xo();return{addSigners:async({address:t,signers:n})=>e({address:t,signers:n}),removeSigners:async({address:e})=>t({address:e})}},Lo=()=>{let{signWithUserSigner:e}=Rr();return l((()=>({async generateAuthorizationSignature(t){let{targetAppId:n,...r}=t,{signature:a}=await v((async({message:t})=>e({message:t,targetAppId:n})),r);return{signature:a}}})),[e])},jo=()=>{let{setUser:e,client:t}=a(Pe),{user:n}=a(N);return{user:n,refreshUser:h((async()=>{let n=await(t?.updateUserAndIdToken());return e(n??null),n}),[t,e])}};function qo(){let{user:e}=C(),{client:t}=Ee(),n=Ze(),r=h((async({address:r,recipientPublicKey:a})=>{if(!e)throw new ke("User must be authenticated before exporting their wallet");let i=await t.getAccessToken();if(!i)throw new ke("Must have valid access token");let s=R(e,r);if(!s)throw new ke("User does not have a wallet with this address");if(!E(s))throw new ke("Client export is only supported for unified stack wallets. On-device wallets are not supported.");return function(e,t,n){let r=document.createElement("iframe");return r.style.display="none",r.src=e,document.body.appendChild(r),new Promise(((e,a)=>{let i=null,s=()=>{null!==i&&(clearTimeout(i),i=null),window.removeEventListener("message",o),r.parentNode&&r.parentNode.removeChild(r)},o=t=>{var r;t.origin===n&&"object"==typeof(r=t.data)&&null!==r&&"type"in r&&("CLIENT_EXPORT_RESPONSE"===r.type||"CLIENT_EXPORT_ERROR"===r.type)&&(s(),"CLIENT_EXPORT_ERROR"===t.data.type?a(new ke(t.data.error)):e({ciphertext:t.data.ciphertext,encapsulatedKey:t.data.encapsulatedKey,chainType:t.data.chainType}))};window.addEventListener("message",o),r.onload=()=>{r.contentWindow?.postMessage({type:"CLIENT_EXPORT_REQUEST",recipientPublicKey:t},n)},i=setTimeout((()=>{s(),a(new ke("Wallet export timed out"))}),3e4)}))}(or({origin:t.apiUrl,path:`/apps/${n.id}/embedded-wallets/export`,query:{v:"1-unified",wallet_id:s.id,client_id:n.appClientId,mode:"client-export"},hash:{token:i}}),a,t.apiUrl)}),[e,t,n.id,n.appClientId]);return l((()=>({getWalletPrivateKey:r})),[r])}const zo=e=>{let t=Aa(),{initLoginWithTelegram:n,loginWithTelegram:r,telegramAuthState:a,setTelegramAuthState:i}=Ee();return{login:h((async a=>{try{if(t.enabled&&"success"!==t.status)throw new fa(t.error,null,Ce.CAPTCHA_FAILURE);await n(t.token,a?.disableSignup);let{user:i,isNewUser:s,loginAccount:o,wasAlreadyAuthenticated:l}=await r({intent:"login"});e?.onComplete?.({user:i,isNewUser:s,wasAlreadyAuthenticated:l,loginMethod:"telegram",loginAccount:o})}catch(a){throw i({status:"error",error:a}),e?.onError?.(a.privyErrorCode||Ce.UNKNOWN_AUTH_ERROR),a}}),[n,r,t]),state:a}},Ho=()=>{let{revokeDelegatedWallets:e,delegateWallet:t}=Ee();return{delegateWallet:async({address:e,chainType:n})=>await t({address:e,chainType:n,showDelegationUIs:!1}),revokeWallets:async()=>await e({showDelegationUIs:!1})}},Bo=Ka;export{eo as $,Ri as A,us as B,fa as C,Dr as D,Lr as E,Pi as F,hs as G,Fr as H,Ds as I,Hs as J,Ia as K,vs as L,Bs as M,Rs as N,Fs as O,ei as P,$s as Q,Zr as R,wa as S,Gs as T,ks as U,Ys as V,Za as W,Js as X,Qs as Y,Zs as Z,Xs as _,Aa as a,to as a0,no as a1,ro as a2,ao as a3,io as a4,so as a5,oo as a6,Wa as a7,lo as a8,co as a9,Lo as aA,jo as aB,qo as aC,zo as aD,Ho as aE,Bo as aF,Ka as aG,So as aH,Li as aI,uo as aa,ho as ab,po as ac,wo as ad,mo as ae,yo as af,go as ag,fo as ah,vo as ai,Ao as aj,ko as ak,To as al,Co as am,_o as an,bo as ao,Eo as ap,Io as aq,Po as ar,Uo as as,No as at,Xi as au,Oo as av,Ro as aw,Mo as ax,Fo as ay,Do as az,pa as b,Wi as c,Ks as d,ni as e,oi as f,ii as g,ai as h,li as i,si as j,Ji as k,da as l,Ca as m,ri as n,ia as o,Di as p,sa as q,oa as r,Gi as s,Fi as t,Vs as u,Zi as v,Ii as w,Mi as x,Ni as y,Vr as z};
|