@revibase/lite 0.0.22 → 0.0.23
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/index.cjs +1 -1
- package/dist/index.cjs.map +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
package/dist/index.cjs
CHANGED
|
@@ -5,6 +5,6 @@ Install @solana/webcrypto-ed25519-polyfill and call its \`install\` function bef
|
|
|
5
5
|
For a list of runtimes that currently support Ed25519 operations, visit https://github.com/WICG/webcrypto-secure-curves/issues/20.`,[_t]:"No signature verification implementation could be found.",[At]:"No key generation implementation could be found.",[Rt]:"No signing implementation could be found.",[Et]:"No key export implementation could be found.",[Ue]:"Timestamp value must be in the range [-(2n ** 63n), (2n ** 63n) - 1]. `$value` given",[mr]:"Transaction processing left an account with an outstanding borrowed reference",[ur]:"Account in use",[Ir]:"Account loaded twice",[_r]:"Attempt to debit an account but found no record of a prior credit.",[Fr]:"Transaction loads an address table account that doesn't exist",[Tr]:"This transaction has already been processed",[lr]:"Blockhash not found",[Dr]:"Loader call chain is too deep",[fr]:"Transactions are currently disabled due to cluster maintenance",[kr]:"Transaction contains a duplicate instruction ($index) that is not allowed",[Rr]:"Insufficient funds for fee",[Wr]:"Transaction results in an account ($accountIndex) with insufficient funds for rent",[Er]:"This account may not be used to pay transaction fees",[Nr]:"Transaction contains an invalid account reference",[vr]:"Transaction loads an address table account with invalid data",[br]:"Transaction address table lookup uses an invalid index",[Pr]:"Transaction loads an address table account with an invalid owner",[Gr]:"LoadedAccountsDataSizeLimit set for transaction must be greater than 0.",[Or]:"This program may not be used for executing instructions",[Br]:"Transaction leaves an account with a lower balance than rent-exempt minimum",[hr]:"Transaction loads a writable account that cannot be written",[xr]:"Transaction exceeded max loaded accounts data size cap",[gr]:"Transaction requires a fee but has no signature present",[Ar]:"Attempt to load a program that does not exist",[Hr]:"Execution of the program referenced by account at index $accountIndex is temporarily restricted.",[Vr]:"ResanitizationNeeded",[Sr]:"Transaction failed to sanitize accounts offsets correctly",[Cr]:"Transaction did not pass signature verification",[Ur]:"Transaction locked too many accounts",[Kr]:"Sum of account balances before and after transaction do not match",[dr]:"The transaction failed with the error `$errorName`",[Mr]:"Transaction version is unsupported",[yr]:"Transaction would exceed account data limit within the block",[wr]:"Transaction would exceed total account data limit",[Lr]:"Transaction would exceed max account limit within the block",[pr]:"Transaction would exceed max Block Cost Limit",[zr]:"Transaction would exceed max Vote Cost Limit",[tr]:"Attempted to sign a transaction with an address that is not a signer for it",[qn]:"Transaction is missing an address at index: $index.",[nr]:"Transaction has no expected signers therefore it cannot be encoded",[ar]:"Transaction size $transactionSize exceeds limit of $transactionSizeLimit bytes",[Gn]:"Transaction does not have a blockhash lifetime",[Vn]:"Transaction is not a durable nonce transaction",[Kn]:"Contents of these address lookup tables unknown: $lookupTableAddresses",[$n]:"Lookup of address at index $highestRequestedIndex failed for lookup table `$lookupTableAddress`. Highest known index is $highestKnownIndex. The lookup table may have been extended since its contents were retrieved",[Xn]:"No fee payer set in CompiledTransaction",[Yn]:"Could not find program address at index $index",[ir]:"Failed to estimate the compute unit consumption for this transaction message. This is likely because simulating the transaction failed. Inspect the `cause` property of this error to learn more",[or]:"Transaction failed when it was simulated in order to estimate the compute unit consumption. The compute unit estimate provided is for a transaction that failed when simulated and may not be representative of the compute units this transaction would consume if successful. Inspect the `cause` property of this error to learn more",[jn]:"Transaction is missing a fee payer.",[Jn]:"Could not determine this transaction's signature. Make sure that the transaction has been signed by its fee payer.",[er]:"Transaction first instruction is not advance nonce account instruction.",[Qn]:"Transaction with no instructions cannot be durable nonce transaction.",[Wn]:"This transaction includes an address (`$programAddress`) which is both invoked and set as the fee payer. Program addresses may not pay fees",[xn]:"This transaction includes an address (`$programAddress`) which is both invoked and marked writable. Program addresses may not be writable",[rr]:"The transaction message expected the transaction to have $numRequiredSignatures signatures, got $signaturesLength.",[Zn]:"Transaction is missing signatures for addresses: $addresses.",[Hn]:"Transaction version must be in the range [0, 127]. `$actualVersion` given",[sr]:"This version of Kit does not support decoding transactions with version $unsupportedVersion. The current max supported version is 0.",[cr]:"The transaction has a durable nonce lifetime (with nonce `$nonce`), but the nonce account address is in a lookup table. The lifetime constraint cannot be constructed without fetching the lookup tables for the transaction."},l="i",A="t";function zi(e,t={}){let n=Bi[e];if(n.length===0)return "";let r;function i(o){if(r[A]===2){let s=n.slice(r[l]+1,o);a.push(s in t?`${t[s]}`:`$${s}`);}else r[A]===1&&a.push(n.slice(r[l],o));}let a=[];return n.split("").forEach((o,s)=>{if(s===0){r={[l]:0,[A]:n[0]==="\\"?0:n[0]==="$"?2:1};return}let c;switch(r[A]){case 0:c={[l]:s,[A]:1};break;case 1:o==="\\"?c={[l]:s,[A]:0}:o==="$"&&(c={[l]:s,[A]:2});break;case 2:o==="\\"?c={[l]:s,[A]:0}:o==="$"?c={[l]:s,[A]:2}:o.match(/\w/)||(c={[l]:s,[A]:1});break}c&&(r!==c&&i(s),r=c);}),i(),a.join("")}function wi(e,t={}){if(process.env.NODE_ENV!=="production")return zi(e,t);{let n=`Solana error #${e}; Decode this error by running \`npx @solana/errors decode -- ${e}`;return Object.keys(t).length&&(n+=` '${bi(t)}'`),`${n}\``}}var g=class extends Error{cause=this.cause;context;constructor(...[e,t]){let n,r;t&&Object.entries(Object.getOwnPropertyDescriptors(t)).forEach(([a,o])=>{a==="cause"?r={cause:o.value}:(n===void 0&&(n={}),Object.defineProperty(n,a,o));});let i=wi(e,n);super(i,r),this.context=n===void 0?{}:n,this.context.__code=e,this.name="SolanaError";}};function ki(e,t){return "fixedSize"in t?t.fixedSize:t.getSizeFromValue(e)}function N(e){return Object.freeze({...e,encode:t=>{let n=new Uint8Array(ki(t,e));return e.write(t,n,0),n}})}function L(e){return Object.freeze({...e,decode:(t,n=0)=>e.read(t,n)[0]})}function Wi(e){return "fixedSize"in e&&typeof e.fixedSize=="number"}function xi(e){return !Wi(e)}function Y(e,t){return N({fixedSize:t,write:(n,r,i)=>{let a=e.encode(n),o=a.length>t?a.slice(0,t):a;return r.set(o,i),i+t}})}function X(e,t){return N({...xi(e)?{...e,getSizeFromValue:n=>e.getSizeFromValue(t(n))}:e,write:(n,r,i)=>e.write(t(n),r,i)})}function J(e,t,n=t){if(!t.match(new RegExp(`^[${e}]*$`)))throw new g(h,{alphabet:e,base:e.length,value:n})}var Gi=e=>N({getSizeFromValue:t=>{let[n,r]=Z(t,e[0]);if(!r)return t.length;let i=q(r,e);return n.length+Math.ceil(i.toString(16).length/2)},write(t,n,r){if(J(e,t),t==="")return r;let[i,a]=Z(t,e[0]);if(!a)return n.set(new Uint8Array(i.length).fill(0),r),r+i.length;let o=q(a,e),s=[];for(;o>0n;)s.unshift(Number(o%256n)),o/=256n;let c=[...Array(i.length).fill(0),...s];return n.set(c,r),r+c.length}});function Z(e,t){let[n,r]=e.split(new RegExp(`((?!${t}).*)`));return [n,r]}function q(e,t){let n=BigInt(t.length),r=0n;for(let i of e)r*=n,r+=BigInt(t.indexOf(i));return r}var Vi="123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz",Q=()=>Gi(Vi);var Hi="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",ee=()=>N({getSizeFromValue:e=>Buffer.from(e,"base64").length,write(e,t,n){J(Hi,e.replace(/=/g,""));let r=Buffer.from(e,"base64");return t.set(r,n),r.length+n}}),_=()=>L({read:(e,t=0)=>[Buffer.from(e,t).toString("base64"),e.length]});var y;function te(){return y||(y=Q()),y}function Ki(e){if(e.length<32||e.length>44)throw new g(p,{actualLength:e.length});let r=te().encode(e).byteLength;if(r!==32)throw new g(m,{actualLength:r})}function C(e){return Ki(e),e}function U(){return X(Y(te(),32),e=>C(e))}function $i(e,t,n,r){if(r<t||r>n)throw new g(M,{codecDescription:e,max:n,min:t,value:r})}function Yi(e){return e?.endian!==1}function Xi(e){return N({fixedSize:e.size,write(t,n,r){e.range&&$i(e.name,e.range[0],e.range[1],t);let i=new ArrayBuffer(e.size);return e.set(new DataView(i),t,Yi(e.config)),n.set(new Uint8Array(i),r),r+e.size}})}var ne=(e={})=>Xi({config:e,name:"u64",range:[0n,BigInt("0xffffffffffffffff")],set:(t,n,r)=>t.setBigUint64(0,BigInt(n),r),size:8});function F(e){if(typeof window>"u")throw new Error("Function can only be called in a browser environment");let t=window.innerWidth||window.screen.availWidth,n=window.innerHeight||window.screen.availHeight,r=t<=768,i,a,o,s;if(r)i=t,a=n,o=0,s=0;else {let u=window.screenLeft??window.screenX??0,E=window.screenTop??window.screenY??0,T=window.innerWidth??document.documentElement.clientWidth??window.screen.width,O=window.innerHeight??document.documentElement.clientHeight??window.screen.height;i=500,a=600,s=Math.round(u+(T-i)/2),o=Math.round(E+(O-a)/2);}let c=["popup=yes",`width=${i}`,`height=${a}`,`top=${o}`,`left=${s}`,"toolbar=no","location=no","status=no","menubar=no","scrollbars=yes","resizable=yes"].join(",");return window.open(e??"","_blank",c)}function re(e){let t=e.domain?`${e.domain} wants you to sign in with your account.`:"Sign in with your account.",n=[];return e.nonce&&n.push(`Nonce: ${e.nonce}`),n.length>0?`${t}
|
|
6
6
|
|
|
7
7
|
${n.join(`
|
|
8
|
-
`)}`:t}async function xo(e){let t=window.origin,n=_().decode(crypto.getRandomValues(new Uint8Array(16))),r={phase:"start",rid:n,validTill:Date.now()+6e5,data:{type:"message",payload:re({domain:t,nonce:_().decode(crypto.getRandomValues(new Uint8Array(16)))})},redirectOrigin:t};return await Promise.all([e.onClientAuthorizationCallback(r),e.sendPayloadToProvider({rid:n,redirectOrigin:t})]),await e.onClientAuthorizationCallback({phase:"complete",data:{type:"message",rid:n}})}async function $o(e,t,n){let{instructions:r,signer:i,addressesByLookupTableAddress:a}=t,o=core.prepareTransactionMessage({payer:C(i.walletAddress),instructions:r,addressesByLookupTableAddress:a}),s=await core.getSettingsFromIndex(i.settingsIndexWithAddress.index),c=await core.fetchSettingsAccountData(s,i.settingsIndexWithAddress.settingsAddressTreeIndex),u={transactionMessageBytes:_().decode(o),transactionAddress:s,transactionActionType:c.members.some(O=>O.role===core.UserRole.TransactionManager)?"execute":"create_with_preauthorized_execution"},E=window.origin;n=n??_().decode(crypto.getRandomValues(new Uint8Array(16)));let T={phase:"start",rid:n,validTill:Date.now()+6e5,data:{type:"transaction",payload:u,sendTx:true},redirectOrigin:E,signer:i.publicKey};return await Promise.all([e.onClientAuthorizationCallback(T),e.sendPayloadToProvider({rid:n,redirectOrigin:E})]),await e.onClientAuthorizationCallback({phase:"complete",data:{type:"transaction",rid:n}})}var S="11111111111111111111111111111111";var ie=0,oe=1,ae=2,se=3,ce=4,de=5,ue=6,Ie=7,_e=8;process.env.NODE_ENV!=="production"&&({[ie]:"an account with the same address already exists",[de]:"provided address does not match addressed derived from seed",[se]:"cannot allocate account data of this length",[ae]:"cannot assign account to this program id",[ce]:"length of requested seed is too long",[Ie]:"stored nonce is still in recent_blockhashes",[ue]:"advancing stored nonce requires a populated RecentBlockhashes sysvar",[_e]:"specified nonce does not match stored nonce",[oe]:"account does not have enough SOL to perform the operation"});var P="TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA";async function Df(e,t){if(t.amount<=0)throw new Error("Transfer amount must be greater than 0");if(!t.destination||typeof t.destination!="string")throw new Error("Destination address is required");let{mint:n,tokenProgram:r=P,amount:i,destination:a,signer:o}=t,s={transactionActionType:"transfer_intent",transactionAddress:n?r:S,transactionMessageBytes:_().decode(new Uint8Array([...ne().encode(i),...U().encode(C(a)),...U().encode(C(n??S))]))},c=window.origin,u=_().decode(crypto.getRandomValues(new Uint8Array(16))),E={phase:"start",rid:u,validTill:Date.now()+6e5,data:{type:"transaction",payload:s,sendTx:true},redirectOrigin:c,signer:o?.publicKey};return await Promise.all([e.onClientAuthorizationCallback(E),e.sendPayloadToProvider({rid:u,redirectOrigin:c})]),await e.onClientAuthorizationCallback({phase:"complete",data:{type:"transaction",rid:u}})}var D="https://auth.revibase.com";var Ae="https://rpc.revibase.com",Re="revibase.com";var Ee=class{pending=new Map;onClientAuthorizationCallback;providerOrigin;popUp=null;constructor(t){this.onClientAuthorizationCallback=t.onClientAuthorizationCallback,this.providerOrigin=t.providerOrigin??D,core.initialize({rpcEndpoint:t.rpcEndpoint??Ae});}openPopUp(){let t=window.origin,n=_().decode(crypto.getRandomValues(new Uint8Array(16))),r=new URL(this.providerOrigin);if(r.searchParams.set("rid",n),r.searchParams.set("redirectOrigin",t),this.popUp=F(r.toString()),!this.popUp)throw new Error("Popup blocked. Please enable popups.");return {rid:n}}async sendPayloadToProvider({rid:t,redirectOrigin:n,timeoutMs:r=6e5}){if(typeof window>"u")throw new Error("Provider can only be used in a browser environment");if(this.pending.size>0)throw new Error("An authorization flow is already in progress");let i=new URL(this.providerOrigin);return i.searchParams.set("rid",t),i.searchParams.set("redirectOrigin",n),new Promise((a,o)=>{let s=setTimeout(()=>{let c=this.pending.get(t);c&&(c.cancel?c.cancel(new Error("Authentication timed out")):(this.pending.delete(t),o(new Error("Authentication timed out"))));},r);this.pending.set(t,{rid:t,resolve:a,reject:o,timeoutId:s}),this.openWebPopup({startUrl:i.toString(),origin:i.origin,rid:t});})}openWebPopup(t){let{startUrl:n,origin:r,rid:i}=t,a=this.pending.get(i);if(!a)return;let o=this.popUp??null,s=null,c=false,u=false,E=()=>{window.removeEventListener("message",f);try{s?.close();}catch{}s=null;try{o&&!o.closed&&o.close();}catch{}this.popUp=null,clearInterval(Oe);},T=I=>{c||(c=true,clearTimeout(a.timeoutId),this.pending.delete(i),E(),a.reject(I));},O=()=>{c||(c=true,clearTimeout(a.timeoutId),this.pending.delete(i),E(),a.resolve({rid:i}));};a.cancel=T;let Ce=()=>{if(!o)o=F(n);else try{o.location.href!==n&&o.location.replace(n);}catch{try{o.location.replace(n);}catch{throw new Error("Unable to navigate popup to provider URL")}}if(!o)throw new Error("Popup blocked. Please enable popups.");return o};try{o=Ce();}catch(I){T(I instanceof Error?I:new Error(String(I)));return}let Oe=setInterval(()=>{o?.closed&&(u||(u=true,T(new Error("Popup was closed by the user"))));},2e3),f=I=>{if(I.origin!==r||I.source!==o)return;let b=I.data;b?.type==="popup-connect"&&b.rid===i&&I.ports?.[0]&&(s=I.ports[0],s.start(),s.postMessage({type:"popup-init"}),s.onmessage=B=>{switch(B.data.type){case "popup-complete":O();break;case "popup-error":T(new Error(B.data.error));break;case "popup-closed":{T(new Error("Lost connection with the popup."));break}}},window.removeEventListener("message",f));};window.addEventListener("message",f);}};var Te=d__default.default.looseObject({publicKey:d__default.default.string(),walletAddress:d__default.default.string(),settingsIndexWithAddress:d__default.default.object({index:d__default.default.union([d__default.default.number(),d__default.default.bigint()]),settingsAddressTreeIndex:d__default.default.number()}),username:d__default.default.string().optional(),image:d__default.default.string().optional()}),le=d__default.default.object({phase:d__default.default.literal("complete"),data:d__default.default.object({type:d__default.default.literal("message"),rid:d__default.default.string()})}),De=d__default.default.object({phase:d__default.default.literal("complete"),data:d__default.default.object({type:d__default.default.literal("transaction"),rid:d__default.default.string()})});async function ge({rid:e,privateKey:t,providerOrigin:n=D}){let r=core.convertBase64StringToJWK(t);if(!r.alg)throw new Error("Property alg in JWK is missing.");let i=await new jose.CompactSign(ee().encode(e)).setProtectedHeader({alg:r.alg}).sign(r),a=await fetch(`${n}/api/getResult`,{method:"POST",body:JSON.stringify({rid:e,signature:i})});if(!a.ok)throw new Error((await a.json()).error);return await a.json()}async function Ne(e,t=D,n=Re){let{payload:r}=e.data;if(r.startRequest.data.type!=="message")throw new Error("Invalid request type.");let i=r.startRequest.data.payload,a=core.createMessageChallenge(i,r.client.clientOrigin,r.device.jwk,r.startRequest.rid),{verified:o}=await server.verifyAuthenticationResponse({response:r.authResponse,expectedChallenge:core.bufferToBase64URLString(a),expectedRPID:n,expectedOrigin:t,requireUserVerification:false,credential:{counter:0,id:r.authResponse.id,publicKey:core.convertPubkeyCompressedToCose(r.signer)}});if(!o)throw new Error("WebAuthn message verification failed");let s=r.additionalInfo?.
|
|
8
|
+
`)}`:t}async function xo(e){let t=window.origin,n=_().decode(crypto.getRandomValues(new Uint8Array(16))),r={phase:"start",rid:n,validTill:Date.now()+6e5,data:{type:"message",payload:re({domain:t,nonce:_().decode(crypto.getRandomValues(new Uint8Array(16)))})},redirectOrigin:t};return await Promise.all([e.onClientAuthorizationCallback(r),e.sendPayloadToProvider({rid:n,redirectOrigin:t})]),await e.onClientAuthorizationCallback({phase:"complete",data:{type:"message",rid:n}})}async function $o(e,t,n){let{instructions:r,signer:i,addressesByLookupTableAddress:a}=t,o=core.prepareTransactionMessage({payer:C(i.walletAddress),instructions:r,addressesByLookupTableAddress:a}),s=await core.getSettingsFromIndex(i.settingsIndexWithAddress.index),c=await core.fetchSettingsAccountData(s,i.settingsIndexWithAddress.settingsAddressTreeIndex),u={transactionMessageBytes:_().decode(o),transactionAddress:s,transactionActionType:c.members.some(O=>O.role===core.UserRole.TransactionManager)?"execute":"create_with_preauthorized_execution"},E=window.origin;n=n??_().decode(crypto.getRandomValues(new Uint8Array(16)));let T={phase:"start",rid:n,validTill:Date.now()+6e5,data:{type:"transaction",payload:u,sendTx:true},redirectOrigin:E,signer:i.publicKey};return await Promise.all([e.onClientAuthorizationCallback(T),e.sendPayloadToProvider({rid:n,redirectOrigin:E})]),await e.onClientAuthorizationCallback({phase:"complete",data:{type:"transaction",rid:n}})}var S="11111111111111111111111111111111";var ie=0,oe=1,ae=2,se=3,ce=4,de=5,ue=6,Ie=7,_e=8;process.env.NODE_ENV!=="production"&&({[ie]:"an account with the same address already exists",[de]:"provided address does not match addressed derived from seed",[se]:"cannot allocate account data of this length",[ae]:"cannot assign account to this program id",[ce]:"length of requested seed is too long",[Ie]:"stored nonce is still in recent_blockhashes",[ue]:"advancing stored nonce requires a populated RecentBlockhashes sysvar",[_e]:"specified nonce does not match stored nonce",[oe]:"account does not have enough SOL to perform the operation"});var P="TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA";async function Df(e,t){if(t.amount<=0)throw new Error("Transfer amount must be greater than 0");if(!t.destination||typeof t.destination!="string")throw new Error("Destination address is required");let{mint:n,tokenProgram:r=P,amount:i,destination:a,signer:o}=t,s={transactionActionType:"transfer_intent",transactionAddress:n?r:S,transactionMessageBytes:_().decode(new Uint8Array([...ne().encode(i),...U().encode(C(a)),...U().encode(C(n??S))]))},c=window.origin,u=_().decode(crypto.getRandomValues(new Uint8Array(16))),E={phase:"start",rid:u,validTill:Date.now()+6e5,data:{type:"transaction",payload:s,sendTx:true},redirectOrigin:c,signer:o?.publicKey};return await Promise.all([e.onClientAuthorizationCallback(E),e.sendPayloadToProvider({rid:u,redirectOrigin:c})]),await e.onClientAuthorizationCallback({phase:"complete",data:{type:"transaction",rid:u}})}var D="https://auth.revibase.com";var Ae="https://rpc.revibase.com",Re="revibase.com";var Ee=class{pending=new Map;onClientAuthorizationCallback;providerOrigin;popUp=null;constructor(t){this.onClientAuthorizationCallback=t.onClientAuthorizationCallback,this.providerOrigin=t.providerOrigin??D,core.initialize({rpcEndpoint:t.rpcEndpoint??Ae});}openPopUp(){let t=window.origin,n=_().decode(crypto.getRandomValues(new Uint8Array(16))),r=new URL(this.providerOrigin);if(r.searchParams.set("rid",n),r.searchParams.set("redirectOrigin",t),this.popUp=F(r.toString()),!this.popUp)throw new Error("Popup blocked. Please enable popups.");return {rid:n}}async sendPayloadToProvider({rid:t,redirectOrigin:n,timeoutMs:r=6e5}){if(typeof window>"u")throw new Error("Provider can only be used in a browser environment");if(this.pending.size>0)throw new Error("An authorization flow is already in progress");let i=new URL(this.providerOrigin);return i.searchParams.set("rid",t),i.searchParams.set("redirectOrigin",n),new Promise((a,o)=>{let s=setTimeout(()=>{let c=this.pending.get(t);c&&(c.cancel?c.cancel(new Error("Authentication timed out")):(this.pending.delete(t),o(new Error("Authentication timed out"))));},r);this.pending.set(t,{rid:t,resolve:a,reject:o,timeoutId:s}),this.openWebPopup({startUrl:i.toString(),origin:i.origin,rid:t});})}openWebPopup(t){let{startUrl:n,origin:r,rid:i}=t,a=this.pending.get(i);if(!a)return;let o=this.popUp??null,s=null,c=false,u=false,E=()=>{window.removeEventListener("message",f);try{s?.close();}catch{}s=null;try{o&&!o.closed&&o.close();}catch{}this.popUp=null,clearInterval(Oe);},T=I=>{c||(c=true,clearTimeout(a.timeoutId),this.pending.delete(i),E(),a.reject(I));},O=()=>{c||(c=true,clearTimeout(a.timeoutId),this.pending.delete(i),E(),a.resolve({rid:i}));};a.cancel=T;let Ce=()=>{if(!o)o=F(n);else try{o.location.href!==n&&o.location.replace(n);}catch{try{o.location.replace(n);}catch{throw new Error("Unable to navigate popup to provider URL")}}if(!o)throw new Error("Popup blocked. Please enable popups.");return o};try{o=Ce();}catch(I){T(I instanceof Error?I:new Error(String(I)));return}let Oe=setInterval(()=>{o?.closed&&(u||(u=true,T(new Error("Popup was closed by the user"))));},2e3),f=I=>{if(I.origin!==r||I.source!==o)return;let b=I.data;b?.type==="popup-connect"&&b.rid===i&&I.ports?.[0]&&(s=I.ports[0],s.start(),s.postMessage({type:"popup-init"}),s.onmessage=B=>{switch(B.data.type){case "popup-complete":O();break;case "popup-error":T(new Error(B.data.error));break;case "popup-closed":{T(new Error("Lost connection with the popup."));break}}},window.removeEventListener("message",f));};window.addEventListener("message",f);}};var Te=d__default.default.looseObject({publicKey:d__default.default.string(),walletAddress:d__default.default.string(),settingsIndexWithAddress:d__default.default.object({index:d__default.default.union([d__default.default.number(),d__default.default.bigint()]),settingsAddressTreeIndex:d__default.default.number()}),username:d__default.default.string().optional(),image:d__default.default.string().optional()}),le=d__default.default.object({phase:d__default.default.literal("complete"),data:d__default.default.object({type:d__default.default.literal("message"),rid:d__default.default.string()})}),De=d__default.default.object({phase:d__default.default.literal("complete"),data:d__default.default.object({type:d__default.default.literal("transaction"),rid:d__default.default.string()})});async function ge({rid:e,privateKey:t,providerOrigin:n=D}){let r=core.convertBase64StringToJWK(t);if(!r.alg)throw new Error("Property alg in JWK is missing.");let i=await new jose.CompactSign(ee().encode(e)).setProtectedHeader({alg:r.alg}).sign(r),a=await fetch(`${n}/api/getResult`,{method:"POST",body:JSON.stringify({rid:e,signature:i})});if(!a.ok)throw new Error((await a.json()).error);return await a.json()}async function Ne(e,t=D,n=Re){let{payload:r}=e.data;if(r.startRequest.data.type!=="message")throw new Error("Invalid request type.");let i=r.startRequest.data.payload,a=core.createMessageChallenge(i,r.client.clientOrigin,r.device.jwk,r.startRequest.rid),{verified:o}=await server.verifyAuthenticationResponse({response:r.authResponse,expectedChallenge:core.bufferToBase64URLString(a),expectedRPID:n,expectedOrigin:t,requireUserVerification:false,credential:{counter:0,id:r.authResponse.id,publicKey:core.convertPubkeyCompressedToCose(r.signer)}});if(!o)throw new Error("WebAuthn message verification failed");let s=r.additionalInfo?.settingsIndexWithAddress;if(!s)throw new Error("User is not delegated");let c=await core.getWalletAddressFromIndex(s.index),u={publicKey:r.signer,walletAddress:c,settingsIndexWithAddress:s,...r.additionalInfo};return Te.parse(u)}async function v({privateKey:e,request:t,providerOrigin:n=D}){let r=core.convertBase64StringToJWK(e);if(!r.alg)throw new Error("Property alg in JWK is missing.");let i=await new jose.CompactSign(core.createClientAuthorizationStartRequestChallenge(t)).setProtectedHeader({alg:r.alg}).sign(r),a=await fetch(`${n}/api/startRequest`,{method:"POST",body:JSON.stringify({signature:i,request:t})});if(!a.ok)throw new Error((await a.json()).error);return await a.json()}async function rm({request:e,privateKey:t,providerOrigin:n,rpId:r}){let i=d__default.default.union([core.StartTransactionRequestSchema,core.StartMessageRequestSchema,De,le]).parse(e);if(i.phase==="start"){let{data:o,signer:s,redirectOrigin:c,rid:u}=i;return o.type==="message"?await v({request:{phase:"start",redirectOrigin:c,signer:s,rid:u,validTill:Date.now()+6e5,data:{type:"message",payload:o.payload}},privateKey:t,providerOrigin:n}):await v({request:{phase:"start",redirectOrigin:c,signer:s,rid:u,validTill:Date.now()+6e5,data:{type:"transaction",payload:o.payload,sendTx:true}},providerOrigin:n,privateKey:t})}let a=await ge({rid:i.data.rid,providerOrigin:n,privateKey:t});return a.data.type==="message"?{user:await Ne({data:a.data},n,r)}:{txSig:a.data.payload.txSig}}
|
|
9
9
|
exports.CompleteMessageRequestSchema=le;exports.CompleteTransactionRequestSchema=De;exports.RevibaseProvider=Ee;exports.UserSchema=Te;exports.executeTransaction=$o;exports.processClientAuthCallback=rm;exports.signIn=xo;exports.transferTokens=Df;//# sourceMappingURL=index.cjs.map
|
|
10
10
|
//# sourceMappingURL=index.cjs.map
|