UNPKG

@privy-io/expo

Version:

Expo client for the Privy Auth API

1 lines • 72.6 kB
import{a as W,b as N,d}from"./chunk-OWCFWPAL.js";import{useEffect as It}from"react";import{create as Ot}from"zustand";var mr=Ot(()=>({status:"disconnected"})),ye=()=>mr.getState().onNeedsRecovery,Mt=e=>{It(()=>{mr.setState({onNeedsRecovery:e==null?void 0:e.onNeedsRecovery})},[e==null?void 0:e.onNeedsRecovery])};import{applicationId as pr}from"expo-application";import*as L from"expo-secure-store";import{PrivyClientError as Lt}from"@privy-io/js-sdk-core";var yr=()=>{if(typeof pr!="string")throw new Lt({error:"Cannot determine native application ID. Please make sure `expo-application` is installed as a dependency and that `ios.bundleId` or `android.package` is set.",code:"invalid_native_app_id"});return pr};function fr(e){return{get(r){return e.get(r.replaceAll(":","-"))},put(r,t){return e.put(r.replaceAll(":","-"),t)},del(r){return e.del(r.replaceAll(":","-"))},getKeys:()=>d(this,null,function*(){return[]})}}var fe={get(e){return L.getItemAsync(e,{keychainAccessible:L.AFTER_FIRST_UNLOCK_THIS_DEVICE_ONLY})},put(e,r){return L.setItemAsync(e,r,{keychainAccessible:L.AFTER_FIRST_UNLOCK_THIS_DEVICE_ONLY})},del(e){return L.deleteItemAsync(e,{keychainAccessible:L.AFTER_FIRST_UNLOCK_THIS_DEVICE_ONLY})},getKeys:()=>d(void 0,null,function*(){return[]})};import{digest as Tt}from"expo-crypto";import Nt from"@privy-io/js-sdk-core";var gr={name:"@privy-io/expo",version:"0.58.2",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",dev:"tsup --watch",format:'eslint "src/**/*.{ts,tsx,js,jsx}" --fix',"generate-types":"tsup --dts-only",lint:'eslint "src/**/*.{ts,tsx,js,jsx}"',test:"jest"},browserslist:["defaults","node >= 18","not op_mini all"],dependencies:{"@privy-io/js-sdk-core":"0.53.3","@scure/base":"^1.2.4",tweetnacl:"^1.0.3","react-fast-compare":"^3.2.2",zustand:"^5.0.4"},devDependencies:{"@privy-io/eslint-config-custom":"*","@privy-io/eslint-plugin-privy-rules":"*","@privy-io/tsconfig":"*","@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":"^1.0.3","@types/jest":"^29.1.2",buffer:"^5.4.3","eslint-plugin-react-hooks":"^5.0.0-canary-7118f5dd7-20230705",expo:"52.0.37","expo-apple-authentication":"7.1.3","expo-application":"6.0.2","expo-clipboard":"7.0.1","expo-crypto":"14.0.2",jest:"^29.7.0","jest-expo":"52.0.5","lucide-react-native":"^0.474.0",react:"^18.3.1","react-native":"0.77.1","react-test-renderer":"^18.3.1",tsup:"^6.2.3",typescript:"~5.5.3"},peerDependencies:{"@expo-google-fonts/inter":"*","@privy-io/expo-native-extensions":"0.0.5","expo-apple-authentication":"*","expo-application":"*","expo-clipboard":"*","expo-crypto":"*","expo-font":"*","expo-linking":"*","expo-secure-store":"*","expo-web-browser":"*",permissionless:"^0.2.47",react:"*","react-native":"*","react-native-passkeys":"^0.3.0","react-native-qrcode-styled":"*","react-native-safe-area-context":"*","react-native-svg":"*","react-native-webview":"*",viem:"^2.32.0"},peerDependenciesMeta:{"@expo-google-fonts/inter":{optional:!0},"expo-font":{optional:!0},permissionless:{optional:!0},viem:{optional:!0},"react-native-svg":{optional:!0},"expo-clipboard":{optional:!0},"react-native-qrcode-styled":{optional:!0},"react-native-safe-area-context":{optional:!0}},publishConfig:{access:"public"}};var hr=({appId:e,clientId:r,storage:t=fe,supportedChains:n,baseUrl:i,logLevel:o})=>new Nt({appId:e,clientId:r,supportedChains:n,storage:fr(t),sdkVersion:`expo:${gr.version}`,nativeAppIdentifier:yr(),crypto:{digest:Tt},baseUrl:i,logLevel:o});import{useCallback as ar,useContext as Wi}from"react";import{PrivyClientError as xi}from"@privy-io/js-sdk-core";import Z,{useState as O,useMemo as _i,createContext as Ei,useCallback as Ae,useRef as de,useEffect as St,useContext as Ci}from"react";import{AppState as _t,View as ki}from"react-native";import{PrivyClientError as Et}from"@privy-io/js-sdk-core";import Dt from"react-fast-compare";import{create as jt}from"zustand";var ge=jt(()=>{}),vr=e=>ge.setState(r=>Dt(r,e)?r:e),x=ge.getState;import Ht from"react";import{useCallback as zt,useEffect as Bt,useRef as qt}from"react";import{AppState as Gt}from"react-native";import Jt from"react-native-webview";import*as F from"expo-secure-store";function wr(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 br(e){return d(this,null,function*(){switch(e.event){case"app:secure-storage:get":{let{key:r}=e.data,t=yield F.getItemAsync(Oe(r),{keychainAccessible:F.AFTER_FIRST_UNLOCK_THIS_DEVICE_ONLY}).catch(n=>(console.warn("Failed to get the value from secure store",n),null));return{event:e.event,id:e.id,data:{value:t}}}case"app:secure-storage:remove":{let{key:r}=e.data,t=yield F.deleteItemAsync(Oe(r),{keychainAccessible:F.AFTER_FIRST_UNLOCK_THIS_DEVICE_ONLY}).then(()=>!0).catch(n=>(console.warn("Failed to remove the value from secure store",n),!1));return{event:e.event,id:e.id,data:{success:t}}}case"app:secure-storage:set":{let{key:r,value:t}=e.data,n=yield F.setItemAsync(Oe(r),t,{keychainAccessible:F.AFTER_FIRST_UNLOCK_THIS_DEVICE_ONLY}).then(()=>!0).catch(i=>(console.warn("Failed to write the value to secure store",i),!1));return{event:e.event,id:e.id,data:{success:n}}}}})}var Oe=e=>e.replaceAll(":","-");import Vt from"react-fast-compare";import{createStore as Kt,useStore as Me}from"zustand";var V=Kt()(()=>({user:null,proxyStatus:"loading"}));function b(){return V.getState().user}var Yi=V.subscribe.bind(V);function Le(e){V.setState(({user:r})=>Vt(r,e)?{}:{user:e})}var Fe=e=>V.setState({proxyStatus:e});function A(){return Me(V,e=>e.user)}function $i(){return Me(V,e=>!!e.user)}function K(){return Me(V,e=>e.proxyStatus!=="loading")}var Yt={shouldUseAppBackedStorage:!0},Sr=({client:e,isClientReady:r})=>{let t=qt(null);Bt(()=>Gt.addEventListener("change",o=>d(void 0,null,function*(){o==="active"&&((yield e.embeddedWallet.ping(500))||(Fe("reloading"),e.embeddedWallet.reload()))})).remove,[e]);let n=zt(i=>d(void 0,null,function*(){var s;let{data:o}=i.nativeEvent,a=JSON.parse(o);if(wr(a)){let l=yield br(a);(s=t.current)==null||s.postMessage(JSON.stringify(l));return}e.embeddedWallet.onMessage(a)}),[e]);return r?Ht.createElement(Jt,{style:{flex:1},ref:i=>{i&&(e.setMessagePoster(i),t.current=i)},cacheEnabled:!1,cacheMode:"LOAD_NO_CACHE",injectedJavaScriptObject:Yt,source:{uri:e.embeddedWallet.getURL()},webviewDebuggingEnabled:e.logger.level==="DEBUG",onLoad:()=>Fe("loaded"),onError:console.error,onMessage:n}):null};import{useCallback as Te,useEffect as kr,useMemo as Ne}from"react";import{errorIndicatesRecoveryIsNeeded as Qt,getAllUserEmbeddedSolanaWallets as Xt,getEntropyDetailsFromUser as Pr,PrivyClientError as te}from"@privy-io/js-sdk-core";import{getAllUserEmbeddedSolanaWallets as he,getEntropyDetailsFromAccount as _r,getUserEmbeddedEthereumWallet as $t,PrivyClientError as q}from"@privy-io/js-sdk-core";function Er(o){return d(this,arguments,function*({client:e,setSolanaWallet:r,createSolanaWalletCallbacks:t,setSolanaRecoveryFlowState:n,opts:i}){var a,s,l;r({status:"creating"});try{let{user:c}=yield e.user.get(),u=he(c),m=u[0],p=(a=$t(c))!=null?a:void 0;if(i!=null&&i.recoveryMethod&&i.recoveryMethod!=="privy")throw new q({code:"embedded_wallet_creation_error",error:"Unsupported recovery method for solana wallet."});if(!(i!=null&&i.createAdditional)&&m)throw new q({code:"embedded_wallet_creation_error",error:"Solana wallet already exists for this user. Set `createAdditional` to `true` to create another wallet"});let v,g;if(m){let y=p!=null?p:m,{entropyId:h,entropyIdVerifier:S}=_r(y),E=Math.max(...u.map(P=>P.wallet_index),0)+1,C=yield e.embeddedWallet.add({chainType:"solana",entropyId:h,entropyIdVerifier:S,hdWalletIndex:E}),k=he(C.user).find(P=>P.wallet_index===E);if(!k)throw new q({error:"Embedded wallet account not created",code:"embedded_wallet_creation_error"});v=yield e.embeddedWallet.getSolanaProvider(k,h,S),g=C.user}else{let y=yield e.embeddedWallet.createSolana({ethereumAccount:p}),h=he(y.user).find(k=>k.wallet_index===0);if(!h)throw new q({error:"Embedded wallet account not created",code:"embedded_wallet_creation_error"});let S=p!=null?p:h,{entropyId:E,entropyIdVerifier:C}=_r(S);v=yield e.embeddedWallet.getSolanaProvider(h,E,C),g=y.user}let w=he(g)[0];if(!w)throw new q({code:"embedded_wallet_creation_error",error:"Unknown error creating solana wallet"});return(l=(s=t.current)==null?void 0:s.onSuccess)==null||l.call(s,v),r({status:"connected",publicKey:w.public_key}),n({status:"initial"}),v}catch(c){let u=c instanceof Error?c.message:"Error creating embedded wallet";throw r({status:"error",error:u}),n({status:"initial"}),new q({code:"embedded_wallet_creation_error",error:u})}})}import{PrivyClientError as z}from"@privy-io/js-sdk-core";function ve(u){return d(this,arguments,function*({client:e,account:r,setWallet:t,recoverWalletCallbacks:n,recoveryMethod:i,setRecoveryFlowState:o,password:a,recoveryKey:s,recoveryToken:l,recoverySecretOverride:c}){var m,p,v,g;if(!r)throw new z({code:"embedded_wallet_does_not_exist",error:"Embedded wallet does not exist"});switch(i){case"user-passcode":if(!a)throw new z({code:"embedded_wallet_recovery_error",error:"password is required for user-passcode recovery method"});break;case"google-drive":if(!l)throw new z({code:"embedded_wallet_recovery_error",error:"Recovery token is required for google-drive recovery method"});break;case"icloud":if(!c)throw new z({code:"embedded_wallet_recovery_error",error:"Record name is required for icloud recovery method"});break;case"recovery-encryption-key":if(!s)throw new z({code:"embedded_wallet_recovery_error",error:"recoveryKey is required for recovery-encryption-key recovery method"});break}t({status:"connecting",account:r});try{let w=yield e.embeddedWallet.getProvider(r,a,l,c,s);return t({status:"connected",provider:w,account:r}),o({status:"initial"}),(p=(m=n.current)==null?void 0:m.onSuccess)==null||p.call(m,w),w}catch(w){t({status:"needs-recovery",account:r}),o({status:"initial"});let y=new z({code:"embedded_wallet_recovery_error",error:w instanceof Error?w.message:"Error recovering embedded wallet"});throw(g=(v=n.current)==null?void 0:v.onError)==null||g.call(v,y),y}})}function Cr(s){return d(this,arguments,function*({client:e,account:r,entropyId:t,entropyIdVerifier:n,setSolanaWallet:i,recoverSolanaWalletCallbacks:o,setSolanaRecoveryFlowState:a}){var l,c,u,m;i({status:"connecting"});try{let p=yield e.embeddedWallet.getSolanaProvider(r,t,n);return i({status:"connected",publicKey:p._publicKey}),a({status:"initial"}),(c=(l=o.current)==null?void 0:l.onSuccess)==null||c.call(l,p),p}catch(p){i({status:"needs-recovery"}),a({status:"initial"});let v=new z({code:"embedded_wallet_recovery_error",error:p instanceof Error?p.message:"Error recovering embedded wallet"});throw(m=(u=o.current)==null?void 0:u.onError)==null||m.call(u,v),v}})}var Wr=({client:e,solanaWallet:r,setSolanaWallet:t,setSolanaRecoveryFlowState:n,createSolanaWalletCallbacks:i,recoverSolanaWalletCallbacks:o})=>{let a=A(),s=Ne(()=>Xt(a),[a]),l=K(),c=Ne(()=>s.length===0?null:Pr(a),[a,s]),u=Ne(()=>{let g=s.map(S=>{let E=Pr(a,S);return E?{account:S,entropy:E}:null});if(g.some(S=>S===null))return[];let w=void 0,y=void 0,h=void 0;return g.filter(S=>S!==null).map(({account:S,entropy:{entropyId:E,entropyIdVerifier:C}})=>({address:S.address,publicKey:S.address,walletIndex:S.wallet_index,getProvider:()=>e.embeddedWallet.getSolanaProvider(S,E,C,w,y,h,k=>d(void 0,null,function*(){var P;yield(P=ye())==null?void 0:P(k)}))}))},[s,a,e]),m=Te(g=>d(void 0,null,function*(){return yield Er({client:e,setSolanaWallet:t,createSolanaWalletCallbacks:i,setSolanaRecoveryFlowState:n,opts:g})}),[e,i]),p=Te(()=>d(void 0,null,function*(){if(!c)throw new te({code:"embedded_wallet_does_not_exist",error:"Embedded wallet does not exist"});let{entropyId:g,entropyIdVerifier:w}=c;return Cr({client:e,account:s[0],entropyId:g,entropyIdVerifier:w,setSolanaWallet:t,recoverSolanaWalletCallbacks:o,setSolanaRecoveryFlowState:n})}),[e,c,s,o,n,t]),v=Te(()=>d(void 0,null,function*(){if(!c)throw t({status:"not-created"}),new te({code:"embedded_wallet_does_not_exist",error:"Embedded wallet does not exist"});t(g=>g.status==="connected"?{status:"reconnecting"}:{status:"connecting"});try{let{entropyId:g,entropyIdVerifier:w}=c,y=yield e.embeddedWallet.getSolanaProvider(s[0],g,w);return t({status:"connected",publicKey:s[0].public_key}),y}catch(g){throw Qt(g)?(t({status:"needs-recovery"}),new te({code:"embedded_wallet_needs_recovery",error:"Embedded wallet not loaded on device"})):g instanceof Error?(t({status:"error",error:g.message}),new te({code:"unknown_embedded_wallet_error",error:g.message})):(t({status:"error",error:"Error loading embedded wallet"}),new te({code:"unknown_embedded_wallet_error",error:"Error loading embedded wallet"}))}}),[s,e,c,t]);return kr(()=>{if(!a&&r.status!=="disconnected")return t({status:"disconnected"});l&&v().catch(()=>{})},[l,a]),kr(()=>{r.status==="error"&&r.error.includes("User must be logged in")&&v()},[r.status]),{create:m,recover:p,getProvider:v,wallets:u}};import{useCallback as ie,useEffect as Ir,useMemo as co}from"react";import{getUserEmbeddedEthereumWallet as lo,getUserEmbeddedSolanaWallet as Or,isUnifiedWallet as uo,throwIfInvalidRecoveryUpgradePath as mo}from"@privy-io/js-sdk-core";import{errorIndicatesRecoveryIsNeeded as po,PrivyClientError as U}from"@privy-io/js-sdk-core";import{getUserEmbeddedEthereumWallet as Zt}from"@privy-io/js-sdk-core";import{PrivyClientError as G}from"@privy-io/js-sdk-core";function we(m){return d(this,arguments,function*({client:e,setWallet:r,createWalletCallbacks:t,recoveryMethod:n,setRecoveryFlowState:i,password:o,recoveryKey:a,recoveryToken:s,recoverySecretOverride:l,iCloudRecordNameOverride:c,solanaAccount:u}){var v,g;switch(n){case"user-passcode":if(!o)throw new G({code:"embedded_wallet_recovery_error",error:"password is required for user-passcode recovery method"});break;case"recovery-encryption-key":if(!a)throw new G({code:"embedded_wallet_recovery_error",error:"key is required for recovery-encryption-key recovery method"});break;case"google-drive":if(!s)throw new G({code:"embedded_wallet_recovery_error",error:"Recovery token is required for google-drive recovery method"});break;case"icloud":if(!l||!c)throw new G({code:"embedded_wallet_recovery_error",error:"iCloud recovery failed due to inability to store credentials"});break}r({status:"creating",account:null});let p=n==="icloud"?"icloud-native":n;try{let{user:w}=yield e.embeddedWallet.create({password:o,recoveryMethod:p,recoveryKey:a,recoveryToken:s,recoverySecretOverride:l,iCloudRecordNameOverride:c,solanaAccount:u}),y=Zt(w);if(!y)throw new G({error:"Embedded wallet account not created",code:"embedded_wallet_creation_error"});let h=yield e.embeddedWallet.getProvider(y);return(g=(v=t.current)==null?void 0:v.onSuccess)==null||g.call(v,h),r({status:"connected",provider:h,account:y}),i({status:"initial"}),h}catch(w){let y=w instanceof Error?w.message:"Error creating embedded wallet";throw r({status:"error",error:y,account:null}),i({status:"initial"}),new G({code:"embedded_wallet_creation_error",error:y})}})}import{Platform as xr}from"react-native";import{PrivyClientError as D}from"@privy-io/js-sdk-core";function Ar(){return d(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(n){return d(this,arguments,function*({user:e,appId:r,client:t}){var s;if(xr.OS==="android")throw new D({code:"embedded_wallet_recovery_error",error:"iCloud recovery is not supported on Android"});let i=yield Ar(),o=yield t.recovery.icloudAuth.getICloudConfiguration("expo-ios");if(!(o==null?void 0:o.container_identifier))throw new D({code:"embedded_wallet_recovery_error",error:"An iCloud Container ID must be specified in the Privy Dashboard."});try{let{recoverySecret:l,iCloudRecordName:c}=yield i.writeRecoverySecretToICloud({containerId:o.container_identifier,appId:r,userId:e.id});return{recoverySecret:l,iCloudRecordName:c}}catch(l){if(l instanceof Error){let c=(s=l.message.split("Caused by: ")[1])!=null?s:"Error writing to iCloud";throw new D({code:"embedded_wallet_recovery_error",error:c})}throw new D({code:"embedded_wallet_recovery_error",error:"Error writing to iCloud"})}})}function be(n){return d(this,arguments,function*({walletAddress:e,client:r,chainType:t}){var c;if(xr.OS==="android")throw new D({code:"embedded_wallet_recovery_error",error:"iCloud recovery is not supported on Android"});let i=yield Ar(),a=(yield r.recovery.getRecoveryKeyMaterial(e,t)).icloud_record_name;if(!a)throw new D({code:"embedded_wallet_recovery_error",error:"iCloud recovery not properly backed up."});let s=yield r.recovery.icloudAuth.getICloudConfiguration("expo-ios"),l=s==null?void 0:s.container_identifier;if(!l)throw new D({code:"embedded_wallet_recovery_error",error:"An iCloud Container ID must be specified in the Privy Dashboard."});try{let{recoverySecret:u}=yield i.readRecoverySecretFromICloud({containerId:l,recordName:a});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 D({code:"embedded_wallet_recovery_error",error:m})}throw new D({code:"embedded_wallet_recovery_error",error:"Error writing to iCloud"})}})}import*as B from"expo-linking";import*as Ur from"expo-web-browser";import{Platform as Rr}from"react-native";import{PrivyClientError as Y}from"@privy-io/js-sdk-core";import Aa from"react-fast-compare";import{PrivyApiError as eo,PrivyClientError as ro}from"@privy-io/js-sdk-core";function _(e){return e instanceof Error||e instanceof eo||e instanceof ro?e:typeof e=="string"?new Error(e):new Error("Unknown error")}var J=e=>new Promise(r=>setTimeout(r,e));import{useEffect as to,useRef as oo}from"react";import{AppState as De}from"react-native";function Se(){let e=oo(De.currentState);to(()=>De.addEventListener("change",n=>{e.current=n}).remove,[]);function r(){return De.currentState}return{appState:e,getCurrentAppState:r}}function ne(i){return d(this,arguments,function*({provider:e,redirectUri:r,client:t,onError:n}){try{let o;switch(e){case"google-drive":{let{url:c}=yield t.recovery.auth.generateURL(B.createURL(r||"/"));o=c;break}default:throw new Y({error:"OAuth invalid provider",code:"embedded_wallet_recovery_error"})}let a=yield Ur.openAuthSessionAsync(o);if(Rr.OS==="android")return;if(a.type!=="success")throw new Y({error:"Recovery OAuth session failed",code:"embedded_wallet_recovery_error"});let{queryParams:s}=B.parse(a.url),l;switch(e){case"google-drive":{let{privy_oauth_state:c,privy_oauth_code:u}=s;if(!u||!c)throw new Y({error:"Recovery OAuth invalid credentials",code:"embedded_wallet_recovery_error"});l=yield _e({oAuthCode:u,oAuthState:c,client:t});break}default:throw new Y({error:"Recovery OAuth invalid provider",code:"embedded_wallet_recovery_error"})}return l}catch(o){throw n==null||n(_(o)),o}})}function _e(n){return d(this,arguments,function*({oAuthCode:e,oAuthState:r,client:t}){let{access_token:i}=yield t.recovery.auth.authorize(e,r);if(!i)throw new Y({error:"OAuth invalid credentials",code:"login_with_oauth_returned_with_invalid_credentials"});return i})}var no=2*60*1e3;function io(e){let r;return new Promise((t,n)=>{r=B.addEventListener("url",o=>d(this,[o],function*({url:i}){if(!i)return;let{queryParams:a}=B.parse(i),{privy_oauth_state:s,privy_oauth_code:l}=a!=null?a:{};if(typeof l!="string"||typeof s!="string")return;let c=yield _e({client:e,oAuthCode:l,oAuthState:s});t(c)})),setTimeout(()=>{n(new Y({code:"embedded_wallet_set_recovery_error",error:"Failed to complete Google Drive recovery flow"}))},no)}).finally(()=>{r==null||r.remove()})}function Ee(e){return d(this,null,function*(){let r;Rr.OS==="android"&&(r=io(e));let t=yield ne({provider:"google-drive",client:e});return t!=null?t:yield r})}import{getUserEmbeddedWallet as ao,PrivyClientError as so}from"@privy-io/js-sdk-core";function Ce(o){return d(this,arguments,function*({client:e,recoveryInput:r,setWalletRecoveryCallbacks:t,setRecoveryFlowState:n,setWallet:i}){var a,s,l,c;try{let{provider:u,user:m}=yield e.embeddedWallet.setRecovery(r),p=u,v=ao(m);return i({status:"connected",provider:p,account:v}),(s=(a=t.current)==null?void 0:a.onSuccess)==null||s.call(a,p),n({status:"initial"}),p}catch(u){let m=new so({code:"embedded_wallet_set_recovery_error",error:u instanceof Error?u.message:"Error setting password on embedded wallet"});throw(c=(l=t.current)==null?void 0:l.onError)==null||c.call(l,m),n({status:"initial"}),m}})}function Mr(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 Lr=({client:e,appId:r,wallet:t,setWallet:n,setRecoveryFlowState:i,createWalletCallbacks:o,recoverWalletCallbacks:a,setWalletRecoveryCallbacks:s})=>{let l=A(),c=co(()=>lo(l),[l]),u=K(),m=ie(y=>d(void 0,null,function*(){var ue,me;if(c)throw new U({error:"This user already has an embedded wallet",code:"embedded_wallet_already_exists"});let{user:h}=yield e.user.get(),{password:S,recoveryMethod:E,recoveryKey:C}=Mr(y),k,P,M;if(E==="google-drive"&&(k=yield ne({provider:E,client:e,onError:(ue=o.current)==null?void 0:ue.onError}),i({status:"creating-wallet"}),!k))return null;if(E==="icloud"){if(!h)throw new U({code:"embedded_wallet_recovery_error",error:"User must be loaded before creating a wallet with iCloud."});let{recoverySecret:Ue,iCloudRecordName:re}=yield oe({user:h,appId:r,client:e});P=Ue,M=re}return yield we({client:e,setWallet:n,createWalletCallbacks:o,recoveryMethod:E,recoveryKey:C,setRecoveryFlowState:i,password:S,recoverySecretOverride:P,iCloudRecordNameOverride:M,solanaAccount:(me=Or(h))!=null?me:void 0})}),[e,c,l]),p=ie(y=>d(void 0,null,function*(){var E;if(t.status!=="connected")throw new U({code:"attempted_to_set_password_before_connected",error:"Embedded wallet must be connected before setting password"});if(!c)throw new U({code:"embedded_wallet_does_not_exist",error:"Embedded wallet does not exist"});if(Or(l))throw new U({code:"embedded_wallet_set_recovery_error",error:"Cannot set user-controlled recovery for a user with an embedded Solana wallet."});if(uo(c))throw new U({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"});mo({currentRecoveryMethod:c.recovery_method,upgradeToRecoveryMethod:y.recoveryMethod});let h,S;switch(y.recoveryMethod){case"privy":S=N(W({},y),{wallet:c});break;case"user-passcode":S=N(W({},y),{wallet:c,password:y.password});break;case"google-drive":if(h=yield ne({provider:y.recoveryMethod,client:e,onError:(E=s.current)==null?void 0:E.onError}),i({status:"upgrading-recovery"}),!h)return null;S={recoveryMethod:"google-drive",wallet:c,recoveryAccessToken:h};break;case"icloud":if(!l)throw new U({code:"embedded_wallet_recovery_error",error:"User must be loaded before backing up to iCloud."});let{recoverySecret:C,iCloudRecordName:k}=yield oe({user:l,appId:r,client:e});S={recoveryMethod:"icloud-native",recoverySecretOverride:C,iCloudRecordNameOverride:k,wallet:c};break;default:throw new U({code:"embedded_wallet_recovery_error",error:"Unrecognized recovery method"})}return Ce({client:e,recoveryInput:S,setWalletRecoveryCallbacks:s,setRecoveryFlowState:i,setWallet:n})}),[e,c,t.status,l]),v=ie(y=>d(void 0,null,function*(){return p({recoveryMethod:"user-passcode",password:y})}),[e,c,t.status]),g=ie(y=>d(void 0,null,function*(){var P;if(!c)throw new U({code:"embedded_wallet_does_not_exist",error:"Embedded wallet does not exist"});let{password:h,recoveryMethod:S,recoveryKey:E}=Mr(y),C,k;if(S==="google-drive"&&(C=yield ne({provider:S,client:e,onError:(P=a.current)==null?void 0:P.onError}),i({status:"recovering"}),!C))return null;if(S==="icloud"){if(!l)throw new U({code:"embedded_wallet_recovery_error",error:"User must be loaded before recovering via iCloud."});let{recoverySecret:M}=yield be({client:e,walletAddress:c.address});k=M}return ve({client:e,account:c,setWallet:n,recoverWalletCallbacks:a,recoveryMethod:S,setRecoveryFlowState:i,recoveryKey:E,password:h,recoveryToken:C,recoverySecretOverride:k})}),[e,c]),w=ie(()=>d(void 0,null,function*(){if(!c)throw n({status:"not-created",account:null}),new U({code:"embedded_wallet_does_not_exist",error:"Embedded wallet does not exist"});n(y=>y.status==="connected"?{status:"reconnecting",account:c}:{status:"connecting",account:c});try{let y=yield e.embeddedWallet.getProvider(c);return n({status:"connected",provider:y,account:c}),y}catch(y){throw po(y)?(n({status:"needs-recovery",account:c}),new U({code:"embedded_wallet_needs_recovery",error:"Embedded wallet not loaded on device"})):y instanceof Error?(n({status:"error",error:y.message,account:c}),new U({code:"unknown_embedded_wallet_error",error:y.message})):(n({status:"error",error:"Error loading embedded wallet",account:c}),new U({code:"unknown_embedded_wallet_error",error:"Error loading embedded wallet"}))}}),[e,c]);return Ir(()=>{if(!l&&t.status!=="disconnected")return n({status:"disconnected",account:null});u&&w().catch(()=>{})},[u,l,c]),Ir(()=>{t.status==="error"&&t.error.includes("User must be logged in")&&w()},[t.status]),{create:m,recover:g,setPassword:v,setRecovery:p,getProvider:w}};import{useEffect as yo,useState as fo}from"react";import{PrivyClientError as Fr}from"@privy-io/js-sdk-core";var Tr=({client:e,isReady:r})=>{let t=A(),n=ge(a=>a==null?void 0:a.customAuth),[i,o]=fo({status:"initial"});return yo(()=>{(()=>d(void 0,null,function*(){if(!(n!=null&&n.enabled)){o({status:"not-enabled"});return}o({status:"loading"});let{getCustomAccessToken:s,isLoading:l}=n;if(!(!r||l))try{let c=yield s();if(!c&&t){yield e.auth.logout(),o({status:"done"});return}if(!c){o({status:"done"});return}if(t){o({status:"done"});return}let u=x();if(!(yield e.auth.customProvider.syncWithToken(c,{embedded:u==null?void 0:u.embedded}))){yield e.auth.logout(),o({status:"error",error:new Fr({error:"Failed to sync with custom auth provider",code:"third_party_auth_error"})});return}o({status:"done"})}catch(c){if(console.log("Error syncing with custom auth provider",c),o({status:"error",error:c}),t)throw yield e.auth.logout(),new Fr({error:"Third-party auth failed",code:"third_party_auth_error"})}}))()},[e,t,r,n==null?void 0:n.enabled,n==null?void 0:n.getCustomAccessToken,n==null?void 0:n.isLoading]),{customAuthState:i,customAuthStateIsSettled:i.status!=="loading"&&i.status!=="initial"}};import*as $ from"expo-linking";import{useCallback as go,useEffect as ho,useMemo as vo}from"react";import{Platform as wo}from"react-native";import{getUserEmbeddedSolanaWallet as bo,getUserEmbeddedWallet as So}from"@privy-io/js-sdk-core";var Nr=({client:e,createWalletCallbacks:r,recoverWalletCallbacks:t,setWalletRecoveryCallbacks:n,recoveryFlowState:i,oAuthState:o,setRecoveryFlowState:a,setWallet:s,appStateVisible:l})=>{let c=$.useURL(),u=A(),m=vo(()=>So(u),[u]),p=K(),v=go(g=>{var y,h,S,E;let w=_(g);i.status==="creating-wallet"?(h=(y=r.current).onError)==null||h.call(y,_(w)):(E=(S=t.current).onError)==null||E.call(S,_(w)),a({status:"initial"})},[i]);return ho(()=>{function g(){return d(this,null,function*(){var S;if(!c&&i.status!=="initial"&&l&&v(new Error("Recovery OAuth session failed")),!c||i.status==="initial"||o.status!=="initial"||!l||!p)return;let{queryParams:w}=$.parse(c),{privy_oauth_state:y,privy_oauth_code:h}=w;if(!(!h||!y)){yield $.openURL(c.split("?")[0]);try{let E=yield _e({oAuthCode:h,oAuthState:y,client:e});if(i.status==="creating-wallet"){let C=(S=bo(u))!=null?S:void 0;yield we({client:e,setWallet:s,createWalletCallbacks:r,recoveryMethod:"google-drive",setRecoveryFlowState:a,recoveryToken:E,solanaAccount:C})}else if(i.status==="upgrading-recovery"){if(!m)throw new Error("Embedded wallet not found");yield Ce({client:e,recoveryInput:{recoveryMethod:"google-drive",wallet:m,recoveryAccessToken:E},setWalletRecoveryCallbacks:n,setRecoveryFlowState:a,setWallet:s})}else yield ve({client:e,account:m,setWallet:s,recoverWalletCallbacks:t,recoveryMethod:"google-drive",setRecoveryFlowState:a,recoveryToken:E})}catch(E){v(E)}}})}wo.OS==="android"&&g()},[c,i.status,l,p])};import{useEffect as _o}from"react";var Dr=({client:e,isUserInitialized:r,setIsUserInitialized:t,setError:n})=>{_o(()=>{r||(()=>d(void 0,null,function*(){try{yield e.initialize()}catch(o){n(o instanceof Error?o:new Error(String(o)))}try{yield e.user.get()}catch(o){}finally{t(!0)}}))()},[e,r,n,t])};import{useEffect as bi,useRef as Si}from"react";import{useCallback as je,useContext as Eo}from"react";import{PrivyClientError as Co}from"@privy-io/js-sdk-core";var Ls=e=>{let{client:r,setSiweState:t,siweState:n}=Eo(f),i=je(s=>{var c;let l=_(s);return t({status:"error",error:l}),(c=e==null?void 0:e.onError)==null||c.call(e,l),l},[e==null?void 0:e.onError]),o=je(u=>d(void 0,[u],function*({wallet:s,from:{domain:l,uri:c}}){var m;try{t({status:"generating-message"});let p=yield r.auth.siwe.init(s,l,c);return t({status:"awaiting-signature"}),(m=e==null?void 0:e.onGenerateMessage)==null||m.call(e,p.message),p.message}catch(p){throw i(p)}}),[r,i,e==null?void 0:e.onGenerateMessage]);return{loginWithSiwe:je(u=>d(void 0,[u],function*({signature:s,messageOverride:l,disableSignup:c}){var m;try{if(b())throw new Co({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"});t({status:"submitting-signature"});let v=x(),g=yield r.auth.siwe.loginWithSiwe(s,void 0,l,c?"no-signup":"login-or-sign-up",{embedded:v==null?void 0:v.embedded});return t({status:"done"}),(m=e==null?void 0:e.onSuccess)==null||m.call(e,g.user,g.is_new_user),g.user}catch(p){throw i(p)}}),[r,i,e==null?void 0:e.onSuccess]),generateSiweMessage:o,state:n}};import{useCallback as jr}from"react";import{createSiwsMessage as Po,PrivyClientError as Wo}from"@privy-io/js-sdk-core";import{useContext as ko}from"react";var I=()=>{let{client:e}=ko(f);return e};var qs=()=>{let e=I(),r=jr(a=>d(void 0,[a],function*({wallet:{address:n},from:{domain:i,uri:o}}){try{let{nonce:s}=yield e.auth.siws.fetchNonce({address:n});return{message:Po({address:n,domain:i,uri:o,nonce:s})}}catch(s){throw _(s)}}),[e]),t=jr(s=>d(void 0,[s],function*({signature:n,message:i,wallet:{walletClientType:o,connectorType:a}={}}){try{if(!b())throw new Wo({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:n,message:i,walletClientType:o,connectorType:a});return c}catch(l){throw _(l)}}),[e]);return{generateMessage:r,link:t}};import{useCallback as Vr}from"react";import{createSiwsMessage as xo,PrivyClientError as Ao}from"@privy-io/js-sdk-core";var ec=()=>{let e=I(),r=Vr(a=>d(void 0,[a],function*({wallet:{address:n},from:{domain:i,uri:o}}){try{let{nonce:s}=yield e.auth.siws.fetchNonce({address:n});return{message:xo({address:n,domain:i,uri:o,nonce:s})}}catch(s){throw _(s)}}),[e]),t=Vr(l=>d(void 0,[l],function*({signature:n,message:i,wallet:{walletClientType:o,connectorType:a}={},disableSignup:s}){try{if(b())throw new Ao({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"});return(yield e.auth.siws.login({signature:n,message:i,walletClientType:o,connectorType:a,mode:s?"no-signup":"login-or-sign-up"})).user}catch(c){throw _(c)}}),[e]);return{generateMessage:r,login:t}};import{useCallback as Kr,useContext as Uo}from"react";import{PrivyClientError as Ro}from"@privy-io/js-sdk-core";var cc=e=>{let{client:r}=Uo(f),t=Kr(i=>{var a;let o=_(i);return(a=e==null?void 0:e.onError)==null||a.call(e,o),o},[e==null?void 0:e.onError]);return{unlinkWallet:Kr(o=>d(void 0,[o],function*({address:i}){var a;try{if(!b())throw new Ro({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:l}=yield r.auth.siwe.unlinkWallet(i);return(a=e==null?void 0:e.onSuccess)==null||a.call(e,l),l}catch(s){throw t(s)}}),[r,t,e==null?void 0:e.onSuccess])}};import{useCallback as Ve,useContext as Io,useState as Oo}from"react";import{PrivyClientError as Hr}from"@privy-io/js-sdk-core";var gc=e=>{let[r,t]=Oo(""),{client:n,otpState:i,setOtpState:o}=Io(f),a=Ve(c=>{var m;let u=_(c);return o({status:"error",error:u}),(m=e==null?void 0:e.onError)==null||m.call(e,u),u},[e,o]),s=Ve(u=>d(void 0,[u],function*({email:c}){var m;t(c);try{o({status:"sending-code"});let p=yield n.auth.email.sendCode(c);return o({status:"awaiting-code-input"}),(m=e==null?void 0:e.onSendCodeSuccess)==null||m.call(e,{email:c}),p}catch(p){throw a(p)}}),[n,a,e,o]),l=Ve(m=>d(void 0,[m],function*({code:c,email:u}){var p;try{if(!b())throw new Hr({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||r;if(!g)throw new Hr({code:"attempted_submit_otp_before_sending",error:"Must `sendCode` with a valid email before calling `linkWithCode`"});o({status:"submitting-code"});let{user:w}=yield n.auth.email.linkWithCode(g,c);return o({status:"done"}),(p=e==null?void 0:e.onLinkSuccess)==null||p.call(e,w),w}catch(v){throw a(v)}}),[r,o,n,e,a]);return{sendCode:s,linkWithCode:l,state:i}};import{useCallback as zr,useContext as Mo}from"react";var _c=e=>{let{client:r}=Mo(f),t=zr(i=>{var a;let o=_(i);return(a=e==null?void 0:e.onError)==null||a.call(e,o),o},[e==null?void 0:e.onError]);return{unlinkEmail:zr(o=>d(void 0,[o],function*({email:i}){var a;try{let{user:s}=yield r.auth.email.unlink(i);return(a=e==null?void 0:e.onSuccess)==null||a.call(e,s),s}catch(s){throw t(s)}}),[r,e==null?void 0:e.onSuccess,t])}};import{useCallback as Ke,useContext as Lo,useState as Fo}from"react";import{PrivyClientError as Br}from"@privy-io/js-sdk-core";var Rc=e=>{let[r,t]=Fo(""),{client:n,otpState:i,setOtpState:o}=Lo(f),a=Ke(c=>{var m;let u=_(c);return o({status:"error",error:u}),(m=e==null?void 0:e.onError)==null||m.call(e,u),u},[e,o]),s=Ke(u=>d(void 0,[u],function*({email:c}){var m;t(c);try{o({status:"sending-code"});let p=yield n.auth.email.sendCode(c);return o({status:"awaiting-code-input"}),(m=e==null?void 0:e.onSendCodeSuccess)==null||m.call(e,{email:c}),p}catch(p){throw a(p)}}),[n,a,e,o]),l=Ke(p=>d(void 0,[p],function*({code:c,email:u,disableSignup:m}){var v;try{if(b())throw new Br({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 w=u||r;if(!w)throw new Br({code:"attempted_submit_otp_before_sending",error:"Must `sendCode` with a valid email before calling `loginWithCode`"});o({status:"submitting-code"});let y=x(),h=yield n.auth.email.loginWithCode(w,c,m?"no-signup":"login-or-sign-up",{embedded:y==null?void 0:y.embedded});return o({status:"done"}),(v=e==null?void 0:e.onLoginSuccess)==null||v.call(e,h.user,h.is_new_user),h==null?void 0:h.user}catch(g){throw a(g)}}),[r,o,n,e,a]);return{sendCode:s,loginWithCode:l,state:i}};import{useCallback as He,useContext as To,useState as No}from"react";import{PrivyClientError as qr}from"@privy-io/js-sdk-core";var Dc=e=>{let[r,t]=No(""),{client:n,otpState:i,setOtpState:o}=To(f),a=He(c=>{var m;let u=_(c);return o({status:"error",error:u}),(m=e==null?void 0:e.onError)==null||m.call(e,u),u},[e,o]),s=He(u=>d(void 0,[u],function*({phone:c}){var m;t(c);try{o({status:"sending-code"});let p=yield n.auth.phone.sendCode(c);return o({status:"awaiting-code-input"}),(m=e==null?void 0:e.onSendCodeSuccess)==null||m.call(e,{phone:c}),p}catch(p){throw a(p)}}),[n,a,e,o]),l=He(m=>d(void 0,[m],function*({code:c,phone:u}){var p;try{if(!b())throw new qr({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||r))throw new qr({code:"attempted_submit_otp_before_sending",error:"Must `sendCode` with a valid phone number before calling `linkWithCode`"});o({status:"submitting-code"});let{user:w}=yield n.auth.phone.linkWithCode(u||r,c);return o({status:"done"}),(p=e==null?void 0:e.onLinkSuccess)==null||p.call(e,w),w}catch(v){throw a(v)}}),[r,o,n,e,a]);return{sendCode:s,linkWithCode:l,state:i}};import{useCallback as ze,useContext as Do,useState as jo}from"react";import{PrivyClientError as Gr}from"@privy-io/js-sdk-core";var Jc=e=>{let[r,t]=jo(""),{client:n,otpState:i,setOtpState:o}=Do(f),a=ze(c=>{var m;let u=_(c);return o({status:"error",error:u}),(m=e==null?void 0:e.onError)==null||m.call(e,u),u},[e,o]),s=ze(u=>d(void 0,[u],function*({phone:c}){var m;t(c);try{o({status:"sending-code"});let p=yield n.auth.phone.sendCode(c);return o({status:"awaiting-code-input"}),(m=e==null?void 0:e.onSendCodeSuccess)==null||m.call(e,{phone:c}),p}catch(p){throw a(p)}}),[n,a,e,o]),l=ze(p=>d(void 0,[p],function*({code:c,phone:u,disableSignup:m}){var v;try{if(b())throw new Gr({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||r))throw new Gr({code:"attempted_submit_otp_before_sending",error:"Must `sendCode` with a valid phone number before calling `loginWithCode`"});o({status:"submitting-code"});let y=x(),h=yield n.auth.phone.loginWithCode(u||r,c,m?"no-signup":"login-or-sign-up",{embedded:y==null?void 0:y.embedded});return o({status:"done"}),(v=e==null?void 0:e.onLoginSuccess)==null||v.call(e,h.user,h.is_new_user),h==null?void 0:h.user}catch(g){throw a(g)}}),[r,o,n,e,a]);return{sendCode:s,loginWithCode:l,state:i}};import*as ke from"expo-linking";import{useCallback as Be,useContext as Vo,useRef as Ko}from"react";import{PrivyClientError as ae}from"@privy-io/js-sdk-core";var tl=e=>{let{appState:r,getCurrentAppState:t}=Se(),{client:n,farcasterState:i,setFarcasterState:o}=Vo(f),a=Ko(!1),s=Be(u=>{var p;let m=_(u);return o({status:"error",error:m}),(p=e==null?void 0:e.onError)==null||p.call(e,m),m},[e==null?void 0:e.onError,o]),l=Be(()=>{a.current=!0},[]);return{linkWithFarcaster:Be((v,...g)=>d(void 0,[v,...g],function*({relyingParty:u,redirectUrl:m},p={pollAttempts:10,pollIntervalMs:1e3}){var w;try{let y=b();if(a.current=!1,!y)throw new ae({code:"attempted_link_farcaster_before_logged_in",error:"Must be logged in to link a Farcaster account."});o({status:"generating-uri"});let{connect_uri:h,channel_token:S}=yield n.auth.farcaster.initializeAuth({relyingParty:u,redirectUrl:ke.createURL(m!=null?m:"/")});if(!h)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 ke.openURL(h),o({status:"polling-status"});let E=0;for(;E<p.pollAttempts;){if(a.current)throw new ae({code:"farcaster_polling_canceled",error:"Farcaster polling canceled"});if(r.current!=="active"&&t()!=="active"){yield J(p.pollIntervalMs);continue}let C=yield n.auth.farcaster.getFarcasterStatus({channel_token:S});if(C.state==="completed"){o({status:"submitting-token"});let{user:k}=yield n.auth.farcaster.link(W({channel_token:S},C));return o({status:"done"}),(w=e==null?void 0:e.onSuccess)==null||w.call(e,k),k}E++,yield J(p.pollIntervalMs)}throw new ae({code:"farcaster_polling_timeout",error:"Farcasting polling timed out"})}catch(y){throw s(y)}}),[n,e==null?void 0:e.onSuccess,s,o]),state:i,cancel:l}};import{useCallback as Jr,useContext as Ho}from"react";var cl=e=>{let{client:r}=Ho(f),t=Jr(i=>{var a;let o=_(i);return(a=e==null?void 0:e.onError)==null||a.call(e,o),o},[e==null?void 0:e.onError]);return{unlinkFarcaster:Jr(o=>d(void 0,[o],function*({fid:i}){var a;try{let{user:s}=yield r.auth.farcaster.unlink({fid:i});return(a=e==null?void 0:e.onSuccess)==null||a.call(e,s),s}catch(s){throw t(s)}}),[r,e==null?void 0:e.onSuccess,t])}};import*as Pe from"expo-linking";import{useCallback as Je,useContext as zo,useRef as Bo}from"react";import{PrivyClientError as se}from"@privy-io/js-sdk-core";var hl=e=>{let{appState:r,getCurrentAppState:t}=Se(),{client:n,farcasterState:i,setFarcasterState:o}=zo(f),a=Bo(!1),s=Je(u=>{var p;let m=_(u);return o({status:"error",error:m}),(p=e==null?void 0:e.onError)==null||p.call(e,m),m},[e==null?void 0:e.onError,o]),l=Je(()=>{a.current=!0},[]);return{loginWithFarcaster:Je((g,...w)=>d(void 0,[g,...w],function*({relyingParty:u,redirectUrl:m,disableSignup:p},v={pollAttempts:10,pollIntervalMs:1e3}){var y;try{if(a.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"});o({status:"generating-uri"});let{connect_uri:S,channel_token:E}=yield n.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(!E)throw new se({code:"failed_to_generate_farcaster_channel_token",error:"Failed to generate farcaster channel token"});yield Pe.openURL(S),o({status:"polling-status"});let C=0;for(;C<v.pollAttempts;){if(a.current)throw new se({code:"farcaster_polling_canceled",error:"Farcaster polling canceled"});if(r.current!=="active"&&t()!=="active"){yield J(v.pollIntervalMs);continue}let k=yield n.auth.farcaster.getFarcasterStatus({channel_token:E});if(k.state==="completed"){o({status:"submitting-token"});let P=x(),M=yield n.auth.farcaster.authenticate(W({channel_token:E,mode:p?"no-signup":"login-or-sign-up"},k),{embedded:P==null?void 0:P.embedded});return o({status:"done"}),(y=e==null?void 0:e.onSuccess)==null||y.call(e,M.user,M.is_new_user),M.user}C++,yield J(v.pollIntervalMs)}throw new se({code:"farcaster_polling_timeout",error:"Farcasting polling timed out"})}catch(h){throw s(h)}}),[n,s,e==null?void 0:e.onSuccess,o,r]),state:i,cancel:l}};import{useCallback as Yr,useContext as qo}from"react";import{create as Go}from"zustand";import{PrivyClientError as Jo}from"@privy-io/js-sdk-core";var Ye=Go(()=>({status:"initial"})),H=e=>Ye.setState(e,!0),Yo=Ye.getState,Wl=()=>{let{client:e}=qo(f),r=Ye(),t=Yr(()=>d(void 0,null,function*(){try{H({status:"fetching-nonce"});let i=yield e.auth.farcasterV2.initializeAuth();return H({status:"awaiting-signature"}),i}catch(i){let o=_(i);throw H({status:"initial",error:o}),o}}),[e]),n=Yr(i=>d(void 0,null,function*(){let o=Yo().status;try{if(b()){let c=new Jo({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 H({status:o,error:c}),c}H({status:"submitting-signature"});let s=x(),l=yield e.auth.farcasterV2.authenticate(i,{embedded:s==null?void 0:s.embedded});return H({status:"done"}),setTimeout(()=>H({status:"initial"}),1500),{user:l.user}}catch(a){let s=_(a);throw H({status:o,error:s}),s}}),[e]);return{init:t,login:n,state:r}};import{useContext as $o,useMemo as Qo}from"react";import{delegatedActions as $r}from"@privy-io/js-sdk-core";var Ol=()=>{let{client:e}=$o(f);return Qo(()=>({delegateWallet:$r.delegateWallet(e),revokeWallets:$r.revokeWallets(e)}),[e])};import{useContext as en,useMemo as rn}from"react";import{addSessionSigners as tn,removeSessionSigners as on}from"@privy-io/js-sdk-core";import{isEmbeddedWalletAccount as Xo}from"@privy-io/js-sdk-core";function Zo(e,r){return e.linked_accounts.filter(Xo).find(t=>t.address===r)}function $e(e){let r=b();if(!r)throw new Error("User must be authenticated to perform this operation");let t=Zo(r,e);if(!t)throw new Error(`No wallet found with address ${e}`);return t}var Kl=()=>{let{client:e}=en(f);return rn(()=>({addSessionSigners:({address:r,signers:t})=>tn({client:e,wallet:$e(r),signers:t.map(n=>({signer_id:n.signerId,override_policy_ids:n.policyIds}))}),removeSessionSigners:({address:r})=>on({client:e,wallet:$e(r)})}),[e])};import{useContext as nn,useMemo as an}from"react";import{PrivyClientError as Xr}from"@privy-io/js-sdk-core";var Jl=()=>{let{client:e}=nn(f);return an(()=>({sendCode(n){return d(this,arguments,function*({newEmailAddress:t}){Qr(),yield e.auth.email.sendCode(t)})},updateEmail(i){return d(this,arguments,function*({newEmailAddress:t,code:n}){let{address:o}=Qr(),{user:a}=yield e.auth.email.updateEmail({oldEmailAddress:o,newEmailAddress:t,code:n});return a})}}),[e])};function Qr(){let r=sn().linked_accounts.find(t=>t.type==="email");if(!r)throw new Xr({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 r}function sn(){let e=b();if(!e)throw new Xr({code:"attempted_update_before_logged_in",error:"Must be logged in to update a user profile."});return e}import{useContext as cn,useMemo as ln}from"react";import{PrivyClientError as et}from"@privy-io/js-sdk-core";var rd=()=>{let{client:e}=cn(f);return ln(()=>({sendCode(n){return d(this,arguments,function*({newPhoneNumber:t}){Zr(),yield e.auth.phone.sendCode(t)})},updatePhone(i){return d(this,arguments,function*({newPhoneNumber:t,code:n}){let{phoneNumber:o}=Zr(),{user:a}=yield e.auth.phone.updatePhone({oldPhoneNumber:o,newPhoneNumber:t,code:n});return a})}}),[e])};function Zr(){let r=dn().linked_accounts.find(t=>t.type==="phone");if(!r)throw new et({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 r}function dn(){let e=b();if(!e)throw new et({code:"attempted_update_before_logged_in",error:"Must be logged in to update a user profile."});return e}import*as ot from"expo-linking";import{useCallback as mn,useContext as pn,useMemo as yn}from"react";import{crossApp as fn,PrivyClientError as gn}from"@privy-io/js-sdk-core";import*as tt from"expo-linking";import*as ce from"expo-web-browser";import{PrivyClientError as rt}from"@privy-io/js-sdk-core";var T=(e,r)=>d(void 0,null,function*(){let t=yield ce.openAuthSessionAsync(e,r,{createTask:!1});if(t.type!=="success")throw t.type===ce.WebBrowserResultType.CANCEL||t.type===ce.WebBrowserResultType.DISMISS?new rt({error:"OAuth session was cancelled",code:"oauth_session_failed"}):new rt({error:"OAuth session failed",code:"oauth_session_failed"});return un(t.url)});function un(e){let{queryParams:r}=tt.parse(e);return r}var md=()=>{let{client:e}=pn(f),r=yn(()=>fn.loginWithCrossAppAuth({client:e,openAuthSession:T}),[e]);return{loginWithCrossApp:mn(o=>d(void 0,[o],function*({appId:n,redirectUri:i}){if(b())throw new gn({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 r({providerAppId:n,redirectUrl:ot.createURL(i||"/")});return{user:s}}),[r])}};import*as nt from"expo-linking";import{useCallback as hn,useContext as vn,useMemo as wn}from"react";import{crossApp as bn,PrivyClientError as Sn}from"@privy-io/js-sdk-core";var bd=()=>{let{client:e}=vn(f),r=wn(()=>bn.linkWithCrossAppAuth({client:e,openAuthSession:T}),[e]);return{linkWithCrossApp:hn(o=>d(void 0,[o],function*({appId:n,redirectUri:i}){if(!b())throw new Sn({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 r({providerAppId:n,redirectUrl:nt.createURL(i||"/")})}}),[r])}};import*as at from"expo-linking";import{useContext as _n,useMemo as it}from"react";import{crossApp as En}from"@privy-io/js-sdk-core";var xd=()=>{let{client:e}=_n(f),r=it(()=>En.wallet.signMessage({client:e,openAuthSession:T}),[e]);return it(()=>({signMessage:({address:t,message:n,redirectUri:i="/"})=>r({user:b(),address:t,message:n,redirectUrl:at.createURL(i)})}),[r])};import*as ct from"expo-linking";import{useContext as Cn,useMemo as st}from"react";import{crossApp as kn}from"@privy-io/js-sdk-core";var Ld=()=>{let{client:e}=Cn(f),r=st(()=>kn.wallet.signTypedData({client:e,openAuthSession:T}),[e]);return st(()=>({signTypedData:({address:t,typedData:n,redirectUri:i="/"})=>r({user:b(),address:t,typedData:n,redirectUrl:ct.cr