@crossmint/client-sdk-react-native-ui 0.4.18 → 0.4.19
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{chunk-XBWLXXPM.cjs → chunk-CTP7RCPJ.cjs} +1 -1
- package/dist/chunk-HFKH3XVQ.js +17 -0
- package/dist/{chunk-56YROBGG.js → chunk-MMOOXJQF.js} +1 -1
- package/dist/chunk-PIEHDVJR.cjs +17 -0
- package/dist/hooks/useWalletsAuth.cjs +1 -1
- package/dist/hooks/useWalletsAuth.js +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.js +1 -1
- package/dist/providers/CrossmintRecoveryKeyProvider.cjs +1 -1
- package/dist/providers/CrossmintRecoveryKeyProvider.js +1 -1
- package/dist/providers/CrossmintWalletProvider.cjs +1 -1
- package/dist/providers/CrossmintWalletProvider.js +1 -1
- package/dist/providers/index.cjs +1 -1
- package/dist/providers/index.js +1 -1
- package/package.json +6 -6
- package/dist/chunk-24LYBMXY.cjs +0 -17
- package/dist/chunk-F4CHPSRS.js +0 -17
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports, "__esModule", {value: true});var
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunkPIEHDVJRcjs = require('./chunk-PIEHDVJR.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, _chunkPIEHDVJRcjs.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, _chunkPIEHDVJRcjs.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;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import{e as U}from"./chunk-XA3CJXOO.js";import{a as D,b as N,c as g}from"./chunk-22GIA4MK.js";import re,{useCallback as u,useContext as F,useEffect as A,useRef as m,useState as T,useMemo as j}from"react";import k from"bs58";import{PublicKey as te}from"@solana/web3.js";import{RNWebView as ne}from"@crossmint/client-sdk-rn-window";import{WebViewParent as oe}from"@crossmint/client-sdk-rn-window";import{signerInboundEvents as se,signerOutboundEvents as ie}from"@crossmint/client-signers";import{View as ae}from"react-native";import{validateApiKeyAndGetCrossmintBaseUrl as ce}from"@crossmint/common-sdk-base";import{WalletContext as le}from"@crossmint/client-sdk-react-base";import{jsx as J,jsxs as ue}from"react/jsx-runtime";var $=re.createContext(null);function ke(){let b=F($);if(b==null)throw new Error("useCrossmintRecoveryKey must be used within a CrossmintRecoveryKeyProvider");return b}var v={timeoutMs:1e4,intervalMs:5e3},I="https://crossmint-signer-frames.onrender.com";function Oe({children:b,experimental_secureEndpointUrl:B=I}){let{crossmint:{apiKey:a,jwt:i,appId:h}}=U(),{getOrCreateWallet:E,clearWallet:G}=F(le),w=m(null),d=m(null),[p,P]=T(!1),[de,O]=T(null),[y,c]=T(!1),W=m(!1),S=m(!1),f=m(null),L=j(()=>h!=null?`window.crossmintAppId = '${h}';`:"",[h]);A(()=>{w.current!=null&&d.current==null&&(d.current=new oe(w,{incomingEvents:ie,outgoingEvents:se}))},[]),A(()=>{i==null&&!W.current?(c(!1),O(null),G(),W.current=!0):i!=null&&(W.current=!1,p&&Q())},[i,p]),A(()=>{S.current=y},[y]);let x=u(()=>g(this,null,function*(){if(console.log("handleAuthRequired needsAuth",S.current),!S.current)return;let t,s,n=new Promise((e,r)=>{t=e,s=r});f.current={promise:n,resolve:t,reject:s};try{console.log("Waiting for auth promise"),yield f.current.promise,console.log("Auth promise resolved")}catch(e){throw e}}),[]),C=u(t=>g(this,null,function*(){var e;let s=d.current;if(s==null||!p)throw new Error("[sendEmailWithOtp] WebViewParent not ready or handshake incomplete.");if(i==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 n=`email:${t}`;try{let r=yield s.sendAction({event:"request:start-onboarding",responseEvent:"response:start-onboarding",data:{authData:{jwt:i,apiKey:a},data:{authId:n}},options:v});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,i,a,y]),K=u(t=>g(this,null,function*(){var n,e,r;let s=d.current;if(s==null||!p)throw new Error("[verifyOtp] WebViewParent not ready or handshake incomplete.");if(i==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 o=yield s.sendAction({event:"request:complete-onboarding",responseEvent:"response:complete-onboarding",data:{authData:{jwt:i,apiKey:a},data:{onboardingAuthentication:{encryptedOtp:t}}},options:v});if((o==null?void 0:o.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:",o),c(!0);let l=o&&o.status==="error"?o.error:"Failed to validate encrypted OTP";throw(e=f.current)==null||e.reject(new Error(l)),new Error(l)}}catch(o){throw console.error("[verifyOtp] Error sending OTP validation request:",o),c(!0),(r=f.current)==null||r.reject(o),o}}),[p,i,a,y]),z=m(null),V=u(t=>{z.current=t},[]),H=t=>{if(t.encoding!=="base58"||t.keyType!=="ed25519")throw new Error("Unsupported key type and encoding: "+t.keyType+" "+t.encoding)},R=u(t=>{let s=d.current;if(s==null||i==null||a==null)throw new Error("Cannot build signer: Missing prerequisites (parent, jwt, apiKey).");return{type:"solana-keypair",address:t,signer:{signMessage:n=>g(this,null,function*(){yield x();try{let e=yield s.sendAction({event:"request:sign",responseEvent:"response:sign",data:{authData:{jwt:i,apiKey:a},data:{bytes:k.encode(n),keyType:"ed25519",encoding:"base58"}},options:v});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 k.decode(e.signature.bytes);throw new Error("Unsupported encoding: "+e.signature.encoding)}catch(e){throw console.error("Error during signMessage:",e),e}}),signTransaction:n=>g(this,null,function*(){yield x();try{let e=n.message.serialize(),r=yield s.sendAction({event:"request:sign",responseEvent:"response:sign",data:{authData:{jwt:i,apiKey:a},data:{bytes:k.encode(e),keyType:"ed25519",encoding:"base58"}},options:v});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 te(t),k.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}})}}},[i,a,x]),Q=u(()=>g(this,null,function*(){var s;let t=d.current;if(t==null||!p||i==null||a==null){console.warn("[checkSignerExists] Prerequisites not met (WebView, JWT, API Key). Status:",{isWebViewReady:p,hasJwt:i!=null,hasApiKey:a!=null}),c(!1);return}try{let n=yield t.sendAction({event:"request:get-status",responseEvent:"response:get-status",data:{authData:{jwt:i,apiKey:a}},options:v});if((n==null?void 0:n.status)==="success"&&n.signerStatus==="ready"){let e=(s=n.publicKeys)==null?void 0:s.ed25519;if(e==null||e.bytes==null||e.encoding==null)throw new Error("No public key found");H(N(D({},e),{keyType:"ed25519"}));let r=R(e.bytes);c(!1),yield E({type:"solana-smart-wallet",args:{adminSigner:r}})}else console.log("checkSignerExists needsAuth true",y),c(!0)}catch(n){console.error("[checkSignerExists] Error checking for signer:",n),c(!0)}}),[p,i,a,R,E]),X=u(()=>g(this,null,function*(){let t=d.current;if(t!=null)try{yield t.handshakeWithChild(),P(!0)}catch(s){console.error("[RN] handshakeWithChild error:",s),P(!1)}}),[]),Y=u(t=>{let s=d.current;if(s!=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}}),o=`[WebView:${e.toUpperCase()}]`;switch(e){case"log":console.log(o,...r);break;case"error":console.error(o,...r);break;case"warn":console.warn(o,...r);break;case"info":console.info(o,...r);break;default:console.log(`[WebView Unknown:${e}]`,...r)}return}}catch(n){}s.handleMessage(t)}},[]),q=u(t=>g(this,null,function*(){if(i==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 n=ce(a),e=yield fetch(`${n}api/v1/signers/derive-public-key`,{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${i}`,"x-api-key":a,"x-app-identifier":h},body:JSON.stringify({authId:`email:${t}`,keyType:"ed25519"})});if(!e.ok){let ee=yield e.text();throw new Error(`Failed to fetch public key: ${e.status} ${ee}`)}let o=(yield e.json()).publicKey;if(o==null)throw new Error("No public key found");if(o.encoding!=="base58"||o.keyType!=="ed25519"||o.bytes==null)throw new Error("Not supported. Expected public key to be in base58 encoding and ed25519 key type. Got: "+JSON.stringify(o));let l=o.bytes,_=R(l);return yield E({type:"solana-smart-wallet",args:{adminSigner:_}}),c(!0),null}catch(n){return console.error("[createRecoveryKeySigner] Error during public key fetch or processing:",n),c(!0),null}}),[i,a,h,R,E]),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
|
+
`)},[]),Z=j(()=>({experimental_needsAuth:y,experimental_createRecoveryKeySigner:q,experimental_sendEmailWithOtp:C,experimental_verifyOtp:K,onAuthRequired:V,experimental_clearStorage:M}),[y,q,C,K,V,M]);return ue($.Provider,{value:Z,children:[b,J(ae,{style:{position:"absolute",width:0,height:0,overflow:"hidden"},children:J(ne,{ref:w,source:{uri:B},injectedGlobals:L,onLoadEnd:X,onMessage:Y,onError:t=>{console.error("WebView onError:",t.nativeEvent),P(!1),c(!1)},onHttpError:t=>{console.error("WebView onHttpError:",t.nativeEvent),P(!1),c(!1)},style:{width:1,height:1},javaScriptCanOpenWindowsAutomatically:!1,thirdPartyCookiesEnabled:!1,sharedCookiesEnabled:!1,incognito:!1,setSupportMultipleWindows:!1,originWhitelist:[I]})})]})}export{$ as a,ke as b,Oe as c};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a as c,c as m}from"./chunk-
|
|
1
|
+
import{a as c,c as m}from"./chunk-HFKH3XVQ.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,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 $=_react2.default.createContext(null);function Re(){let b=_react.useContext.call(void 0, $);if(b==null)throw new Error("useCrossmintRecoveryKey must be used within a CrossmintRecoveryKeyProvider");return b}var v={timeoutMs:1e4,intervalMs:5e3},I="https://crossmint-signer-frames.onrender.com";function ke({children:b,experimental_secureEndpointUrl:B=I}){let{crossmint:{apiKey:a,jwt:i,appId:h}}=_chunkOCM4UKCZcjs.e.call(void 0, ),{getOrCreateWallet:E,clearWallet:G}=_react.useContext.call(void 0, _clientsdkreactbase.WalletContext),w=_react.useRef.call(void 0, null),d=_react.useRef.call(void 0, null),[p,P]=_react.useState.call(void 0, !1),[de,O]=_react.useState.call(void 0, null),[y,c]=_react.useState.call(void 0, !1),W=_react.useRef.call(void 0, !1),S=_react.useRef.call(void 0, !1),f=_react.useRef.call(void 0, null),L=_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, ()=>{i==null&&!W.current?(c(!1),O(null),G(),W.current=!0):i!=null&&(W.current=!1,p&&Q())},[i,p]),_react.useEffect.call(void 0, ()=>{S.current=y},[y]);let x=_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,s,n=new Promise((e,r)=>{t=e,s=r});f.current={promise:n,resolve:t,reject:s};try{console.log("Waiting for auth promise"),yield f.current.promise,console.log("Auth promise resolved")}catch(e){throw e}}),[]),C=_react.useCallback.call(void 0, t=>_chunkCK4JCQY6cjs.c.call(void 0, this,null,function*(){var e;let s=d.current;if(s==null||!p)throw new Error("[sendEmailWithOtp] WebViewParent not ready or handshake incomplete.");if(i==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 n=`email:${t}`;try{let r=yield s.sendAction({event:"request:start-onboarding",responseEvent:"response:start-onboarding",data:{authData:{jwt:i,apiKey:a},data:{authId:n}},options:v});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,i,a,y]),K=_react.useCallback.call(void 0, t=>_chunkCK4JCQY6cjs.c.call(void 0, this,null,function*(){var n,e,r;let s=d.current;if(s==null||!p)throw new Error("[verifyOtp] WebViewParent not ready or handshake incomplete.");if(i==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 o=yield s.sendAction({event:"request:complete-onboarding",responseEvent:"response:complete-onboarding",data:{authData:{jwt:i,apiKey:a},data:{onboardingAuthentication:{encryptedOtp:t}}},options:v});if((o==null?void 0:o.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:",o),c(!0);let l=o&&o.status==="error"?o.error:"Failed to validate encrypted OTP";throw(e=f.current)==null||e.reject(new Error(l)),new Error(l)}}catch(o){throw console.error("[verifyOtp] Error sending OTP validation request:",o),c(!0),(r=f.current)==null||r.reject(o),o}}),[p,i,a,y]),z=_react.useRef.call(void 0, null),V=_react.useCallback.call(void 0, t=>{z.current=t},[]),H=t=>{if(t.encoding!=="base58"||t.keyType!=="ed25519")throw new Error("Unsupported key type and encoding: "+t.keyType+" "+t.encoding)},R=_react.useCallback.call(void 0, t=>{let s=d.current;if(s==null||i==null||a==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 x();try{let e=yield s.sendAction({event:"request:sign",responseEvent:"response:sign",data:{authData:{jwt:i,apiKey:a},data:{bytes:_bs582.default.encode(n),keyType:"ed25519",encoding:"base58"}},options:v});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 x();try{let e=n.message.serialize(),r=yield s.sendAction({event:"request:sign",responseEvent:"response:sign",data:{authData:{jwt:i,apiKey:a},data:{bytes:_bs582.default.encode(e),keyType:"ed25519",encoding:"base58"}},options:v});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}})}}},[i,a,x]),Q=_react.useCallback.call(void 0, ()=>_chunkCK4JCQY6cjs.c.call(void 0, this,null,function*(){var s;let t=d.current;if(t==null||!p||i==null||a==null){console.warn("[checkSignerExists] Prerequisites not met (WebView, JWT, API Key). Status:",{isWebViewReady:p,hasJwt:i!=null,hasApiKey:a!=null}),c(!1);return}try{let n=yield t.sendAction({event:"request:get-status",responseEvent:"response:get-status",data:{authData:{jwt:i,apiKey:a}},options:v});if((n==null?void 0:n.status)==="success"&&n.signerStatus==="ready"){let e=(s=n.publicKeys)==null?void 0:s.ed25519;if(e==null||e.bytes==null||e.encoding==null)throw new Error("No public key found");H(_chunkCK4JCQY6cjs.b.call(void 0, _chunkCK4JCQY6cjs.a.call(void 0, {},e),{keyType:"ed25519"}));let r=R(e.bytes);c(!1),yield E({type:"solana-smart-wallet",args:{adminSigner:r}})}else console.log("checkSignerExists needsAuth true",y),c(!0)}catch(n){console.error("[checkSignerExists] Error checking for signer:",n),c(!0)}}),[p,i,a,R,E]),X=_react.useCallback.call(void 0, ()=>_chunkCK4JCQY6cjs.c.call(void 0, this,null,function*(){let t=d.current;if(t!=null)try{yield t.handshakeWithChild(),P(!0)}catch(s){console.error("[RN] handshakeWithChild error:",s),P(!1)}}),[]),Y=_react.useCallback.call(void 0, t=>{let s=d.current;if(s!=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}}),o=`[WebView:${e.toUpperCase()}]`;switch(e){case"log":console.log(o,...r);break;case"error":console.error(o,...r);break;case"warn":console.warn(o,...r);break;case"info":console.info(o,...r);break;default:console.log(`[WebView Unknown:${e}]`,...r)}return}}catch(n){}s.handleMessage(t)}},[]),q=_react.useCallback.call(void 0, t=>_chunkCK4JCQY6cjs.c.call(void 0, this,null,function*(){if(i==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 n=_commonsdkbase.validateApiKeyAndGetCrossmintBaseUrl.call(void 0, a),e=yield fetch(`${n}api/v1/signers/derive-public-key`,{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${i}`,"x-api-key":a,"x-app-identifier":h},body:JSON.stringify({authId:`email:${t}`,keyType:"ed25519"})});if(!e.ok){let ee=yield e.text();throw new Error(`Failed to fetch public key: ${e.status} ${ee}`)}let o=(yield e.json()).publicKey;if(o==null)throw new Error("No public key found");if(o.encoding!=="base58"||o.keyType!=="ed25519"||o.bytes==null)throw new Error("Not supported. Expected public key to be in base58 encoding and ed25519 key type. Got: "+JSON.stringify(o));let l=o.bytes,_=R(l);return yield E({type:"solana-smart-wallet",args:{adminSigner:_}}),c(!0),null}catch(n){return console.error("[createRecoveryKeySigner] Error during public key fetch or processing:",n),c(!0),null}}),[i,a,h,R,E]),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
|
+
`)},[]),Z=_react.useMemo.call(void 0, ()=>({experimental_needsAuth:y,experimental_createRecoveryKeySigner:q,experimental_sendEmailWithOtp:C,experimental_verifyOtp:K,onAuthRequired:V,experimental_clearStorage:M}),[y,q,C,K,V,M]);return _jsxruntime.jsxs.call(void 0, $.Provider,{value:Z,children:[b,_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:B},injectedGlobals:L,onLoadEnd:X,onMessage:Y,onError:t=>{console.error("WebView onError:",t.nativeEvent),P(!1),c(!1)},onHttpError:t=>{console.error("WebView onHttpError:",t.nativeEvent),P(!1),c(!1)},style:{width:1,height:1},javaScriptCanOpenWindowsAutomatically:!1,thirdPartyCookiesEnabled:!1,sharedCookiesEnabled:!1,incognito:!1,setSupportMultipleWindows:!1,originWhitelist:[I]})})]})}exports.a = $; exports.b = Re; exports.c = ke;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports, "__esModule", {value: true});var
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunkPIEHDVJRcjs = require('../chunk-PIEHDVJR.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, _chunkPIEHDVJRcjs.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-
|
|
1
|
+
import{a as t}from"../chunk-HFKH3XVQ.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
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true});require('./chunk-ZR6BLDCD.cjs');var _chunkCTP7RCPJcjs = require('./chunk-CTP7RCPJ.cjs');require('./chunk-PIEHDVJR.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 = _chunkCTP7RCPJcjs.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-
|
|
1
|
+
import"./chunk-C62HRWJA.js";import{a as l}from"./chunk-MMOOXJQF.js";import"./chunk-HFKH3XVQ.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
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunkPIEHDVJRcjs = require('../chunk-PIEHDVJR.cjs');require('../chunk-OCM4UKCZ.cjs');require('../chunk-R3KSNRO2.cjs');require('../chunk-KWIO2XXJ.cjs');require('../chunk-CK4JCQY6.cjs');exports.CrossmintRecoveryKeyContext = _chunkPIEHDVJRcjs.a; exports.CrossmintRecoveryKeyProvider = _chunkPIEHDVJRcjs.c; exports.useCrossmintRecoveryKey = _chunkPIEHDVJRcjs.b;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a,b,c}from"../chunk-
|
|
1
|
+
import{a,b,c}from"../chunk-HFKH3XVQ.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
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunkCTP7RCPJcjs = require('../chunk-CTP7RCPJ.cjs');require('../chunk-PIEHDVJR.cjs');require('../chunk-OCM4UKCZ.cjs');require('../chunk-R3KSNRO2.cjs');require('../chunk-KWIO2XXJ.cjs');require('../chunk-CK4JCQY6.cjs');exports.CrossmintWalletProvider = _chunkCTP7RCPJcjs.a;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a}from"../chunk-
|
|
1
|
+
import{a}from"../chunk-MMOOXJQF.js";import"../chunk-HFKH3XVQ.js";import"../chunk-XA3CJXOO.js";import"../chunk-SYFNPOWZ.js";import"../chunk-KZMAEKSM.js";import"../chunk-22GIA4MK.js";export{a as CrossmintWalletProvider};
|
package/dist/providers/index.cjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports, "__esModule", {value: true});require('../chunk-ZR6BLDCD.cjs');var
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true});require('../chunk-ZR6BLDCD.cjs');var _chunkCTP7RCPJcjs = require('../chunk-CTP7RCPJ.cjs');require('../chunk-PIEHDVJR.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 = _chunkCTP7RCPJcjs.a;
|
package/dist/providers/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import"../chunk-C62HRWJA.js";import{a as c}from"../chunk-
|
|
1
|
+
import"../chunk-C62HRWJA.js";import{a as c}from"../chunk-MMOOXJQF.js";import"../chunk-HFKH3XVQ.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};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@crossmint/client-sdk-react-native-ui",
|
|
3
|
-
"version": "0.4.
|
|
3
|
+
"version": "0.4.19",
|
|
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-rn-window": "0.2.2",
|
|
28
|
-
"@crossmint/client-sdk-react-base": "0.2.16",
|
|
29
|
-
"@crossmint/client-sdk-base": "1.5.1",
|
|
30
27
|
"@crossmint/client-sdk-auth": "1.2.9",
|
|
28
|
+
"@crossmint/client-sdk-base": "1.5.1",
|
|
29
|
+
"@crossmint/client-sdk-react-base": "0.2.16",
|
|
30
|
+
"@crossmint/client-sdk-rn-window": "0.2.2",
|
|
31
31
|
"@crossmint/client-signers": "0.0.15",
|
|
32
32
|
"@crossmint/common-sdk-auth": "1.0.32",
|
|
33
|
-
"@crossmint/
|
|
34
|
-
"@crossmint/
|
|
33
|
+
"@crossmint/common-sdk-base": "0.5.1",
|
|
34
|
+
"@crossmint/wallets-sdk": "0.8.1"
|
|
35
35
|
},
|
|
36
36
|
"devDependencies": {
|
|
37
37
|
"@types/react": "19.0.12"
|
package/dist/chunk-24LYBMXY.cjs
DELETED
|
@@ -1,17 +0,0 @@
|
|
|
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;
|
package/dist/chunk-F4CHPSRS.js
DELETED
|
@@ -1,17 +0,0 @@
|
|
|
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};
|