UNPKG

@privy-io/expo

Version:

Expo client for the Privy Auth API

1 lines • 84.9 kB
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { newObj[key] = obj[key]; } } } newObj.default = obj; return newObj; } } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }var _chunkQTVIWU3Njs = require('./chunk-QTVIWU3N.js');var _react = require('react'); var _react2 = _interopRequireDefault(_react);var _zustand = require('zustand');var ft=_zustand.create.call(void 0, ()=>({status:"disconnected"})),he=()=>ft.getState().onNeedsRecovery,Fr= exports.f =e=>{_react.useEffect.call(void 0, ()=>{ft.setState({onNeedsRecovery:e==null?void 0:e.onNeedsRecovery})},[e==null?void 0:e.onNeedsRecovery])};var _expocrypto = require('expo-crypto');var _jssdkcore = require('@privy-io/js-sdk-core'); var _jssdkcore2 = _interopRequireDefault(_jssdkcore);var gt={name:"@privy-io/expo",version:"0.69.0",description:"Expo client for the Privy Auth API",keywords:["authentication","authorization","identity","privacy","privy","user data","react-native","expo","web3"],homepage:"https://docs.privy.io",bugs:{url:"https://privy.io/slack"},license:"Apache-2.0",author:"privy.io",exports:{".":{require:"./dist/index.js",import:"./dist/esm/index.js",types:"./dist/index.d.ts"},"./passkey":{require:"./dist/passkey.js",import:"./dist/esm/passkey.js",types:"./dist/passkey.d.ts"},"./smart-wallets":{require:"./dist/smart-wallets.js",import:"./dist/esm/smart-wallets.js",types:"./dist/smart-wallets.d.ts"},"./extended-chains":{require:"./dist/extended-chains.js",import:"./dist/esm/extended-chains.js",types:"./dist/extended-chains.d.ts"},"./ui":{require:"./dist/ui.js",import:"./dist/esm/ui.js",types:"./dist/ui.d.ts"},"./connectors":{require:"./dist/connectors.js",import:"./dist/esm/connectors.js",types:"./dist/connectors.d.ts"}},main:"./dist/esm/index.js",source:"./src/index.ts",types:"./dist/index.d.ts",files:["dist/**/*","LICENSE","README.md"],scripts:{build:"tsup --clean --minify","check-types":"tsc --noEmit",clean:"rm -rf dist .turbo *.tsbuildinfo","clean:reset":"rm -rf dist .turbo node_modules *.tsbuildinfo",dev:"tsup --watch",format:"oxlint src --fix","generate-types":"tsup --dts-only",lint:"oxlint src",test:"jest"},browserslist:["defaults","node >= 18","not op_mini all"],dependencies:{"@privy-io/api-types":"catalog:","@privy-io/encoding":"workspace:^","@privy-io/js-sdk-core":"workspace:*","@privy-io/routes":"workspace:*","@scure/base":"^1.2.4","react-fast-compare":"^3.2.2",tweetnacl:"^1.0.3",zustand:"^5.0.4"},devDependencies:{oxlint:"catalog:package-new","oxlint-tsgolint":"catalog:package-new","@privy-io/eslint-plugin-privy-rules":"workspace:*","@privy-io/tsconfig":"workspace:*","@simplewebauthn/types":"9.0.1","@solana/web3.js":"^1.98.0","@svgr/core":"^8.1.0","@svgr/plugin-jsx":"^8.1.0","@svgr/plugin-svgo":"^8.1.0","@testing-library/react-native":"^13.1.0","@tsconfig/node16-strictest-esm":"catalog:","@types/jest":"^29.1.2","@types/react":"catalog:","expo-apple-authentication":"55.0.13","expo-application":"55.0.14","expo-clipboard":"55.0.13","expo-crypto":"55.0.14","expo-linking":"55.0.14","expo-secure-store":"55.0.13","expo-web-browser":"55.0.14",jest:"catalog:","jest-expo":"55.0.16","lucide-react-native":"^0.474.0",react:"catalog:","react-native":"0.83.6","react-native-webview":"13.16.0","react-test-renderer":"19.2.0",tsup:"^6.2.3",typescript:"catalog:"},peerDependencies:{"@privy-io/expo-native-extensions":"workspace:*","expo-apple-authentication":"*","expo-application":"*","expo-clipboard":"*","expo-crypto":"*","expo-linking":"*","expo-secure-store":"*","expo-web-browser":"*",permissionless:"^0.2.47",react:"*","react-native":"*","react-native-passkeys":"^0.4.0","react-native-qrcode-styled":"0.3.3","react-native-safe-area-context":"*","react-native-svg":"*","react-native-webview":"*",viem:"2.52.0"},peerDependenciesMeta:{permissionless:{optional:!0},viem:{optional:!0},"react-native-svg":{optional:!0},"expo-apple-authentication":{optional:!0},"expo-clipboard":{optional:!0},"expo-linking":{optional:!0},"expo-secure-store":{optional:!0},"expo-web-browser":{optional:!0},"react-native-qrcode-styled":{optional:!0},"react-native-safe-area-context":{optional:!0}},publishConfig:{access:"public"}};var ht=({appId:e,clientId:t,storage:r=_chunkQTVIWU3Njs.g,supportedChains:o,baseUrl:n,logLevel:a,logger:i})=>new (0, _jssdkcore2.default)({appId:e,clientId:t,supportedChains:o,storage:_chunkQTVIWU3Njs.f.call(void 0, r),sdkVersion:`expo:${gt.version}`,nativeAppIdentifier:_chunkQTVIWU3Njs.e.call(void 0, ),crypto:{digest:_expocrypto.digest,randomUUID:_expocrypto.randomUUID},baseUrl:n,logLevel:a,logger:i});var _reactnative = require('react-native');var _reactfastcompare = require('react-fast-compare'); var _reactfastcompare2 = _interopRequireDefault(_reactfastcompare);var we=_zustand.create.call(void 0, ()=>{}),wt=e=>we.setState(t=>_reactfastcompare2.default.call(void 0, t,e)?t:e),x= exports.a =we.getState;var _reactnativewebview = require('react-native-webview'); var _reactnativewebview2 = _interopRequireDefault(_reactnativewebview);var _exposecurestore = require('expo-secure-store'); var F = _interopRequireWildcard(_exposecurestore);function vt(e){return typeof e!="object"||e===null||!("event"in e&&typeof e.event=="string")||!("id"in e&&typeof e.id=="string")||!("data"in e&&typeof e.data=="object")||e.data===null?!1:e.event.startsWith("app:secure-storage:")}function bt(e){return _chunkQTVIWU3Njs.d.call(void 0, this,null,function*(){switch(e.event){case"app:secure-storage:get":{let{key:t}=e.data,r=yield F.getItemAsync(Le(t),{keychainAccessible:F.AFTER_FIRST_UNLOCK_THIS_DEVICE_ONLY}).catch(o=>(console.warn("Failed to get the value from secure store",o),null));return{event:e.event,id:e.id,data:{value:r}}}case"app:secure-storage:remove":{let{key:t}=e.data,r=yield F.deleteItemAsync(Le(t),{keychainAccessible:F.AFTER_FIRST_UNLOCK_THIS_DEVICE_ONLY}).then(()=>!0).catch(o=>(console.warn("Failed to remove the value from secure store",o),!1));return{event:e.event,id:e.id,data:{success:r}}}case"app:secure-storage:set":{let{key:t,value:r}=e.data,o=yield F.setItemAsync(Le(t),r,{keychainAccessible:F.AFTER_FIRST_UNLOCK_THIS_DEVICE_ONLY}).then(()=>!0).catch(n=>(console.warn("Failed to write the value to secure store",n),!1));return{event:e.event,id:e.id,data:{success:o}}}}})}var Le=e=>e.replaceAll(":","-");var z=_zustand.createStore.call(void 0, )(()=>({user:null,proxyStatus:"loading"}));function b(){return z.getState().user}var pa=z.subscribe.bind(z);function Fe(e){z.setState(({user:t})=>_reactfastcompare2.default.call(void 0, t,e)?{}:{user:e})}var Te=e=>z.setState({proxyStatus:e});function A(){return _zustand.useStore.call(void 0, z,e=>e.user)}function ya(){return _zustand.useStore.call(void 0, z,e=>!!e.user)}function j(){return _zustand.useStore.call(void 0, z,e=>e.proxyStatus!=="loading")}var Yr={shouldUseAppBackedStorage:!0},St=({client:e,isClientReady:t})=>{let r=_react.useRef.call(void 0, null);_react.useEffect.call(void 0, ()=>{let n=_reactnative.AppState.addEventListener("change",a=>_chunkQTVIWU3Njs.d.call(void 0, void 0,null,function*(){a==="active"&&((yield e.embeddedWallet.ping(500))||(Te("reloading"),e.embeddedWallet.reload()))}));return()=>n.remove()},[e]);let o=_react.useCallback.call(void 0, n=>_chunkQTVIWU3Njs.d.call(void 0, void 0,null,function*(){var s;let{data:a}=n.nativeEvent,i=JSON.parse(a);if(vt(i)){let d=yield bt(i);(s=r.current)==null||s.postMessage(JSON.stringify(d));return}e.embeddedWallet.onMessage(i)}),[e]);return t?_react2.default.createElement(_reactnativewebview2.default,{style:{flex:1},ref:n=>{n&&(e.setMessagePoster(n),r.current=n)},cacheEnabled:!1,cacheMode:"LOAD_NO_CACHE",injectedJavaScriptObject:Yr,source:{uri:e.embeddedWallet.getURL()},webviewDebuggingEnabled:e.logger.level==="DEBUG",onLoad:()=>Te("loaded"),onError:console.error,onMessage:o}):null};function Ct(a){return _chunkQTVIWU3Njs.d.call(void 0, this,arguments,function*({client:e,setSolanaWallet:t,createSolanaWalletCallbacks:r,setSolanaRecoveryFlowState:o,opts:n}){var i,s,d;t({status:"creating"});try{let{user:c}=yield e.user.get(),u=_jssdkcore.getAllUserEmbeddedSolanaWallets.call(void 0, c),m=u[0],p=(i=_jssdkcore.getUserEmbeddedEthereumWallet.call(void 0, c))!=null?i:void 0;if(n!=null&&n.recoveryMethod&&n.recoveryMethod!=="privy")throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_creation_error",error:"Unsupported recovery method for solana wallet."});if(!(n!=null&&n.createAdditional)&&m)throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_creation_error",error:"Solana wallet already exists for this user. Set `createAdditional` to `true` to create another wallet"});let h,g;if(m){let f=p!=null?p:m,{entropyId:w,entropyIdVerifier:S}=_jssdkcore.getEntropyDetailsFromAccount.call(void 0, f),C=Math.max(...u.map(P=>P.wallet_index),0)+1,k=yield e.embeddedWallet.add({chainType:"solana",entropyId:w,entropyIdVerifier:S,hdWalletIndex:C}),W=_jssdkcore.getAllUserEmbeddedSolanaWallets.call(void 0, k.user).find(P=>P.wallet_index===C);if(!W)throw new (0, _jssdkcore.PrivyClientError)({error:"Embedded wallet account not created",code:"embedded_wallet_creation_error"});h=yield e.embeddedWallet.getSolanaProvider(W,w,S),g=k.user}else{let f=yield e.embeddedWallet.createSolana({ethereumAccount:p}),w=_jssdkcore.getAllUserEmbeddedSolanaWallets.call(void 0, f.user).find(W=>W.wallet_index===0);if(!w)throw new (0, _jssdkcore.PrivyClientError)({error:"Embedded wallet account not created",code:"embedded_wallet_creation_error"});let S=p!=null?p:w,{entropyId:C,entropyIdVerifier:k}=_jssdkcore.getEntropyDetailsFromAccount.call(void 0, S);h=yield e.embeddedWallet.getSolanaProvider(w,C,k),g=f.user}let v=_jssdkcore.getAllUserEmbeddedSolanaWallets.call(void 0, g)[0];if(!v)throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_creation_error",error:"Unknown error creating solana wallet"});return(d=(s=r.current)==null?void 0:s.onSuccess)==null||d.call(s,h),t({status:"connected",publicKey:v.public_key}),o({status:"initial"}),h}catch(c){let u=c instanceof Error?c.message:"Error creating embedded wallet";throw t({status:"error",error:u}),o({status:"initial"}),new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_creation_error",error:u})}})}function be(u){return _chunkQTVIWU3Njs.d.call(void 0, this,arguments,function*({client:e,account:t,setWallet:r,recoverWalletCallbacks:o,recoveryMethod:n,setRecoveryFlowState:a,password:i,recoveryKey:s,recoveryToken:d,recoverySecretOverride:c}){var m,p,h,g;if(!t)throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_does_not_exist",error:"Embedded wallet does not exist"});switch(n){case"user-passcode":if(!i)throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_recovery_error",error:"password is required for user-passcode recovery method"});break;case"google-drive":if(!d)throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_recovery_error",error:"Recovery token is required for google-drive recovery method"});break;case"icloud":if(!c)throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_recovery_error",error:"Record name is required for icloud recovery method"});break;case"recovery-encryption-key":if(!s)throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_recovery_error",error:"recoveryKey is required for recovery-encryption-key recovery method"});break}r({status:"connecting",account:t});try{let v=yield e.embeddedWallet.getProvider(t,i,d,c,s);return r({status:"connected",provider:v,account:t}),a({status:"initial"}),(p=(m=o.current)==null?void 0:m.onSuccess)==null||p.call(m,v),v}catch(v){r({status:"needs-recovery",account:t}),a({status:"initial"});let f=new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_recovery_error",error:v instanceof Error?v.message:"Error recovering embedded wallet"});throw(g=(h=o.current)==null?void 0:h.onError)==null||g.call(h,f),f}})}function _t(s){return _chunkQTVIWU3Njs.d.call(void 0, this,arguments,function*({client:e,account:t,entropyId:r,entropyIdVerifier:o,setSolanaWallet:n,recoverSolanaWalletCallbacks:a,setSolanaRecoveryFlowState:i}){var d,c,u,m;n({status:"connecting"});try{let p=yield e.embeddedWallet.getSolanaProvider(t,r,o);return n({status:"connected",publicKey:p._publicKey}),i({status:"initial"}),(c=(d=a.current)==null?void 0:d.onSuccess)==null||c.call(d,p),p}catch(p){n({status:"needs-recovery"}),i({status:"initial"});let h=new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_recovery_error",error:p instanceof Error?p.message:"Error recovering embedded wallet"});throw(m=(u=a.current)==null?void 0:u.onError)==null||m.call(u,h),h}})}var xt=({client:e,solanaWallet:t,setSolanaWallet:r,setSolanaRecoveryFlowState:o,createSolanaWalletCallbacks:n,recoverSolanaWalletCallbacks:a})=>{let i=A(),s=_react.useMemo.call(void 0, ()=>_jssdkcore.getAllUserEmbeddedSolanaWallets.call(void 0, i),[i]),d=j(),c=_react.useMemo.call(void 0, ()=>s.length===0?null:_jssdkcore.getEntropyDetailsFromUser.call(void 0, i),[i,s]),u=_react.useMemo.call(void 0, ()=>{let g=s.map(S=>{let C=_jssdkcore.getEntropyDetailsFromUser.call(void 0, i,S);return C?{account:S,entropy:C}:null});if(g.some(S=>S===null))return[];let v=void 0,f=void 0,w=void 0;return g.filter(S=>S!==null).map(({account:S,entropy:{entropyId:C,entropyIdVerifier:k}})=>({address:S.address,publicKey:S.address,walletIndex:S.wallet_index,getProvider:()=>e.embeddedWallet.getSolanaProvider(S,C,k,v,f,w,W=>_chunkQTVIWU3Njs.d.call(void 0, void 0,null,function*(){var P;yield(P=he())==null?void 0:P(W)}))}))},[s,i,e]),m=_react.useCallback.call(void 0, g=>_chunkQTVIWU3Njs.d.call(void 0, void 0,null,function*(){return yield Ct({client:e,setSolanaWallet:r,createSolanaWalletCallbacks:n,setSolanaRecoveryFlowState:o,opts:g})}),[e,n]),p=_react.useCallback.call(void 0, ()=>_chunkQTVIWU3Njs.d.call(void 0, void 0,null,function*(){if(!c)throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_does_not_exist",error:"Embedded wallet does not exist"});let{entropyId:g,entropyIdVerifier:v}=c;return _t({client:e,account:s[0],entropyId:g,entropyIdVerifier:v,setSolanaWallet:r,recoverSolanaWalletCallbacks:a,setSolanaRecoveryFlowState:o})}),[e,c,s,a,o,r]),h=_react.useCallback.call(void 0, ()=>_chunkQTVIWU3Njs.d.call(void 0, void 0,null,function*(){if(!c)throw r({status:"not-created"}),new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_does_not_exist",error:"Embedded wallet does not exist"});r(g=>g.status==="connected"?{status:"reconnecting"}:{status:"connecting"});try{let{entropyId:g,entropyIdVerifier:v}=c,f=yield e.embeddedWallet.getSolanaProvider(s[0],g,v);return r({status:"connected",publicKey:s[0].public_key}),f}catch(g){throw _jssdkcore.errorIndicatesRecoveryIsNeeded.call(void 0, g)?(r({status:"needs-recovery"}),new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_needs_recovery",error:"Embedded wallet not loaded on device"})):g instanceof Error?(r({status:"error",error:g.message}),new (0, _jssdkcore.PrivyClientError)({code:"unknown_embedded_wallet_error",error:g.message})):(r({status:"error",error:"Error loading embedded wallet"}),new (0, _jssdkcore.PrivyClientError)({code:"unknown_embedded_wallet_error",error:"Error loading embedded wallet"}))}}),[s,e,c,r]);return _react.useEffect.call(void 0, ()=>{if(!i&&t.status!=="disconnected")return r({status:"disconnected"});d&&h().catch(()=>{})},[d,i]),_react.useEffect.call(void 0, ()=>{t.status==="error"&&t.error.includes("User must be logged in")&&h()},[t.status]),{create:m,recover:p,getProvider:h,wallets:u}};function Se(m){return _chunkQTVIWU3Njs.d.call(void 0, this,arguments,function*({client:e,setWallet:t,createWalletCallbacks:r,recoveryMethod:o,setRecoveryFlowState:n,password:a,recoveryKey:i,recoveryToken:s,recoverySecretOverride:d,iCloudRecordNameOverride:c,solanaAccount:u}){var h,g;switch(o){case"user-passcode":if(!a)throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_recovery_error",error:"password is required for user-passcode recovery method"});break;case"recovery-encryption-key":if(!i)throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_recovery_error",error:"key is required for recovery-encryption-key recovery method"});break;case"google-drive":if(!s)throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_recovery_error",error:"Recovery token is required for google-drive recovery method"});break;case"icloud":if(!d||!c)throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_recovery_error",error:"iCloud recovery failed due to inability to store credentials"});break}t({status:"creating",account:null});let p=o==="icloud"?"icloud-native":o;try{let{user:v}=yield e.embeddedWallet.create({password:a,recoveryMethod:p,recoveryKey:i,recoveryToken:s,recoverySecretOverride:d,iCloudRecordNameOverride:c,solanaAccount:u}),f=_jssdkcore.getUserEmbeddedEthereumWallet.call(void 0, v);if(!f)throw new (0, _jssdkcore.PrivyClientError)({error:"Embedded wallet account not created",code:"embedded_wallet_creation_error"});let w=yield e.embeddedWallet.getProvider(f);return(g=(h=r.current)==null?void 0:h.onSuccess)==null||g.call(h,w),t({status:"connected",provider:w,account:f}),n({status:"initial"}),w}catch(v){let f=v instanceof Error?v.message:"Error creating embedded wallet";throw t({status:"error",error:f,account:null}),n({status:"initial"}),new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_creation_error",error:f})}})}function At(){return _chunkQTVIWU3Njs.d.call(void 0, this,null,function*(){try{return yield Promise.resolve().then(() => _interopRequireWildcard(require("@privy-io/expo-native-extensions")))}catch(e){throw new Error("@privy-io/expo-native-extensions not found. Ensure that you're explicitly including as a dependency, and running an Expo development build")}})}function oe(o){return _chunkQTVIWU3Njs.d.call(void 0, this,arguments,function*({user:e,appId:t,client:r}){var s;if(_reactnative.Platform.OS==="android")throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_recovery_error",error:"iCloud recovery is not supported on Android"});let n=yield At(),a=yield r.recovery.icloudAuth.getICloudConfiguration("expo-ios");if(!(a==null?void 0:a.container_identifier))throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_recovery_error",error:"An iCloud Container ID must be specified in the Privy Dashboard."});try{let{recoverySecret:d,iCloudRecordName:c}=yield n.writeRecoverySecretToICloud({containerId:a.container_identifier,appId:t,userId:e.id});return{recoverySecret:d,iCloudRecordName:c}}catch(d){if(d instanceof Error){let c=(s=d.message.split("Caused by: ")[1])!=null?s:"Error writing to iCloud";throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_recovery_error",error:c})}throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_recovery_error",error:"Error writing to iCloud"})}})}function Ee(o){return _chunkQTVIWU3Njs.d.call(void 0, this,arguments,function*({walletAddress:e,client:t,chainType:r}){var c;if(_reactnative.Platform.OS==="android")throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_recovery_error",error:"iCloud recovery is not supported on Android"});let n=yield At(),i=(yield t.recovery.getRecoveryKeyMaterial(e,r)).icloud_record_name;if(!i)throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_recovery_error",error:"iCloud recovery not properly backed up."});let s=yield t.recovery.icloudAuth.getICloudConfiguration("expo-ios"),d=s==null?void 0:s.container_identifier;if(!d)throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_recovery_error",error:"An iCloud Container ID must be specified in the Privy Dashboard."});try{let{recoverySecret:u}=yield n.readRecoverySecretFromICloud({containerId:d,recordName:i});return{recoverySecret:u}}catch(u){if(u instanceof Error){let m=(c=u.message.split("Caused by: ")[1])!=null?c:"Error writing to iCloud";throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_recovery_error",error:m})}throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_recovery_error",error:"Error writing to iCloud"})}})}var _expolinking = require('expo-linking'); var G = _interopRequireWildcard(_expolinking); var $ = _interopRequireWildcard(_expolinking); var xe = _interopRequireWildcard(_expolinking); var Pe = _interopRequireWildcard(_expolinking); var or = _interopRequireWildcard(_expolinking); var rr = _interopRequireWildcard(_expolinking); var nr = _interopRequireWildcard(_expolinking); var ar = _interopRequireWildcard(_expolinking); var cr = _interopRequireWildcard(_expolinking); var lr = _interopRequireWildcard(_expolinking);var _expowebbrowser = require('expo-web-browser'); var Ut = _interopRequireWildcard(_expowebbrowser); var de = _interopRequireWildcard(_expowebbrowser);function E(e){return e instanceof Error||e instanceof _jssdkcore.PrivyApiError||e instanceof _jssdkcore.PrivyClientError?e:typeof e=="string"?new Error(e):new Error("Unknown error")}var B=e=>new Promise(t=>setTimeout(t,e));function Ce(){let e=_react.useRef.call(void 0, _reactnative.AppState.currentState);_react.useEffect.call(void 0, ()=>_reactnative.AppState.addEventListener("change",o=>{e.current=o}).remove,[]);function t(){return _reactnative.AppState.currentState}return{appState:e,getCurrentAppState:t}}function ne(n){return _chunkQTVIWU3Njs.d.call(void 0, this,arguments,function*({provider:e,redirectUri:t,client:r,onError:o}){try{let a;switch(e){case"google-drive":{let{url:c}=yield r.recovery.auth.generateURL(G.createURL(t||"/"));a=c;break}default:throw new (0, _jssdkcore.PrivyClientError)({error:"OAuth invalid provider",code:"embedded_wallet_recovery_error"})}let i=yield Ut.openAuthSessionAsync(a);if(_reactnative.Platform.OS==="android")return;if(i.type!=="success")throw new (0, _jssdkcore.PrivyClientError)({error:"Recovery OAuth session failed",code:"embedded_wallet_recovery_error"});let{queryParams:s}=G.parse(i.url),d;switch(e){case"google-drive":{let{privy_oauth_state:c,privy_oauth_code:u}=s;if(!u||!c)throw new (0, _jssdkcore.PrivyClientError)({error:"Recovery OAuth invalid credentials",code:"embedded_wallet_recovery_error"});d=yield _e({oAuthCode:u,oAuthState:c,client:r});break}default:throw new (0, _jssdkcore.PrivyClientError)({error:"Recovery OAuth invalid provider",code:"embedded_wallet_recovery_error"})}return d}catch(a){throw o==null||o(E(a)),a}})}function _e(o){return _chunkQTVIWU3Njs.d.call(void 0, this,arguments,function*({oAuthCode:e,oAuthState:t,client:r}){let{access_token:n}=yield r.recovery.auth.authorize(e,t);if(!n)throw new (0, _jssdkcore.PrivyClientError)({error:"OAuth invalid credentials",code:"login_with_oauth_returned_with_invalid_credentials"});return n})}var ao=2*60*1e3;function so(e){let t;return new Promise((r,o)=>{t=G.addEventListener("url",a=>_chunkQTVIWU3Njs.d.call(void 0, this,[a],function*({url:n}){if(!n)return;let{queryParams:i}=G.parse(n),{privy_oauth_state:s,privy_oauth_code:d}=i!=null?i:{};if(typeof d!="string"||typeof s!="string")return;let c=yield _e({client:e,oAuthCode:d,oAuthState:s});r(c)})),setTimeout(()=>{o(new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_set_recovery_error",error:"Failed to complete Google Drive recovery flow"}))},ao)}).finally(()=>{t==null||t.remove()})}function ke(e){return _chunkQTVIWU3Njs.d.call(void 0, this,null,function*(){let t;_reactnative.Platform.OS==="android"&&(t=so(e));let r=yield ne({provider:"google-drive",client:e});return r!=null?r:yield t})}function We(a){return _chunkQTVIWU3Njs.d.call(void 0, this,arguments,function*({client:e,recoveryInput:t,setWalletRecoveryCallbacks:r,setRecoveryFlowState:o,setWallet:n}){var i,s,d,c;try{let{provider:u,user:m}=yield e.embeddedWallet.setRecovery(t),p=u,h=_jssdkcore.getUserEmbeddedWallet.call(void 0, m);return n({status:"connected",provider:p,account:h}),(s=(i=r.current)==null?void 0:i.onSuccess)==null||s.call(i,p),o({status:"initial"}),p}catch(u){let m=new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_set_recovery_error",error:u instanceof Error?u.message:"Error setting password on embedded wallet"});throw(c=(d=r.current)==null?void 0:d.onError)==null||c.call(d,m),o({status:"initial"}),m}})}function Lt(e){return e===void 0?{recoveryMethod:"privy"}:typeof e=="string"?{recoveryMethod:"user-passcode",password:e}:e.recoveryMethod==="user-passcode"?{recoveryMethod:"user-passcode",password:e.password}:e.recoveryMethod==="recovery-encryption-key"?{recoveryMethod:"recovery-encryption-key",recoveryKey:e.recoveryKey}:{recoveryMethod:e.recoveryMethod}}var Mt=({client:e,appId:t,wallet:r,setWallet:o,setRecoveryFlowState:n,createWalletCallbacks:a,recoverWalletCallbacks:i,setWalletRecoveryCallbacks:s})=>{let d=A(),c=_react.useMemo.call(void 0, ()=>_jssdkcore.getUserEmbeddedEthereumWallet.call(void 0, d),[d]),u=j(),m=_react.useCallback.call(void 0, f=>_chunkQTVIWU3Njs.d.call(void 0, void 0,null,function*(){var pe,ye;if(c)throw new (0, _jssdkcore.PrivyClientError)({error:"This user already has an embedded wallet",code:"embedded_wallet_already_exists"});let{user:w}=yield e.user.get(),{password:S,recoveryMethod:C,recoveryKey:k}=Lt(f),W,P,M;if(C==="google-drive"&&(W=yield ne({provider:C,client:e,onError:(pe=a.current)==null?void 0:pe.onError}),n({status:"creating-wallet"}),!W))return null;if(C==="icloud"){if(!w)throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_recovery_error",error:"User must be loaded before creating a wallet with iCloud."});let{recoverySecret:Re,iCloudRecordName:te}=yield oe({user:w,appId:t,client:e});P=Re,M=te}return yield Se({client:e,setWallet:o,createWalletCallbacks:a,recoveryMethod:C,recoveryKey:k,setRecoveryFlowState:n,password:S,recoverySecretOverride:P,iCloudRecordNameOverride:M,solanaAccount:(ye=_jssdkcore.getUserEmbeddedSolanaWallet.call(void 0, w))!=null?ye:void 0})}),[e,c,d]),p=_react.useCallback.call(void 0, f=>_chunkQTVIWU3Njs.d.call(void 0, void 0,null,function*(){var C;if(r.status!=="connected")throw new (0, _jssdkcore.PrivyClientError)({code:"attempted_to_set_password_before_connected",error:"Embedded wallet must be connected before setting password"});if(!c)throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_does_not_exist",error:"Embedded wallet does not exist"});if(_jssdkcore.getUserEmbeddedSolanaWallet.call(void 0, d))throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_set_recovery_error",error:"Cannot set user-controlled recovery for a user with an embedded Solana wallet."});if(_jssdkcore.isUnifiedWallet.call(void 0, c))throw new (0, _jssdkcore.PrivyClientError)({code:"unsupported_wallet_type",error:"Embedded 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"});_jssdkcore.throwIfInvalidRecoveryUpgradePath.call(void 0, {currentRecoveryMethod:c.recovery_method,upgradeToRecoveryMethod:f.recoveryMethod});let w,S;switch(f.recoveryMethod){case"privy":S=_chunkQTVIWU3Njs.b.call(void 0, _chunkQTVIWU3Njs.a.call(void 0, {},f),{wallet:c});break;case"user-passcode":S=_chunkQTVIWU3Njs.b.call(void 0, _chunkQTVIWU3Njs.a.call(void 0, {},f),{wallet:c,password:f.password});break;case"google-drive":if(w=yield ne({provider:f.recoveryMethod,client:e,onError:(C=s.current)==null?void 0:C.onError}),n({status:"upgrading-recovery"}),!w)return null;S={recoveryMethod:"google-drive",wallet:c,recoveryAccessToken:w};break;case"icloud":if(!d)throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_recovery_error",error:"User must be loaded before backing up to iCloud."});let{recoverySecret:k,iCloudRecordName:W}=yield oe({user:d,appId:t,client:e});S={recoveryMethod:"icloud-native",recoverySecretOverride:k,iCloudRecordNameOverride:W,wallet:c};break;default:throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_recovery_error",error:"Unrecognized recovery method"})}return We({client:e,recoveryInput:S,setWalletRecoveryCallbacks:s,setRecoveryFlowState:n,setWallet:o})}),[e,c,r.status,d]),h=_react.useCallback.call(void 0, f=>_chunkQTVIWU3Njs.d.call(void 0, void 0,null,function*(){return p({recoveryMethod:"user-passcode",password:f})}),[e,c,r.status]),g=_react.useCallback.call(void 0, f=>_chunkQTVIWU3Njs.d.call(void 0, void 0,null,function*(){var P;if(!c)throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_does_not_exist",error:"Embedded wallet does not exist"});let{password:w,recoveryMethod:S,recoveryKey:C}=Lt(f),k,W;if(S==="google-drive"&&(k=yield ne({provider:S,client:e,onError:(P=i.current)==null?void 0:P.onError}),n({status:"recovering"}),!k))return null;if(S==="icloud"){if(!d)throw new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_recovery_error",error:"User must be loaded before recovering via iCloud."});let{recoverySecret:M}=yield Ee({client:e,walletAddress:c.address});W=M}return be({client:e,account:c,setWallet:o,recoverWalletCallbacks:i,recoveryMethod:S,setRecoveryFlowState:n,recoveryKey:C,password:w,recoveryToken:k,recoverySecretOverride:W})}),[e,c]),v=_react.useCallback.call(void 0, ()=>_chunkQTVIWU3Njs.d.call(void 0, void 0,null,function*(){if(!c)throw o({status:"not-created",account:null}),new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_does_not_exist",error:"Embedded wallet does not exist"});o(f=>f.status==="connected"?{status:"reconnecting",account:c}:{status:"connecting",account:c});try{let f=yield e.embeddedWallet.getProvider(c);return o({status:"connected",provider:f,account:c}),f}catch(f){throw _jssdkcore.errorIndicatesRecoveryIsNeeded.call(void 0, f)?(o({status:"needs-recovery",account:c}),new (0, _jssdkcore.PrivyClientError)({code:"embedded_wallet_needs_recovery",error:"Embedded wallet not loaded on device"})):f instanceof Error?(o({status:"error",error:f.message,account:c}),new (0, _jssdkcore.PrivyClientError)({code:"unknown_embedded_wallet_error",error:f.message})):(o({status:"error",error:"Error loading embedded wallet",account:c}),new (0, _jssdkcore.PrivyClientError)({code:"unknown_embedded_wallet_error",error:"Error loading embedded wallet"}))}}),[e,c]);return _react.useEffect.call(void 0, ()=>{if(!d&&r.status!=="disconnected")return o({status:"disconnected",account:null});u&&v().catch(()=>{})},[u,d,c]),_react.useEffect.call(void 0, ()=>{r.status==="error"&&r.error.includes("User must be logged in")&&v()},[r.status]),{create:m,recover:g,setPassword:h,setRecovery:p,getProvider:v}};var Tt=({client:e,isReady:t})=>{let r=A(),o=we(i=>i==null?void 0:i.customAuth),[n,a]=_react.useState.call(void 0, {status:"initial"});return _react.useEffect.call(void 0, ()=>{(()=>_chunkQTVIWU3Njs.d.call(void 0, void 0,null,function*(){if(!(o!=null&&o.enabled)){a({status:"not-enabled"});return}a({status:"loading"});let{getCustomAccessToken:s,isLoading:d}=o;if(!(!t||d))try{let c=yield s();if(!c&&r){yield e.auth.logout(),a({status:"done"});return}if(!c){a({status:"done"});return}if(r){a({status:"done"});return}let u=x();if(!(yield e.auth.customProvider.syncWithToken(c,{embedded:u==null?void 0:u.embedded}))){yield e.auth.logout(),a({status:"error",error:new (0, _jssdkcore.PrivyClientError)({error:"Failed to sync with custom auth provider",code:"third_party_auth_error"})});return}a({status:"done"})}catch(c){if(console.log("Error syncing with custom auth provider",c),a({status:"error",error:c}),r)throw yield e.auth.logout(),new (0, _jssdkcore.PrivyClientError)({error:"Third-party auth failed",code:"third_party_auth_error"})}}))()},[e,r,t,o==null?void 0:o.enabled,o==null?void 0:o.getCustomAccessToken,o==null?void 0:o.isLoading]),{customAuthState:n,customAuthStateIsSettled:n.status!=="loading"&&n.status!=="initial"}};var Dt=({client:e,createWalletCallbacks:t,recoverWalletCallbacks:r,setWalletRecoveryCallbacks:o,recoveryFlowState:n,oAuthState:a,setRecoveryFlowState:i,setWallet:s,appStateVisible:d})=>{let c=$.useURL(),u=A(),m=_react.useMemo.call(void 0, ()=>_jssdkcore.getUserEmbeddedWallet.call(void 0, u),[u]),p=j(),h=_react.useCallback.call(void 0, g=>{var f,w,S,C;let v=E(g);n.status==="creating-wallet"?(w=(f=t.current).onError)==null||w.call(f,E(v)):(C=(S=r.current).onError)==null||C.call(S,E(v)),i({status:"initial"})},[n]);return _react.useEffect.call(void 0, ()=>{function g(){return _chunkQTVIWU3Njs.d.call(void 0, this,null,function*(){var S;if(!c&&n.status!=="initial"&&d&&h(new Error("Recovery OAuth session failed")),!c||n.status==="initial"||a.status!=="initial"||!d||!p)return;let{queryParams:v}=$.parse(c),{privy_oauth_state:f,privy_oauth_code:w}=v;if(!(!w||!f)){yield $.openURL(c.split("?")[0]);try{let C=yield _e({oAuthCode:w,oAuthState:f,client:e});if(n.status==="creating-wallet"){let k=(S=_jssdkcore.getUserEmbeddedSolanaWallet.call(void 0, u))!=null?S:void 0;yield Se({client:e,setWallet:s,createWalletCallbacks:t,recoveryMethod:"google-drive",setRecoveryFlowState:i,recoveryToken:C,solanaAccount:k})}else if(n.status==="upgrading-recovery"){if(!m)throw new Error("Embedded wallet not found");yield We({client:e,recoveryInput:{recoveryMethod:"google-drive",wallet:m,recoveryAccessToken:C},setWalletRecoveryCallbacks:o,setRecoveryFlowState:i,setWallet:s})}else yield be({client:e,account:m,setWallet:s,recoverWalletCallbacks:r,recoveryMethod:"google-drive",setRecoveryFlowState:i,recoveryToken:C})}catch(C){h(C)}}})}_reactnative.Platform.OS==="android"&&g()},[c,n.status,d,p])};var Nt=({client:e,isUserInitialized:t,setIsUserInitialized:r,setError:o})=>{_react.useEffect.call(void 0, ()=>{t||(()=>_chunkQTVIWU3Njs.d.call(void 0, void 0,null,function*(){try{yield e.initialize()}catch(a){o(a instanceof Error?a:new Error(String(a)))}try{yield e.user.get()}catch(a){}finally{r(!0)}}))()},[e,t,o,r])};var Zs=e=>{let{client:t,setSiweState:r,siweState:o}=_react.useContext.call(void 0, y),n=_react.useCallback.call(void 0, s=>{var c;let d=E(s);return r({status:"error",error:d}),(c=e==null?void 0:e.onError)==null||c.call(e,d),d},[e==null?void 0:e.onError]),a=_react.useCallback.call(void 0, u=>_chunkQTVIWU3Njs.d.call(void 0, void 0,[u],function*({wallet:s,from:{domain:d,uri:c}}){var m;try{r({status:"generating-message"});let p=yield t.auth.siwe.init(s,d,c);return r({status:"awaiting-signature"}),(m=e==null?void 0:e.onGenerateMessage)==null||m.call(e,p.message),p.message}catch(p){throw n(p)}}),[t,n,e==null?void 0:e.onGenerateMessage]);return{loginWithSiwe:_react.useCallback.call(void 0, u=>_chunkQTVIWU3Njs.d.call(void 0, void 0,[u],function*({signature:s,messageOverride:d,disableSignup:c}){var m;try{if(b())throw new (0, _jssdkcore.PrivyClientError)({code:"attempted_login_with_siwe_while_already_logged_in",error:"Already logged in, use `useLinkWithSiwe` if you are trying to link a wallet to an existing account"});r({status:"submitting-signature"});let h=x(),g=yield t.auth.siwe.loginWithSiwe(s,void 0,d,c?"no-signup":"login-or-sign-up",{embedded:h==null?void 0:h.embedded});return r({status:"done"}),(m=e==null?void 0:e.onSuccess)==null||m.call(e,g.user,g.is_new_user),g.user}catch(p){throw n(p)}}),[t,n,e==null?void 0:e.onSuccess]),generateSiweMessage:a,state:o}};var U=()=>{let{client:e}=_react.useContext.call(void 0, y);return e};var lc=()=>{let e=U(),t=_react.useCallback.call(void 0, i=>_chunkQTVIWU3Njs.d.call(void 0, void 0,[i],function*({wallet:{address:o},from:{domain:n,uri:a}}){try{let{nonce:s}=yield e.auth.siws.fetchNonce({address:o});return{message:_jssdkcore.createSiwsMessage.call(void 0, {address:o,domain:n,uri:a,nonce:s})}}catch(s){throw E(s)}}),[e]),r=_react.useCallback.call(void 0, s=>_chunkQTVIWU3Njs.d.call(void 0, void 0,[s],function*({signature:o,message:n,wallet:{walletClientType:a,connectorType:i}={}}){try{if(!b())throw new (0, _jssdkcore.PrivyClientError)({code:"attempted_link_siws_before_logged_in",error:"Must be logged in to link a wallet, Use `useLoginWithSiws` to login with a wallet"});let{user:c}=yield e.auth.siws.link({signature:o,message:n,walletClientType:a,connectorType:i});return c}catch(d){throw E(d)}}),[e]);return{generateMessage:t,link:r}};var vc=()=>{let e=U(),t=_react.useCallback.call(void 0, i=>_chunkQTVIWU3Njs.d.call(void 0, void 0,[i],function*({wallet:{address:o},from:{domain:n,uri:a}}){try{let{nonce:s}=yield e.auth.siws.fetchNonce({address:o});return{message:_jssdkcore.createSiwsMessage.call(void 0, {address:o,domain:n,uri:a,nonce:s})}}catch(s){throw E(s)}}),[e]),r=_react.useCallback.call(void 0, d=>_chunkQTVIWU3Njs.d.call(void 0, void 0,[d],function*({signature:o,message:n,wallet:{walletClientType:a,connectorType:i}={},disableSignup:s}){try{if(b())throw new (0, _jssdkcore.PrivyClientError)({code:"attempted_login_with_siws_while_already_logged_in",error:"Already logged in, use `useLinkWithSiws` if you are trying to link a wallet to an existing account"});let u=x();return(yield e.auth.siws.login({signature:o,message:n,walletClientType:a,connectorType:i,mode:s?"no-signup":"login-or-sign-up",opts:{embedded:u==null?void 0:u.embedded}})).user}catch(c){throw E(c)}}),[e]);return{generateMessage:t,login:r}};var xc=e=>{let{client:t}=_react.useContext.call(void 0, y),r=_react.useCallback.call(void 0, n=>{var i;let a=E(n);return(i=e==null?void 0:e.onError)==null||i.call(e,a),a},[e==null?void 0:e.onError]);return{unlinkWallet:_react.useCallback.call(void 0, a=>_chunkQTVIWU3Njs.d.call(void 0, void 0,[a],function*({address:n}){var i;try{if(!b())throw new (0, _jssdkcore.PrivyClientError)({code:"attempted_unlink_siwe_before_logged_in",error:"Must be logged in to unlink a wallet, Use `useLoginWithSiwe` to login with a wallet"});let{user:d}=yield t.auth.siwe.unlinkWallet(n);return(i=e==null?void 0:e.onSuccess)==null||i.call(e,d),d}catch(s){throw r(s)}}),[t,r,e==null?void 0:e.onSuccess])}};var Mc=e=>{let[t,r]=_react.useState.call(void 0, ""),{client:o,otpState:n,setOtpState:a}=_react.useContext.call(void 0, y),i=_react.useCallback.call(void 0, c=>{var m;let u=E(c);return a({status:"error",error:u}),(m=e==null?void 0:e.onError)==null||m.call(e,u),u},[e,a]),s=_react.useCallback.call(void 0, u=>_chunkQTVIWU3Njs.d.call(void 0, void 0,[u],function*({email:c}){var m;r(c);try{a({status:"sending-code"});let p=yield o.auth.email.sendCode(c);return a({status:"awaiting-code-input"}),(m=e==null?void 0:e.onSendCodeSuccess)==null||m.call(e,{email:c}),p}catch(p){throw i(p)}}),[o,i,e,a]),d=_react.useCallback.call(void 0, m=>_chunkQTVIWU3Njs.d.call(void 0, void 0,[m],function*({code:c,email:u}){var p;try{if(!b())throw new (0, _jssdkcore.PrivyClientError)({code:"attempted_link_email_before_logged_in",error:"Must be logged in to link an email, Use `useLoginWithEmail` to login with email"});let g=u||t;if(!g)throw new (0, _jssdkcore.PrivyClientError)({code:"attempted_submit_otp_before_sending",error:"Must `sendCode` with a valid email before calling `linkWithCode`"});a({status:"submitting-code"});let{user:v}=yield o.auth.email.linkWithCode(g,c);return a({status:"done"}),(p=e==null?void 0:e.onLinkSuccess)==null||p.call(e,v),v}catch(h){throw i(h)}}),[t,a,o,e,i]);return{sendCode:s,linkWithCode:d,state:n}};var jc=e=>{let{client:t}=_react.useContext.call(void 0, y),r=_react.useCallback.call(void 0, n=>{var i;let a=E(n);return(i=e==null?void 0:e.onError)==null||i.call(e,a),a},[e==null?void 0:e.onError]);return{unlinkEmail:_react.useCallback.call(void 0, a=>_chunkQTVIWU3Njs.d.call(void 0, void 0,[a],function*({email:n}){var i;try{let{user:s}=yield t.auth.email.unlink(n);return(i=e==null?void 0:e.onSuccess)==null||i.call(e,s),s}catch(s){throw r(s)}}),[t,e==null?void 0:e.onSuccess,r])}};var Qc=e=>{let[t,r]=_react.useState.call(void 0, ""),{client:o,otpState:n,setOtpState:a}=_react.useContext.call(void 0, y),i=_react.useCallback.call(void 0, c=>{var m;let u=E(c);return a({status:"error",error:u}),(m=e==null?void 0:e.onError)==null||m.call(e,u),u},[e,a]),s=_react.useCallback.call(void 0, u=>_chunkQTVIWU3Njs.d.call(void 0, void 0,[u],function*({email:c}){var m;r(c);try{a({status:"sending-code"});let p=yield o.auth.email.sendCode(c);return a({status:"awaiting-code-input"}),(m=e==null?void 0:e.onSendCodeSuccess)==null||m.call(e,{email:c}),p}catch(p){throw i(p)}}),[o,i,e,a]),d=_react.useCallback.call(void 0, p=>_chunkQTVIWU3Njs.d.call(void 0, void 0,[p],function*({code:c,email:u,disableSignup:m}){var h;try{if(b())throw new (0, _jssdkcore.PrivyClientError)({code:"attempted_login_with_email_while_already_logged_in",error:"Already logged in, use `useLinkWithEmail` if you are trying to link an email to an existing account"});let v=u||t;if(!v)throw new (0, _jssdkcore.PrivyClientError)({code:"attempted_submit_otp_before_sending",error:"Must `sendCode` with a valid email before calling `loginWithCode`"});a({status:"submitting-code"});let f=x(),w=yield o.auth.email.loginWithCode(v,c,m?"no-signup":"login-or-sign-up",{embedded:f==null?void 0:f.embedded});return a({status:"done"}),(h=e==null?void 0:e.onLoginSuccess)==null||h.call(e,w.user,w.is_new_user),w==null?void 0:w.user}catch(g){throw i(g)}}),[t,a,o,e,i]);return{sendCode:s,loginWithCode:d,state:n}};var nd=e=>{let[t,r]=_react.useState.call(void 0, ""),{client:o,otpState:n,setOtpState:a}=_react.useContext.call(void 0, y),i=_react.useCallback.call(void 0, c=>{var m;let u=E(c);return a({status:"error",error:u}),(m=e==null?void 0:e.onError)==null||m.call(e,u),u},[e,a]),s=_react.useCallback.call(void 0, u=>_chunkQTVIWU3Njs.d.call(void 0, void 0,[u],function*({phone:c}){var m;r(c);try{a({status:"sending-code"});let p=yield o.auth.phone.sendCode(c);return a({status:"awaiting-code-input"}),(m=e==null?void 0:e.onSendCodeSuccess)==null||m.call(e,{phone:c}),p}catch(p){throw i(p)}}),[o,i,e,a]),d=_react.useCallback.call(void 0, m=>_chunkQTVIWU3Njs.d.call(void 0, void 0,[m],function*({code:c,phone:u}){var p;try{if(!b())throw new (0, _jssdkcore.PrivyClientError)({code:"attempted_link_sms_before_logged_in",error:"Must be logged in to link a phone number, Use `useLoginWithSMS` to login with a phone number"});if(!(u||t))throw new (0, _jssdkcore.PrivyClientError)({code:"attempted_submit_otp_before_sending",error:"Must `sendCode` with a valid phone number before calling `linkWithCode`"});a({status:"submitting-code"});let{user:v}=yield o.auth.phone.linkWithCode(u||t,c);return a({status:"done"}),(p=e==null?void 0:e.onLinkSuccess)==null||p.call(e,v),v}catch(h){throw i(h)}}),[t,a,o,e,i]);return{sendCode:s,linkWithCode:d,state:n}};var pd=e=>{let[t,r]=_react.useState.call(void 0, ""),{client:o,otpState:n,setOtpState:a}=_react.useContext.call(void 0, y),i=_react.useCallback.call(void 0, c=>{var m;let u=E(c);return a({status:"error",error:u}),(m=e==null?void 0:e.onError)==null||m.call(e,u),u},[e,a]),s=_react.useCallback.call(void 0, u=>_chunkQTVIWU3Njs.d.call(void 0, void 0,[u],function*({phone:c}){var m;r(c);try{a({status:"sending-code"});let p=yield o.auth.phone.sendCode(c);return a({status:"awaiting-code-input"}),(m=e==null?void 0:e.onSendCodeSuccess)==null||m.call(e,{phone:c}),p}catch(p){throw i(p)}}),[o,i,e,a]),d=_react.useCallback.call(void 0, p=>_chunkQTVIWU3Njs.d.call(void 0, void 0,[p],function*({code:c,phone:u,disableSignup:m}){var h;try{if(b())throw new (0, _jssdkcore.PrivyClientError)({code:"attempted_login_with_sms_while_already_logged_in",error:"Already logged in, use `useLinkWithSMS` if you are trying to link a phone number to an existing account"});if(!(u||t))throw new (0, _jssdkcore.PrivyClientError)({code:"attempted_submit_otp_before_sending",error:"Must `sendCode` with a valid phone number before calling `loginWithCode`"});a({status:"submitting-code"});let f=x(),w=yield o.auth.phone.loginWithCode(u||t,c,m?"no-signup":"login-or-sign-up",{embedded:f==null?void 0:f.embedded});return a({status:"done"}),(h=e==null?void 0:e.onLoginSuccess)==null||h.call(e,w.user,w.is_new_user),w==null?void 0:w.user}catch(g){throw i(g)}}),[t,a,o,e,i]);return{sendCode:s,loginWithCode:d,state:n}};var Sd=e=>{let{appState:t,getCurrentAppState:r}=Ce(),{client:o,farcasterState:n,setFarcasterState:a}=_react.useContext.call(void 0, y),i=_react.useRef.call(void 0, !1),s=_react.useCallback.call(void 0, u=>{var p;let m=E(u);return a({status:"error",error:m}),(p=e==null?void 0:e.onError)==null||p.call(e,m),m},[e==null?void 0:e.onError,a]),d=_react.useCallback.call(void 0, ()=>{i.current=!0},[]);return{linkWithFarcaster:_react.useCallback.call(void 0, (h,...g)=>_chunkQTVIWU3Njs.d.call(void 0, void 0,[h,...g],function*({relyingParty:u,redirectUrl:m},p={pollAttempts:10,pollIntervalMs:1e3}){var v;try{let f=b();if(i.current=!1,!f)throw new (0, _jssdkcore.PrivyClientError)({code:"attempted_link_farcaster_before_logged_in",error:"Must be logged in to link a Farcaster account."});a({status:"generating-uri"});let{connect_uri:w,channel_token:S}=yield o.auth.farcaster.initializeAuth({relyingParty:u,redirectUrl:xe.createURL(m!=null?m:"/")});if(!w)throw new (0, _jssdkcore.PrivyClientError)({code:"failed_to_generate_farcaster_uri",error:"Failed to generate farcaster uri"});if(!S)throw new (0, _jssdkcore.PrivyClientError)({code:"failed_to_generate_farcaster_channel_token",error:"Failed to generate farcaster channel token"});yield xe.openURL(w),a({status:"polling-status"});let C=0;for(;C<p.pollAttempts;){if(i.current)throw new (0, _jssdkcore.PrivyClientError)({code:"farcaster_polling_canceled",error:"Farcaster polling canceled"});if(t.current!=="active"&&r()!=="active"){yield B(p.pollIntervalMs);continue}let k=yield o.auth.farcaster.getFarcasterStatus({channel_token:S});if(k.state==="completed"){a({status:"submitting-token"});let{user:W}=yield o.auth.farcaster.link(_chunkQTVIWU3Njs.a.call(void 0, {channel_token:S},k));return a({status:"done"}),(v=e==null?void 0:e.onSuccess)==null||v.call(e,W),W}C++,yield B(p.pollIntervalMs)}throw new (0, _jssdkcore.PrivyClientError)({code:"farcaster_polling_timeout",error:"Farcasting polling timed out"})}catch(f){throw s(f)}}),[o,e==null?void 0:e.onSuccess,s,a]),state:n,cancel:d}};var xd=e=>{let{client:t}=_react.useContext.call(void 0, y),r=_react.useCallback.call(void 0, n=>{var i;let a=E(n);return(i=e==null?void 0:e.onError)==null||i.call(e,a),a},[e==null?void 0:e.onError]);return{unlinkFarcaster:_react.useCallback.call(void 0, a=>_chunkQTVIWU3Njs.d.call(void 0, void 0,[a],function*({fid:n}){var i;try{let{user:s}=yield t.auth.farcaster.unlink({fid:n});return(i=e==null?void 0:e.onSuccess)==null||i.call(e,s),s}catch(s){throw r(s)}}),[t,e==null?void 0:e.onSuccess,r])}};var Fd=e=>{let{appState:t,getCurrentAppState:r}=Ce(),{client:o,farcasterState:n,setFarcasterState:a}=_react.useContext.call(void 0, y),i=_react.useRef.call(void 0, !1),s=_react.useCallback.call(void 0, u=>{var p;let m=E(u);return a({status:"error",error:m}),(p=e==null?void 0:e.onError)==null||p.call(e,m),m},[e==null?void 0:e.onError,a]),d=_react.useCallback.call(void 0, ()=>{i.current=!0},[]);return{loginWithFarcaster:_react.useCallback.call(void 0, (g,...v)=>_chunkQTVIWU3Njs.d.call(void 0, void 0,[g,...v],function*({relyingParty:u,redirectUrl:m,disableSignup:p},h={pollAttempts:10,pollIntervalMs:1e3}){var f;try{if(i.current=!1,b())throw new (0, _jssdkcore.PrivyClientError)({code:"attempted_login_with_farcaster_while_already_logged_in",error:"Already logged in, use `useLinkWithFarcaster` if you are trying to link farcaster to an existing account"});a({status:"generating-uri"});let{connect_uri:S,channel_token:C}=yield o.auth.farcaster.initializeAuth({relyingParty:u,redirectUrl:Pe.createURL(m!=null?m:"/")});if(!S)throw new (0, _jssdkcore.PrivyClientError)({code:"failed_to_generate_farcaster_uri",error:"Failed to generate farcaster uri"});if(!C)throw new (0, _jssdkcore.PrivyClientError)({code:"failed_to_generate_farcaster_channel_token",error:"Failed to generate farcaster channel token"});yield Pe.openURL(S),a({status:"polling-status"});let k=0;for(;k<h.pollAttempts;){if(i.current)throw new (0, _jssdkcore.PrivyClientError)({code:"farcaster_polling_canceled",error:"Farcaster polling canceled"});if(t.current!=="active"&&r()!=="active"){yield B(h.pollIntervalMs);continue}let W=yield o.auth.farcaster.getFarcasterStatus({channel_token:C});if(W.state==="completed"){a({status:"submitting-token"});let P=x(),M=yield o.auth.farcaster.authenticate(_chunkQTVIWU3Njs.a.call(void 0, {channel_token:C,mode:p?"no-signup":"login-or-sign-up"},W),{embedded:P==null?void 0:P.embedded});return a({status:"done"}),(f=e==null?void 0:e.onSuccess)==null||f.call(e,M.user,M.is_new_user),M.user}k++,yield B(h.pollIntervalMs)}throw new (0, _jssdkcore.PrivyClientError)({code:"farcaster_polling_timeout",error:"Farcasting polling timed out"})}catch(w){throw s(w)}}),[o,s,e==null?void 0:e.onSuccess,a,t]),state:n,cancel:d}};var Qe=_zustand.create.call(void 0, ()=>({status:"initial"})),K=e=>Qe.setState(e,!0),Yo=Qe.getState,qd= exports.x =()=>{let{client:e}=_react.useContext.call(void 0, y),t=Qe(),r=_react.useCallback.call(void 0, ()=>_chunkQTVIWU3Njs.d.call(void 0, void 0,null,function*(){try{K({status:"fetching-nonce"});let n=yield e.auth.farcasterV2.initializeAuth();return K({status:"awaiting-signature"}),n}catch(n){let a=E(n);throw K({status:"initial",error:a}),a}}),[e]),o=_react.useCallback.call(void 0, n=>_chunkQTVIWU3Njs.d.call(void 0, void 0,null,function*(){let a=Yo().status;try{if(b()){let c=new (0, _jssdkcore.PrivyClientError)({code:"attempted_login_with_farcaster_while_already_logged_in",error:"Already logged in, use a link helper if you are trying to link farcaster to an existing account"});throw K({status:a,error:c}),c}K({status:"submitting-signature"});let s=x(),d=yield e.auth.farcasterV2.authenticate(n,{embedded:s==null?void 0:s.embedded});return K({status:"done"}),setTimeout(()=>K({status:"initial"}),1500),{user:d.user}}catch(i){let s=E(i);throw K({status:a,error:s}),s}}),[e]);return{init:r,login:o,state:t}};var Xd=()=>{let{client:e}=_react.useContext.call(void 0, y);return _react.useMemo.call(void 0, ()=>({delegateWallet:_jssdkcore.delegatedActions.delegateWallet(e),revokeWallets:_jssdkcore.delegatedActions.revokeWallets(e)}),[e])};var ol=()=>{let{client:e}=_react.useContext.cal