@revibase/lite 0.0.26 → 0.0.28
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.d.cts +3 -3
- package/dist/index.d.ts +3 -3
- 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.`,[En]:"No signature verification implementation could be found.",[Rn]:"No key generation implementation could be found.",[Tn]:"No signing implementation could be found.",[gn]:"No key export implementation could be found.",[Ft]:"Timestamp value must be in the range [-(2n ** 63n), (2n ** 63n) - 1]. `$value` given",[Io]:"Transaction processing left an account with an outstanding borrowed reference",[Zr]:"Account in use",[jr]:"Account loaded twice",[qr]:"Attempt to debit an account but found no record of a prior credit.",[go]:"Transaction loads an address table account that doesn't exist",[to]:"This transaction has already been processed",[no]:"Blockhash not found",[ro]:"Loader call chain is too deep",[uo]:"Transactions are currently disabled due to cluster maintenance",[mo]:"Transaction contains a duplicate instruction ($index) that is not allowed",[Qr]:"Insufficient funds for fee",[po]:"Transaction results in an account ($accountIndex) with insufficient funds for rent",[eo]:"This account may not be used to pay transaction fees",[io]:"Transaction contains an invalid account reference",[No]:"Transaction loads an address table account with invalid data",[So]:"Transaction address table lookup uses an invalid index",[Do]:"Transaction loads an address table account with an invalid owner",[Mo]:"LoadedAccountsDataSizeLimit set for transaction must be greater than 0.",[so]:"This program may not be used for executing instructions",[Co]:"Transaction leaves an account with a lower balance than rent-exempt minimum",[lo]:"Transaction loads a writable account that cannot be written",[ho]:"Transaction exceeded max loaded accounts data size cap",[oo]:"Transaction requires a fee but has no signature present",[Jr]:"Attempt to load a program that does not exist",[yo]:"Execution of the program referenced by account at index $accountIndex is temporarily restricted.",[Lo]:"ResanitizationNeeded",[co]:"Transaction failed to sanitize accounts offsets correctly",[ao]:"Transaction did not pass signature verification",[To]:"Transaction locked too many accounts",[Uo]:"Sum of account balances before and after transaction do not match",[Xr]:"The transaction failed with the error `$errorName`",[Ao]:"Transaction version is unsupported",[Ro]:"Transaction would exceed account data limit within the block",[fo]:"Transaction would exceed total account data limit",[Eo]:"Transaction would exceed max account limit within the block",[_o]:"Transaction would exceed max Block Cost Limit",[Oo]:"Transaction would exceed max Vote Cost Limit",[he]:"Attempted to sign a transaction with an address that is not a signer for it",[Vr]:"Transaction is missing an address at index: $index.",[Me]:"Transaction has no expected signers therefore it cannot be encoded",[Le]:"Transaction size $transactionSize exceeds limit of $transactionSizeLimit bytes",[x]:"Transaction does not have a blockhash lifetime",[W]:"Transaction is not a durable nonce transaction",[Se]:"Contents of these address lookup tables unknown: $lookupTableAddresses",[Ce]:"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",[fe]:"No fee payer set in CompiledTransaction",[Oe]:"Could not find program address at index $index",[$r]:"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",[Yr]:"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",[Gr]:"Transaction is missing a fee payer.",[pe]:"Could not determine this transaction's signature. Make sure that the transaction has been signed by its fee payer.",[Kr]:"Transaction first instruction is not advance nonce account instruction.",[Hr]:"Transaction with no instructions cannot be durable nonce transaction.",[ge]:"This transaction includes an address (`$programAddress`) which is both invoked and set as the fee payer. Program addresses may not pay fees",[De]:"This transaction includes an address (`$programAddress`) which is both invoked and marked writable. Program addresses may not be writable",[V]:"The transaction message expected the transaction to have $numRequiredSignatures signatures, got $signaturesLength.",[me]:"Transaction is missing signatures for addresses: $addresses.",[Ne]:"Transaction version must be in the range [0, 127]. `$actualVersion` given",[G]:"This version of Kit does not support decoding transactions with version $unsupportedVersion. The current max supported version is 0.",[ye]:"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."},N="i",T="t";function Ii(e,t={}){let n=di[e];if(n.length===0)return "";let r;function o(a){if(r[T]===2){let s=n.slice(r[N]+1,a);i.push(s in t?`${t[s]}`:`$${s}`);}else r[T]===1&&i.push(n.slice(r[N],a));}let i=[];return n.split("").forEach((a,s)=>{if(s===0){r={[N]:0,[T]:n[0]==="\\"?0:n[0]==="$"?2:1};return}let c;switch(r[T]){case 0:c={[N]:s,[T]:1};break;case 1:a==="\\"?c={[N]:s,[T]:0}:a==="$"&&(c={[N]:s,[T]:2});break;case 2:a==="\\"?c={[N]:s,[T]:0}:a==="$"?c={[N]:s,[T]:2}:a.match(/\w/)||(c={[N]:s,[T]:1});break}c&&(r!==c&&o(s),r=c);}),o(),i.join("")}function _i(e,t={}){if(process.env.NODE_ENV!=="production")return Ii(e,t);{let n=`Solana error #${e}; Decode this error by running \`npx @solana/errors decode -- ${e}`;return Object.keys(t).length&&(n+=` '${ui(t)}'`),`${n}\``}}var _=class extends Error{cause=this.cause;context;constructor(...[e,t]){let n,r;t&&Object.entries(Object.getOwnPropertyDescriptors(t)).forEach(([i,a])=>{i==="cause"?r={cause:a.value}:(n===void 0&&(n={}),Object.defineProperty(n,i,a));});let o=_i(e,n);super(o,r),this.context=n===void 0?{}:n,this.context.__code=e,this.name="SolanaError";}};function Ai(e,t){if(e.length>=t)return e;let n=new Uint8Array(t).fill(0);return n.set(e),n}var li=(e,t)=>Ai(e.length<=t?e:e.slice(0,t),t);function We(e,t){return "fixedSize"in t?t.fixedSize:t.getSizeFromValue(e)}function S(e){return Object.freeze({...e,encode:t=>{let n=new Uint8Array(We(t,e));return e.write(t,n,0),n}})}function I(e){return Object.freeze({...e,decode:(t,n=0)=>e.read(t,n)[0]})}function O(e){return "fixedSize"in e&&typeof e.fixedSize=="number"}function Ei(e){return !O(e)}function Ve(e,t,n=0){if(t.length-n<=0)throw new _(H,{codecDescription:e})}function y(e,t,n,r=0){let o=n.length-r;if(o<t)throw new _(K,{bytesLength:o,codecDescription:e,expected:t})}function xe(e,t,n){if(t<0||t>n)throw new _(X,{bytesLength:n,codecDescription:e,offset:t})}function p(e,t){return S({fixedSize:t,write:(n,r,o)=>{let i=e.encode(n),a=i.length>t?i.slice(0,t):i;return r.set(a,o),o+t}})}function f(e,t){return I({fixedSize:t,read:(n,r)=>{y("fixCodecSize",t,n,r),(r>0||n.length>t)&&(n=n.slice(r,r+t)),O(e)&&(n=li(n,e.fixedSize));let[o]=e.read(n,0);return [o,r+t]}})}function Ri(e,t){return I({...e,read:(n,r)=>{let o=u=>Ti(u,n.length),i=t.preOffset?t.preOffset({bytes:n,preOffset:r,wrapBytes:o}):r;xe("offsetDecoder",i,n.length);let[a,s]=e.read(n,i),c=t.postOffset?t.postOffset({bytes:n,newPreOffset:i,postOffset:s,preOffset:r,wrapBytes:o}):s;return xe("offsetDecoder",c,n.length),[a,c]}})}function Ti(e,t){return t===0?0:(e%t+t)%t}function gi(e,t){if(O(e)){let n=t(e.fixedSize);if(n<0)throw new _(Y,{bytesLength:n,codecDescription:"resizeDecoder"});return I({...e,fixedSize:n})}return e}function Ge(e,t){return Ri(gi(e,n=>n+t),{postOffset:({postOffset:n})=>n+t})}function h(e,t){return S({...Ei(e)?{...e,getSizeFromValue:n=>e.getSizeFromValue(t(n))}:e,write:(n,r,o)=>e.write(t(n),r,o)})}function U(e,t){return I({...e,read:(n,r)=>{let[o,i]=e.read(n,r);return [t(o,n,r),i]}})}function $e(e,t,n=t){if(!t.match(new RegExp(`^[${e}]*$`)))throw new _(L,{alphabet:e,base:e.length,value:n})}var Di=e=>S({getSizeFromValue:t=>{let[n,r]=He(t,e[0]);if(!r)return t.length;let o=Ke(r,e);return n.length+Math.ceil(o.toString(16).length/2)},write(t,n,r){if($e(e,t),t==="")return r;let[o,i]=He(t,e[0]);if(!i)return n.set(new Uint8Array(o.length).fill(0),r),r+o.length;let a=Ke(i,e),s=[];for(;a>0n;)s.unshift(Number(a%256n)),a/=256n;let c=[...Array(o.length).fill(0),...s];return n.set(c,r),r+c.length}}),Ni=e=>I({read(t,n){let r=n===0?t:t.slice(n);if(r.length===0)return ["",0];let o=r.findIndex(c=>c!==0);o=o===-1?r.length:o;let i=e[0].repeat(o);if(o===r.length)return [i,t.length];let a=r.slice(o).reduce((c,u)=>c*256n+BigInt(u),0n),s=Si(a,e);return [i+s,t.length]}});function He(e,t){let[n,r]=e.split(new RegExp(`((?!${t}).*)`));return [n,r]}function Ke(e,t){let n=BigInt(t.length),r=0n;for(let o of e)r*=n,r+=BigInt(t.indexOf(o));return r}function Si(e,t){let n=BigInt(t.length),r=[];for(;e>0n;)r.unshift(t[Number(e%n)]),e/=n;return r.join("")}var Ye="123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz",Xe=()=>Di(Ye),b=()=>Ni(Ye);var Ci="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",F=()=>S({getSizeFromValue:e=>Buffer.from(e,"base64").length,write(e,t,n){$e(Ci,e.replace(/=/g,""));let r=Buffer.from(e,"base64");return t.set(r,n),r.length+n}}),R=()=>I({read:(e,t=0)=>[Buffer.from(e,t).toString("base64"),e.length]});var Z,j;function Ze(){return Z||(Z=Xe()),Z}function Oi(){return j||(j=b()),j}function fi(e){if(e.length<32||e.length>44)throw new _(k,{actualLength:e.length});let r=Ze().encode(e).byteLength;if(r!==32)throw new _(w,{actualLength:r})}function m(e){return fi(e),e}function q(){return h(p(Ze(),32),e=>m(e))}function je(){return f(Oi(),32)}function mi(e,t,n,r){if(r<t||r>n)throw new _($,{codecDescription:e,max:n,min:t,value:r})}function qe(e){return e?.endian!==1}function pi(e){return S({fixedSize:e.size,write(t,n,r){e.range&&mi(e.name,e.range[0],e.range[1],t);let o=new ArrayBuffer(e.size);return e.set(new DataView(o),t,qe(e.config)),n.set(new Uint8Array(o),r),r+e.size}})}function Je(e){return I({fixedSize:e.size,read(t,n=0){Ve(e.name,t,n),y(e.name,e.size,t,n);let r=new DataView(hi(t,n,e.size));return [e.get(r,qe(e.config)),n+e.size]}})}function hi(e,t,n){let r=e.byteOffset+(t??0),o=n??e.byteLength;return e.buffer.slice(r,r+o)}var J=()=>I({maxSize:3,read:(e,t)=>{let n=0,r=0;for(;++r;){let o=r-1,i=e[t+o],a=127&i;if(n|=a<<o*7,(i&128)===0)break}return [n,t+r]}});var Qe=(e={})=>Je({config:e,get:(t,n)=>t.getUint32(0,n),name:"u32",size:4});var et=(e={})=>pi({config:e,name:"u64",range:[0n,BigInt("0xffffffffffffffff")],set:(t,n,r)=>t.setBigUint64(0,BigInt(n),r),size:8});var Q=()=>Je({get:e=>e.getUint8(0),name:"u8",size:1});function P(e){return e.reduce((t,n)=>t===null||n===null?null:t+n,0)}function ee(e){return O(e)?e.fixedSize:null}function te(e){return O(e)?e.fixedSize:e.maxSize??null}function ne(e,t={}){let n=t.size??Qe(),r=ee(e),o=tt(n,r),i=tt(n,te(e))??void 0;return I({...o!==null?{fixedSize:o}:{maxSize:i},read:(a,s)=>{let c=[];if(typeof n=="object"&&a.slice(s).length===0)return [c,s];if(n==="remainder"){for(;s<a.length;){let[d,l]=e.read(a,s);s=l,c.push(d);}return [c,s]}let[u,A]=typeof n=="number"?[n,s]:n.read(a,s);s=A;for(let d=0;d<u;d+=1){let[l,B]=e.read(a,s);s=B,c.push(l);}return [c,s]}})}function tt(e,t){return typeof e!="number"?null:e===0?0:t===null?null:t*e}function re(){return I({read:(e,t)=>{let n=e.slice(t);return [n,t+n.length]}})}function nt(e){let t=P(e.map(ee)),n=P(e.map(te))??void 0;return I({...t===null?{maxSize:n}:{fixedSize:t},read:(r,o)=>{let i=[];return e.forEach(a=>{let[s,c]=a.read(r,o);i.push(s),o=c;}),[i,o]}})}function rt(e){let t=e.map(([,o])=>o),n=P(t.map(ee)),r=P(t.map(te))??void 0;return I({...n===null?{maxSize:r}:{fixedSize:n},read:(o,i)=>{let a={};return e.forEach(([s,c])=>{let[u,A]=c.read(o,i);i=A,a[s]=u;}),[a,i]}})}var Mi=0,ot=128;function it(){return I({maxSize:1,read:(e,t)=>{let n=e[t];if((n&ot)===0)return ["legacy",t];{let r=n^ot;if(r>Mi)throw new _(G,{unsupportedVersion:r});return [r,t+1]}}})}function at(){return U(rt([["signatures",ne(f(re(),64),{size:J()})],["messageBytes",re()]]),Li)}function Li(e){let{messageBytes:t,signatures:n}=e,r=nt([it(),Ge(Q(),2),ne(je(),{size:J()})]),[o,i,a]=r.decode(t),s=a.slice(0,i);if(s.length!==n.length)throw new _(V,{numRequiredSignatures:i,signaturesLength:n.length,signerAddresses:s});let c={};return s.forEach((u,A)=>{let d=n[A];d.every(l=>l===0)?c[u]=null:c[u]=d;}),{messageBytes:t,signatures:Object.freeze(c)}}function oe(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,o,i,a,s;if(r)o=t,i=n,a=0,s=0;else {let u=window.screenLeft??window.screenX??0,A=window.screenTop??window.screenY??0,d=window.innerWidth??document.documentElement.clientWidth??window.screen.width,l=window.innerHeight??document.documentElement.clientHeight??window.screen.height;o=500,i=600,s=Math.round(u+(d-o)/2),a=Math.round(A+(l-i)/2);}let c=["popup=yes",`width=${o}`,`height=${i}`,`top=${a}`,`left=${s}`,"toolbar=no","location=no","status=no","menubar=no","scrollbars=yes","resizable=yes"].join(",");return window.open(e??"","_blank",c)}function st(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 Ja(e){let t=window.origin,n=R().decode(crypto.getRandomValues(new Uint8Array(16))),r={phase:"start",rid:n,validTill:Date.now()+6e5,data:{type:"message",payload:st({domain:t,nonce:R().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 rs(e,t,n){let{instructions:r,signer:o,addressesByLookupTableAddress:i}=t,a=core.prepareTransactionMessage({payer:m(o.walletAddress),instructions:r,addressesByLookupTableAddress:i}),s=await core.getSettingsFromIndex(o.settingsIndexWithAddress.index),c=await core.fetchSettingsAccountData(s,o.settingsIndexWithAddress.settingsAddressTreeIndex),u={transactionMessageBytes:R().decode(a),transactionAddress:s,transactionActionType:c.members.some(l=>l.role===core.UserRole.TransactionManager)?"execute":"create_with_preauthorized_execution"},A=window.origin;n=n??R().decode(crypto.getRandomValues(new Uint8Array(16)));let d={phase:"start",rid:n,validTill:Date.now()+6e5,data:{type:"transaction",payload:u,sendTx:true,additionalSigners:t.additionalSigners},redirectOrigin:A,signer:o.publicKey};return await Promise.all([e.onClientAuthorizationCallback(d),e.sendPayloadToProvider({rid:n,redirectOrigin:A})]),await e.onClientAuthorizationCallback({phase:"complete",data:{type:"transaction",rid:n}})}var v="11111111111111111111111111111111";var ct=0,ut=1,dt=2,It=3,_t=4,At=5,lt=6,Et=7,Rt=8;process.env.NODE_ENV!=="production"&&({[ct]:"an account with the same address already exists",[At]:"provided address does not match addressed derived from seed",[It]:"cannot allocate account data of this length",[dt]:"cannot assign account to this program id",[_t]:"length of requested seed is too long",[Et]:"stored nonce is still in recent_blockhashes",[lt]:"advancing stored nonce requires a populated RecentBlockhashes sysvar",[Rt]:"specified nonce does not match stored nonce",[ut]:"account does not have enough SOL to perform the operation"});var ie="TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA";async function Lm(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=ie,amount:o,destination:i,signer:a}=t,s={transactionActionType:"transfer_intent",transactionAddress:n?r:v,transactionMessageBytes:R().decode(new Uint8Array([...et().encode(o),...q().encode(m(i)),...q().encode(m(n??v))]))},c=window.origin,u=R().decode(crypto.getRandomValues(new Uint8Array(16))),A={phase:"start",rid:u,validTill:Date.now()+6e5,data:{type:"transaction",payload:s,sendTx:true},redirectOrigin:c,signer:a?.publicKey};return await Promise.all([e.onClientAuthorizationCallback(A),e.sendPayloadToProvider({rid:u,redirectOrigin:c})]),await e.onClientAuthorizationCallback({phase:"complete",data:{type:"transaction",rid:u}})}var C="https://auth.revibase.com",Tt="https://rpc.revibase.com",gt="revibase.com";var Dt=class{pending=new Map;onClientAuthorizationCallback;providerOrigin;popUp=null;constructor(t){this.onClientAuthorizationCallback=t.onClientAuthorizationCallback,this.providerOrigin=t.providerOrigin??C,core.initialize({rpcEndpoint:t.rpcEndpoint??Tt});}createNewPopup(){let t=window.origin,n=R().decode(crypto.getRandomValues(new Uint8Array(16))),r=new URL(this.providerOrigin);if(r.searchParams.set("rid",n),r.searchParams.set("redirectOrigin",t),this.popUp=oe(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 o=new URL(this.providerOrigin);return o.searchParams.set("rid",t),o.searchParams.set("redirectOrigin",n),new Promise((i,a)=>{let s=setTimeout(()=>{let c=this.pending.get(t);c&&(c.cancel?c.cancel(new Error("Authentication timed out")):(this.pending.delete(t),a(new Error("Authentication timed out"))));},r);this.pending.set(t,{rid:t,resolve:i,reject:a,timeoutId:s}),this.openWebPopup({startUrl:o.toString(),origin:o.origin,rid:t});})}openWebPopup(t){let{startUrl:n,origin:r,rid:o}=t,i=this.pending.get(o);if(!i)return;let a=this.popUp??null,s=null,c=false,u=false,A=()=>{window.removeEventListener("message",z);try{s?.close();}catch{}s=null;try{a&&!a.closed&&a.close();}catch{}this.popUp=null,clearInterval(ft);},d=E=>{c||(c=true,clearTimeout(i.timeoutId),this.pending.delete(o),A(),i.reject(E));},l=()=>{c||(c=true,clearTimeout(i.timeoutId),this.pending.delete(o),A(),i.resolve({rid:o}));};i.cancel=d;let B=()=>{if(!a)a=oe(n);else try{a.location.href!==n&&a.location.replace(n);}catch{try{a.location.replace(n);}catch{throw new Error("Unable to navigate popup to provider URL")}}if(!a)throw new Error("Popup blocked. Please enable popups.");return a};try{a=B();}catch(E){d(E instanceof Error?E:new Error(String(E)));return}let ft=setInterval(()=>{a?.closed&&(u||(u=true,d(new Error("Popup was closed by the user"))));},2e3),z=E=>{if(E.origin!==r||E.source!==a)return;let se=E.data;se?.type==="popup-connect"&&se.rid===o&&E.ports?.[0]&&(s=E.ports[0],s.start(),s.postMessage({type:"popup-init"}),s.onmessage=ce=>{switch(ce.data.type){case "popup-complete":l();break;case "popup-error":d(new Error(ce.data.error));break;case "popup-closed":{d(new Error("Lost connection with the popup."));break}}},window.removeEventListener("message",z));};window.addEventListener("message",z);}};async function Hm(e,t){let n=new Array(e.transactions.length);for(let r=0;r<e.transactions.length;r++){let{messageBytes:o}=at().decode(F().encode(e.transactions[r])),i=await crypto.subtle.sign({name:"Ed25519"},t.keyPair.privateKey,new Uint8Array(o));n[r]=b().decode(new Uint8Array(i));}return {signatures:n}}var Nt=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()})}),St=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 Ct({rid:e,privateKey:t,providerOrigin:n=C}){let r=core.convertBase64StringToJWK(t);if(!r.alg)throw new Error("Property alg in JWK is missing.");let o=await new jose.CompactSign(F().encode(e)).setProtectedHeader({alg:r.alg}).sign(r),i=await fetch(`${n}/api/getResult`,{method:"POST",body:JSON.stringify({rid:e,signature:o})});if(!i.ok)throw new Error((await i.json()).error);return await i.json()}async function Ot(e,t=C,n=gt){let{payload:r}=e.data;if(r.startRequest.data.type!=="message")throw new Error("Invalid request type.");let o=r.startRequest.data.payload,i=core.createMessageChallenge(o,r.client.clientOrigin,r.device.jwk,r.startRequest.rid),{verified:a}=await server.verifyAuthenticationResponse({response:r.authResponse,expectedChallenge:core.bufferToBase64URLString(i),expectedRPID:n,expectedOrigin:t,requireUserVerification:false,credential:{counter:0,id:r.authResponse.id,publicKey:core.convertPubkeyCompressedToCose(r.signer)}});if(!a)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);return core.UserInfoSchema.parse({publicKey:r.signer,walletAddress:c,settingsIndexWithAddress:s,...r.additionalInfo})}async function ae({privateKey:e,request:t,providerOrigin:n=C}){let r=core.convertBase64StringToJWK(e);if(!r.alg)throw new Error("Property alg in JWK is missing.");let o=await new jose.CompactSign(core.createClientAuthorizationStartRequestChallenge(t)).setProtectedHeader({alg:r.alg}).sign(r),i=await fetch(`${n}/api/startRequest`,{method:"POST",body:JSON.stringify({signature:o,request:t})});if(!i.ok)throw new Error((await i.json()).error);return await i.json()}async function Rp({request:e,privateKey:t,providerOrigin:n,rpId:r}){let o=D__default.default.union([core.StartTransactionRequestSchema,core.StartMessageRequestSchema,St,Nt]).parse(e);if(o.phase==="start"){let{data:a,signer:s,redirectOrigin:c,rid:u}=o;return a.type==="message"?await ae({request:{phase:"start",redirectOrigin:c,signer:s,rid:u,validTill:Date.now()+6e5,data:{type:"message",payload:a.payload}},privateKey:t,providerOrigin:n}):await ae({request:{phase:"start",redirectOrigin:c,signer:s,rid:u,validTill:Date.now()+6e5,data:{type:"transaction",payload:a.payload,sendTx:true}},providerOrigin:n,privateKey:t})}let i=await Ct({rid:o.data.rid,providerOrigin:n,privateKey:t});return i.data.type==="message"?{user:await Ot({data:i.data},n,r)}:{txSig:i.data.payload.txSig}}
|
|
8
|
+
`)}`:t}async function Ja(e){let t=window.origin,n=R().decode(crypto.getRandomValues(new Uint8Array(16))),r={phase:"start",rid:n,validTill:Date.now()+6e5,data:{type:"message",payload:st({domain:t,nonce:R().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 rs(e,t,n){let{instructions:r,signer:o,addressesByLookupTableAddress:i}=t,a=core.prepareTransactionMessage({payer:m(o.walletAddress),instructions:r,addressesByLookupTableAddress:i}),s=await core.getSettingsFromIndex(o.settingsIndexWithAddress.index),c=await core.fetchSettingsAccountData(s,o.settingsIndexWithAddress.settingsAddressTreeIndex),u={transactionMessageBytes:R().decode(a),transactionAddress:s,transactionActionType:c.members.some(l=>l.role===core.UserRole.TransactionManager)?"execute":"create_with_preauthorized_execution"},A=window.origin;n=n??R().decode(crypto.getRandomValues(new Uint8Array(16)));let d={phase:"start",rid:n,validTill:Date.now()+6e5,data:{type:"transaction",payload:u,sendTx:true,additionalSigners:t.additionalSigners},redirectOrigin:A,signer:o.publicKey};return await Promise.all([e.onClientAuthorizationCallback(d),e.sendPayloadToProvider({rid:n,redirectOrigin:A})]),await e.onClientAuthorizationCallback({phase:"complete",data:{type:"transaction",rid:n}})}var v="11111111111111111111111111111111";var ct=0,ut=1,dt=2,It=3,_t=4,At=5,lt=6,Et=7,Rt=8;process.env.NODE_ENV!=="production"&&({[ct]:"an account with the same address already exists",[At]:"provided address does not match addressed derived from seed",[It]:"cannot allocate account data of this length",[dt]:"cannot assign account to this program id",[_t]:"length of requested seed is too long",[Et]:"stored nonce is still in recent_blockhashes",[lt]:"advancing stored nonce requires a populated RecentBlockhashes sysvar",[Rt]:"specified nonce does not match stored nonce",[ut]:"account does not have enough SOL to perform the operation"});var ie="TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA";async function Lm(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=ie,amount:o,destination:i,signer:a}=t,s={transactionActionType:"transfer_intent",transactionAddress:n?r:v,transactionMessageBytes:R().decode(new Uint8Array([...et().encode(o),...q().encode(m(i)),...q().encode(m(n??v))]))},c=window.origin,u=R().decode(crypto.getRandomValues(new Uint8Array(16))),A={phase:"start",rid:u,validTill:Date.now()+6e5,data:{type:"transaction",payload:s,sendTx:true},redirectOrigin:c,signer:a?.publicKey};return await Promise.all([e.onClientAuthorizationCallback(A),e.sendPayloadToProvider({rid:u,redirectOrigin:c})]),await e.onClientAuthorizationCallback({phase:"complete",data:{type:"transaction",rid:u}})}var C="https://auth.revibase.com",Tt="https://rpc.revibase.com",gt="revibase.com";var Dt=class{pending=new Map;onClientAuthorizationCallback;providerOrigin;popUp=null;constructor(t){this.onClientAuthorizationCallback=t.onClientAuthorizationCallback,this.providerOrigin=t.providerOrigin??C,core.initialize({rpcEndpoint:t.rpcEndpoint??Tt});}createNewPopup(){let t=window.origin,n=R().decode(crypto.getRandomValues(new Uint8Array(16))),r=new URL(this.providerOrigin);if(r.searchParams.set("rid",n),r.searchParams.set("redirectOrigin",t),this.popUp=oe(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 o=new URL(this.providerOrigin);return o.searchParams.set("rid",t),o.searchParams.set("redirectOrigin",n),new Promise((i,a)=>{let s=setTimeout(()=>{let c=this.pending.get(t);c&&(c.cancel?c.cancel(new Error("Authentication timed out")):(this.pending.delete(t),a(new Error("Authentication timed out"))));},r);this.pending.set(t,{rid:t,resolve:i,reject:a,timeoutId:s}),this.openWebPopup({startUrl:o.toString(),origin:o.origin,rid:t});})}openWebPopup(t){let{startUrl:n,origin:r,rid:o}=t,i=this.pending.get(o);if(!i)return;let a=this.popUp??null,s=null,c=false,u=false,A=()=>{window.removeEventListener("message",z);try{s?.close();}catch{}s=null;try{a&&!a.closed&&a.close();}catch{}this.popUp=null,clearInterval(ft);},d=E=>{c||(c=true,clearTimeout(i.timeoutId),this.pending.delete(o),A(),i.reject(E));},l=()=>{c||(c=true,clearTimeout(i.timeoutId),this.pending.delete(o),A(),i.resolve({rid:o}));};i.cancel=d;let B=()=>{if(!a)a=oe(n);else try{a.location.href!==n&&a.location.replace(n);}catch{try{a.location.replace(n);}catch{throw new Error("Unable to navigate popup to provider URL")}}if(!a)throw new Error("Popup blocked. Please enable popups.");return a};try{a=B();}catch(E){d(E instanceof Error?E:new Error(String(E)));return}let ft=setInterval(()=>{a?.closed&&(u||(u=true,d(new Error("Popup was closed by the user"))));},2e3),z=E=>{if(E.origin!==r||E.source!==a)return;let se=E.data;se?.type==="popup-connect"&&se.rid===o&&E.ports?.[0]&&(s=E.ports[0],s.start(),s.postMessage({type:"popup-init"}),s.onmessage=ce=>{switch(ce.data.type){case "popup-complete":l();break;case "popup-error":d(new Error(ce.data.error));break;case "popup-closed":{d(new Error("Lost connection with the popup."));break}}},window.removeEventListener("message",z));};window.addEventListener("message",z);}};async function Hm(e,t){let n=new Array(e.transactions.length);for(let r=0;r<e.transactions.length;r++){let{messageBytes:o}=at().decode(F().encode(e.transactions[r])),i=await crypto.subtle.sign({name:"Ed25519"},t.keyPair.privateKey,new Uint8Array(o));n[r]=b().decode(new Uint8Array(i));}return {signatures:n}}var Nt=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()})}),St=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 Ct({rid:e,privateKey:t,providerOrigin:n=C}){let r=core.convertBase64StringToJWK(t);if(!r.alg)throw new Error("Property alg in JWK is missing.");let o=await new jose.CompactSign(F().encode(e)).setProtectedHeader({alg:r.alg}).sign(r),i=await fetch(`${n}/api/getResult`,{method:"POST",body:JSON.stringify({rid:e,signature:o})});if(!i.ok)throw new Error((await i.json()).error);return await i.json()}async function Ot(e,t=C,n=gt){let{payload:r}=e.data;if(r.startRequest.data.type!=="message")throw new Error("Invalid request type.");let o=r.startRequest.data.payload,i=core.createMessageChallenge(o,r.client.clientOrigin,r.device.jwk,r.startRequest.rid),{verified:a}=await server.verifyAuthenticationResponse({response:r.authResponse,expectedChallenge:core.bufferToBase64URLString(i),expectedRPID:n,expectedOrigin:t,requireUserVerification:false,credential:{counter:0,id:r.authResponse.id,publicKey:core.convertPubkeyCompressedToCose(r.signer)}});if(!a)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);return core.UserInfoSchema.parse({publicKey:r.signer,walletAddress:c,settingsIndexWithAddress:s,...r.additionalInfo})}async function ae({privateKey:e,request:t,providerOrigin:n=C}){let r=core.convertBase64StringToJWK(e);if(!r.alg)throw new Error("Property alg in JWK is missing.");let o=await new jose.CompactSign(core.createClientAuthorizationStartRequestChallenge(t)).setProtectedHeader({alg:r.alg}).sign(r),i=await fetch(`${n}/api/startRequest`,{method:"POST",body:JSON.stringify({signature:o,request:t})});if(!i.ok)throw new Error((await i.json()).error);return await i.json()}async function Rp({request:e,privateKey:t,providerOrigin:n,rpId:r}){let o=D__default.default.union([core.StartTransactionRequestSchema,core.StartMessageRequestSchema,St,Nt]).parse(e);if(o.phase==="start"){let{data:a,signer:s,redirectOrigin:c,rid:u}=o;return a.type==="message"?await ae({request:{phase:"start",redirectOrigin:c,signer:s,rid:u,validTill:Date.now()+6e5,data:{type:"message",payload:a.payload}},privateKey:t,providerOrigin:n}):await ae({request:{phase:"start",redirectOrigin:c,signer:s,rid:u,validTill:Date.now()+6e5,data:{type:"transaction",payload:a.payload,sendTx:true}},providerOrigin:n,privateKey:t})}let i=await Ct({rid:o.data.rid,providerOrigin:n,privateKey:t});return i.data.type==="message"?{user:await Ot({data:i.data},n,r)}:{txSig:i.data.payload.txSig,user:i.data.payload.user}}
|
|
9
9
|
exports.CompleteMessageRequestSchema=Nt;exports.CompleteTransactionRequestSchema=St;exports.RevibaseProvider=Dt;exports.createTransactionSigner=Hm;exports.executeTransaction=rs;exports.processClientAuthCallback=Rp;exports.signIn=Ja;exports.transferTokens=Lm;//# sourceMappingURL=index.cjs.map
|
|
10
10
|
//# sourceMappingURL=index.cjs.map
|