UNPKG

@privy-io/expo

Version:

Expo client for the Privy Auth API

1 lines • 75.2 kB
import{a as _,b as D,d as l,e as pt,f as yt,g as ge}from"./chunk-QTVIWU3N.js";import{useEffect as Lr}from"react";import{create as Mr}from"zustand";var ft=Mr(()=>({status:"disconnected"})),he=()=>ft.getState().onNeedsRecovery,Fr=e=>{Lr(()=>{ft.setState({onNeedsRecovery:e==null?void 0:e.onNeedsRecovery})},[e==null?void 0:e.onNeedsRecovery])};import{digest as Dr,randomUUID as Nr}from"expo-crypto";import zr from"@privy-io/js-sdk-core";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=ge,supportedChains:o,baseUrl:n,logLevel:a,logger:i})=>new zr({appId:e,clientId:t,supportedChains:o,storage:yt(r),sdkVersion:`expo:${gt.version}`,nativeAppIdentifier:pt(),crypto:{digest:Dr,randomUUID:Nr},baseUrl:n,logLevel:a,logger:i});import{useCallback as st,useContext as $i}from"react";import{PrivyClientError as Qi}from"@privy-io/js-sdk-core";import Z,{useState as L,useMemo as Gi,createContext as Hi,useCallback as Ue,useRef as me,useEffect as Cr,useContext as qi}from"react";import{AppState as _r,View as Bi}from"react-native";import{PrivyClientError as kr}from"@privy-io/js-sdk-core";import jr from"react-fast-compare";import{create as Kr}from"zustand";var we=Kr(()=>{}),wt=e=>we.setState(t=>jr(t,e)?t:e),x=we.getState;import Hr from"react";import{useCallback as qr,useEffect as Br,useRef as Jr}from"react";import{AppState as $r}from"react-native";import Qr from"react-native-webview";import*as F from"expo-secure-store";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 l(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(":","-");import Vr from"react-fast-compare";import{createStore as Gr,useStore as Me}from"zustand";var z=Gr()(()=>({user:null,proxyStatus:"loading"}));function b(){return z.getState().user}var pa=z.subscribe.bind(z);function Fe(e){z.setState(({user:t})=>Vr(t,e)?{}:{user:e})}var Te=e=>z.setState({proxyStatus:e});function A(){return Me(z,e=>e.user)}function ya(){return Me(z,e=>!!e.user)}function j(){return Me(z,e=>e.proxyStatus!=="loading")}var Yr={shouldUseAppBackedStorage:!0},St=({client:e,isClientReady:t})=>{let r=Jr(null);Br(()=>{let n=$r.addEventListener("change",a=>l(void 0,null,function*(){a==="active"&&((yield e.embeddedWallet.ping(500))||(Te("reloading"),e.embeddedWallet.reload()))}));return()=>n.remove()},[e]);let o=qr(n=>l(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?Hr.createElement(Qr,{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};import{useCallback as De,useEffect as kt,useMemo as Ne}from"react";import{errorIndicatesRecoveryIsNeeded as Zr,getAllUserEmbeddedSolanaWallets as eo,getEntropyDetailsFromUser as Wt,PrivyClientError as re}from"@privy-io/js-sdk-core";import{getAllUserEmbeddedSolanaWallets as ve,getEntropyDetailsFromAccount as Et,getUserEmbeddedEthereumWallet as Xr,PrivyClientError as H}from"@privy-io/js-sdk-core";function Ct(a){return l(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=ve(c),m=u[0],p=(i=Xr(c))!=null?i:void 0;if(n!=null&&n.recoveryMethod&&n.recoveryMethod!=="privy")throw new H({code:"embedded_wallet_creation_error",error:"Unsupported recovery method for solana wallet."});if(!(n!=null&&n.createAdditional)&&m)throw new H({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}=Et(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=ve(k.user).find(P=>P.wallet_index===C);if(!W)throw new H({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=ve(f.user).find(W=>W.wallet_index===0);if(!w)throw new H({error:"Embedded wallet account not created",code:"embedded_wallet_creation_error"});let S=p!=null?p:w,{entropyId:C,entropyIdVerifier:k}=Et(S);h=yield e.embeddedWallet.getSolanaProvider(w,C,k),g=f.user}let v=ve(g)[0];if(!v)throw new H({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 H({code:"embedded_wallet_creation_error",error:u})}})}import{PrivyClientError as V}from"@privy-io/js-sdk-core";function be(u){return l(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 V({code:"embedded_wallet_does_not_exist",error:"Embedded wallet does not exist"});switch(n){case"user-passcode":if(!i)throw new V({code:"embedded_wallet_recovery_error",error:"password is required for user-passcode recovery method"});break;case"google-drive":if(!d)throw new V({code:"embedded_wallet_recovery_error",error:"Recovery token is required for google-drive recovery method"});break;case"icloud":if(!c)throw new V({code:"embedded_wallet_recovery_error",error:"Record name is required for icloud recovery method"});break;case"recovery-encryption-key":if(!s)throw new V({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 V({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 l(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 V({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=Ne(()=>eo(i),[i]),d=j(),c=Ne(()=>s.length===0?null:Wt(i),[i,s]),u=Ne(()=>{let g=s.map(S=>{let C=Wt(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=>l(void 0,null,function*(){var P;yield(P=he())==null?void 0:P(W)}))}))},[s,i,e]),m=De(g=>l(void 0,null,function*(){return yield Ct({client:e,setSolanaWallet:r,createSolanaWalletCallbacks:n,setSolanaRecoveryFlowState:o,opts:g})}),[e,n]),p=De(()=>l(void 0,null,function*(){if(!c)throw new re({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=De(()=>l(void 0,null,function*(){if(!c)throw r({status:"not-created"}),new re({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 Zr(g)?(r({status:"needs-recovery"}),new re({code:"embedded_wallet_needs_recovery",error:"Embedded wallet not loaded on device"})):g instanceof Error?(r({status:"error",error:g.message}),new re({code:"unknown_embedded_wallet_error",error:g.message})):(r({status:"error",error:"Error loading embedded wallet"}),new re({code:"unknown_embedded_wallet_error",error:"Error loading embedded wallet"}))}}),[s,e,c,r]);return kt(()=>{if(!i&&t.status!=="disconnected")return r({status:"disconnected"});d&&h().catch(()=>{})},[d,i]),kt(()=>{t.status==="error"&&t.error.includes("User must be logged in")&&h()},[t.status]),{create:m,recover:p,getProvider:h,wallets:u}};import{useCallback as ie,useEffect as It,useMemo as uo}from"react";import{getUserEmbeddedEthereumWallet as mo,getUserEmbeddedSolanaWallet as Ot,isUnifiedWallet as po,throwIfInvalidRecoveryUpgradePath as yo}from"@privy-io/js-sdk-core";import{errorIndicatesRecoveryIsNeeded as fo,PrivyClientError as R}from"@privy-io/js-sdk-core";import{getUserEmbeddedEthereumWallet as to}from"@privy-io/js-sdk-core";import{PrivyClientError as q}from"@privy-io/js-sdk-core";function Se(m){return l(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 q({code:"embedded_wallet_recovery_error",error:"password is required for user-passcode recovery method"});break;case"recovery-encryption-key":if(!i)throw new q({code:"embedded_wallet_recovery_error",error:"key is required for recovery-encryption-key recovery method"});break;case"google-drive":if(!s)throw new q({code:"embedded_wallet_recovery_error",error:"Recovery token is required for google-drive recovery method"});break;case"icloud":if(!d||!c)throw new q({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=to(v);if(!f)throw new q({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 q({code:"embedded_wallet_creation_error",error:f})}})}import{Platform as Pt}from"react-native";import{PrivyClientError as N}from"@privy-io/js-sdk-core";function At(){return l(this,null,function*(){try{return yield import("@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 l(this,arguments,function*({user:e,appId:t,client:r}){var s;if(Pt.OS==="android")throw new N({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 N({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 N({code:"embedded_wallet_recovery_error",error:c})}throw new N({code:"embedded_wallet_recovery_error",error:"Error writing to iCloud"})}})}function Ee(o){return l(this,arguments,function*({walletAddress:e,client:t,chainType:r}){var c;if(Pt.OS==="android")throw new N({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 N({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 N({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 N({code:"embedded_wallet_recovery_error",error:m})}throw new N({code:"embedded_wallet_recovery_error",error:"Error writing to iCloud"})}})}import*as G from"expo-linking";import*as Ut from"expo-web-browser";import{Platform as Rt}from"react-native";import{PrivyClientError as J}from"@privy-io/js-sdk-core";import Ba from"react-fast-compare";import{PrivyApiError as ro,PrivyClientError as oo}from"@privy-io/js-sdk-core";function E(e){return e instanceof Error||e instanceof ro||e instanceof oo?e:typeof e=="string"?new Error(e):new Error("Unknown error")}var B=e=>new Promise(t=>setTimeout(t,e));import{useEffect as no,useRef as io}from"react";import{AppState as ze}from"react-native";function Ce(){let e=io(ze.currentState);no(()=>ze.addEventListener("change",o=>{e.current=o}).remove,[]);function t(){return ze.currentState}return{appState:e,getCurrentAppState:t}}function ne(n){return l(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 J({error:"OAuth invalid provider",code:"embedded_wallet_recovery_error"})}let i=yield Ut.openAuthSessionAsync(a);if(Rt.OS==="android")return;if(i.type!=="success")throw new J({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 J({error:"Recovery OAuth invalid credentials",code:"embedded_wallet_recovery_error"});d=yield _e({oAuthCode:u,oAuthState:c,client:r});break}default:throw new J({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 l(this,arguments,function*({oAuthCode:e,oAuthState:t,client:r}){let{access_token:n}=yield r.recovery.auth.authorize(e,t);if(!n)throw new J({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=>l(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 J({code:"embedded_wallet_set_recovery_error",error:"Failed to complete Google Drive recovery flow"}))},ao)}).finally(()=>{t==null||t.remove()})}function ke(e){return l(this,null,function*(){let t;Rt.OS==="android"&&(t=so(e));let r=yield ne({provider:"google-drive",client:e});return r!=null?r:yield t})}import{getUserEmbeddedWallet as co,PrivyClientError as lo}from"@privy-io/js-sdk-core";function We(a){return l(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=co(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 lo({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=uo(()=>mo(d),[d]),u=j(),m=ie(f=>l(void 0,null,function*(){var pe,ye;if(c)throw new R({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 R({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=Ot(w))!=null?ye:void 0})}),[e,c,d]),p=ie(f=>l(void 0,null,function*(){var C;if(r.status!=="connected")throw new R({code:"attempted_to_set_password_before_connected",error:"Embedded wallet must be connected before setting password"});if(!c)throw new R({code:"embedded_wallet_does_not_exist",error:"Embedded wallet does not exist"});if(Ot(d))throw new R({code:"embedded_wallet_set_recovery_error",error:"Cannot set user-controlled recovery for a user with an embedded Solana wallet."});if(po(c))throw new R({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"});yo({currentRecoveryMethod:c.recovery_method,upgradeToRecoveryMethod:f.recoveryMethod});let w,S;switch(f.recoveryMethod){case"privy":S=D(_({},f),{wallet:c});break;case"user-passcode":S=D(_({},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 R({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 R({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=ie(f=>l(void 0,null,function*(){return p({recoveryMethod:"user-passcode",password:f})}),[e,c,r.status]),g=ie(f=>l(void 0,null,function*(){var P;if(!c)throw new R({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 R({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=ie(()=>l(void 0,null,function*(){if(!c)throw o({status:"not-created",account:null}),new R({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 fo(f)?(o({status:"needs-recovery",account:c}),new R({code:"embedded_wallet_needs_recovery",error:"Embedded wallet not loaded on device"})):f instanceof Error?(o({status:"error",error:f.message,account:c}),new R({code:"unknown_embedded_wallet_error",error:f.message})):(o({status:"error",error:"Error loading embedded wallet",account:c}),new R({code:"unknown_embedded_wallet_error",error:"Error loading embedded wallet"}))}}),[e,c]);return It(()=>{if(!d&&r.status!=="disconnected")return o({status:"disconnected",account:null});u&&v().catch(()=>{})},[u,d,c]),It(()=>{r.status==="error"&&r.error.includes("User must be logged in")&&v()},[r.status]),{create:m,recover:g,setPassword:h,setRecovery:p,getProvider:v}};import{useEffect as go,useState as ho}from"react";import{PrivyClientError as Ft}from"@privy-io/js-sdk-core";var Tt=({client:e,isReady:t})=>{let r=A(),o=we(i=>i==null?void 0:i.customAuth),[n,a]=ho({status:"initial"});return go(()=>{(()=>l(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 Ft({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 Ft({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"}};import*as $ from"expo-linking";import{useCallback as wo,useEffect as vo,useMemo as bo}from"react";import{Platform as So}from"react-native";import{getUserEmbeddedSolanaWallet as Eo,getUserEmbeddedWallet as Co}from"@privy-io/js-sdk-core";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=bo(()=>Co(u),[u]),p=j(),h=wo(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 vo(()=>{function g(){return l(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=Eo(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)}}})}So.OS==="android"&&g()},[c,n.status,d,p])};import{useEffect as _o}from"react";var Nt=({client:e,isUserInitialized:t,setIsUserInitialized:r,setError:o})=>{_o(()=>{t||(()=>l(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])};import{useEffect as Ki,useRef as Vi}from"react";import{useCallback as je,useContext as ko}from"react";import{PrivyClientError as Wo}from"@privy-io/js-sdk-core";var Zs=e=>{let{client:t,setSiweState:r,siweState:o}=ko(y),n=je(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=je(u=>l(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:je(u=>l(void 0,[u],function*({signature:s,messageOverride:d,disableSignup:c}){var m;try{if(b())throw new Wo({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}};import{useCallback as zt}from"react";import{createSiwsMessage as Po,PrivyClientError as Ao}from"@privy-io/js-sdk-core";import{useContext as xo}from"react";var U=()=>{let{client:e}=xo(y);return e};var lc=()=>{let e=U(),t=zt(i=>l(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:Po({address:o,domain:n,uri:a,nonce:s})}}catch(s){throw E(s)}}),[e]),r=zt(s=>l(void 0,[s],function*({signature:o,message:n,wallet:{walletClientType:a,connectorType:i}={}}){try{if(!b())throw new Ao({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}};import{useCallback as jt}from"react";import{createSiwsMessage as Uo,PrivyClientError as Ro}from"@privy-io/js-sdk-core";var vc=()=>{let e=U(),t=jt(i=>l(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:Uo({address:o,domain:n,uri:a,nonce:s})}}catch(s){throw E(s)}}),[e]),r=jt(d=>l(void 0,[d],function*({signature:o,message:n,wallet:{walletClientType:a,connectorType:i}={},disableSignup:s}){try{if(b())throw new Ro({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}};import{useCallback as Kt,useContext as Io}from"react";import{PrivyClientError as Oo}from"@privy-io/js-sdk-core";var xc=e=>{let{client:t}=Io(y),r=Kt(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:Kt(a=>l(void 0,[a],function*({address:n}){var i;try{if(!b())throw new Oo({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])}};import{useCallback as Ke,useContext as Lo,useState as Mo}from"react";import{PrivyClientError as Vt}from"@privy-io/js-sdk-core";var Mc=e=>{let[t,r]=Mo(""),{client:o,otpState:n,setOtpState:a}=Lo(y),i=Ke(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=Ke(u=>l(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=Ke(m=>l(void 0,[m],function*({code:c,email:u}){var p;try{if(!b())throw new Vt({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 Vt({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}};import{useCallback as Gt,useContext as Fo}from"react";var jc=e=>{let{client:t}=Fo(y),r=Gt(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:Gt(a=>l(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])}};import{useCallback as Ve,useContext as To,useState as Do}from"react";import{PrivyClientError as Ht}from"@privy-io/js-sdk-core";var Qc=e=>{let[t,r]=Do(""),{client:o,otpState:n,setOtpState:a}=To(y),i=Ve(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=Ve(u=>l(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=Ve(p=>l(void 0,[p],function*({code:c,email:u,disableSignup:m}){var h;try{if(b())throw new Ht({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 Ht({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}};import{useCallback as Ge,useContext as No,useState as zo}from"react";import{PrivyClientError as qt}from"@privy-io/js-sdk-core";var nd=e=>{let[t,r]=zo(""),{client:o,otpState:n,setOtpState:a}=No(y),i=Ge(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=Ge(u=>l(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=Ge(m=>l(void 0,[m],function*({code:c,phone:u}){var p;try{if(!b())throw new qt({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 qt({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}};import{useCallback as He,useContext as jo,useState as Ko}from"react";import{PrivyClientError as Bt}from"@privy-io/js-sdk-core";var pd=e=>{let[t,r]=Ko(""),{client:o,otpState:n,setOtpState:a}=jo(y),i=He(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=He(u=>l(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=He(p=>l(void 0,[p],function*({code:c,phone:u,disableSignup:m}){var h;try{if(b())throw new Bt({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 Bt({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}};import*as xe from"expo-linking";import{useCallback as qe,useContext as Vo,useRef as Go}from"react";import{PrivyClientError as ae}from"@privy-io/js-sdk-core";var Sd=e=>{let{appState:t,getCurrentAppState:r}=Ce(),{client:o,farcasterState:n,setFarcasterState:a}=Vo(y),i=Go(!1),s=qe(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=qe(()=>{i.current=!0},[]);return{linkWithFarcaster:qe((h,...g)=>l(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 ae({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 ae({code:"failed_to_generate_farcaster_uri",error:"Failed to generate farcaster uri"});if(!S)throw new ae({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 ae({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(_({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 ae({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}};import{useCallback as Jt,useContext as Ho}from"react";var xd=e=>{let{client:t}=Ho(y),r=Jt(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:Jt(a=>l(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])}};import*as Pe from"expo-linking";import{useCallback as $e,useContext as qo,useRef as Bo}from"react";import{PrivyClientError as se}from"@privy-io/js-sdk-core";var Fd=e=>{let{appState:t,getCurrentAppState:r}=Ce(),{client:o,farcasterState:n,setFarcasterState:a}=qo(y),i=Bo(!1),s=$e(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=$e(()=>{i.current=!0},[]);return{loginWithFarcaster:$e((g,...v)=>l(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 se({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 se({code:"failed_to_generate_farcaster_uri",error:"Failed to generate farcaster uri"});if(!C)throw new se({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 se({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(_({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 se({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}};import{useCallback as $t,useContext as Jo}from"react";import{create as $o}from"zustand";import{PrivyClientError as Qo}from"@privy-io/js-sdk-core";var Qe=$o(()=>({status:"initial"})),K=e=>Qe.setState(e,!0),Yo=Qe.getState,qd=()=>{let{client:e}=Jo(y),t=Qe(),r=$t(()=>l(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=$t(n=>l(void 0,null,function*(){let a=Yo().status;try{if(b()){let c=new Qo({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}};import{useContext as Xo,useMemo as Zo}from"react";import{delegatedActions as Qt}from"@privy-io/js-sdk-core";var Xd=()=>{let{client:e}=Xo(y);return Zo(()=>({delegateWallet:Qt.delegateWallet(e),revokeWallets:Qt.revokeWallets(e)}),[e])};import{useContext as en,useMemo as tn}from"react";import{depositAddress as ce}from"@privy-io/js-sdk-core";var ol=()=>{let{client:e}=en(y);return tn(()=>({getConfig:()=>ce.getConfig(e),generateDepositAddress:t=>ce.generateDepositAddress(_({privy:e},t)),getDeposit:t=>ce.getDeposit(_({privy:e},t)),waitForDeposit:t=>ce.waitForDeposit(_({privy:e},t)),waitForCompletion:t=>ce.waitForCompletion(_({privy:e},t))}),[e])};import{useContext as nn,useMemo as an}from"react";import{addSessionSigners as sn,removeSessionSigners as cn}from"@privy-io/js-sdk-core";import{isEmbeddedWalletAccount as rn}from"@privy-io/js-sdk-core";function on(e,t){return e.linked_accounts.filter(rn).find(r=>r.address===t)}function Q(e){let t=b();if(!t)throw new Error("User must be authenticated to perform this operation");let r=on(t,e);if(!r)throw new Error(`No wallet found with address ${e}`);return r}var pl=()=>{let{client:e}=nn(y);return an(()=>({addSessionSigners:({address:t,signers:r})=>sn({client:e,wallet:Q(t),signers:r.map(o=>({signer_id:o.signerId,override_policy_ids:o.policyIds}))}),removeSessionSigners:({address:t})=>cn({client:e,wallet:Q(t)})}),[e])};import{useContext as dn,useMemo as ln}from"react";import{addSessionSigners as un,removeSessionSigners as mn}from"@privy-io/js-sdk-core";var vl=()=>{let{client:e}=dn(y);return ln(()=>({addSigners:({address:t,signers:r})=>un({client:e,wallet:Q(t),signers:r.map(o=>({signer_id:o.signerId,override_policy_ids:o.policyIds}))}),removeSigners:({address:t})=>mn({client:e,wallet:Q(t)})}),[e])};import{useContext as pn,useMemo as yn}from"react";import{PrivyClientError as Xt}from"@privy-io/js-sdk-core";var kl=()=>{let{client:e}=pn(y);return yn(()=>({sendCode(o){return l(this,arguments,function*({newEmailAddress:r}){Yt(),yield e.auth.email.sendCode(r)})},updateEmail(n){return l(this,arguments,function*({newEmailAddress:r,code:o}){let{address:a}=Yt(),{user:i}=yield e.auth.email.updateEmail({oldEmailAddress:a,newEmailAddress:r,code:o});return i})}}),[e])};function Yt(){let t=fn().linked_accounts.find(r=>r.type==="email");if(!t)throw new Xt({code:"attempted_update_email_without_a_linked_email",error:"Must have a linked email account already to update an email address. Use `useLinkEmail` to link an email account."});return t}function fn(){let e=b();if(!e)throw new Xt({code:"attempted_update_before_logged_in",error:"Must be logged in to update a user profile."});return e}import{useContext as gn,useMemo as hn}from"react";import{PrivyClientError as er}from"@privy-io/js-sdk-core";var Il=()=>{let{client:e}=gn(y);return hn(()=>({sendCode(o){return l(this,arguments,function*({newPhoneNumber:r}){Zt(),yield e.auth.phone.sendCode(r)})},updatePhone(n){return l(this,arguments,function*({newPhoneNumber:r,code:o}){let{phoneNumber:a}=Zt(),{user:i}=yield e.auth.phone.updatePhone({oldPhoneNumber:a,newPhoneNumber:r,code:o});return i})}}),[e])};function Zt(){let t=wn().linked_accounts.find(r=>r.type==="phone");if(!t)throw new er({code:"attempted_update_phone_without_a_linked_phone",error:"Must have a linked phone account already to update a phone number. Use `useLinkSMS` to link a phone number."});return t}function wn(){let e=b();if(!e)throw new er({code:"attempted_update_before_logged_in",error:"Must be logged in to update a user profile."});return e}import*as or from"expo-linking";import{useCallback as bn,useContext as Sn,useMemo as En}from"react";import{crossApp as Cn,PrivyClientError as _n}from"@privy-io/js-sdk-core";import*as rr from"expo-linking";import*as de from"expo-web-browser";import{PrivyClientError as tr}from"@privy-io/js-sdk-core";var T=(e,t)=>l(void 0,null,function*(){let r=yield de.openAuthSessionAsync(e,t,{createTask:!1});if(r.type!=="success")throw r.type===de.WebBrowserResultType.CANCEL||r.type===de.WebBrowserResultType.DISMISS?new tr({error:"OAuth session was cancelled",code:"oauth_session_failed"}):new tr({error:"OAuth session failed",code:"oauth_session_failed"});return vn(r.url)});function vn(e){let{queryParams:t}=rr.parse(e);return t}var Vl=()=>{let{client:e}=Sn(y),t=En(()=>Cn.loginWithCrossAppAuth({client:e,openAuthSession:T}),[e]);return{loginWithCrossApp:bn(a=>l(void 0,[a],function*({appId:o,redirectUri:n}){if(b())throw new _n({code:"attempted_login_with_cross_app_while_already_logged_in",error:"Already logged in, use `linkCrossAppAccount` if you are trying to link a cross app account to an existing account"});let{user:s}=yield t({providerAppId:o,redirectUrl:or.createURL(n||"/")});return{user:s}}),[t])}};import*as nr from"expo-linking";import{useCallback as kn,useContext as Wn,useMemo as xn}from"react";import{crossApp as Pn,PrivyClientError as An}from"@privy-io/js-sdk-core";var Yl=()=>{let{client:e}=Wn(y),t=xn(()=>Pn.linkWithCrossAppAuth({client:e,openAuthSession:T}),[e]);return{linkWithCrossApp:kn(a=>l(void 0,[a],function*({appId:o,redirectUri:n}){if(!b())throw new An({code:"attempted_link_cross_app_before_logged_in",error:"Must be logged in to link a cross app account, Use `loginWithCrossAppAccount` to login with cross app"});return{user:yield t({providerAppId:o,redirectUrl:nr.createURL(n||"/")})}}),[t])}};import*as ar from"expo-linking";import{useContext as Un,useMemo as ir}from"react";import{crossApp as Rn}from"@privy-io/js-sdk-core";var iu=()=>{let{client:e}=Un(y),t=ir(()=>Rn.wallet.signMessage({client:e,openAuthSession:T}),[e]);return ir(()=>({signMessage:({address:r,message:o,redirectUri:n="/"})=>t({user:b(),address:r,message:o,redirectUrl:ar.createURL(n)})}),[t])};import*as cr from"expo-linking";import{useContext as In,useMemo as sr}from