@crossmint/client-sdk-react-native-ui 0.4.16 → 0.4.18

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (40) hide show
  1. package/dist/chunk-22GIA4MK.js +1 -0
  2. package/dist/chunk-24LYBMXY.cjs +17 -0
  3. package/dist/{chunk-P3LUXXWV.js → chunk-56YROBGG.js} +1 -1
  4. package/dist/chunk-CK4JCQY6.cjs +1 -0
  5. package/dist/chunk-F4CHPSRS.js +17 -0
  6. package/dist/{chunk-VIA5NAWD.cjs → chunk-OCM4UKCZ.cjs} +1 -1
  7. package/dist/{chunk-BZACBNUH.cjs → chunk-R3KSNRO2.cjs} +1 -1
  8. package/dist/{chunk-ZRIYUAKZ.js → chunk-SYFNPOWZ.js} +1 -1
  9. package/dist/chunk-XA3CJXOO.js +1 -0
  10. package/dist/{chunk-OFWUQQBR.cjs → chunk-XBWLXXPM.cjs} +1 -1
  11. package/dist/hooks/index.cjs +1 -1
  12. package/dist/hooks/index.js +1 -1
  13. package/dist/hooks/useCrossmintAuth.cjs +1 -1
  14. package/dist/hooks/useCrossmintAuth.js +1 -1
  15. package/dist/hooks/useWallet.cjs +1 -1
  16. package/dist/hooks/useWallet.js +1 -1
  17. package/dist/hooks/useWalletsAuth.cjs +1 -1
  18. package/dist/hooks/useWalletsAuth.js +1 -1
  19. package/dist/index.cjs +1 -1
  20. package/dist/index.js +1 -1
  21. package/dist/providers/CrossmintAuthProvider.cjs +1 -1
  22. package/dist/providers/CrossmintAuthProvider.js +1 -1
  23. package/dist/providers/CrossmintProvider.cjs +1 -1
  24. package/dist/providers/CrossmintProvider.js +1 -1
  25. package/dist/providers/CrossmintRecoveryKeyProvider.cjs +1 -1
  26. package/dist/providers/CrossmintRecoveryKeyProvider.js +1 -1
  27. package/dist/providers/CrossmintWalletProvider.cjs +1 -1
  28. package/dist/providers/CrossmintWalletProvider.js +1 -1
  29. package/dist/providers/index.cjs +1 -1
  30. package/dist/providers/index.js +1 -1
  31. package/dist/testUtils.cjs +1 -1
  32. package/dist/testUtils.js +1 -1
  33. package/dist/utils/SecureStorage.cjs +1 -1
  34. package/dist/utils/SecureStorage.js +1 -1
  35. package/package.json +8 -8
  36. package/dist/chunk-O5AL6DBJ.cjs +0 -1
  37. package/dist/chunk-T3Q4KTE4.js +0 -1
  38. package/dist/chunk-TKB736C5.js +0 -1
  39. package/dist/chunk-WTPTLPLV.cjs +0 -17
  40. package/dist/chunk-YWHWC4WZ.js +0 -17
@@ -0,0 +1 @@
1
+ var m=Object.defineProperty,n=Object.defineProperties;var o=Object.getOwnPropertyDescriptors;var h=Object.getOwnPropertySymbols;var p=Object.prototype.hasOwnProperty,q=Object.prototype.propertyIsEnumerable;var i=(c,b,a)=>b in c?m(c,b,{enumerable:!0,configurable:!0,writable:!0,value:a}):c[b]=a,r=(c,b)=>{for(var a in b||(b={}))p.call(b,a)&&i(c,a,b[a]);if(h)for(var a of h(b))q.call(b,a)&&i(c,a,b[a]);return c},s=(c,b)=>n(c,o(b));var t=(c,b,a)=>new Promise((j,g)=>{var k=d=>{try{e(a.next(d))}catch(f){g(f)}},l=d=>{try{e(a.throw(d))}catch(f){g(f)}},e=d=>d.done?j(d.value):Promise.resolve(d.value).then(k,l);e((a=a.apply(c,b)).next())});export{r as a,s as b,t as c};
@@ -0,0 +1,17 @@
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }var _chunkOCM4UKCZcjs = require('./chunk-OCM4UKCZ.cjs');var _chunkCK4JCQY6cjs = require('./chunk-CK4JCQY6.cjs');var _react = require('react'); var _react2 = _interopRequireDefault(_react);var _bs58 = require('bs58'); var _bs582 = _interopRequireDefault(_bs58);var _web3js = require('@solana/web3.js');var _clientsdkrnwindow = require('@crossmint/client-sdk-rn-window');var _clientsigners = require('@crossmint/client-signers');var _reactnative = require('react-native');var _commonsdkbase = require('@crossmint/common-sdk-base');var _clientsdkreactbase = require('@crossmint/client-sdk-react-base');var _jsxruntime = require('react/jsx-runtime');var B=_react2.default.createContext(null);function Oe(){let E=_react.useContext.call(void 0, B);if(E==null)throw new Error("useCrossmintRecoveryKey must be used within a CrossmintRecoveryKeyProvider");return E}var b={timeoutMs:1e4,intervalMs:5e3},I="https://crossmint-signer-frames.onrender.com";function We({children:E,experimental_secureEndpointUrl:G=I}){let{crossmint:{apiKey:i,jwt:s,appId:h}}=_chunkOCM4UKCZcjs.e.call(void 0, ),{getOrCreateWallet:P,clearWallet:L}=_react.useContext.call(void 0, _clientsdkreactbase.WalletContext),w=_react.useRef.call(void 0, null),d=_react.useRef.call(void 0, null),[p,R]=_react.useState.call(void 0, !1),[pe,W]=_react.useState.call(void 0, null),[g,c]=_react.useState.call(void 0, !1),k=_react.useRef.call(void 0, !1),S=_react.useRef.call(void 0, !1),f=_react.useRef.call(void 0, null),z=_react.useMemo.call(void 0, ()=>h!=null?`window.crossmintAppId = '${h}';`:"",[h]);_react.useEffect.call(void 0, ()=>{w.current!=null&&d.current==null&&(d.current=new (0, _clientsdkrnwindow.WebViewParent)(w,{incomingEvents:_clientsigners.signerOutboundEvents,outgoingEvents:_clientsigners.signerInboundEvents}))},[]),_react.useEffect.call(void 0, ()=>{s==null&&!k.current?(c(!1),W(null),L(),k.current=!0):s!=null&&(k.current=!1,p&&X())},[s,p]),_react.useEffect.call(void 0, ()=>{S.current=g},[g]);let A=_react.useCallback.call(void 0, ()=>_chunkCK4JCQY6cjs.c.call(void 0, this,null,function*(){if(console.log("handleAuthRequired needsAuth",S.current),!S.current)return;let t,o,n=new Promise((e,r)=>{t=e,o=r});f.current={promise:n,resolve:t,reject:o};try{console.log("Waiting for auth promise"),yield f.current.promise,console.log("Auth promise resolved")}catch(e){throw e}}),[]),K=_react.useCallback.call(void 0, t=>_chunkCK4JCQY6cjs.c.call(void 0, this,null,function*(){var e;let o=d.current;if(o==null||!p)throw new Error("[sendEmailWithOtp] WebViewParent not ready or handshake incomplete.");if(s==null||i==null)throw new Error("[sendEmailWithOtp] Missing authentication credentials (JWT or API Key).");if(!g)throw new Error("OTP email request is not applicable in the current state.");W(t);let n=`email:${t}`;try{let r=yield o.sendAction({event:"request:start-onboarding",responseEvent:"response:start-onboarding",data:{authData:{jwt:s,apiKey:i},data:{authId:n}},options:b});if((r==null?void 0:r.status)==="success"&&r.signerStatus==="ready"){c(!1);return}if((r==null?void 0:r.status)==="error")throw console.error("[sendEmailWithOtp] Failed to send OTP:",r),new Error(r.error||"Failed to initiate OTP process.");console.log("[sendEmailWithOtp] OTP process likely initiated. Waiting for verification.")}catch(r){throw console.error("[sendEmailWithOtp] Error sending start-onboarding request:",r),(e=f.current)==null||e.reject(r),r}}),[p,s,i,g]),V=_react.useCallback.call(void 0, t=>_chunkCK4JCQY6cjs.c.call(void 0, this,null,function*(){var n,e,r;let o=d.current;if(o==null||!p)throw new Error("[verifyOtp] WebViewParent not ready or handshake incomplete.");if(s==null||i==null)throw new Error("[verifyOtp] Missing authentication credentials (JWT or API Key).");if(!g)throw new Error("Not currently awaiting OTP validation.");try{let a=yield o.sendAction({event:"request:complete-onboarding",responseEvent:"response:complete-onboarding",data:{authData:{jwt:s,apiKey:i},data:{onboardingAuthentication:{encryptedOtp:t}}},options:b});if((a==null?void 0:a.status)==="success"){console.log("[verifyOtp] OTP validation successful"),c(!1),(n=f.current)==null||n.resolve();return}else{console.error("[verifyOtp] Failed to validate OTP:",a),c(!0);let l=a&&a.status==="error"?a.error:"Failed to validate encrypted OTP";throw(e=f.current)==null||e.reject(new Error(l)),new Error(l)}}catch(a){throw console.error("[verifyOtp] Error sending OTP validation request:",a),c(!0),(r=f.current)==null||r.reject(a),a}}),[p,s,i,g]),H=_react.useRef.call(void 0, null),q=_react.useCallback.call(void 0, t=>{H.current=t},[]),Q=t=>{if(t.encoding!=="base58"||t.keyType!=="ed25519")throw new Error("Unsupported key type and encoding: "+t.keyType+" "+t.encoding)},O=_react.useCallback.call(void 0, t=>{let o=d.current;if(o==null||s==null||i==null)throw new Error("Cannot build signer: Missing prerequisites (parent, jwt, apiKey).");return{type:"solana-keypair",address:t,signer:{signMessage:n=>_chunkCK4JCQY6cjs.c.call(void 0, this,null,function*(){yield A();try{let e=yield o.sendAction({event:"request:sign",responseEvent:"response:sign",data:{authData:{jwt:s,apiKey:i},data:{bytes:_bs582.default.encode(n),keyType:"ed25519",encoding:"base58"}},options:b});if(e==null||e.status==="error"||e.signature==null)throw console.error("Failed signMessage response:",e),new Error("Failed to sign message");if(e.signature.encoding==="base58"&&e.signature.bytes)return _bs582.default.decode(e.signature.bytes);throw new Error("Unsupported encoding: "+e.signature.encoding)}catch(e){throw console.error("Error during signMessage:",e),e}}),signTransaction:n=>_chunkCK4JCQY6cjs.c.call(void 0, this,null,function*(){yield A();try{let e=n.message.serialize(),r=yield o.sendAction({event:"request:sign",responseEvent:"response:sign",data:{authData:{jwt:s,apiKey:i},data:{bytes:_bs582.default.encode(e),keyType:"ed25519",encoding:"base58"}},options:b});if(r==null||r.status==="error"||r.signature==null)throw new Error("Failed to sign transaction: No signature returned");if(r.signature.encoding==="base58"&&r.signature.bytes)n.addSignature(new (0, _web3js.PublicKey)(t),_bs582.default.decode(r.signature.bytes));else throw new Error("Unsupported encoding: "+r.signature.encoding);return n}catch(e){throw console.error("Error during signTransaction:",e),e}})}}},[s,i,A]),X=_react.useCallback.call(void 0, ()=>_chunkCK4JCQY6cjs.c.call(void 0, this,null,function*(){var o;let t=d.current;if(t==null||!p||s==null||i==null){console.warn("[checkSignerExists] Prerequisites not met (WebView, JWT, API Key). Status:",{isWebViewReady:p,hasJwt:s!=null,hasApiKey:i!=null}),c(!1);return}try{let n=yield t.sendAction({event:"request:get-status",responseEvent:"response:get-status",data:{authData:{jwt:s,apiKey:i}},options:b});if((n==null?void 0:n.status)==="success"&&n.signerStatus==="ready"){let e=(o=n.publicKeys)==null?void 0:o.ed25519;if(e==null||e.bytes==null||e.encoding==null)throw new Error("No public key found");Q(_chunkCK4JCQY6cjs.b.call(void 0, _chunkCK4JCQY6cjs.a.call(void 0, {},e),{keyType:"ed25519"}));let r=O(e.bytes);c(!1),yield P({type:"solana-smart-wallet",args:{adminSigner:r}})}else console.log("checkSignerExists needsAuth true",g),c(!0)}catch(n){console.error("[checkSignerExists] Error checking for signer:",n),c(!0)}}),[p,s,i,O,P]),Y=_react.useCallback.call(void 0, ()=>_chunkCK4JCQY6cjs.c.call(void 0, this,null,function*(){let t=d.current;if(t!=null)try{yield t.handshakeWithChild(),R(!0)}catch(o){console.error("[RN] handshakeWithChild error:",o),R(!1)}}),[]),Z=_react.useCallback.call(void 0, t=>{let o=d.current;if(o!=null){try{let n=JSON.parse(t.nativeEvent.data);if(n&&typeof n.type=="string"&&n.type.startsWith("console.")){let e=n.type.split(".")[1],r=(n.data||[]).map(l=>{try{return l==="[Function]"||l==="[Circular Reference]"||l==="[Unserializable Object]"?l:JSON.parse(l)}catch(_){return l}}),a=`[WebView:${e.toUpperCase()}]`;switch(e){case"log":console.log(a,...r);break;case"error":console.error(a,...r);break;case"warn":console.warn(a,...r);break;case"info":console.info(a,...r);break;default:console.log(`[WebView Unknown:${e}]`,...r)}return}}catch(n){}o.handleMessage(t)}},[]),D=_react.useCallback.call(void 0, t=>_chunkCK4JCQY6cjs.c.call(void 0, this,null,function*(){if(s==null||i==null||h==null)return console.warn("[createRecoveryKeySigner] Prerequisites not met (WebView ready, JWT, API Key, App ID). Cannot proceed."),c(!1),null;if(W(t),d.current==null)return console.error("[createRecoveryKeySigner] WebView parent disappeared unexpectedly."),c(!1),null;try{let n=_commonsdkbase.validateApiKeyAndGetCrossmintBaseUrl.call(void 0, i),e=yield fetch(`${n}api/unstable/wallets/ncs/irrelevant/public-key`,{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${s}`,"x-api-key":i,"x-app-identifier":h},body:JSON.stringify({authId:`email:${t}`,signingAlgorithm:"EDDSA_ED25519"})});if(!e.ok){let x=yield e.text();throw new Error(`Failed to fetch public key: ${e.status} ${x}`)}let r=yield e.json();if(!r.publicKey)throw new Error("Fetched data does not contain a public key.");let a=r.publicKey,l=Uint8Array.from(atob(a),x=>x.charCodeAt(0)),_=_bs582.default.encode(l),re=O(_);return yield P({type:"solana-smart-wallet",args:{adminSigner:re}}),c(!0),null}catch(n){return console.error("[createRecoveryKeySigner] Error during public key fetch or processing:",n),c(!0),null}}),[s,i,h,O,P]),M=_react.useCallback.call(void 0, ()=>{if(w.current==null)return;w.current.injectJavaScript(`
2
+ try {
3
+ localStorage.clear();
4
+ sessionStorage.clear();
5
+ const cookies = document.cookie.split(';');
6
+ for (let i = 0; i < cookies.length; i++) {
7
+ const cookie = cookies[i];
8
+ const eqPos = cookie.indexOf('=');
9
+ const name = eqPos > -1 ? cookie.substr(0, eqPos) : cookie;
10
+ document.cookie = name + '=;expires=Thu, 01 Jan 1970 00:00:00 GMT;path=/';
11
+ }
12
+ indexedDB.deleteDatabase('crossmint');
13
+ indexedDB.deleteDatabase('crossmint-signer');
14
+ } catch (error) {
15
+ console.error('Error clearing storage:', error);
16
+ }
17
+ `)},[]),ee=_react.useMemo.call(void 0, ()=>({experimental_needsAuth:g,experimental_createRecoveryKeySigner:D,experimental_sendEmailWithOtp:K,experimental_verifyOtp:V,onAuthRequired:q,experimental_clearStorage:M}),[g,D,K,V,q,M]);return _jsxruntime.jsxs.call(void 0, B.Provider,{value:ee,children:[E,_jsxruntime.jsx.call(void 0, _reactnative.View,{style:{position:"absolute",width:0,height:0,overflow:"hidden"},children:_jsxruntime.jsx.call(void 0, _clientsdkrnwindow.RNWebView,{ref:w,source:{uri:G},injectedGlobals:z,onLoadEnd:Y,onMessage:Z,onError:t=>{console.error("WebView onError:",t.nativeEvent),R(!1),c(!1)},onHttpError:t=>{console.error("WebView onHttpError:",t.nativeEvent),R(!1),c(!1)},style:{width:1,height:1},javaScriptCanOpenWindowsAutomatically:!1,thirdPartyCookiesEnabled:!1,sharedCookiesEnabled:!1,incognito:!1,setSupportMultipleWindows:!1,originWhitelist:[I]})})]})}exports.a = B; exports.b = Oe; exports.c = We;
@@ -1 +1 @@
1
- import{a as c,c as m}from"./chunk-YWHWC4WZ.js";import{a as l}from"./chunk-KZMAEKSM.js";import{a as i}from"./chunk-TKB736C5.js";import{useContext as v,useMemo as y}from"react";import{CrossmintWalletProvider as p,WalletContext as d}from"@crossmint/client-sdk-react-base";import{Fragment as W,jsx as t}from"react/jsx-runtime";var C=["experimental_needsAuth","experimental_createRecoveryKeySigner","experimental_sendEmailWithOtp","experimental_verifyOtp"];function u({children:n}){let r=v(d),o=v(c);if(r==null)throw new Error("BaseWalletContext not found. Ensure CrossmintWalletProvider structure is correct.");let s=y(()=>{let e=i({},r);if(o!=null)Object.assign(e,o);else for(let a of C)Object.defineProperty(e,a,{get(){throw new Error(`Cannot access '${a}'. Ensure 'experimental_enableRecoveryKeys={true}' is set on CrossmintWalletProvider.`)},enumerable:!0,configurable:!0});return e},[r,o]);return t(l.Provider,{value:s,children:n})}function h({children:n,experimental_enableRecoveryKeys:r=!1,experimental_secureEndpointUrl:o}){return t(p,{children:t(({children:e})=>r?t(m,{experimental_secureEndpointUrl:o,children:e}):t(W,{children:e}),{children:t(u,{children:n})})})}export{h as a};
1
+ import{a as c,c as m}from"./chunk-F4CHPSRS.js";import{a as l}from"./chunk-KZMAEKSM.js";import{a as i}from"./chunk-22GIA4MK.js";import{useContext as v,useMemo as y}from"react";import{CrossmintWalletProvider as p,WalletContext as d}from"@crossmint/client-sdk-react-base";import{Fragment as W,jsx as t}from"react/jsx-runtime";var C=["experimental_needsAuth","experimental_createRecoveryKeySigner","experimental_sendEmailWithOtp","experimental_verifyOtp"];function u({children:n}){let r=v(d),o=v(c);if(r==null)throw new Error("BaseWalletContext not found. Ensure CrossmintWalletProvider structure is correct.");let s=y(()=>{let e=i({},r);if(o!=null)Object.assign(e,o);else for(let a of C)Object.defineProperty(e,a,{get(){throw new Error(`Cannot access '${a}'. Ensure 'experimental_enableRecoveryKeys={true}' is set on CrossmintWalletProvider.`)},enumerable:!0,configurable:!0});return e},[r,o]);return t(l.Provider,{value:s,children:n})}function h({children:n,experimental_enableRecoveryKeys:r=!1,experimental_secureEndpointUrl:o}){return t(p,{children:t(({children:e})=>r?t(m,{experimental_secureEndpointUrl:o,children:e}):t(W,{children:e}),{children:t(u,{children:n})})})}export{h as a};
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true});var m=Object.defineProperty,n=Object.defineProperties;var o=Object.getOwnPropertyDescriptors;var h=Object.getOwnPropertySymbols;var p=Object.prototype.hasOwnProperty,q=Object.prototype.propertyIsEnumerable;var i=(c,b,a)=>b in c?m(c,b,{enumerable:!0,configurable:!0,writable:!0,value:a}):c[b]=a,r= exports.a =(c,b)=>{for(var a in b||(b={}))p.call(b,a)&&i(c,a,b[a]);if(h)for(var a of h(b))q.call(b,a)&&i(c,a,b[a]);return c},s= exports.b =(c,b)=>n(c,o(b));var t=(c,b,a)=>new Promise((j,g)=>{var k=d=>{try{e(a.next(d))}catch(f){g(f)}},l=d=>{try{e(a.throw(d))}catch(f){g(f)}},e=d=>d.done?j(d.value):Promise.resolve(d.value).then(k,l);e((a=a.apply(c,b)).next())});exports.a = r; exports.b = s; exports.c = t;
@@ -0,0 +1,17 @@
1
+ import{e as N}from"./chunk-XA3CJXOO.js";import{a as U,b as j,c as y}from"./chunk-22GIA4MK.js";import te,{useCallback as u,useContext as $,useEffect as C,useRef as m,useState as T,useMemo as F}from"react";import v from"bs58";import{PublicKey as ne}from"@solana/web3.js";import{RNWebView as oe}from"@crossmint/client-sdk-rn-window";import{WebViewParent as se}from"@crossmint/client-sdk-rn-window";import{signerInboundEvents as ie,signerOutboundEvents as ae}from"@crossmint/client-signers";import{View as ce}from"react-native";import{validateApiKeyAndGetCrossmintBaseUrl as le}from"@crossmint/common-sdk-base";import{WalletContext as ue}from"@crossmint/client-sdk-react-base";import{jsx as J,jsxs as de}from"react/jsx-runtime";var B=te.createContext(null);function We(){let E=$(B);if(E==null)throw new Error("useCrossmintRecoveryKey must be used within a CrossmintRecoveryKeyProvider");return E}var b={timeoutMs:1e4,intervalMs:5e3},I="https://crossmint-signer-frames.onrender.com";function ke({children:E,experimental_secureEndpointUrl:G=I}){let{crossmint:{apiKey:i,jwt:s,appId:h}}=N(),{getOrCreateWallet:P,clearWallet:L}=$(ue),w=m(null),d=m(null),[p,R]=T(!1),[pe,W]=T(null),[g,c]=T(!1),k=m(!1),S=m(!1),f=m(null),z=F(()=>h!=null?`window.crossmintAppId = '${h}';`:"",[h]);C(()=>{w.current!=null&&d.current==null&&(d.current=new se(w,{incomingEvents:ae,outgoingEvents:ie}))},[]),C(()=>{s==null&&!k.current?(c(!1),W(null),L(),k.current=!0):s!=null&&(k.current=!1,p&&X())},[s,p]),C(()=>{S.current=g},[g]);let A=u(()=>y(this,null,function*(){if(console.log("handleAuthRequired needsAuth",S.current),!S.current)return;let t,o,n=new Promise((e,r)=>{t=e,o=r});f.current={promise:n,resolve:t,reject:o};try{console.log("Waiting for auth promise"),yield f.current.promise,console.log("Auth promise resolved")}catch(e){throw e}}),[]),K=u(t=>y(this,null,function*(){var e;let o=d.current;if(o==null||!p)throw new Error("[sendEmailWithOtp] WebViewParent not ready or handshake incomplete.");if(s==null||i==null)throw new Error("[sendEmailWithOtp] Missing authentication credentials (JWT or API Key).");if(!g)throw new Error("OTP email request is not applicable in the current state.");W(t);let n=`email:${t}`;try{let r=yield o.sendAction({event:"request:start-onboarding",responseEvent:"response:start-onboarding",data:{authData:{jwt:s,apiKey:i},data:{authId:n}},options:b});if((r==null?void 0:r.status)==="success"&&r.signerStatus==="ready"){c(!1);return}if((r==null?void 0:r.status)==="error")throw console.error("[sendEmailWithOtp] Failed to send OTP:",r),new Error(r.error||"Failed to initiate OTP process.");console.log("[sendEmailWithOtp] OTP process likely initiated. Waiting for verification.")}catch(r){throw console.error("[sendEmailWithOtp] Error sending start-onboarding request:",r),(e=f.current)==null||e.reject(r),r}}),[p,s,i,g]),V=u(t=>y(this,null,function*(){var n,e,r;let o=d.current;if(o==null||!p)throw new Error("[verifyOtp] WebViewParent not ready or handshake incomplete.");if(s==null||i==null)throw new Error("[verifyOtp] Missing authentication credentials (JWT or API Key).");if(!g)throw new Error("Not currently awaiting OTP validation.");try{let a=yield o.sendAction({event:"request:complete-onboarding",responseEvent:"response:complete-onboarding",data:{authData:{jwt:s,apiKey:i},data:{onboardingAuthentication:{encryptedOtp:t}}},options:b});if((a==null?void 0:a.status)==="success"){console.log("[verifyOtp] OTP validation successful"),c(!1),(n=f.current)==null||n.resolve();return}else{console.error("[verifyOtp] Failed to validate OTP:",a),c(!0);let l=a&&a.status==="error"?a.error:"Failed to validate encrypted OTP";throw(e=f.current)==null||e.reject(new Error(l)),new Error(l)}}catch(a){throw console.error("[verifyOtp] Error sending OTP validation request:",a),c(!0),(r=f.current)==null||r.reject(a),a}}),[p,s,i,g]),H=m(null),q=u(t=>{H.current=t},[]),Q=t=>{if(t.encoding!=="base58"||t.keyType!=="ed25519")throw new Error("Unsupported key type and encoding: "+t.keyType+" "+t.encoding)},O=u(t=>{let o=d.current;if(o==null||s==null||i==null)throw new Error("Cannot build signer: Missing prerequisites (parent, jwt, apiKey).");return{type:"solana-keypair",address:t,signer:{signMessage:n=>y(this,null,function*(){yield A();try{let e=yield o.sendAction({event:"request:sign",responseEvent:"response:sign",data:{authData:{jwt:s,apiKey:i},data:{bytes:v.encode(n),keyType:"ed25519",encoding:"base58"}},options:b});if(e==null||e.status==="error"||e.signature==null)throw console.error("Failed signMessage response:",e),new Error("Failed to sign message");if(e.signature.encoding==="base58"&&e.signature.bytes)return v.decode(e.signature.bytes);throw new Error("Unsupported encoding: "+e.signature.encoding)}catch(e){throw console.error("Error during signMessage:",e),e}}),signTransaction:n=>y(this,null,function*(){yield A();try{let e=n.message.serialize(),r=yield o.sendAction({event:"request:sign",responseEvent:"response:sign",data:{authData:{jwt:s,apiKey:i},data:{bytes:v.encode(e),keyType:"ed25519",encoding:"base58"}},options:b});if(r==null||r.status==="error"||r.signature==null)throw new Error("Failed to sign transaction: No signature returned");if(r.signature.encoding==="base58"&&r.signature.bytes)n.addSignature(new ne(t),v.decode(r.signature.bytes));else throw new Error("Unsupported encoding: "+r.signature.encoding);return n}catch(e){throw console.error("Error during signTransaction:",e),e}})}}},[s,i,A]),X=u(()=>y(this,null,function*(){var o;let t=d.current;if(t==null||!p||s==null||i==null){console.warn("[checkSignerExists] Prerequisites not met (WebView, JWT, API Key). Status:",{isWebViewReady:p,hasJwt:s!=null,hasApiKey:i!=null}),c(!1);return}try{let n=yield t.sendAction({event:"request:get-status",responseEvent:"response:get-status",data:{authData:{jwt:s,apiKey:i}},options:b});if((n==null?void 0:n.status)==="success"&&n.signerStatus==="ready"){let e=(o=n.publicKeys)==null?void 0:o.ed25519;if(e==null||e.bytes==null||e.encoding==null)throw new Error("No public key found");Q(j(U({},e),{keyType:"ed25519"}));let r=O(e.bytes);c(!1),yield P({type:"solana-smart-wallet",args:{adminSigner:r}})}else console.log("checkSignerExists needsAuth true",g),c(!0)}catch(n){console.error("[checkSignerExists] Error checking for signer:",n),c(!0)}}),[p,s,i,O,P]),Y=u(()=>y(this,null,function*(){let t=d.current;if(t!=null)try{yield t.handshakeWithChild(),R(!0)}catch(o){console.error("[RN] handshakeWithChild error:",o),R(!1)}}),[]),Z=u(t=>{let o=d.current;if(o!=null){try{let n=JSON.parse(t.nativeEvent.data);if(n&&typeof n.type=="string"&&n.type.startsWith("console.")){let e=n.type.split(".")[1],r=(n.data||[]).map(l=>{try{return l==="[Function]"||l==="[Circular Reference]"||l==="[Unserializable Object]"?l:JSON.parse(l)}catch(_){return l}}),a=`[WebView:${e.toUpperCase()}]`;switch(e){case"log":console.log(a,...r);break;case"error":console.error(a,...r);break;case"warn":console.warn(a,...r);break;case"info":console.info(a,...r);break;default:console.log(`[WebView Unknown:${e}]`,...r)}return}}catch(n){}o.handleMessage(t)}},[]),D=u(t=>y(this,null,function*(){if(s==null||i==null||h==null)return console.warn("[createRecoveryKeySigner] Prerequisites not met (WebView ready, JWT, API Key, App ID). Cannot proceed."),c(!1),null;if(W(t),d.current==null)return console.error("[createRecoveryKeySigner] WebView parent disappeared unexpectedly."),c(!1),null;try{let n=le(i),e=yield fetch(`${n}api/unstable/wallets/ncs/irrelevant/public-key`,{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${s}`,"x-api-key":i,"x-app-identifier":h},body:JSON.stringify({authId:`email:${t}`,signingAlgorithm:"EDDSA_ED25519"})});if(!e.ok){let x=yield e.text();throw new Error(`Failed to fetch public key: ${e.status} ${x}`)}let r=yield e.json();if(!r.publicKey)throw new Error("Fetched data does not contain a public key.");let a=r.publicKey,l=Uint8Array.from(atob(a),x=>x.charCodeAt(0)),_=v.encode(l),re=O(_);return yield P({type:"solana-smart-wallet",args:{adminSigner:re}}),c(!0),null}catch(n){return console.error("[createRecoveryKeySigner] Error during public key fetch or processing:",n),c(!0),null}}),[s,i,h,O,P]),M=u(()=>{if(w.current==null)return;w.current.injectJavaScript(`
2
+ try {
3
+ localStorage.clear();
4
+ sessionStorage.clear();
5
+ const cookies = document.cookie.split(';');
6
+ for (let i = 0; i < cookies.length; i++) {
7
+ const cookie = cookies[i];
8
+ const eqPos = cookie.indexOf('=');
9
+ const name = eqPos > -1 ? cookie.substr(0, eqPos) : cookie;
10
+ document.cookie = name + '=;expires=Thu, 01 Jan 1970 00:00:00 GMT;path=/';
11
+ }
12
+ indexedDB.deleteDatabase('crossmint');
13
+ indexedDB.deleteDatabase('crossmint-signer');
14
+ } catch (error) {
15
+ console.error('Error clearing storage:', error);
16
+ }
17
+ `)},[]),ee=F(()=>({experimental_needsAuth:g,experimental_createRecoveryKeySigner:D,experimental_sendEmailWithOtp:K,experimental_verifyOtp:V,onAuthRequired:q,experimental_clearStorage:M}),[g,D,K,V,q,M]);return de(B.Provider,{value:ee,children:[E,J(ce,{style:{position:"absolute",width:0,height:0,overflow:"hidden"},children:J(oe,{ref:w,source:{uri:G},injectedGlobals:z,onLoadEnd:Y,onMessage:Z,onError:t=>{console.error("WebView onError:",t.nativeEvent),R(!1),c(!1)},onHttpError:t=>{console.error("WebView onHttpError:",t.nativeEvent),R(!1),c(!1)},style:{width:1,height:1},javaScriptCanOpenWindowsAutomatically:!1,thirdPartyCookiesEnabled:!1,sharedCookiesEnabled:!1,incognito:!1,setSupportMultipleWindows:!1,originWhitelist:[I]})})]})}export{B as a,We as b,ke as c};
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { newObj[key] = obj[key]; } } } newObj.default = obj; return newObj; } } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }var _chunkBZACBNUHcjs = require('./chunk-BZACBNUH.cjs');var _chunkO5AL6DBJcjs = require('./chunk-O5AL6DBJ.cjs');var _react = require('react');var _expowebbrowser = require('expo-web-browser'); var i = _interopRequireWildcard(_expowebbrowser);var _clientsdkauth = require('@crossmint/client-sdk-auth');var _commonsdkauth = require('@crossmint/common-sdk-auth');var _clientsdkreactbase = require('@crossmint/client-sdk-react-base');function ot(){let o=_react.useContext.call(void 0, A);if(!o)throw new Error("useCrossmintAuth must be used within a CrossmintAuthProvider");return o}function nt(){let o=_react.useContext.call(void 0, A);if(!o)throw new Error("useAuth must be used within a CrossmintAuthProvider");return o}var _reactnative = require('react-native');var _expoconstants = require('expo-constants'); var _expoconstants2 = _interopRequireDefault(_expoconstants);var _jsxruntime = require('react/jsx-runtime');var z={google:null,twitter:null},Y={crossmintAuth:void 0,logout:()=>{},jwt:void 0,user:void 0,status:"initializing",getUser:()=>{},loginWithOAuth:()=>Promise.resolve(),createAuthSession:()=>Promise.resolve(null)},A= exports.a =_react.createContext.call(void 0, Y);function yt({children:o,onLoginSuccess:u,refreshRoute:h,logoutRoute:O,customStorageProvider:p,appSchema:f}){let[w,y]=_react.useState.call(void 0, void 0),{crossmint:n,setJwt:d}=_clientsdkreactbase.useCrossmint.call(void 0, "CrossmintAuthProvider must be used within CrossmintProvider"),[k,D]=_react.useState.call(void 0, z),U=_react.useRef.call(void 0, null),a=_react.useMemo.call(void 0, ()=>p!=null?p:new _chunkBZACBNUHcjs.a,[p]),[F,S]=_react.useState.call(void 0, !1),[K,x]=_react.useState.call(void 0, !1),N=Array.isArray(f)?f[0]:f,b=_expoconstants2.default.executionEnvironment==="storeClient"||_expoconstants2.default.appOwnership==="expo"||!!_expoconstants2.default.expoVersion?"exp://127.0.0.1:8081":N,e=_react.useMemo.call(void 0, ()=>{if(!U.current){let t={callbacks:{onLogout:()=>{d(void 0),y(void 0)},onTokenRefresh:r=>{d(r.jwt),y(r.user)}},refreshRoute:h,logoutRoute:O,storageProvider:a};U.current=_clientsdkauth.CrossmintAuth.from(n,t)}return U.current},[a]),M=_react.useCallback.call(void 0, ()=>{u==null||u()},[u]);_react.useEffect.call(void 0, ()=>{n.jwt==null?a==null||a.get(_commonsdkauth.SESSION_PREFIX).then(t=>{t!=null&&d(t)}).finally(()=>{S(!0)}):S(!0)},[n.jwt,d,a]),_react.useEffect.call(void 0, ()=>{n.jwt!=null&&M()},[n.jwt,M]);let _=()=>{e.logout()},R=_react.useCallback.call(void 0, ()=>_chunkO5AL6DBJcjs.b.call(void 0, this,null,function*(){try{let r=Object.keys(z).map(l=>_chunkO5AL6DBJcjs.b.call(void 0, this,null,function*(){let m=yield e==null?void 0:e.getOAuthUrl(l,{appSchema:b});return{[l]:m}})),s=Object.assign({},...yield Promise.all(r));D(s)}catch(t){console.error(t)}}),[e]);_react.useEffect.call(void 0, ()=>{w==null&&R()},[R,w]);let G=()=>F?K?"in-progress":n.jwt!=null?"logged-in":"logged-out":"initializing",J=()=>_chunkO5AL6DBJcjs.b.call(void 0, this,null,function*(){if(n.jwt==null){console.log("User not logged in");return}let t=yield e.getUser();y(t)}),V=t=>_chunkO5AL6DBJcjs.b.call(void 0, this,null,function*(){var r;try{x(!0);let s=(r=k[t])!=null?r:yield e.getOAuthUrl(t,{appSchema:b});yield i.warmUpAsync();let l=new URL(s);if(t==="google"&&l.searchParams.append("provider_prompt","select_account"),_reactnative.Platform.OS==="android")yield i.openBrowserAsync(l.toString());else{let m=yield i.openAuthSessionAsync(l.toString());m.type==="success"&&(yield E(m.url))}yield i.coolDownAsync()}catch(s){console.error("[CrossmintAuthProvider] Error during OAuth login:",s)}}),E=_react.useCallback.call(void 0, t=>_chunkO5AL6DBJcjs.b.call(void 0, this,null,function*(){let r=t.includes("://")?Z(t):t;if(r!=null)try{return x(!0),yield e.handleRefreshAuthMaterial(r)}catch(s){throw s}finally{x(!1)}return null}),[e]);return _jsxruntime.jsx.call(void 0, A.Provider,{value:{crossmintAuth:e,logout:_,jwt:n.jwt,user:w,status:G(),getUser:J,loginWithOAuth:V,createAuthSession:E},children:o})}var Z=o=>{let u=/[?&]oneTimeSecret=([^&#]+)/,h=o.match(u);return h?decodeURIComponent(h[1]):void 0};exports.a = A; exports.b = yt; exports.c = ot; exports.d = nt; exports.e = _clientsdkreactbase.useCrossmint;
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { newObj[key] = obj[key]; } } } newObj.default = obj; return newObj; } } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }var _chunkR3KSNRO2cjs = require('./chunk-R3KSNRO2.cjs');var _chunkCK4JCQY6cjs = require('./chunk-CK4JCQY6.cjs');var _react = require('react');var _expowebbrowser = require('expo-web-browser'); var i = _interopRequireWildcard(_expowebbrowser);var _clientsdkauth = require('@crossmint/client-sdk-auth');var _commonsdkauth = require('@crossmint/common-sdk-auth');var _clientsdkreactbase = require('@crossmint/client-sdk-react-base');function ot(){let o=_react.useContext.call(void 0, A);if(!o)throw new Error("useCrossmintAuth must be used within a CrossmintAuthProvider");return o}function nt(){let o=_react.useContext.call(void 0, A);if(!o)throw new Error("useAuth must be used within a CrossmintAuthProvider");return o}var _reactnative = require('react-native');var _expoconstants = require('expo-constants'); var _expoconstants2 = _interopRequireDefault(_expoconstants);var _jsxruntime = require('react/jsx-runtime');var z={google:null,twitter:null},Y={crossmintAuth:void 0,logout:()=>{},jwt:void 0,user:void 0,status:"initializing",getUser:()=>{},loginWithOAuth:()=>Promise.resolve(),createAuthSession:()=>Promise.resolve(null)},A= exports.a =_react.createContext.call(void 0, Y);function yt({children:o,onLoginSuccess:u,refreshRoute:h,logoutRoute:O,customStorageProvider:p,appSchema:f}){let[w,y]=_react.useState.call(void 0, void 0),{crossmint:n,setJwt:d}=_clientsdkreactbase.useCrossmint.call(void 0, "CrossmintAuthProvider must be used within CrossmintProvider"),[k,D]=_react.useState.call(void 0, z),U=_react.useRef.call(void 0, null),a=_react.useMemo.call(void 0, ()=>p!=null?p:new _chunkR3KSNRO2cjs.a,[p]),[F,S]=_react.useState.call(void 0, !1),[K,x]=_react.useState.call(void 0, !1),N=Array.isArray(f)?f[0]:f,b=_expoconstants2.default.executionEnvironment==="storeClient"||_expoconstants2.default.appOwnership==="expo"||!!_expoconstants2.default.expoVersion?"exp://127.0.0.1:8081":N,e=_react.useMemo.call(void 0, ()=>{if(!U.current){let t={callbacks:{onLogout:()=>{d(void 0),y(void 0)},onTokenRefresh:r=>{d(r.jwt),y(r.user)}},refreshRoute:h,logoutRoute:O,storageProvider:a};U.current=_clientsdkauth.CrossmintAuth.from(n,t)}return U.current},[a]),M=_react.useCallback.call(void 0, ()=>{u==null||u()},[u]);_react.useEffect.call(void 0, ()=>{n.jwt==null?a==null||a.get(_commonsdkauth.SESSION_PREFIX).then(t=>{t!=null&&d(t)}).finally(()=>{S(!0)}):S(!0)},[n.jwt,d,a]),_react.useEffect.call(void 0, ()=>{n.jwt!=null&&M()},[n.jwt,M]);let _=()=>{e.logout()},R=_react.useCallback.call(void 0, ()=>_chunkCK4JCQY6cjs.c.call(void 0, this,null,function*(){try{let r=Object.keys(z).map(l=>_chunkCK4JCQY6cjs.c.call(void 0, this,null,function*(){let m=yield e==null?void 0:e.getOAuthUrl(l,{appSchema:b});return{[l]:m}})),s=Object.assign({},...yield Promise.all(r));D(s)}catch(t){console.error(t)}}),[e]);_react.useEffect.call(void 0, ()=>{w==null&&R()},[R,w]);let G=()=>F?K?"in-progress":n.jwt!=null?"logged-in":"logged-out":"initializing",J=()=>_chunkCK4JCQY6cjs.c.call(void 0, this,null,function*(){if(n.jwt==null){console.log("User not logged in");return}let t=yield e.getUser();y(t)}),V=t=>_chunkCK4JCQY6cjs.c.call(void 0, this,null,function*(){var r;try{x(!0);let s=(r=k[t])!=null?r:yield e.getOAuthUrl(t,{appSchema:b});yield i.warmUpAsync();let l=new URL(s);if(t==="google"&&l.searchParams.append("provider_prompt","select_account"),_reactnative.Platform.OS==="android")yield i.openBrowserAsync(l.toString());else{let m=yield i.openAuthSessionAsync(l.toString());m.type==="success"&&(yield E(m.url))}yield i.coolDownAsync()}catch(s){console.error("[CrossmintAuthProvider] Error during OAuth login:",s)}}),E=_react.useCallback.call(void 0, t=>_chunkCK4JCQY6cjs.c.call(void 0, this,null,function*(){let r=t.includes("://")?Z(t):t;if(r!=null)try{return x(!0),yield e.handleRefreshAuthMaterial(r)}catch(s){throw s}finally{x(!1)}return null}),[e]);return _jsxruntime.jsx.call(void 0, A.Provider,{value:{crossmintAuth:e,logout:_,jwt:n.jwt,user:w,status:G(),getUser:J,loginWithOAuth:V,createAuthSession:E},children:o})}var Z=o=>{let u=/[?&]oneTimeSecret=([^&#]+)/,h=o.match(u);return h?decodeURIComponent(h[1]):void 0};exports.a = A; exports.b = yt; exports.c = ot; exports.d = nt; exports.e = _clientsdkreactbase.useCrossmint;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { newObj[key] = obj[key]; } } } newObj.default = obj; return newObj; } }var _chunkO5AL6DBJcjs = require('./chunk-O5AL6DBJ.cjs');var _exposecurestore = require('expo-secure-store'); var e = _interopRequireWildcard(_exposecurestore);var i=class{get(t){return _chunkO5AL6DBJcjs.b.call(void 0, this,null,function*(){try{let r=yield e.getItemAsync(t);if(!r)return;try{let o=JSON.parse(r);if(o.expiresAt&&new Date(o.expiresAt)<new Date){yield this.remove(t);return}return o.value}catch(o){return r}}catch(r){console.error("Error reading from SecureStore:",r);return}})}set(t,r,o){return _chunkO5AL6DBJcjs.b.call(void 0, this,null,function*(){try{if(o){let s=JSON.stringify({value:r,expiresAt:o});yield e.setItemAsync(t,s)}else yield e.setItemAsync(t,r)}catch(s){console.error("Error writing to SecureStore:",s)}})}remove(t){return _chunkO5AL6DBJcjs.b.call(void 0, this,null,function*(){try{yield e.deleteItemAsync(t)}catch(r){console.error("Error removing from SecureStore:",r)}})}isAvailable(){return _chunkO5AL6DBJcjs.b.call(void 0, this,null,function*(){try{return yield e.isAvailableAsync()}catch(t){return!1}})}};exports.a = i;
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { newObj[key] = obj[key]; } } } newObj.default = obj; return newObj; } }var _chunkCK4JCQY6cjs = require('./chunk-CK4JCQY6.cjs');var _exposecurestore = require('expo-secure-store'); var e = _interopRequireWildcard(_exposecurestore);var i=class{get(t){return _chunkCK4JCQY6cjs.c.call(void 0, this,null,function*(){try{let r=yield e.getItemAsync(t);if(!r)return;try{let o=JSON.parse(r);if(o.expiresAt&&new Date(o.expiresAt)<new Date){yield this.remove(t);return}return o.value}catch(o){return r}}catch(r){console.error("Error reading from SecureStore:",r);return}})}set(t,r,o){return _chunkCK4JCQY6cjs.c.call(void 0, this,null,function*(){try{if(o){let s=JSON.stringify({value:r,expiresAt:o});yield e.setItemAsync(t,s)}else yield e.setItemAsync(t,r)}catch(s){console.error("Error writing to SecureStore:",s)}})}remove(t){return _chunkCK4JCQY6cjs.c.call(void 0, this,null,function*(){try{yield e.deleteItemAsync(t)}catch(r){console.error("Error removing from SecureStore:",r)}})}isAvailable(){return _chunkCK4JCQY6cjs.c.call(void 0, this,null,function*(){try{return yield e.isAvailableAsync()}catch(t){return!1}})}};exports.a = i;
@@ -1 +1 @@
1
- import{b as n}from"./chunk-TKB736C5.js";import*as e from"expo-secure-store";var i=class{get(t){return n(this,null,function*(){try{let r=yield e.getItemAsync(t);if(!r)return;try{let o=JSON.parse(r);if(o.expiresAt&&new Date(o.expiresAt)<new Date){yield this.remove(t);return}return o.value}catch(o){return r}}catch(r){console.error("Error reading from SecureStore:",r);return}})}set(t,r,o){return n(this,null,function*(){try{if(o){let s=JSON.stringify({value:r,expiresAt:o});yield e.setItemAsync(t,s)}else yield e.setItemAsync(t,r)}catch(s){console.error("Error writing to SecureStore:",s)}})}remove(t){return n(this,null,function*(){try{yield e.deleteItemAsync(t)}catch(r){console.error("Error removing from SecureStore:",r)}})}isAvailable(){return n(this,null,function*(){try{return yield e.isAvailableAsync()}catch(t){return!1}})}};export{i as a};
1
+ import{c as n}from"./chunk-22GIA4MK.js";import*as e from"expo-secure-store";var i=class{get(t){return n(this,null,function*(){try{let r=yield e.getItemAsync(t);if(!r)return;try{let o=JSON.parse(r);if(o.expiresAt&&new Date(o.expiresAt)<new Date){yield this.remove(t);return}return o.value}catch(o){return r}}catch(r){console.error("Error reading from SecureStore:",r);return}})}set(t,r,o){return n(this,null,function*(){try{if(o){let s=JSON.stringify({value:r,expiresAt:o});yield e.setItemAsync(t,s)}else yield e.setItemAsync(t,r)}catch(s){console.error("Error writing to SecureStore:",s)}})}remove(t){return n(this,null,function*(){try{yield e.deleteItemAsync(t)}catch(r){console.error("Error removing from SecureStore:",r)}})}isAvailable(){return n(this,null,function*(){try{return yield e.isAvailableAsync()}catch(t){return!1}})}};export{i as a};
@@ -0,0 +1 @@
1
+ import{a as j}from"./chunk-SYFNPOWZ.js";import{c}from"./chunk-22GIA4MK.js";import{createContext as X,useEffect as C,useMemo as z,useRef as q,useState as g,useCallback as P}from"react";import*as i from"expo-web-browser";import{CrossmintAuth as L}from"@crossmint/client-sdk-auth";import{SESSION_PREFIX as Q}from"@crossmint/common-sdk-auth";import{useCrossmint as B}from"@crossmint/client-sdk-react-base";import{useContext as T}from"react";function nt(){let o=T(A);if(!o)throw new Error("useCrossmintAuth must be used within a CrossmintAuthProvider");return o}function st(){let o=T(A);if(!o)throw new Error("useAuth must be used within a CrossmintAuthProvider");return o}import{Platform as Y}from"react-native";import v from"expo-constants";import{jsx as tt}from"react/jsx-runtime";var k={google:null,twitter:null},Z={crossmintAuth:void 0,logout:()=>{},jwt:void 0,user:void 0,status:"initializing",getUser:()=>{},loginWithOAuth:()=>Promise.resolve(),createAuthSession:()=>Promise.resolve(null)},A=X(Z);function Ut({children:o,onLoginSuccess:u,refreshRoute:h,logoutRoute:O,customStorageProvider:p,appSchema:f}){let[w,y]=g(void 0),{crossmint:n,setJwt:d}=B("CrossmintAuthProvider must be used within CrossmintProvider"),[D,F]=g(k),U=q(null),a=z(()=>p!=null?p:new j,[p]),[K,S]=g(!1),[N,x]=g(!1),_=Array.isArray(f)?f[0]:f,b=v.executionEnvironment==="storeClient"||v.appOwnership==="expo"||!!v.expoVersion?"exp://127.0.0.1:8081":_,e=z(()=>{if(!U.current){let t={callbacks:{onLogout:()=>{d(void 0),y(void 0)},onTokenRefresh:r=>{d(r.jwt),y(r.user)}},refreshRoute:h,logoutRoute:O,storageProvider:a};U.current=L.from(n,t)}return U.current},[a]),M=P(()=>{u==null||u()},[u]);C(()=>{n.jwt==null?a==null||a.get(Q).then(t=>{t!=null&&d(t)}).finally(()=>{S(!0)}):S(!0)},[n.jwt,d,a]),C(()=>{n.jwt!=null&&M()},[n.jwt,M]);let G=()=>{e.logout()},R=P(()=>c(this,null,function*(){try{let r=Object.keys(k).map(l=>c(this,null,function*(){let m=yield e==null?void 0:e.getOAuthUrl(l,{appSchema:b});return{[l]:m}})),s=Object.assign({},...yield Promise.all(r));F(s)}catch(t){console.error(t)}}),[e]);C(()=>{w==null&&R()},[R,w]);let J=()=>K?N?"in-progress":n.jwt!=null?"logged-in":"logged-out":"initializing",V=()=>c(this,null,function*(){if(n.jwt==null){console.log("User not logged in");return}let t=yield e.getUser();y(t)}),H=t=>c(this,null,function*(){var r;try{x(!0);let s=(r=D[t])!=null?r:yield e.getOAuthUrl(t,{appSchema:b});yield i.warmUpAsync();let l=new URL(s);if(t==="google"&&l.searchParams.append("provider_prompt","select_account"),Y.OS==="android")yield i.openBrowserAsync(l.toString());else{let m=yield i.openAuthSessionAsync(l.toString());m.type==="success"&&(yield E(m.url))}yield i.coolDownAsync()}catch(s){console.error("[CrossmintAuthProvider] Error during OAuth login:",s)}}),E=P(t=>c(this,null,function*(){let r=t.includes("://")?$(t):t;if(r!=null)try{return x(!0),yield e.handleRefreshAuthMaterial(r)}catch(s){throw s}finally{x(!1)}return null}),[e]);return tt(A.Provider,{value:{crossmintAuth:e,logout:G,jwt:n.jwt,user:w,status:J(),getUser:V,loginWithOAuth:H,createAuthSession:E},children:o})}var $=o=>{let u=/[?&]oneTimeSecret=([^&#]+)/,h=o.match(u);return h?decodeURIComponent(h[1]):void 0};export{A as a,Ut as b,nt as c,st as d,B as e};
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunkWTPTLPLVcjs = require('./chunk-WTPTLPLV.cjs');var _chunkKWIO2XXJcjs = require('./chunk-KWIO2XXJ.cjs');var _chunkO5AL6DBJcjs = require('./chunk-O5AL6DBJ.cjs');var _react = require('react');var _clientsdkreactbase = require('@crossmint/client-sdk-react-base');var _jsxruntime = require('react/jsx-runtime');var C=["experimental_needsAuth","experimental_createRecoveryKeySigner","experimental_sendEmailWithOtp","experimental_verifyOtp"];function u({children:n}){let r=_react.useContext.call(void 0, _clientsdkreactbase.WalletContext),o=_react.useContext.call(void 0, _chunkWTPTLPLVcjs.a);if(r==null)throw new Error("BaseWalletContext not found. Ensure CrossmintWalletProvider structure is correct.");let s=_react.useMemo.call(void 0, ()=>{let e=_chunkO5AL6DBJcjs.a.call(void 0, {},r);if(o!=null)Object.assign(e,o);else for(let a of C)Object.defineProperty(e,a,{get(){throw new Error(`Cannot access '${a}'. Ensure 'experimental_enableRecoveryKeys={true}' is set on CrossmintWalletProvider.`)},enumerable:!0,configurable:!0});return e},[r,o]);return _jsxruntime.jsx.call(void 0, _chunkKWIO2XXJcjs.a.Provider,{value:s,children:n})}function b({children:n,experimental_enableRecoveryKeys:r=!1,experimental_secureEndpointUrl:o}){return _jsxruntime.jsx.call(void 0, _clientsdkreactbase.CrossmintWalletProvider,{children:_jsxruntime.jsx.call(void 0, ({children:e})=>r?_jsxruntime.jsx.call(void 0, _chunkWTPTLPLVcjs.c,{experimental_secureEndpointUrl:o,children:e}):_jsxruntime.jsx.call(void 0, _jsxruntime.Fragment,{children:e}),{children:_jsxruntime.jsx.call(void 0, u,{children:n})})})}exports.a = b;
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunk24LYBMXYcjs = require('./chunk-24LYBMXY.cjs');var _chunkKWIO2XXJcjs = require('./chunk-KWIO2XXJ.cjs');var _chunkCK4JCQY6cjs = require('./chunk-CK4JCQY6.cjs');var _react = require('react');var _clientsdkreactbase = require('@crossmint/client-sdk-react-base');var _jsxruntime = require('react/jsx-runtime');var C=["experimental_needsAuth","experimental_createRecoveryKeySigner","experimental_sendEmailWithOtp","experimental_verifyOtp"];function u({children:n}){let r=_react.useContext.call(void 0, _clientsdkreactbase.WalletContext),o=_react.useContext.call(void 0, _chunk24LYBMXYcjs.a);if(r==null)throw new Error("BaseWalletContext not found. Ensure CrossmintWalletProvider structure is correct.");let s=_react.useMemo.call(void 0, ()=>{let e=_chunkCK4JCQY6cjs.a.call(void 0, {},r);if(o!=null)Object.assign(e,o);else for(let a of C)Object.defineProperty(e,a,{get(){throw new Error(`Cannot access '${a}'. Ensure 'experimental_enableRecoveryKeys={true}' is set on CrossmintWalletProvider.`)},enumerable:!0,configurable:!0});return e},[r,o]);return _jsxruntime.jsx.call(void 0, _chunkKWIO2XXJcjs.a.Provider,{value:s,children:n})}function b({children:n,experimental_enableRecoveryKeys:r=!1,experimental_secureEndpointUrl:o}){return _jsxruntime.jsx.call(void 0, _clientsdkreactbase.CrossmintWalletProvider,{children:_jsxruntime.jsx.call(void 0, ({children:e})=>r?_jsxruntime.jsx.call(void 0, _chunk24LYBMXYcjs.c,{experimental_secureEndpointUrl:o,children:e}):_jsxruntime.jsx.call(void 0, _jsxruntime.Fragment,{children:e}),{children:_jsxruntime.jsx.call(void 0, u,{children:n})})})}exports.a = b;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunkVIA5NAWDcjs = require('../chunk-VIA5NAWD.cjs');require('../chunk-BZACBNUH.cjs');var _chunkKWIO2XXJcjs = require('../chunk-KWIO2XXJ.cjs');require('../chunk-O5AL6DBJ.cjs');exports.WalletContext = _chunkKWIO2XXJcjs.a; exports.useAuth = _chunkVIA5NAWDcjs.d; exports.useCrossmint = _chunkVIA5NAWDcjs.e; exports.useCrossmintAuth = _chunkVIA5NAWDcjs.c; exports.useWallet = _chunkKWIO2XXJcjs.b;
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunkOCM4UKCZcjs = require('../chunk-OCM4UKCZ.cjs');require('../chunk-R3KSNRO2.cjs');var _chunkKWIO2XXJcjs = require('../chunk-KWIO2XXJ.cjs');require('../chunk-CK4JCQY6.cjs');exports.WalletContext = _chunkKWIO2XXJcjs.a; exports.useAuth = _chunkOCM4UKCZcjs.d; exports.useCrossmint = _chunkOCM4UKCZcjs.e; exports.useCrossmintAuth = _chunkOCM4UKCZcjs.c; exports.useWallet = _chunkKWIO2XXJcjs.b;
@@ -1 +1 @@
1
- import{c as a,d as b,e}from"../chunk-T3Q4KTE4.js";import"../chunk-ZRIYUAKZ.js";import{a as c,b as d}from"../chunk-KZMAEKSM.js";import"../chunk-TKB736C5.js";export{c as WalletContext,b as useAuth,e as useCrossmint,a as useCrossmintAuth,d as useWallet};
1
+ import{c as a,d as b,e}from"../chunk-XA3CJXOO.js";import"../chunk-SYFNPOWZ.js";import{a as c,b as d}from"../chunk-KZMAEKSM.js";import"../chunk-22GIA4MK.js";export{c as WalletContext,b as useAuth,e as useCrossmint,a as useCrossmintAuth,d as useWallet};
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunkVIA5NAWDcjs = require('../chunk-VIA5NAWD.cjs');require('../chunk-BZACBNUH.cjs');require('../chunk-KWIO2XXJ.cjs');require('../chunk-O5AL6DBJ.cjs');exports.useAuth = _chunkVIA5NAWDcjs.d; exports.useCrossmintAuth = _chunkVIA5NAWDcjs.c;
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunkOCM4UKCZcjs = require('../chunk-OCM4UKCZ.cjs');require('../chunk-R3KSNRO2.cjs');require('../chunk-KWIO2XXJ.cjs');require('../chunk-CK4JCQY6.cjs');exports.useAuth = _chunkOCM4UKCZcjs.d; exports.useCrossmintAuth = _chunkOCM4UKCZcjs.c;
@@ -1 +1 @@
1
- import{c as a,d as b}from"../chunk-T3Q4KTE4.js";import"../chunk-ZRIYUAKZ.js";import"../chunk-KZMAEKSM.js";import"../chunk-TKB736C5.js";export{b as useAuth,a as useCrossmintAuth};
1
+ import{c as a,d as b}from"../chunk-XA3CJXOO.js";import"../chunk-SYFNPOWZ.js";import"../chunk-KZMAEKSM.js";import"../chunk-22GIA4MK.js";export{b as useAuth,a as useCrossmintAuth};
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunkKWIO2XXJcjs = require('../chunk-KWIO2XXJ.cjs');require('../chunk-O5AL6DBJ.cjs');exports.WalletContext = _chunkKWIO2XXJcjs.a; exports.useWallet = _chunkKWIO2XXJcjs.b;
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunkKWIO2XXJcjs = require('../chunk-KWIO2XXJ.cjs');require('../chunk-CK4JCQY6.cjs');exports.WalletContext = _chunkKWIO2XXJcjs.a; exports.useWallet = _chunkKWIO2XXJcjs.b;
@@ -1 +1 @@
1
- import{a,b}from"../chunk-KZMAEKSM.js";import"../chunk-TKB736C5.js";export{a as WalletContext,b as useWallet};
1
+ import{a,b}from"../chunk-KZMAEKSM.js";import"../chunk-22GIA4MK.js";export{a as WalletContext,b as useWallet};
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunkWTPTLPLVcjs = require('../chunk-WTPTLPLV.cjs');require('../chunk-VIA5NAWD.cjs');require('../chunk-BZACBNUH.cjs');require('../chunk-KWIO2XXJ.cjs');require('../chunk-O5AL6DBJ.cjs');var _react = require('react');function a(){let e=_react.useContext.call(void 0, _chunkWTPTLPLVcjs.a);if(e==null)throw new Error("useWalletsAuth must be used within a CrossmintWalletProvider with experimental_enableRecoveryKeys enabled.");return{experimental_needsAuth:e.experimental_needsAuth,experimental_createRecoveryKeySigner:e.experimental_createRecoveryKeySigner,experimental_sendEmailWithOtp:e.experimental_sendEmailWithOtp,experimental_verifyOtp:e.experimental_verifyOtp,experimental_clearStorage:e.experimental_clearStorage,onAuthRequired:e.onAuthRequired}}exports.useWalletsAuth = a;
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunk24LYBMXYcjs = require('../chunk-24LYBMXY.cjs');require('../chunk-OCM4UKCZ.cjs');require('../chunk-R3KSNRO2.cjs');require('../chunk-KWIO2XXJ.cjs');require('../chunk-CK4JCQY6.cjs');var _react = require('react');function a(){let e=_react.useContext.call(void 0, _chunk24LYBMXYcjs.a);if(e==null)throw new Error("useWalletsAuth must be used within a CrossmintWalletProvider with experimental_enableRecoveryKeys enabled.");return{experimental_needsAuth:e.experimental_needsAuth,experimental_createRecoveryKeySigner:e.experimental_createRecoveryKeySigner,experimental_sendEmailWithOtp:e.experimental_sendEmailWithOtp,experimental_verifyOtp:e.experimental_verifyOtp,experimental_clearStorage:e.experimental_clearStorage,onAuthRequired:e.onAuthRequired}}exports.useWalletsAuth = a;
@@ -1 +1 @@
1
- import{a as t}from"../chunk-YWHWC4WZ.js";import"../chunk-T3Q4KTE4.js";import"../chunk-ZRIYUAKZ.js";import"../chunk-KZMAEKSM.js";import"../chunk-TKB736C5.js";import{useContext as r}from"react";function l(){let e=r(t);if(e==null)throw new Error("useWalletsAuth must be used within a CrossmintWalletProvider with experimental_enableRecoveryKeys enabled.");return{experimental_needsAuth:e.experimental_needsAuth,experimental_createRecoveryKeySigner:e.experimental_createRecoveryKeySigner,experimental_sendEmailWithOtp:e.experimental_sendEmailWithOtp,experimental_verifyOtp:e.experimental_verifyOtp,experimental_clearStorage:e.experimental_clearStorage,onAuthRequired:e.onAuthRequired}}export{l as useWalletsAuth};
1
+ import{a as t}from"../chunk-F4CHPSRS.js";import"../chunk-XA3CJXOO.js";import"../chunk-SYFNPOWZ.js";import"../chunk-KZMAEKSM.js";import"../chunk-22GIA4MK.js";import{useContext as r}from"react";function l(){let e=r(t);if(e==null)throw new Error("useWalletsAuth must be used within a CrossmintWalletProvider with experimental_enableRecoveryKeys enabled.");return{experimental_needsAuth:e.experimental_needsAuth,experimental_createRecoveryKeySigner:e.experimental_createRecoveryKeySigner,experimental_sendEmailWithOtp:e.experimental_sendEmailWithOtp,experimental_verifyOtp:e.experimental_verifyOtp,experimental_clearStorage:e.experimental_clearStorage,onAuthRequired:e.onAuthRequired}}export{l as useWalletsAuth};
package/dist/index.cjs CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});require('./chunk-ZR6BLDCD.cjs');var _chunkOFWUQQBRcjs = require('./chunk-OFWUQQBR.cjs');require('./chunk-WTPTLPLV.cjs');var _chunkVIA5NAWDcjs = require('./chunk-VIA5NAWD.cjs');require('./chunk-BZACBNUH.cjs');var _chunkKWIO2XXJcjs = require('./chunk-KWIO2XXJ.cjs');var _chunk4L2OHRE5cjs = require('./chunk-4L2OHRE5.cjs');require('./chunk-O5AL6DBJ.cjs');exports.CrossmintAuthProvider = _chunkVIA5NAWDcjs.b; exports.CrossmintProvider = _chunk4L2OHRE5cjs.a; exports.CrossmintWalletProvider = _chunkOFWUQQBRcjs.a; exports.WalletContext = _chunkKWIO2XXJcjs.a; exports.useAuth = _chunkVIA5NAWDcjs.d; exports.useCrossmint = _chunkVIA5NAWDcjs.e; exports.useCrossmintAuth = _chunkVIA5NAWDcjs.c; exports.useWallet = _chunkKWIO2XXJcjs.b;
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true});require('./chunk-ZR6BLDCD.cjs');var _chunkXBWLXXPMcjs = require('./chunk-XBWLXXPM.cjs');require('./chunk-24LYBMXY.cjs');var _chunkOCM4UKCZcjs = require('./chunk-OCM4UKCZ.cjs');require('./chunk-R3KSNRO2.cjs');var _chunkKWIO2XXJcjs = require('./chunk-KWIO2XXJ.cjs');var _chunk4L2OHRE5cjs = require('./chunk-4L2OHRE5.cjs');require('./chunk-CK4JCQY6.cjs');exports.CrossmintAuthProvider = _chunkOCM4UKCZcjs.b; exports.CrossmintProvider = _chunk4L2OHRE5cjs.a; exports.CrossmintWalletProvider = _chunkXBWLXXPMcjs.a; exports.WalletContext = _chunkKWIO2XXJcjs.a; exports.useAuth = _chunkOCM4UKCZcjs.d; exports.useCrossmint = _chunkOCM4UKCZcjs.e; exports.useCrossmintAuth = _chunkOCM4UKCZcjs.c; exports.useWallet = _chunkKWIO2XXJcjs.b;
package/dist/index.js CHANGED
@@ -1 +1 @@
1
- import"./chunk-C62HRWJA.js";import{a as l}from"./chunk-P3LUXXWV.js";import"./chunk-YWHWC4WZ.js";import{b as t,c as e,d as r,e as a}from"./chunk-T3Q4KTE4.js";import"./chunk-ZRIYUAKZ.js";import{a as o,b as s}from"./chunk-KZMAEKSM.js";import{a as m}from"./chunk-I52CP62R.js";import"./chunk-TKB736C5.js";export{t as CrossmintAuthProvider,m as CrossmintProvider,l as CrossmintWalletProvider,o as WalletContext,r as useAuth,a as useCrossmint,e as useCrossmintAuth,s as useWallet};
1
+ import"./chunk-C62HRWJA.js";import{a as l}from"./chunk-56YROBGG.js";import"./chunk-F4CHPSRS.js";import{b as t,c as e,d as r,e as a}from"./chunk-XA3CJXOO.js";import"./chunk-SYFNPOWZ.js";import{a as o,b as s}from"./chunk-KZMAEKSM.js";import{a as m}from"./chunk-I52CP62R.js";import"./chunk-22GIA4MK.js";export{t as CrossmintAuthProvider,m as CrossmintProvider,l as CrossmintWalletProvider,o as WalletContext,r as useAuth,a as useCrossmint,e as useCrossmintAuth,s as useWallet};
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunkVIA5NAWDcjs = require('../chunk-VIA5NAWD.cjs');require('../chunk-BZACBNUH.cjs');require('../chunk-KWIO2XXJ.cjs');require('../chunk-O5AL6DBJ.cjs');exports.AuthContext = _chunkVIA5NAWDcjs.a; exports.CrossmintAuthProvider = _chunkVIA5NAWDcjs.b;
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunkOCM4UKCZcjs = require('../chunk-OCM4UKCZ.cjs');require('../chunk-R3KSNRO2.cjs');require('../chunk-KWIO2XXJ.cjs');require('../chunk-CK4JCQY6.cjs');exports.AuthContext = _chunkOCM4UKCZcjs.a; exports.CrossmintAuthProvider = _chunkOCM4UKCZcjs.b;
@@ -1 +1 @@
1
- import{a,b}from"../chunk-T3Q4KTE4.js";import"../chunk-ZRIYUAKZ.js";import"../chunk-KZMAEKSM.js";import"../chunk-TKB736C5.js";export{a as AuthContext,b as CrossmintAuthProvider};
1
+ import{a,b}from"../chunk-XA3CJXOO.js";import"../chunk-SYFNPOWZ.js";import"../chunk-KZMAEKSM.js";import"../chunk-22GIA4MK.js";export{a as AuthContext,b as CrossmintAuthProvider};
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunk4L2OHRE5cjs = require('../chunk-4L2OHRE5.cjs');require('../chunk-O5AL6DBJ.cjs');exports.CrossmintProvider = _chunk4L2OHRE5cjs.a;
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunk4L2OHRE5cjs = require('../chunk-4L2OHRE5.cjs');require('../chunk-CK4JCQY6.cjs');exports.CrossmintProvider = _chunk4L2OHRE5cjs.a;
@@ -1 +1 @@
1
- import{a}from"../chunk-I52CP62R.js";import"../chunk-TKB736C5.js";export{a as CrossmintProvider};
1
+ import{a}from"../chunk-I52CP62R.js";import"../chunk-22GIA4MK.js";export{a as CrossmintProvider};
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunkWTPTLPLVcjs = require('../chunk-WTPTLPLV.cjs');require('../chunk-VIA5NAWD.cjs');require('../chunk-BZACBNUH.cjs');require('../chunk-KWIO2XXJ.cjs');require('../chunk-O5AL6DBJ.cjs');exports.CrossmintRecoveryKeyContext = _chunkWTPTLPLVcjs.a; exports.CrossmintRecoveryKeyProvider = _chunkWTPTLPLVcjs.c; exports.useCrossmintRecoveryKey = _chunkWTPTLPLVcjs.b;
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunk24LYBMXYcjs = require('../chunk-24LYBMXY.cjs');require('../chunk-OCM4UKCZ.cjs');require('../chunk-R3KSNRO2.cjs');require('../chunk-KWIO2XXJ.cjs');require('../chunk-CK4JCQY6.cjs');exports.CrossmintRecoveryKeyContext = _chunk24LYBMXYcjs.a; exports.CrossmintRecoveryKeyProvider = _chunk24LYBMXYcjs.c; exports.useCrossmintRecoveryKey = _chunk24LYBMXYcjs.b;
@@ -1 +1 @@
1
- import{a,b,c}from"../chunk-YWHWC4WZ.js";import"../chunk-T3Q4KTE4.js";import"../chunk-ZRIYUAKZ.js";import"../chunk-KZMAEKSM.js";import"../chunk-TKB736C5.js";export{a as CrossmintRecoveryKeyContext,c as CrossmintRecoveryKeyProvider,b as useCrossmintRecoveryKey};
1
+ import{a,b,c}from"../chunk-F4CHPSRS.js";import"../chunk-XA3CJXOO.js";import"../chunk-SYFNPOWZ.js";import"../chunk-KZMAEKSM.js";import"../chunk-22GIA4MK.js";export{a as CrossmintRecoveryKeyContext,c as CrossmintRecoveryKeyProvider,b as useCrossmintRecoveryKey};
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunkOFWUQQBRcjs = require('../chunk-OFWUQQBR.cjs');require('../chunk-WTPTLPLV.cjs');require('../chunk-VIA5NAWD.cjs');require('../chunk-BZACBNUH.cjs');require('../chunk-KWIO2XXJ.cjs');require('../chunk-O5AL6DBJ.cjs');exports.CrossmintWalletProvider = _chunkOFWUQQBRcjs.a;
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunkXBWLXXPMcjs = require('../chunk-XBWLXXPM.cjs');require('../chunk-24LYBMXY.cjs');require('../chunk-OCM4UKCZ.cjs');require('../chunk-R3KSNRO2.cjs');require('../chunk-KWIO2XXJ.cjs');require('../chunk-CK4JCQY6.cjs');exports.CrossmintWalletProvider = _chunkXBWLXXPMcjs.a;
@@ -1 +1 @@
1
- import{a}from"../chunk-P3LUXXWV.js";import"../chunk-YWHWC4WZ.js";import"../chunk-T3Q4KTE4.js";import"../chunk-ZRIYUAKZ.js";import"../chunk-KZMAEKSM.js";import"../chunk-TKB736C5.js";export{a as CrossmintWalletProvider};
1
+ import{a}from"../chunk-56YROBGG.js";import"../chunk-F4CHPSRS.js";import"../chunk-XA3CJXOO.js";import"../chunk-SYFNPOWZ.js";import"../chunk-KZMAEKSM.js";import"../chunk-22GIA4MK.js";export{a as CrossmintWalletProvider};
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});require('../chunk-ZR6BLDCD.cjs');var _chunkOFWUQQBRcjs = require('../chunk-OFWUQQBR.cjs');require('../chunk-WTPTLPLV.cjs');var _chunkVIA5NAWDcjs = require('../chunk-VIA5NAWD.cjs');require('../chunk-BZACBNUH.cjs');require('../chunk-KWIO2XXJ.cjs');var _chunk4L2OHRE5cjs = require('../chunk-4L2OHRE5.cjs');require('../chunk-O5AL6DBJ.cjs');exports.CrossmintAuthProvider = _chunkVIA5NAWDcjs.b; exports.CrossmintProvider = _chunk4L2OHRE5cjs.a; exports.CrossmintWalletProvider = _chunkOFWUQQBRcjs.a;
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true});require('../chunk-ZR6BLDCD.cjs');var _chunkXBWLXXPMcjs = require('../chunk-XBWLXXPM.cjs');require('../chunk-24LYBMXY.cjs');var _chunkOCM4UKCZcjs = require('../chunk-OCM4UKCZ.cjs');require('../chunk-R3KSNRO2.cjs');require('../chunk-KWIO2XXJ.cjs');var _chunk4L2OHRE5cjs = require('../chunk-4L2OHRE5.cjs');require('../chunk-CK4JCQY6.cjs');exports.CrossmintAuthProvider = _chunkOCM4UKCZcjs.b; exports.CrossmintProvider = _chunk4L2OHRE5cjs.a; exports.CrossmintWalletProvider = _chunkXBWLXXPMcjs.a;
@@ -1 +1 @@
1
- import"../chunk-C62HRWJA.js";import{a as c}from"../chunk-P3LUXXWV.js";import"../chunk-YWHWC4WZ.js";import{b as a}from"../chunk-T3Q4KTE4.js";import"../chunk-ZRIYUAKZ.js";import"../chunk-KZMAEKSM.js";import{a as b}from"../chunk-I52CP62R.js";import"../chunk-TKB736C5.js";export{a as CrossmintAuthProvider,b as CrossmintProvider,c as CrossmintWalletProvider};
1
+ import"../chunk-C62HRWJA.js";import{a as c}from"../chunk-56YROBGG.js";import"../chunk-F4CHPSRS.js";import{b as a}from"../chunk-XA3CJXOO.js";import"../chunk-SYFNPOWZ.js";import"../chunk-KZMAEKSM.js";import{a as b}from"../chunk-I52CP62R.js";import"../chunk-22GIA4MK.js";export{a as CrossmintAuthProvider,b as CrossmintProvider,c as CrossmintWalletProvider};
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});require('./chunk-O5AL6DBJ.cjs');var _="sk_development_12341234",e= exports.MOCK_APP_ID ="com.app.id";exports.MOCK_API_KEY = _; exports.MOCK_APP_ID = e;
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true});require('./chunk-CK4JCQY6.cjs');var _="sk_development_12341234",e= exports.MOCK_APP_ID ="com.app.id";exports.MOCK_API_KEY = _; exports.MOCK_APP_ID = e;
package/dist/testUtils.js CHANGED
@@ -1 +1 @@
1
- import"./chunk-TKB736C5.js";var e="sk_development_12341234",p="com.app.id";export{e as MOCK_API_KEY,p as MOCK_APP_ID};
1
+ import"./chunk-22GIA4MK.js";var e="sk_development_12341234",p="com.app.id";export{e as MOCK_API_KEY,p as MOCK_APP_ID};
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunkBZACBNUHcjs = require('../chunk-BZACBNUH.cjs');require('../chunk-O5AL6DBJ.cjs');exports.SecureStorage = _chunkBZACBNUHcjs.a;
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunkR3KSNRO2cjs = require('../chunk-R3KSNRO2.cjs');require('../chunk-CK4JCQY6.cjs');exports.SecureStorage = _chunkR3KSNRO2cjs.a;
@@ -1 +1 @@
1
- import{a}from"../chunk-ZRIYUAKZ.js";import"../chunk-TKB736C5.js";export{a as SecureStorage};
1
+ import{a}from"../chunk-SYFNPOWZ.js";import"../chunk-22GIA4MK.js";export{a as SecureStorage};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@crossmint/client-sdk-react-native-ui",
3
- "version": "0.4.16",
3
+ "version": "0.4.18",
4
4
  "repository": "https://github.com/Crossmint/crossmint-sdk",
5
5
  "license": "Apache-2.0",
6
6
  "author": "Paella Labs Inc",
@@ -24,14 +24,14 @@
24
24
  "expo-secure-store": "14.0.1",
25
25
  "expo-web-browser": "~14.0.2",
26
26
  "react-native-webview": "13.12.5",
27
- "@crossmint/client-sdk-auth": "1.2.8",
28
- "@crossmint/client-sdk-base": "1.5.0",
29
- "@crossmint/client-sdk-react-base": "0.2.15",
30
27
  "@crossmint/client-sdk-rn-window": "0.2.2",
31
- "@crossmint/client-signers": "0.0.14",
32
- "@crossmint/common-sdk-auth": "1.0.31",
33
- "@crossmint/common-sdk-base": "0.5.0",
34
- "@crossmint/wallets-sdk": "0.8.0"
28
+ "@crossmint/client-sdk-react-base": "0.2.16",
29
+ "@crossmint/client-sdk-base": "1.5.1",
30
+ "@crossmint/client-sdk-auth": "1.2.9",
31
+ "@crossmint/client-signers": "0.0.15",
32
+ "@crossmint/common-sdk-auth": "1.0.32",
33
+ "@crossmint/wallets-sdk": "0.8.1",
34
+ "@crossmint/common-sdk-base": "0.5.1"
35
35
  },
36
36
  "devDependencies": {
37
37
  "@types/react": "19.0.12"
@@ -1 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});var m=Object.defineProperty;var h=Object.getOwnPropertySymbols;var n=Object.prototype.hasOwnProperty,o=Object.prototype.propertyIsEnumerable;var i=(c,b,a)=>b in c?m(c,b,{enumerable:!0,configurable:!0,writable:!0,value:a}):c[b]=a,p= exports.a =(c,b)=>{for(var a in b||(b={}))n.call(b,a)&&i(c,a,b[a]);if(h)for(var a of h(b))o.call(b,a)&&i(c,a,b[a]);return c};var q=(c,b,a)=>new Promise((j,g)=>{var k=d=>{try{e(a.next(d))}catch(f){g(f)}},l=d=>{try{e(a.throw(d))}catch(f){g(f)}},e=d=>d.done?j(d.value):Promise.resolve(d.value).then(k,l);e((a=a.apply(c,b)).next())});exports.a = p; exports.b = q;
@@ -1 +0,0 @@
1
- import{a as j}from"./chunk-ZRIYUAKZ.js";import{b as c}from"./chunk-TKB736C5.js";import{createContext as X,useEffect as C,useMemo as z,useRef as q,useState as g,useCallback as P}from"react";import*as i from"expo-web-browser";import{CrossmintAuth as L}from"@crossmint/client-sdk-auth";import{SESSION_PREFIX as Q}from"@crossmint/common-sdk-auth";import{useCrossmint as B}from"@crossmint/client-sdk-react-base";import{useContext as T}from"react";function nt(){let o=T(A);if(!o)throw new Error("useCrossmintAuth must be used within a CrossmintAuthProvider");return o}function st(){let o=T(A);if(!o)throw new Error("useAuth must be used within a CrossmintAuthProvider");return o}import{Platform as Y}from"react-native";import v from"expo-constants";import{jsx as tt}from"react/jsx-runtime";var k={google:null,twitter:null},Z={crossmintAuth:void 0,logout:()=>{},jwt:void 0,user:void 0,status:"initializing",getUser:()=>{},loginWithOAuth:()=>Promise.resolve(),createAuthSession:()=>Promise.resolve(null)},A=X(Z);function Ut({children:o,onLoginSuccess:u,refreshRoute:h,logoutRoute:O,customStorageProvider:p,appSchema:f}){let[w,y]=g(void 0),{crossmint:n,setJwt:d}=B("CrossmintAuthProvider must be used within CrossmintProvider"),[D,F]=g(k),U=q(null),a=z(()=>p!=null?p:new j,[p]),[K,S]=g(!1),[N,x]=g(!1),_=Array.isArray(f)?f[0]:f,b=v.executionEnvironment==="storeClient"||v.appOwnership==="expo"||!!v.expoVersion?"exp://127.0.0.1:8081":_,e=z(()=>{if(!U.current){let t={callbacks:{onLogout:()=>{d(void 0),y(void 0)},onTokenRefresh:r=>{d(r.jwt),y(r.user)}},refreshRoute:h,logoutRoute:O,storageProvider:a};U.current=L.from(n,t)}return U.current},[a]),M=P(()=>{u==null||u()},[u]);C(()=>{n.jwt==null?a==null||a.get(Q).then(t=>{t!=null&&d(t)}).finally(()=>{S(!0)}):S(!0)},[n.jwt,d,a]),C(()=>{n.jwt!=null&&M()},[n.jwt,M]);let G=()=>{e.logout()},R=P(()=>c(this,null,function*(){try{let r=Object.keys(k).map(l=>c(this,null,function*(){let m=yield e==null?void 0:e.getOAuthUrl(l,{appSchema:b});return{[l]:m}})),s=Object.assign({},...yield Promise.all(r));F(s)}catch(t){console.error(t)}}),[e]);C(()=>{w==null&&R()},[R,w]);let J=()=>K?N?"in-progress":n.jwt!=null?"logged-in":"logged-out":"initializing",V=()=>c(this,null,function*(){if(n.jwt==null){console.log("User not logged in");return}let t=yield e.getUser();y(t)}),H=t=>c(this,null,function*(){var r;try{x(!0);let s=(r=D[t])!=null?r:yield e.getOAuthUrl(t,{appSchema:b});yield i.warmUpAsync();let l=new URL(s);if(t==="google"&&l.searchParams.append("provider_prompt","select_account"),Y.OS==="android")yield i.openBrowserAsync(l.toString());else{let m=yield i.openAuthSessionAsync(l.toString());m.type==="success"&&(yield E(m.url))}yield i.coolDownAsync()}catch(s){console.error("[CrossmintAuthProvider] Error during OAuth login:",s)}}),E=P(t=>c(this,null,function*(){let r=t.includes("://")?$(t):t;if(r!=null)try{return x(!0),yield e.handleRefreshAuthMaterial(r)}catch(s){throw s}finally{x(!1)}return null}),[e]);return tt(A.Provider,{value:{crossmintAuth:e,logout:G,jwt:n.jwt,user:w,status:J(),getUser:V,loginWithOAuth:H,createAuthSession:E},children:o})}var $=o=>{let u=/[?&]oneTimeSecret=([^&#]+)/,h=o.match(u);return h?decodeURIComponent(h[1]):void 0};export{A as a,Ut as b,nt as c,st as d,B as e};
@@ -1 +0,0 @@
1
- var m=Object.defineProperty;var h=Object.getOwnPropertySymbols;var n=Object.prototype.hasOwnProperty,o=Object.prototype.propertyIsEnumerable;var i=(c,b,a)=>b in c?m(c,b,{enumerable:!0,configurable:!0,writable:!0,value:a}):c[b]=a,p=(c,b)=>{for(var a in b||(b={}))n.call(b,a)&&i(c,a,b[a]);if(h)for(var a of h(b))o.call(b,a)&&i(c,a,b[a]);return c};var q=(c,b,a)=>new Promise((j,g)=>{var k=d=>{try{e(a.next(d))}catch(f){g(f)}},l=d=>{try{e(a.throw(d))}catch(f){g(f)}},e=d=>d.done?j(d.value):Promise.resolve(d.value).then(k,l);e((a=a.apply(c,b)).next())});export{p as a,q as b};
@@ -1,17 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }var _chunkVIA5NAWDcjs = require('./chunk-VIA5NAWD.cjs');var _chunkO5AL6DBJcjs = require('./chunk-O5AL6DBJ.cjs');var _react = require('react'); var _react2 = _interopRequireDefault(_react);var _bs58 = require('bs58'); var _bs582 = _interopRequireDefault(_bs58);var _web3js = require('@solana/web3.js');var _clientsdkrnwindow = require('@crossmint/client-sdk-rn-window');var _clientsigners = require('@crossmint/client-signers');var _reactnative = require('react-native');var _commonsdkbase = require('@crossmint/common-sdk-base');var _clientsdkreactbase = require('@crossmint/client-sdk-react-base');var _jsxruntime = require('react/jsx-runtime');var J=_react2.default.createContext(null);function Pe(){let E=_react.useContext.call(void 0, J);if(E==null)throw new Error("useCrossmintRecoveryKey must be used within a CrossmintRecoveryKeyProvider");return E}var b={timeoutMs:1e4,intervalMs:5e3},N="https://crossmint-signer-frames.onrender.com";function Re({children:E,experimental_secureEndpointUrl:$=N}){let{crossmint:{apiKey:a,jwt:s,appId:h}}=_chunkVIA5NAWDcjs.e.call(void 0, ),{getOrCreateWallet:P,clearWallet:B}=_react.useContext.call(void 0, _clientsdkreactbase.WalletContext),w=_react.useRef.call(void 0, null),d=_react.useRef.call(void 0, null),[p,R]=_react.useState.call(void 0, !1),[ue,O]=_react.useState.call(void 0, null),[y,c]=_react.useState.call(void 0, !1),W=_react.useRef.call(void 0, !1),A=_react.useRef.call(void 0, !1),m=_react.useRef.call(void 0, null),G=_react.useMemo.call(void 0, ()=>h!=null?`window.crossmintAppId = '${h}';`:"",[h]);_react.useEffect.call(void 0, ()=>{w.current!=null&&d.current==null&&(d.current=new (0, _clientsdkrnwindow.WebViewParent)(w,{incomingEvents:_clientsigners.signerOutboundEvents,outgoingEvents:_clientsigners.signerInboundEvents}))},[]),_react.useEffect.call(void 0, ()=>{s==null&&!W.current?(c(!1),O(null),B(),W.current=!0):s!=null&&(W.current=!1,p&&H())},[s,p]),_react.useEffect.call(void 0, ()=>{A.current=y},[y]);let S=_react.useCallback.call(void 0, ()=>_chunkO5AL6DBJcjs.b.call(void 0, this,null,function*(){if(console.log("handleAuthRequired needsAuth",A.current),!A.current)return;let t,n,o=new Promise((e,r)=>{t=e,n=r});m.current={promise:o,resolve:t,reject:n};try{console.log("Waiting for auth promise"),yield m.current.promise,console.log("Auth promise resolved")}catch(e){throw e}}),[]),K=_react.useCallback.call(void 0, t=>_chunkO5AL6DBJcjs.b.call(void 0, this,null,function*(){var e;let n=d.current;if(n==null||!p)throw new Error("[sendEmailWithOtp] WebViewParent not ready or handshake incomplete.");if(s==null||a==null)throw new Error("[sendEmailWithOtp] Missing authentication credentials (JWT or API Key).");if(!y)throw new Error("OTP email request is not applicable in the current state.");O(t);let o=`email:${t}`;try{let r=yield n.sendAction({event:"request:start-onboarding",responseEvent:"response:start-onboarding",data:{authData:{jwt:s,apiKey:a},data:{authId:o,keyType:"ed25519"}},options:b});if((r==null?void 0:r.status)==="success"&&r.publicKey){c(!1);return}if((r==null?void 0:r.status)==="error")throw console.error("[sendEmailWithOtp] Failed to send OTP:",r),new Error(r.error||"Failed to initiate OTP process.");console.log("[sendEmailWithOtp] OTP process likely initiated. Waiting for verification.")}catch(r){throw console.error("[sendEmailWithOtp] Error sending start-onboarding request:",r),(e=m.current)==null||e.reject(r),r}}),[p,s,a,y]),V=_react.useCallback.call(void 0, t=>_chunkO5AL6DBJcjs.b.call(void 0, this,null,function*(){var o,e,r;let n=d.current;if(n==null||!p)throw new Error("[verifyOtp] WebViewParent not ready or handshake incomplete.");if(s==null||a==null)throw new Error("[verifyOtp] Missing authentication credentials (JWT or API Key).");if(!y)throw new Error("Not currently awaiting OTP validation.");try{let i=yield n.sendAction({event:"request:complete-onboarding",responseEvent:"response:complete-onboarding",data:{authData:{jwt:s,apiKey:a},data:{keyType:"ed25519",onboardingAuthentication:{encryptedOtp:t}}},options:b});if((i==null?void 0:i.status)==="success"&&i.publicKey){console.log("[verifyOtp] OTP validation successful. Signer address:",i.publicKey),c(!1),(o=m.current)==null||o.resolve();return}else{console.error("[verifyOtp] Failed to validate OTP:",i),c(!0);let l=i&&i.status==="error"?i.error:"Failed to validate encrypted OTP";throw(e=m.current)==null||e.reject(new Error(l)),new Error(l)}}catch(i){throw console.error("[verifyOtp] Error sending OTP validation request:",i),c(!0),(r=m.current)==null||r.reject(i),i}}),[p,s,a,y]),L=_react.useRef.call(void 0, null),q=_react.useCallback.call(void 0, t=>{L.current=t},[]),z=t=>{if(t.encoding!=="base58"||t.keyType!=="ed25519")throw new Error("Unsupported key type and encoding: "+t.keyType+" "+t.encoding)},k=_react.useCallback.call(void 0, t=>{let n=d.current;if(n==null||s==null||a==null)throw new Error("Cannot build signer: Missing prerequisites (parent, jwt, apiKey).");return{type:"solana-keypair",address:t,signer:{signMessage:o=>_chunkO5AL6DBJcjs.b.call(void 0, this,null,function*(){yield S();try{let e=yield n.sendAction({event:"request:sign",responseEvent:"response:sign",data:{authData:{jwt:s,apiKey:a},data:{bytes:_bs582.default.encode(o),keyType:"ed25519",encoding:"base58"}},options:b});if(e==null||e.status==="error"||e.signature==null)throw console.error("Failed signMessage response:",e),new Error("Failed to sign message");if(e.signature.encoding==="base58"&&e.signature.bytes)return _bs582.default.decode(e.signature.bytes);throw new Error("Unsupported encoding: "+e.signature.encoding)}catch(e){throw console.error("Error during signMessage:",e),e}}),signTransaction:o=>_chunkO5AL6DBJcjs.b.call(void 0, this,null,function*(){yield S();try{let e=o.message.serialize(),r=yield n.sendAction({event:"request:sign",responseEvent:"response:sign",data:{authData:{jwt:s,apiKey:a},data:{bytes:_bs582.default.encode(e),keyType:"ed25519",encoding:"base58"}},options:b});if(r==null||r.status==="error"||r.signature==null)throw new Error("Failed to sign transaction: No signature returned");if(r.signature.encoding==="base58"&&r.signature.bytes)o.addSignature(new (0, _web3js.PublicKey)(t),_bs582.default.decode(r.signature.bytes));else throw new Error("Unsupported encoding: "+r.signature.encoding);return o}catch(e){throw console.error("Error during signTransaction:",e),e}})}}},[s,a,S]),H=_react.useCallback.call(void 0, ()=>_chunkO5AL6DBJcjs.b.call(void 0, this,null,function*(){let t=d.current;if(t==null||!p||s==null||a==null){console.warn("[checkSignerExists] Prerequisites not met (WebView, JWT, API Key). Status:",{isWebViewReady:p,hasJwt:s!=null,hasApiKey:a!=null}),c(!1);return}try{let n=yield t.sendAction({event:"request:get-public-key",responseEvent:"response:get-public-key",data:{authData:{jwt:s,apiKey:a},data:{keyType:"ed25519"}},options:b});if((n==null?void 0:n.status)==="success"&&n.publicKey){z(n.publicKey);let o=k(n.publicKey.bytes);c(!1),yield P({type:"solana-smart-wallet",args:{adminSigner:o}})}else console.log("checkSignerExists needsAuth true",y),c(!0)}catch(n){console.error("[checkSignerExists] Error checking for signer:",n),c(!0)}}),[p,s,a,k,P]),Q=_react.useCallback.call(void 0, ()=>_chunkO5AL6DBJcjs.b.call(void 0, this,null,function*(){let t=d.current;if(t!=null)try{yield t.handshakeWithChild(),R(!0)}catch(n){console.error("[RN] handshakeWithChild error:",n),R(!1)}}),[]),X=_react.useCallback.call(void 0, t=>{let n=d.current;if(n!=null){try{let o=JSON.parse(t.nativeEvent.data);if(o&&typeof o.type=="string"&&o.type.startsWith("console.")){let e=o.type.split(".")[1],r=(o.data||[]).map(l=>{try{return l==="[Function]"||l==="[Circular Reference]"||l==="[Unserializable Object]"?l:JSON.parse(l)}catch(_){return l}}),i=`[WebView:${e.toUpperCase()}]`;switch(e){case"log":console.log(i,...r);break;case"error":console.error(i,...r);break;case"warn":console.warn(i,...r);break;case"info":console.info(i,...r);break;default:console.log(`[WebView Unknown:${e}]`,...r)}return}}catch(o){}n.handleMessage(t)}},[]),D=_react.useCallback.call(void 0, t=>_chunkO5AL6DBJcjs.b.call(void 0, this,null,function*(){if(s==null||a==null||h==null)return console.warn("[createRecoveryKeySigner] Prerequisites not met (WebView ready, JWT, API Key, App ID). Cannot proceed."),c(!1),null;if(O(t),d.current==null)return console.error("[createRecoveryKeySigner] WebView parent disappeared unexpectedly."),c(!1),null;try{let o=_commonsdkbase.validateApiKeyAndGetCrossmintBaseUrl.call(void 0, a),e=yield fetch(`${o}api/unstable/wallets/ncs/irrelevant/public-key`,{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${s}`,"x-api-key":a,"x-app-identifier":h},body:JSON.stringify({authId:`email:${t}`,signingAlgorithm:"EDDSA_ED25519"})});if(!e.ok){let x=yield e.text();throw new Error(`Failed to fetch public key: ${e.status} ${x}`)}let r=yield e.json();if(!r.publicKey)throw new Error("Fetched data does not contain a public key.");let i=r.publicKey,l=Uint8Array.from(atob(i),x=>x.charCodeAt(0)),_=_bs582.default.encode(l),Z=k(_);return yield P({type:"solana-smart-wallet",args:{adminSigner:Z}}),c(!0),null}catch(o){return console.error("[createRecoveryKeySigner] Error during public key fetch or processing:",o),c(!0),null}}),[s,a,h,k,P]),M=_react.useCallback.call(void 0, ()=>{if(w.current==null)return;w.current.injectJavaScript(`
2
- try {
3
- localStorage.clear();
4
- sessionStorage.clear();
5
- const cookies = document.cookie.split(';');
6
- for (let i = 0; i < cookies.length; i++) {
7
- const cookie = cookies[i];
8
- const eqPos = cookie.indexOf('=');
9
- const name = eqPos > -1 ? cookie.substr(0, eqPos) : cookie;
10
- document.cookie = name + '=;expires=Thu, 01 Jan 1970 00:00:00 GMT;path=/';
11
- }
12
- indexedDB.deleteDatabase('crossmint');
13
- indexedDB.deleteDatabase('crossmint-signer');
14
- } catch (error) {
15
- console.error('Error clearing storage:', error);
16
- }
17
- `)},[]),Y=_react.useMemo.call(void 0, ()=>({experimental_needsAuth:y,experimental_createRecoveryKeySigner:D,experimental_sendEmailWithOtp:K,experimental_verifyOtp:V,onAuthRequired:q,experimental_clearStorage:M}),[y,D,K,V,q,M]);return _jsxruntime.jsxs.call(void 0, J.Provider,{value:Y,children:[E,_jsxruntime.jsx.call(void 0, _reactnative.View,{style:{position:"absolute",width:0,height:0,overflow:"hidden"},children:_jsxruntime.jsx.call(void 0, _clientsdkrnwindow.RNWebView,{ref:w,source:{uri:$},injectedGlobals:G,onLoadEnd:Q,onMessage:X,onError:t=>{console.error("WebView onError:",t.nativeEvent),R(!1),c(!1)},onHttpError:t=>{console.error("WebView onHttpError:",t.nativeEvent),R(!1),c(!1)},style:{width:1,height:1},javaScriptCanOpenWindowsAutomatically:!1,thirdPartyCookiesEnabled:!1,sharedCookiesEnabled:!1,incognito:!1,setSupportMultipleWindows:!1,originWhitelist:[N]})})]})}exports.a = J; exports.b = Pe; exports.c = Re;
@@ -1,17 +0,0 @@
1
- import{e as U}from"./chunk-T3Q4KTE4.js";import{b as g}from"./chunk-TKB736C5.js";import ee,{useCallback as u,useContext as I,useEffect as T,useRef as f,useState as C,useMemo as j}from"react";import v from"bs58";import{PublicKey as re}from"@solana/web3.js";import{RNWebView as te}from"@crossmint/client-sdk-rn-window";import{WebViewParent as ne}from"@crossmint/client-sdk-rn-window";import{signerInboundEvents as oe,signerOutboundEvents as se}from"@crossmint/client-signers";import{View as ie}from"react-native";import{validateApiKeyAndGetCrossmintBaseUrl as ae}from"@crossmint/common-sdk-base";import{WalletContext as ce}from"@crossmint/client-sdk-react-base";import{jsx as F,jsxs as le}from"react/jsx-runtime";var J=ee.createContext(null);function Re(){let E=I(J);if(E==null)throw new Error("useCrossmintRecoveryKey must be used within a CrossmintRecoveryKeyProvider");return E}var b={timeoutMs:1e4,intervalMs:5e3},N="https://crossmint-signer-frames.onrender.com";function ke({children:E,experimental_secureEndpointUrl:$=N}){let{crossmint:{apiKey:a,jwt:s,appId:h}}=U(),{getOrCreateWallet:P,clearWallet:B}=I(ce),w=f(null),d=f(null),[p,R]=C(!1),[ue,O]=C(null),[y,c]=C(!1),W=f(!1),A=f(!1),m=f(null),G=j(()=>h!=null?`window.crossmintAppId = '${h}';`:"",[h]);T(()=>{w.current!=null&&d.current==null&&(d.current=new ne(w,{incomingEvents:se,outgoingEvents:oe}))},[]),T(()=>{s==null&&!W.current?(c(!1),O(null),B(),W.current=!0):s!=null&&(W.current=!1,p&&H())},[s,p]),T(()=>{A.current=y},[y]);let S=u(()=>g(this,null,function*(){if(console.log("handleAuthRequired needsAuth",A.current),!A.current)return;let t,n,o=new Promise((e,r)=>{t=e,n=r});m.current={promise:o,resolve:t,reject:n};try{console.log("Waiting for auth promise"),yield m.current.promise,console.log("Auth promise resolved")}catch(e){throw e}}),[]),K=u(t=>g(this,null,function*(){var e;let n=d.current;if(n==null||!p)throw new Error("[sendEmailWithOtp] WebViewParent not ready or handshake incomplete.");if(s==null||a==null)throw new Error("[sendEmailWithOtp] Missing authentication credentials (JWT or API Key).");if(!y)throw new Error("OTP email request is not applicable in the current state.");O(t);let o=`email:${t}`;try{let r=yield n.sendAction({event:"request:start-onboarding",responseEvent:"response:start-onboarding",data:{authData:{jwt:s,apiKey:a},data:{authId:o,keyType:"ed25519"}},options:b});if((r==null?void 0:r.status)==="success"&&r.publicKey){c(!1);return}if((r==null?void 0:r.status)==="error")throw console.error("[sendEmailWithOtp] Failed to send OTP:",r),new Error(r.error||"Failed to initiate OTP process.");console.log("[sendEmailWithOtp] OTP process likely initiated. Waiting for verification.")}catch(r){throw console.error("[sendEmailWithOtp] Error sending start-onboarding request:",r),(e=m.current)==null||e.reject(r),r}}),[p,s,a,y]),V=u(t=>g(this,null,function*(){var o,e,r;let n=d.current;if(n==null||!p)throw new Error("[verifyOtp] WebViewParent not ready or handshake incomplete.");if(s==null||a==null)throw new Error("[verifyOtp] Missing authentication credentials (JWT or API Key).");if(!y)throw new Error("Not currently awaiting OTP validation.");try{let i=yield n.sendAction({event:"request:complete-onboarding",responseEvent:"response:complete-onboarding",data:{authData:{jwt:s,apiKey:a},data:{keyType:"ed25519",onboardingAuthentication:{encryptedOtp:t}}},options:b});if((i==null?void 0:i.status)==="success"&&i.publicKey){console.log("[verifyOtp] OTP validation successful. Signer address:",i.publicKey),c(!1),(o=m.current)==null||o.resolve();return}else{console.error("[verifyOtp] Failed to validate OTP:",i),c(!0);let l=i&&i.status==="error"?i.error:"Failed to validate encrypted OTP";throw(e=m.current)==null||e.reject(new Error(l)),new Error(l)}}catch(i){throw console.error("[verifyOtp] Error sending OTP validation request:",i),c(!0),(r=m.current)==null||r.reject(i),i}}),[p,s,a,y]),L=f(null),q=u(t=>{L.current=t},[]),z=t=>{if(t.encoding!=="base58"||t.keyType!=="ed25519")throw new Error("Unsupported key type and encoding: "+t.keyType+" "+t.encoding)},k=u(t=>{let n=d.current;if(n==null||s==null||a==null)throw new Error("Cannot build signer: Missing prerequisites (parent, jwt, apiKey).");return{type:"solana-keypair",address:t,signer:{signMessage:o=>g(this,null,function*(){yield S();try{let e=yield n.sendAction({event:"request:sign",responseEvent:"response:sign",data:{authData:{jwt:s,apiKey:a},data:{bytes:v.encode(o),keyType:"ed25519",encoding:"base58"}},options:b});if(e==null||e.status==="error"||e.signature==null)throw console.error("Failed signMessage response:",e),new Error("Failed to sign message");if(e.signature.encoding==="base58"&&e.signature.bytes)return v.decode(e.signature.bytes);throw new Error("Unsupported encoding: "+e.signature.encoding)}catch(e){throw console.error("Error during signMessage:",e),e}}),signTransaction:o=>g(this,null,function*(){yield S();try{let e=o.message.serialize(),r=yield n.sendAction({event:"request:sign",responseEvent:"response:sign",data:{authData:{jwt:s,apiKey:a},data:{bytes:v.encode(e),keyType:"ed25519",encoding:"base58"}},options:b});if(r==null||r.status==="error"||r.signature==null)throw new Error("Failed to sign transaction: No signature returned");if(r.signature.encoding==="base58"&&r.signature.bytes)o.addSignature(new re(t),v.decode(r.signature.bytes));else throw new Error("Unsupported encoding: "+r.signature.encoding);return o}catch(e){throw console.error("Error during signTransaction:",e),e}})}}},[s,a,S]),H=u(()=>g(this,null,function*(){let t=d.current;if(t==null||!p||s==null||a==null){console.warn("[checkSignerExists] Prerequisites not met (WebView, JWT, API Key). Status:",{isWebViewReady:p,hasJwt:s!=null,hasApiKey:a!=null}),c(!1);return}try{let n=yield t.sendAction({event:"request:get-public-key",responseEvent:"response:get-public-key",data:{authData:{jwt:s,apiKey:a},data:{keyType:"ed25519"}},options:b});if((n==null?void 0:n.status)==="success"&&n.publicKey){z(n.publicKey);let o=k(n.publicKey.bytes);c(!1),yield P({type:"solana-smart-wallet",args:{adminSigner:o}})}else console.log("checkSignerExists needsAuth true",y),c(!0)}catch(n){console.error("[checkSignerExists] Error checking for signer:",n),c(!0)}}),[p,s,a,k,P]),Q=u(()=>g(this,null,function*(){let t=d.current;if(t!=null)try{yield t.handshakeWithChild(),R(!0)}catch(n){console.error("[RN] handshakeWithChild error:",n),R(!1)}}),[]),X=u(t=>{let n=d.current;if(n!=null){try{let o=JSON.parse(t.nativeEvent.data);if(o&&typeof o.type=="string"&&o.type.startsWith("console.")){let e=o.type.split(".")[1],r=(o.data||[]).map(l=>{try{return l==="[Function]"||l==="[Circular Reference]"||l==="[Unserializable Object]"?l:JSON.parse(l)}catch(_){return l}}),i=`[WebView:${e.toUpperCase()}]`;switch(e){case"log":console.log(i,...r);break;case"error":console.error(i,...r);break;case"warn":console.warn(i,...r);break;case"info":console.info(i,...r);break;default:console.log(`[WebView Unknown:${e}]`,...r)}return}}catch(o){}n.handleMessage(t)}},[]),D=u(t=>g(this,null,function*(){if(s==null||a==null||h==null)return console.warn("[createRecoveryKeySigner] Prerequisites not met (WebView ready, JWT, API Key, App ID). Cannot proceed."),c(!1),null;if(O(t),d.current==null)return console.error("[createRecoveryKeySigner] WebView parent disappeared unexpectedly."),c(!1),null;try{let o=ae(a),e=yield fetch(`${o}api/unstable/wallets/ncs/irrelevant/public-key`,{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${s}`,"x-api-key":a,"x-app-identifier":h},body:JSON.stringify({authId:`email:${t}`,signingAlgorithm:"EDDSA_ED25519"})});if(!e.ok){let x=yield e.text();throw new Error(`Failed to fetch public key: ${e.status} ${x}`)}let r=yield e.json();if(!r.publicKey)throw new Error("Fetched data does not contain a public key.");let i=r.publicKey,l=Uint8Array.from(atob(i),x=>x.charCodeAt(0)),_=v.encode(l),Z=k(_);return yield P({type:"solana-smart-wallet",args:{adminSigner:Z}}),c(!0),null}catch(o){return console.error("[createRecoveryKeySigner] Error during public key fetch or processing:",o),c(!0),null}}),[s,a,h,k,P]),M=u(()=>{if(w.current==null)return;w.current.injectJavaScript(`
2
- try {
3
- localStorage.clear();
4
- sessionStorage.clear();
5
- const cookies = document.cookie.split(';');
6
- for (let i = 0; i < cookies.length; i++) {
7
- const cookie = cookies[i];
8
- const eqPos = cookie.indexOf('=');
9
- const name = eqPos > -1 ? cookie.substr(0, eqPos) : cookie;
10
- document.cookie = name + '=;expires=Thu, 01 Jan 1970 00:00:00 GMT;path=/';
11
- }
12
- indexedDB.deleteDatabase('crossmint');
13
- indexedDB.deleteDatabase('crossmint-signer');
14
- } catch (error) {
15
- console.error('Error clearing storage:', error);
16
- }
17
- `)},[]),Y=j(()=>({experimental_needsAuth:y,experimental_createRecoveryKeySigner:D,experimental_sendEmailWithOtp:K,experimental_verifyOtp:V,onAuthRequired:q,experimental_clearStorage:M}),[y,D,K,V,q,M]);return le(J.Provider,{value:Y,children:[E,F(ie,{style:{position:"absolute",width:0,height:0,overflow:"hidden"},children:F(te,{ref:w,source:{uri:$},injectedGlobals:G,onLoadEnd:Q,onMessage:X,onError:t=>{console.error("WebView onError:",t.nativeEvent),R(!1),c(!1)},onHttpError:t=>{console.error("WebView onHttpError:",t.nativeEvent),R(!1),c(!1)},style:{width:1,height:1},javaScriptCanOpenWindowsAutomatically:!1,thirdPartyCookiesEnabled:!1,sharedCookiesEnabled:!1,incognito:!1,setSupportMultipleWindows:!1,originWhitelist:[N]})})]})}export{J as a,Re as b,ke as c};