@crossmint/client-sdk-react-native-ui 0.4.17 → 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-22GIA4MK.js +1 -0
- package/dist/chunk-CK4JCQY6.cjs +1 -0
- package/dist/{chunk-OFWUQQBR.cjs → chunk-CTP7RCPJ.cjs} +1 -1
- package/dist/chunk-HFKH3XVQ.js +17 -0
- package/dist/{chunk-P3LUXXWV.js → chunk-MMOOXJQF.js} +1 -1
- package/dist/{chunk-VIA5NAWD.cjs → chunk-OCM4UKCZ.cjs} +1 -1
- package/dist/chunk-PIEHDVJR.cjs +17 -0
- package/dist/{chunk-BZACBNUH.cjs → chunk-R3KSNRO2.cjs} +1 -1
- package/dist/{chunk-ZRIYUAKZ.js → chunk-SYFNPOWZ.js} +1 -1
- package/dist/chunk-XA3CJXOO.js +1 -0
- package/dist/hooks/index.cjs +1 -1
- package/dist/hooks/index.js +1 -1
- package/dist/hooks/useCrossmintAuth.cjs +1 -1
- package/dist/hooks/useCrossmintAuth.js +1 -1
- package/dist/hooks/useWallet.cjs +1 -1
- package/dist/hooks/useWallet.js +1 -1
- 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/CrossmintAuthProvider.cjs +1 -1
- package/dist/providers/CrossmintAuthProvider.js +1 -1
- package/dist/providers/CrossmintProvider.cjs +1 -1
- package/dist/providers/CrossmintProvider.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/dist/testUtils.cjs +1 -1
- package/dist/testUtils.js +1 -1
- package/dist/utils/SecureStorage.cjs +1 -1
- package/dist/utils/SecureStorage.js +1 -1
- package/package.json +2 -2
- package/dist/chunk-O5AL6DBJ.cjs +0 -1
- package/dist/chunk-T3Q4KTE4.js +0 -1
- package/dist/chunk-TKB736C5.js +0 -1
- package/dist/chunk-WTPTLPLV.cjs +0 -17
- 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 @@
|
|
|
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;
|
|
@@ -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};
|
|
@@ -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
|
|
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;
|
|
@@ -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}); 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
|
|
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{
|
|
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};
|
package/dist/hooks/index.cjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports, "__esModule", {value: true});var
|
|
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;
|
package/dist/hooks/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{c as a,d as b,e}from"../chunk-
|
|
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
|
|
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-
|
|
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};
|
package/dist/hooks/useWallet.cjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunkKWIO2XXJcjs = require('../chunk-KWIO2XXJ.cjs');require('../chunk-
|
|
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;
|
package/dist/hooks/useWallet.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a,b}from"../chunk-KZMAEKSM.js";import"../chunk-
|
|
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
|
|
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 _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-
|
|
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-
|
|
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-
|
|
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
|
|
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/dist/testUtils.cjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports, "__esModule", {value: true});require('./chunk-
|
|
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-
|
|
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
|
|
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-
|
|
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.
|
|
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",
|
|
@@ -28,7 +28,7 @@
|
|
|
28
28
|
"@crossmint/client-sdk-base": "1.5.1",
|
|
29
29
|
"@crossmint/client-sdk-react-base": "0.2.16",
|
|
30
30
|
"@crossmint/client-sdk-rn-window": "0.2.2",
|
|
31
|
-
"@crossmint/client-signers": "0.0.
|
|
31
|
+
"@crossmint/client-signers": "0.0.15",
|
|
32
32
|
"@crossmint/common-sdk-auth": "1.0.32",
|
|
33
33
|
"@crossmint/common-sdk-base": "0.5.1",
|
|
34
34
|
"@crossmint/wallets-sdk": "0.8.1"
|
package/dist/chunk-O5AL6DBJ.cjs
DELETED
|
@@ -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;
|
package/dist/chunk-T3Q4KTE4.js
DELETED
|
@@ -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};
|
package/dist/chunk-TKB736C5.js
DELETED
|
@@ -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};
|
package/dist/chunk-WTPTLPLV.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 _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;
|
package/dist/chunk-YWHWC4WZ.js
DELETED
|
@@ -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};
|