nostr-crypto-utils 0.5.2 → 0.6.0
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/browser/crypto.nostr-crypto-utils.min.js +8 -8
- package/dist/browser/crypto.nostr-crypto-utils.min.js.map +4 -4
- package/dist/browser/main.nostr-crypto-utils.min.js +8 -8
- package/dist/browser/main.nostr-crypto-utils.min.js.map +4 -4
- package/dist/browser/nip-44.nostr-crypto-utils.min.js +7 -8
- package/dist/browser/nip-44.nostr-crypto-utils.min.js.map +4 -4
- package/dist/browser/nip-46.nostr-crypto-utils.min.js +7 -8
- package/dist/browser/nip-46.nostr-crypto-utils.min.js.map +4 -4
- package/dist/browser/nip-49.nostr-crypto-utils.min.js +2 -2
- package/dist/browser/nip-49.nostr-crypto-utils.min.js.map +4 -4
- package/dist/browser/validation.nostr-crypto-utils.min.js +7 -8
- package/dist/browser/validation.nostr-crypto-utils.min.js.map +4 -4
- package/dist/cjs/crypto.js +46 -33
- package/dist/cjs/crypto.js.map +1 -1
- package/dist/cjs/encoding/base64.js +29 -12
- package/dist/cjs/encoding/base64.js.map +1 -1
- package/dist/cjs/event/creation.js +4 -4
- package/dist/cjs/event/creation.js.map +1 -1
- package/dist/cjs/event/signing.js +6 -6
- package/dist/cjs/event/signing.js.map +1 -1
- package/dist/cjs/nips/nip-01.js +10 -10
- package/dist/cjs/nips/nip-01.js.map +1 -1
- package/dist/cjs/nips/nip-04.js +6 -6
- package/dist/cjs/nips/nip-04.js.map +1 -1
- package/dist/cjs/nips/nip-26.js +9 -9
- package/dist/cjs/nips/nip-26.js.map +1 -1
- package/dist/cjs/nips/nip-44.js +13 -13
- package/dist/cjs/nips/nip-44.js.map +1 -1
- package/dist/cjs/nips/nip-46.js +16 -17
- package/dist/cjs/nips/nip-46.js.map +1 -1
- package/dist/cjs/nips/nip-49.js +7 -7
- package/dist/cjs/nips/nip-49.js.map +1 -1
- package/dist/cjs/utils/validation.js +6 -6
- package/dist/cjs/utils/validation.js.map +1 -1
- package/dist/cjs/validation/index.js +6 -6
- package/dist/cjs/validation/index.js.map +1 -1
- package/dist/esm/crypto.js +22 -9
- package/dist/esm/crypto.js.map +1 -1
- package/dist/esm/encoding/base64.js +29 -12
- package/dist/esm/encoding/base64.js.map +1 -1
- package/dist/esm/event/creation.js +2 -2
- package/dist/esm/event/creation.js.map +1 -1
- package/dist/esm/event/signing.js +4 -4
- package/dist/esm/event/signing.js.map +1 -1
- package/dist/esm/nips/nip-01.js +4 -4
- package/dist/esm/nips/nip-01.js.map +1 -1
- package/dist/esm/nips/nip-04.js +5 -5
- package/dist/esm/nips/nip-04.js.map +1 -1
- package/dist/esm/nips/nip-26.js +5 -5
- package/dist/esm/nips/nip-26.js.map +1 -1
- package/dist/esm/nips/nip-44.js +6 -6
- package/dist/esm/nips/nip-44.js.map +1 -1
- package/dist/esm/nips/nip-46.js +3 -4
- package/dist/esm/nips/nip-46.js.map +1 -1
- package/dist/esm/nips/nip-49.js +2 -2
- package/dist/esm/nips/nip-49.js.map +1 -1
- package/dist/esm/utils/validation.js +3 -3
- package/dist/esm/utils/validation.js.map +1 -1
- package/dist/esm/validation/index.js +4 -4
- package/dist/esm/validation/index.js.map +1 -1
- package/dist/types/crypto.d.ts +10 -8
- package/dist/types/crypto.d.ts.map +1 -1
- package/dist/types/encoding/base64.d.ts +7 -6
- package/dist/types/encoding/base64.d.ts.map +1 -1
- package/dist/types/nips/nip-46.d.ts.map +1 -1
- package/dist/types/utils/index.d.ts +1 -1
- package/dist/types/utils/index.d.ts.map +1 -1
- package/package.json +8 -8
- package/src/__tests__/nips/nip-44.test.ts +2 -3
- package/src/__tests__/nips/nip-46.test.ts +3 -4
- package/src/__tests__/nips/nip-49.test.ts +1 -2
- package/src/__tests__/validation.test.ts +1 -1
- package/src/crypto.ts +27 -12
- package/src/encoding/base64.ts +31 -14
- package/src/event/creation.ts +2 -2
- package/src/event/signing.ts +4 -4
- package/src/nips/nip-01.ts +4 -4
- package/src/nips/nip-04.ts +5 -5
- package/src/nips/nip-26.ts +5 -5
- package/src/nips/nip-44.ts +6 -6
- package/src/nips/nip-46.ts +3 -4
- package/src/nips/nip-49.ts +2 -2
- package/src/utils/validation.ts +3 -3
- package/src/validation/index.ts +4 -4
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
"use strict";var NostrCryptoUtils=NostrCryptoUtils||{};NostrCryptoUtils.Crypto=(()=>{var Zr=Object.create;var Nt=Object.defineProperty;var Gr=Object.getOwnPropertyDescriptor;var $r=Object.getOwnPropertyNames;var Yr=Object.getPrototypeOf,Wr=Object.prototype.hasOwnProperty;var Xr=(t,e,n)=>e in t?Nt(t,e,{enumerable:!0,configurable:!0,writable:!0,value:n}):t[e]=n;var Jr=(t,e)=>()=>(t&&(e=t(t=0)),e);var $e=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports),Ye=(t,e)=>{for(var n in e)Nt(t,n,{get:e[n],enumerable:!0})},We=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of $r(e))!Wr.call(t,o)&&o!==n&&Nt(t,o,{get:()=>e[o],enumerable:!(r=Gr(e,o))||r.enumerable});return t};var Qr=(t,e,n)=>(n=t!=null?Zr(Yr(t)):{},We(e||!t||!t.__esModule?Nt(n,"default",{value:t,enumerable:!0}):n,t)),Fr=t=>We(Nt({},"__esModule",{value:!0}),t);var Wt=(t,e,n)=>Xr(t,typeof e!="symbol"?e+"":e,n);var kr=$e((os,Ur)=>{"use strict";function On(t){try{return JSON.stringify(t)}catch{return'"[Circular]"'}}Ur.exports=Hn;function Hn(t,e,n){var r=n&&n.stringify||On,o=1;if(typeof t=="object"&&t!==null){var s=e.length+o;if(s===1)return t;var i=new Array(s);i[0]=r(t);for(var c=1;c<s;c++)i[c]=r(e[c]);return i.join(" ")}if(typeof t!="string")return t;var f=e.length;if(f===0)return t;for(var a="",d=1-o,b=-1,l=t&&t.length||0,u=0;u<l;){if(t.charCodeAt(u)===37&&u+1<l){switch(b=b>-1?b:0,t.charCodeAt(u+1)){case 100:case 102:if(d>=f||e[d]==null)break;b<u&&(a+=t.slice(b,u)),a+=Number(e[d]),b=u+2,u++;break;case 105:if(d>=f||e[d]==null)break;b<u&&(a+=t.slice(b,u)),a+=Math.floor(Number(e[d])),b=u+2,u++;break;case 79:case 111:case 106:if(d>=f||e[d]===void 0)break;b<u&&(a+=t.slice(b,u));var x=typeof e[d];if(x==="string"){a+="'"+e[d]+"'",b=u+2,u++;break}if(x==="function"){a+=e[d].name||"<anonymous>",b=u+2,u++;break}a+=r(e[d]),b=u+2,u++;break;case 115:if(d>=f)break;b<u&&(a+=t.slice(b,u)),a+=String(e[d]),b=u+2,u++;break;case 37:b<u&&(a+=t.slice(b,u)),a+="%",b=u+2,u++,d--;break}++d}++u}return b===-1?t:(b<l&&(a+=t.slice(b)),a)}});var Vr=$e((ss,ye)=>{"use strict";var Rr=kr();ye.exports=ct;var Dt=Mn().console||{},Tn={mapHttpRequest:de,mapHttpResponse:de,wrapRequestSerializer:qe,wrapResponseSerializer:qe,wrapErrorSerializer:qe,req:de,res:de,err:Cr,errWithCause:Cr};function he(t,e){return t==="silent"?1/0:e.levels.values[t]}var Pe=Symbol("pino.logFuncs"),Ke=Symbol("pino.hierarchy"),Ln={error:"log",fatal:"error",warn:"error",info:"log",debug:"log",trace:"log"};function Nr(t,e){let n={logger:e,parent:t[Ke]};e[Ke]=n}function Un(t,e,n){let r={};e.forEach(o=>{r[o]=n[o]?n[o]:Dt[o]||Dt[Ln[o]||"log"]||Mt}),t[Pe]=r}function kn(t,e){return Array.isArray(t)?t.filter(function(r){return r!=="!stdSerializers.err"}):t===!0?Object.keys(e):!1}function ct(t){t=t||{},t.browser=t.browser||{};let e=t.browser.transmit;if(e&&typeof e.send!="function")throw Error("pino: transmit option must have a send function");let n=t.browser.write||Dt;t.browser.write&&(t.browser.asObject=!0);let r=t.serializers||{},o=kn(t.browser.serialize,r),s=t.browser.serialize;Array.isArray(t.browser.serialize)&&t.browser.serialize.indexOf("!stdSerializers.err")>-1&&(s=!1);let i=Object.keys(t.customLevels||{}),c=["error","fatal","warn","info","debug","trace"].concat(i);typeof n=="function"&&c.forEach(function(m){n[m]=n}),(t.enabled===!1||t.browser.disabled)&&(t.level="silent");let f=t.level||"info",a=Object.create(n);a.log||(a.log=Mt),Un(a,c,n),Nr({},a),Object.defineProperty(a,"levelVal",{get:b}),Object.defineProperty(a,"level",{get:l,set:u});let d={transmit:e,serialize:o,asObject:t.browser.asObject,formatters:t.browser.formatters,levels:c,timestamp:jn(t)};a.levels=Rn(t),a.level=f,a.setMaxListeners=a.getMaxListeners=a.emit=a.addListener=a.on=a.prependListener=a.once=a.prependOnceListener=a.removeListener=a.removeAllListeners=a.listeners=a.listenerCount=a.eventNames=a.write=a.flush=Mt,a.serializers=r,a._serialize=o,a._stdErrSerialize=s,a.child=x,e&&(a._logEvent=Ve());function b(){return he(this.level,this)}function l(){return this._level}function u(m){if(m!=="silent"&&!this.levels.values[m])throw Error("unknown level "+m);this._level=m,Bt(this,d,a,"error"),Bt(this,d,a,"fatal"),Bt(this,d,a,"warn"),Bt(this,d,a,"info"),Bt(this,d,a,"debug"),Bt(this,d,a,"trace"),i.forEach(_=>{Bt(this,d,a,_)})}function x(m,_){if(!m)throw new Error("missing bindings for child Pino");_=_||{},o&&m.serializers&&(_.serializers=m.serializers);let L=_.serializers;if(o&&L){var J=Object.assign({},r,L),U=t.browser.serialize===!0?Object.keys(J):o;delete m.serializers,be([m],U,J,this._stdErrSerialize)}function Q(tt){this._childLevel=(tt._childLevel|0)+1,this.bindings=m,J&&(this.serializers=J,this._serialize=U),e&&(this._logEvent=Ve([].concat(tt._logEvent.bindings,m)))}Q.prototype=this;let Z=new Q(this);return Nr(this,Z),Z.level=this.level,Z}return a}function Rn(t){let e=t.customLevels||{},n=Object.assign({},ct.levels.values,e),r=Object.assign({},ct.levels.labels,Nn(e));return{values:n,labels:r}}function Nn(t){let e={};return Object.keys(t).forEach(function(n){e[t[n]]=n}),e}ct.levels={values:{fatal:60,error:50,warn:40,info:30,debug:20,trace:10},labels:{10:"trace",20:"debug",30:"info",40:"warn",50:"error",60:"fatal"}};ct.stdSerializers=Tn;ct.stdTimeFunctions=Object.assign({},{nullTime:qr,epochTime:Kr,unixTime:zn,isoTime:Dn});function Cn(t){let e=[];t.bindings&&e.push(t.bindings);let n=t[Ke];for(;n.parent;)n=n.parent,n.logger.bindings&&e.push(n.logger.bindings);return e.reverse()}function Bt(t,e,n,r){if(Object.defineProperty(t,r,{value:he(t.level,n)>he(r,n)?Mt:n[Pe][r],writable:!0,enumerable:!0,configurable:!0}),!e.transmit&&t[r]===Mt)return;t[r]=Kn(t,e,n,r);let o=Cn(t);o.length!==0&&(t[r]=qn(o,t[r]))}function qn(t,e){return function(){return e.apply(this,[...t,...arguments])}}function Kn(t,e,n,r){return(function(o){return function(){let i=e.timestamp(),c=new Array(arguments.length),f=Object.getPrototypeOf&&Object.getPrototypeOf(this)===Dt?Dt:this;for(var a=0;a<c.length;a++)c[a]=arguments[a];if(e.serialize&&!e.asObject&&be(c,this._serialize,this.serializers,this._stdErrSerialize),e.asObject||e.formatters?o.call(f,Vn(this,r,c,i,e.formatters)):o.apply(f,c),e.transmit){let d=e.transmit.level||t._level,b=n.levels.values[d],l=n.levels.values[r];if(l<b)return;Pn(this,{ts:i,methodLevel:r,methodValue:l,transmitLevel:d,transmitValue:n.levels.values[e.transmit.level||t._level],send:e.transmit.send,val:he(t._level,n)},c)}}})(t[Pe][r])}function Vn(t,e,n,r,o={}){let{level:s=()=>t.levels.values[e],log:i=l=>l}=o;t._serialize&&be(n,t._serialize,t.serializers,t._stdErrSerialize);let c=n.slice(),f=c[0],a={};r&&(a.time=r),a.level=s(e,t.levels.values[e]);let d=(t._childLevel|0)+1;if(d<1&&(d=1),f!==null&&typeof f=="object"){for(;d--&&typeof c[0]=="object";)Object.assign(a,c.shift());f=c.length?Rr(c.shift(),c):void 0}else typeof f=="string"&&(f=Rr(c.shift(),c));return f!==void 0&&(a.msg=f),i(a)}function be(t,e,n,r){for(let o in t)if(r&&t[o]instanceof Error)t[o]=ct.stdSerializers.err(t[o]);else if(typeof t[o]=="object"&&!Array.isArray(t[o]))for(let s in t[o])e&&e.indexOf(s)>-1&&s in n&&(t[o][s]=n[s](t[o][s]))}function Pn(t,e,n){let r=e.send,o=e.ts,s=e.methodLevel,i=e.methodValue,c=e.val,f=t._logEvent.bindings;be(n,t._serialize||Object.keys(t.serializers),t.serializers,t._stdErrSerialize===void 0?!0:t._stdErrSerialize),t._logEvent.ts=o,t._logEvent.messages=n.filter(function(a){return f.indexOf(a)===-1}),t._logEvent.level.label=s,t._logEvent.level.value=i,r(s,t._logEvent,c),t._logEvent=Ve(f)}function Ve(t){return{ts:0,messages:[],bindings:t||[],level:{label:"",value:0}}}function Cr(t){let e={type:t.constructor.name,msg:t.message,stack:t.stack};for(let n in t)e[n]===void 0&&(e[n]=t[n]);return e}function jn(t){return typeof t.timestamp=="function"?t.timestamp:t.timestamp===!1?qr:Kr}function de(){return{}}function qe(t){return t}function Mt(){}function qr(){return!1}function Kr(){return Date.now()}function zn(){return Math.round(Date.now()/1e3)}function Dn(){return new Date(Date.now()).toISOString()}function Mn(){function t(e){return typeof e<"u"&&e}try{return typeof globalThis<"u"||Object.defineProperty(Object.prototype,"globalThis",{get:function(){return delete Object.prototype.globalThis,this.globalThis=this},configurable:!0}),globalThis}catch{return t(self)||t(window)||t(this)||{}}}ye.exports.default=ct;ye.exports.pino=ct});var jr={};Ye(jr,{default:()=>Gn});var Gn,zr=Jr(()=>{Gn={}});var so={};Ye(so,{createEvent:()=>to,customCrypto:()=>Zt,decrypt:()=>oo,encrypt:()=>no,finalizeEvent:()=>eo,generateKeyPair:()=>Qn,getCompressedPublicKey:()=>Xn,getPublicKey:()=>Me,getPublicKeySync:()=>Mr,getSchnorrPublicKey:()=>Jn,signEvent:()=>Dr,signSchnorr:()=>Yn,validateKeyPair:()=>Fn,verifySchnorrSignature:()=>Wn,verifySignature:()=>ro});var pt=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function ft(t){return t instanceof Uint8Array||ArrayBuffer.isView(t)&&t.constructor.name==="Uint8Array"}function St(t){if(!Number.isSafeInteger(t)||t<0)throw new Error("positive integer expected, got "+t)}function G(t,...e){if(!ft(t))throw new Error("Uint8Array expected");if(e.length>0&&!e.includes(t.length))throw new Error("Uint8Array expected of length "+e+", got length="+t.length)}function Xt(t){if(typeof t!="function"||typeof t.create!="function")throw new Error("Hash should be wrapped by utils.createHasher");St(t.outputLen),St(t.blockLen)}function _t(t,e=!0){if(t.destroyed)throw new Error("Hash instance has been destroyed");if(e&&t.finished)throw new Error("Hash#digest() has already been called")}function Je(t,e){G(t);let n=e.outputLen;if(t.length<n)throw new Error("digestInto() expects output buffer of length at least "+n)}function gt(...t){for(let e=0;e<t.length;e++)t[e].fill(0)}function Jt(t){return new DataView(t.buffer,t.byteOffset,t.byteLength)}function $(t,e){return t<<32-e|t>>>e}var Qe=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",tn=Array.from({length:256},(t,e)=>e.toString(16).padStart(2,"0"));function Y(t){if(G(t),Qe)return t.toHex();let e="";for(let n=0;n<t.length;n++)e+=tn[t[n]];return e}var et={_0:48,_9:57,A:65,F:70,a:97,f:102};function Xe(t){if(t>=et._0&&t<=et._9)return t-et._0;if(t>=et.A&&t<=et.F)return t-(et.A-10);if(t>=et.a&&t<=et.f)return t-(et.a-10)}function rt(t){if(typeof t!="string")throw new Error("hex string expected, got "+typeof t);if(Qe)return Uint8Array.fromHex(t);let e=t.length,n=e/2;if(e%2)throw new Error("hex string expected, got unpadded hex of length "+e);let r=new Uint8Array(n);for(let o=0,s=0;o<n;o++,s+=2){let i=Xe(t.charCodeAt(s)),c=Xe(t.charCodeAt(s+1));if(i===void 0||c===void 0){let f=t[s]+t[s+1];throw new Error('hex string expected, got non-hex character "'+f+'" at index '+s)}r[o]=i*16+c}return r}function Ct(t){if(typeof t!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(t))}function qt(t){return typeof t=="string"&&(t=Ct(t)),G(t),t}function P(...t){let e=0;for(let r=0;r<t.length;r++){let o=t[r];G(o),e+=o.length}let n=new Uint8Array(e);for(let r=0,o=0;r<t.length;r++){let s=t[r];n.set(s,o),o+=s.length}return n}var At=class{};function Fe(t){let e=r=>t().update(qt(r)).digest(),n=t();return e.outputLen=n.outputLen,e.blockLen=n.blockLen,e.create=()=>t(),e}function W(t=32){if(pt&&typeof pt.getRandomValues=="function")return pt.getRandomValues(new Uint8Array(t));if(pt&&typeof pt.randomBytes=="function")return Uint8Array.from(pt.randomBytes(t));throw new Error("crypto.getRandomValues must be defined")}function en(t,e,n,r){if(typeof t.setBigUint64=="function")return t.setBigUint64(e,n,r);let o=BigInt(32),s=BigInt(4294967295),i=Number(n>>o&s),c=Number(n&s),f=r?4:0,a=r?0:4;t.setUint32(e+f,i,r),t.setUint32(e+a,c,r)}function tr(t,e,n){return t&e^~t&n}function er(t,e,n){return t&e^t&n^e&n}var Qt=class extends At{constructor(e,n,r,o){super(),this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.blockLen=e,this.outputLen=n,this.padOffset=r,this.isLE=o,this.buffer=new Uint8Array(e),this.view=Jt(this.buffer)}update(e){_t(this),e=qt(e),G(e);let{view:n,buffer:r,blockLen:o}=this,s=e.length;for(let i=0;i<s;){let c=Math.min(o-this.pos,s-i);if(c===o){let f=Jt(e);for(;o<=s-i;i+=o)this.process(f,i);continue}r.set(e.subarray(i,i+c),this.pos),this.pos+=c,i+=c,this.pos===o&&(this.process(n,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){_t(this),Je(e,this),this.finished=!0;let{buffer:n,view:r,blockLen:o,isLE:s}=this,{pos:i}=this;n[i++]=128,gt(this.buffer.subarray(i)),this.padOffset>o-i&&(this.process(r,0),i=0);for(let b=i;b<o;b++)n[b]=0;en(r,o-8,BigInt(this.length*8),s),this.process(r,0);let c=Jt(e),f=this.outputLen;if(f%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let a=f/4,d=this.get();if(a>d.length)throw new Error("_sha2: outputLen bigger than state");for(let b=0;b<a;b++)c.setUint32(4*b,d[b],s)}digest(){let{buffer:e,outputLen:n}=this;this.digestInto(e);let r=e.slice(0,n);return this.destroy(),r}_cloneInto(e){e||(e=new this.constructor),e.set(...this.get());let{blockLen:n,buffer:r,length:o,finished:s,destroyed:i,pos:c}=this;return e.destroyed=i,e.finished=s,e.length=o,e.pos=c,o%n&&e.buffer.set(r),e}clone(){return this._cloneInto()}},nt=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var rn=Uint32Array.from([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),ut=new Uint32Array(64),Ft=class extends Qt{constructor(e=32){super(64,e,8,!1),this.A=nt[0]|0,this.B=nt[1]|0,this.C=nt[2]|0,this.D=nt[3]|0,this.E=nt[4]|0,this.F=nt[5]|0,this.G=nt[6]|0,this.H=nt[7]|0}get(){let{A:e,B:n,C:r,D:o,E:s,F:i,G:c,H:f}=this;return[e,n,r,o,s,i,c,f]}set(e,n,r,o,s,i,c,f){this.A=e|0,this.B=n|0,this.C=r|0,this.D=o|0,this.E=s|0,this.F=i|0,this.G=c|0,this.H=f|0}process(e,n){for(let b=0;b<16;b++,n+=4)ut[b]=e.getUint32(n,!1);for(let b=16;b<64;b++){let l=ut[b-15],u=ut[b-2],x=$(l,7)^$(l,18)^l>>>3,m=$(u,17)^$(u,19)^u>>>10;ut[b]=m+ut[b-7]+x+ut[b-16]|0}let{A:r,B:o,C:s,D:i,E:c,F:f,G:a,H:d}=this;for(let b=0;b<64;b++){let l=$(c,6)^$(c,11)^$(c,25),u=d+l+tr(c,f,a)+rn[b]+ut[b]|0,m=($(r,2)^$(r,13)^$(r,22))+er(r,o,s)|0;d=a,a=f,f=c,c=i+u|0,i=s,s=o,o=r,r=u+m|0}r=r+this.A|0,o=o+this.B|0,s=s+this.C|0,i=i+this.D|0,c=c+this.E|0,f=f+this.F|0,a=a+this.G|0,d=d+this.H|0,this.set(r,o,s,i,c,f,a,d)}roundClean(){gt(ut)}destroy(){this.set(0,0,0,0,0,0,0,0),gt(this.buffer)}};var It=Fe(()=>new Ft);var te=class extends At{constructor(e,n){super(),this.finished=!1,this.destroyed=!1,Xt(e);let r=qt(n);if(this.iHash=e.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let o=this.blockLen,s=new Uint8Array(o);s.set(r.length>o?e.create().update(r).digest():r);for(let i=0;i<s.length;i++)s[i]^=54;this.iHash.update(s),this.oHash=e.create();for(let i=0;i<s.length;i++)s[i]^=106;this.oHash.update(s),gt(s)}update(e){return _t(this),this.iHash.update(e),this}digestInto(e){_t(this),G(e,this.outputLen),this.finished=!0,this.iHash.digestInto(e),this.oHash.update(e),this.oHash.digestInto(e),this.destroy()}digest(){let e=new Uint8Array(this.oHash.outputLen);return this.digestInto(e),e}_cloneInto(e){e||(e=Object.create(Object.getPrototypeOf(this),{}));let{oHash:n,iHash:r,finished:o,destroyed:s,blockLen:i,outputLen:c}=this;return e=e,e.finished=o,e.destroyed=s,e.blockLen=i,e.outputLen=c,e.oHash=n._cloneInto(e.oHash),e.iHash=r._cloneInto(e.iHash),e}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},pe=(t,e,n)=>new te(t,e).update(n).digest();pe.create=(t,e)=>new te(t,e);var xe=BigInt(0),me=BigInt(1);function Kt(t,e=""){if(typeof t!="boolean"){let n=e&&`"${e}"`;throw new Error(n+"expected boolean, got type="+typeof t)}return t}function lt(t,e,n=""){let r=ft(t),o=t?.length,s=e!==void 0;if(!r||s&&o!==e){let i=n&&`"${n}" `,c=s?` of length ${e}`:"",f=r?`length=${o}`:`type=${typeof t}`;throw new Error(i+"expected Uint8Array"+c+", got "+f)}return t}function Ot(t){let e=t.toString(16);return e.length&1?"0"+e:e}function we(t){if(typeof t!="string")throw new Error("hex string expected, got "+typeof t);return t===""?xe:BigInt("0x"+t)}function F(t){return we(Y(t))}function ee(t){return G(t),we(Y(Uint8Array.from(t).reverse()))}function mt(t,e){return rt(t.toString(16).padStart(e*2,"0"))}function re(t,e){return mt(t,e).reverse()}function k(t,e,n){let r;if(typeof e=="string")try{r=rt(e)}catch(s){throw new Error(t+" must be hex string or Uint8Array, cause: "+s)}else if(ft(e))r=Uint8Array.from(e);else throw new Error(t+" must be hex string or Uint8Array");let o=r.length;if(typeof n=="number"&&o!==n)throw new Error(t+" of length "+n+" expected, got "+o);return r}var ge=t=>typeof t=="bigint"&&xe<=t;function Ht(t,e,n){return ge(t)&&ge(e)&&ge(n)&&e<=t&&t<n}function Ee(t,e,n,r){if(!Ht(e,n,r))throw new Error("expected valid "+t+": "+n+" <= n < "+r+", got "+e)}function Vt(t){let e;for(e=0;t>xe;t>>=me,e+=1);return e}var ot=t=>(me<<BigInt(t))-me;function Be(t,e,n){if(typeof t!="number"||t<2)throw new Error("hashLen must be a number");if(typeof e!="number"||e<2)throw new Error("qByteLen must be a number");if(typeof n!="function")throw new Error("hmacFn must be a function");let r=u=>new Uint8Array(u),o=u=>Uint8Array.of(u),s=r(t),i=r(t),c=0,f=()=>{s.fill(1),i.fill(0),c=0},a=(...u)=>n(i,s,...u),d=(u=r(0))=>{i=a(o(0),u),s=a(),u.length!==0&&(i=a(o(1),u),s=a())},b=()=>{if(c++>=1e3)throw new Error("drbg: tried 1000 values");let u=0,x=[];for(;u<e;){s=a();let m=s.slice();x.push(m),u+=s.length}return P(...x)};return(u,x)=>{f(),d(u);let m;for(;!(m=x(b()));)d();return f(),m}}function Pt(t,e,n={}){if(!t||typeof t!="object")throw new Error("expected valid options object");function r(o,s,i){let c=t[o];if(i&&c===void 0)return;let f=typeof c;if(f!==s||c===null)throw new Error(`param "${o}" is invalid: expected ${s}, got ${f}`)}Object.entries(e).forEach(([o,s])=>r(o,s,!1)),Object.entries(n).forEach(([o,s])=>r(o,s,!0))}function ne(t){let e=new WeakMap;return(n,...r)=>{let o=e.get(n);if(o!==void 0)return o;let s=t(n,...r);return e.set(n,s),s}}var j=BigInt(0),V=BigInt(1),xt=BigInt(2),or=BigInt(3),sr=BigInt(4),ir=BigInt(5),sn=BigInt(7),cr=BigInt(8),cn=BigInt(9),ar=BigInt(16);function D(t,e){let n=t%e;return n>=j?n:e+n}function M(t,e,n){let r=t;for(;e-- >j;)r*=r,r%=n;return r}function rr(t,e){if(t===j)throw new Error("invert: expected non-zero number");if(e<=j)throw new Error("invert: expected positive modulus, got "+e);let n=D(t,e),r=e,o=j,s=V,i=V,c=j;for(;n!==j;){let a=r/n,d=r%n,b=o-i*a,l=s-c*a;r=n,n=d,o=i,s=c,i=b,c=l}if(r!==V)throw new Error("invert: does not exist");return D(o,e)}function ve(t,e,n){if(!t.eql(t.sqr(e),n))throw new Error("Cannot find square root")}function fr(t,e){let n=(t.ORDER+V)/sr,r=t.pow(e,n);return ve(t,r,e),r}function an(t,e){let n=(t.ORDER-ir)/cr,r=t.mul(e,xt),o=t.pow(r,n),s=t.mul(e,o),i=t.mul(t.mul(s,xt),o),c=t.mul(s,t.sub(i,t.ONE));return ve(t,c,e),c}function fn(t){let e=dt(t),n=ur(t),r=n(e,e.neg(e.ONE)),o=n(e,r),s=n(e,e.neg(r)),i=(t+sn)/ar;return(c,f)=>{let a=c.pow(f,i),d=c.mul(a,r),b=c.mul(a,o),l=c.mul(a,s),u=c.eql(c.sqr(d),f),x=c.eql(c.sqr(b),f);a=c.cmov(a,d,u),d=c.cmov(l,b,x);let m=c.eql(c.sqr(d),f),_=c.cmov(a,d,m);return ve(c,_,f),_}}function ur(t){if(t<or)throw new Error("sqrt is not defined for small field");let e=t-V,n=0;for(;e%xt===j;)e/=xt,n++;let r=xt,o=dt(t);for(;nr(o,r)===1;)if(r++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(n===1)return fr;let s=o.pow(r,e),i=(e+V)/xt;return function(f,a){if(f.is0(a))return a;if(nr(f,a)!==1)throw new Error("Cannot find square root");let d=n,b=f.mul(f.ONE,s),l=f.pow(a,e),u=f.pow(a,i);for(;!f.eql(l,f.ONE);){if(f.is0(l))return f.ZERO;let x=1,m=f.sqr(l);for(;!f.eql(m,f.ONE);)if(x++,m=f.sqr(m),x===d)throw new Error("Cannot find square root");let _=V<<BigInt(d-x-1),L=f.pow(b,_);d=x,b=f.sqr(L),l=f.mul(l,b),u=f.mul(u,L)}return u}}function un(t){return t%sr===or?fr:t%cr===ir?an:t%ar===cn?fn(t):ur(t)}var ln=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Se(t){let e={ORDER:"bigint",MASK:"bigint",BYTES:"number",BITS:"number"},n=ln.reduce((r,o)=>(r[o]="function",r),e);return Pt(t,n),t}function dn(t,e,n){if(n<j)throw new Error("invalid exponent, negatives unsupported");if(n===j)return t.ONE;if(n===V)return e;let r=t.ONE,o=e;for(;n>j;)n&V&&(r=t.mul(r,o)),o=t.sqr(o),n>>=V;return r}function oe(t,e,n=!1){let r=new Array(e.length).fill(n?t.ZERO:void 0),o=e.reduce((i,c,f)=>t.is0(c)?i:(r[f]=i,t.mul(i,c)),t.ONE),s=t.inv(o);return e.reduceRight((i,c,f)=>t.is0(c)?i:(r[f]=t.mul(i,r[f]),t.mul(i,c)),s),r}function nr(t,e){let n=(t.ORDER-V)/xt,r=t.pow(e,n),o=t.eql(r,t.ONE),s=t.eql(r,t.ZERO),i=t.eql(r,t.neg(t.ONE));if(!o&&!s&&!i)throw new Error("invalid Legendre symbol result");return o?1:s?0:-1}function se(t,e){e!==void 0&&St(e);let n=e!==void 0?e:t.toString(2).length,r=Math.ceil(n/8);return{nBitLength:n,nByteLength:r}}function dt(t,e,n=!1,r={}){if(t<=j)throw new Error("invalid field: expected ORDER > 0, got "+t);let o,s,i=!1,c;if(typeof e=="object"&&e!=null){if(r.sqrt||n)throw new Error("cannot specify opts in two arguments");let l=e;l.BITS&&(o=l.BITS),l.sqrt&&(s=l.sqrt),typeof l.isLE=="boolean"&&(n=l.isLE),typeof l.modFromBytes=="boolean"&&(i=l.modFromBytes),c=l.allowedLengths}else typeof e=="number"&&(o=e),r.sqrt&&(s=r.sqrt);let{nBitLength:f,nByteLength:a}=se(t,o);if(a>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let d,b=Object.freeze({ORDER:t,isLE:n,BITS:f,BYTES:a,MASK:ot(f),ZERO:j,ONE:V,allowedLengths:c,create:l=>D(l,t),isValid:l=>{if(typeof l!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof l);return j<=l&&l<t},is0:l=>l===j,isValidNot0:l=>!b.is0(l)&&b.isValid(l),isOdd:l=>(l&V)===V,neg:l=>D(-l,t),eql:(l,u)=>l===u,sqr:l=>D(l*l,t),add:(l,u)=>D(l+u,t),sub:(l,u)=>D(l-u,t),mul:(l,u)=>D(l*u,t),pow:(l,u)=>dn(b,l,u),div:(l,u)=>D(l*rr(u,t),t),sqrN:l=>l*l,addN:(l,u)=>l+u,subN:(l,u)=>l-u,mulN:(l,u)=>l*u,inv:l=>rr(l,t),sqrt:s||(l=>(d||(d=un(t)),d(b,l))),toBytes:l=>n?re(l,a):mt(l,a),fromBytes:(l,u=!0)=>{if(c){if(!c.includes(l.length)||l.length>a)throw new Error("Field.fromBytes: expected "+c+" bytes, got "+l.length);let m=new Uint8Array(a);m.set(l,n?0:m.length-l.length),l=m}if(l.length!==a)throw new Error("Field.fromBytes: expected "+a+" bytes, got "+l.length);let x=n?ee(l):F(l);if(i&&(x=D(x,t)),!u&&!b.isValid(x))throw new Error("invalid field element: outside of range 0..ORDER");return x},invertBatch:l=>oe(b,l),cmov:(l,u,x)=>x?u:l});return Object.freeze(b)}function lr(t){if(typeof t!="bigint")throw new Error("field order must be bigint");let e=t.toString(2).length;return Math.ceil(e/8)}function Ae(t){let e=lr(t);return e+Math.ceil(e/2)}function ie(t,e,n=!1){let r=t.length,o=lr(e),s=Ae(e);if(r<16||r<s||r>1024)throw new Error("expected "+s+"-1024 bytes of input, got "+r);let i=n?ee(t):F(t),c=D(i,e-V)+V;return n?re(c,o):mt(c,o)}var Tt=BigInt(0),wt=BigInt(1);function jt(t,e){let n=e.negate();return t?n:e}function ae(t,e){let n=oe(t.Fp,e.map(r=>r.Z));return e.map((r,o)=>t.fromAffine(r.toAffine(n[o])))}function yr(t,e){if(!Number.isSafeInteger(t)||t<=0||t>e)throw new Error("invalid window size, expected [1.."+e+"], got W="+t)}function _e(t,e){yr(t,e);let n=Math.ceil(e/t)+1,r=2**(t-1),o=2**t,s=ot(t),i=BigInt(t);return{windows:n,windowSize:r,mask:s,maxNumber:o,shiftBy:i}}function dr(t,e,n){let{windowSize:r,mask:o,maxNumber:s,shiftBy:i}=n,c=Number(t&o),f=t>>i;c>r&&(c-=s,f+=wt);let a=e*r,d=a+Math.abs(c)-1,b=c===0,l=c<0,u=e%2!==0;return{nextN:f,offset:d,isZero:b,isNeg:l,isNegF:u,offsetF:a}}function bn(t,e){if(!Array.isArray(t))throw new Error("array expected");t.forEach((n,r)=>{if(!(n instanceof e))throw new Error("invalid point at index "+r)})}function yn(t,e){if(!Array.isArray(t))throw new Error("array of scalars expected");t.forEach((n,r)=>{if(!e.isValid(n))throw new Error("invalid scalar at index "+r)})}var Ie=new WeakMap,pr=new WeakMap;function Oe(t){return pr.get(t)||1}function hr(t){if(t!==Tt)throw new Error("invalid wNAF")}var ce=class{constructor(e,n){this.BASE=e.BASE,this.ZERO=e.ZERO,this.Fn=e.Fn,this.bits=n}_unsafeLadder(e,n,r=this.ZERO){let o=e;for(;n>Tt;)n&wt&&(r=r.add(o)),o=o.double(),n>>=wt;return r}precomputeWindow(e,n){let{windows:r,windowSize:o}=_e(n,this.bits),s=[],i=e,c=i;for(let f=0;f<r;f++){c=i,s.push(c);for(let a=1;a<o;a++)c=c.add(i),s.push(c);i=c.double()}return s}wNAF(e,n,r){if(!this.Fn.isValid(r))throw new Error("invalid scalar");let o=this.ZERO,s=this.BASE,i=_e(e,this.bits);for(let c=0;c<i.windows;c++){let{nextN:f,offset:a,isZero:d,isNeg:b,isNegF:l,offsetF:u}=dr(r,c,i);r=f,d?s=s.add(jt(l,n[u])):o=o.add(jt(b,n[a]))}return hr(r),{p:o,f:s}}wNAFUnsafe(e,n,r,o=this.ZERO){let s=_e(e,this.bits);for(let i=0;i<s.windows&&r!==Tt;i++){let{nextN:c,offset:f,isZero:a,isNeg:d}=dr(r,i,s);if(r=c,!a){let b=n[f];o=o.add(d?b.negate():b)}}return hr(r),o}getPrecomputes(e,n,r){let o=Ie.get(n);return o||(o=this.precomputeWindow(n,e),e!==1&&(typeof r=="function"&&(o=r(o)),Ie.set(n,o))),o}cached(e,n,r){let o=Oe(e);return this.wNAF(o,this.getPrecomputes(o,e,r),n)}unsafe(e,n,r,o){let s=Oe(e);return s===1?this._unsafeLadder(e,n,o):this.wNAFUnsafe(s,this.getPrecomputes(s,e,r),n,o)}createCache(e,n){yr(n,this.bits),pr.set(e,n),Ie.delete(e)}hasCache(e){return Oe(e)!==1}};function gr(t,e,n,r){let o=e,s=t.ZERO,i=t.ZERO;for(;n>Tt||r>Tt;)n&wt&&(s=s.add(o)),r&wt&&(i=i.add(o)),o=o.double(),n>>=wt,r>>=wt;return{p1:s,p2:i}}function mr(t,e,n,r){bn(n,t),yn(r,e);let o=n.length,s=r.length;if(o!==s)throw new Error("arrays of points and scalars must have equal length");let i=t.ZERO,c=Vt(BigInt(o)),f=1;c>12?f=c-3:c>4?f=c-2:c>0&&(f=2);let a=ot(f),d=new Array(Number(a)+1).fill(i),b=Math.floor((e.BITS-1)/f)*f,l=i;for(let u=b;u>=0;u-=f){d.fill(i);for(let m=0;m<s;m++){let _=r[m],L=Number(_>>BigInt(u)&a);d[L]=d[L].add(n[m])}let x=i;for(let m=d.length-1,_=i;m>0;m--)_=_.add(d[m]),x=x.add(_);if(l=l.add(x),u!==0)for(let m=0;m<f;m++)l=l.double()}return l}function br(t,e,n){if(e){if(e.ORDER!==t)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return Se(e),e}else return dt(t,{isLE:n})}function xr(t,e,n={},r){if(r===void 0&&(r=t==="edwards"),!e||typeof e!="object")throw new Error(`expected valid ${t} CURVE object`);for(let f of["p","n","h"]){let a=e[f];if(!(typeof a=="bigint"&&a>Tt))throw new Error(`CURVE.${f} must be positive bigint`)}let o=br(e.p,n.Fp,r),s=br(e.n,n.Fn,r),c=["Gx","Gy","a",t==="weierstrass"?"b":"d"];for(let f of c)if(!o.isValid(e[f]))throw new Error(`CURVE.${f} must be valid field element of CURVE.Fp`);return e=Object.freeze(Object.assign({},e)),{CURVE:e,Fp:o,Fn:s}}var wr=(t,e)=>(t+(t>=0?e:-e)/Er)/e;function pn(t,e,n){let[[r,o],[s,i]]=e,c=wr(i*t,n),f=wr(-o*t,n),a=t-c*r-f*s,d=-c*o-f*i,b=a<it,l=d<it;b&&(a=-a),l&&(d=-d);let u=ot(Math.ceil(Vt(n)/2))+Lt;if(a<it||a>=u||d<it||d>=u)throw new Error("splitScalar (endomorphism): failed, k="+t);return{k1neg:b,k1:a,k2neg:l,k2:d}}function Te(t){if(!["compact","recovered","der"].includes(t))throw new Error('Signature format must be "compact", "recovered", or "der"');return t}function He(t,e){let n={};for(let r of Object.keys(e))n[r]=t[r]===void 0?e[r]:t[r];return Kt(n.lowS,"lowS"),Kt(n.prehash,"prehash"),n.format!==void 0&&Te(n.format),n}var Le=class extends Error{constructor(e=""){super(e)}},st={Err:Le,_tlv:{encode:(t,e)=>{let{Err:n}=st;if(t<0||t>256)throw new n("tlv.encode: wrong tag");if(e.length&1)throw new n("tlv.encode: unpadded data");let r=e.length/2,o=Ot(r);if(o.length/2&128)throw new n("tlv.encode: long form length too big");let s=r>127?Ot(o.length/2|128):"";return Ot(t)+s+o+e},decode(t,e){let{Err:n}=st,r=0;if(t<0||t>256)throw new n("tlv.encode: wrong tag");if(e.length<2||e[r++]!==t)throw new n("tlv.decode: wrong tlv");let o=e[r++],s=!!(o&128),i=0;if(!s)i=o;else{let f=o&127;if(!f)throw new n("tlv.decode(long): indefinite length not supported");if(f>4)throw new n("tlv.decode(long): byte length is too big");let a=e.subarray(r,r+f);if(a.length!==f)throw new n("tlv.decode: length bytes not complete");if(a[0]===0)throw new n("tlv.decode(long): zero leftmost byte");for(let d of a)i=i<<8|d;if(r+=f,i<128)throw new n("tlv.decode(long): not minimal encoding")}let c=e.subarray(r,r+i);if(c.length!==i)throw new n("tlv.decode: wrong value length");return{v:c,l:e.subarray(r+i)}}},_int:{encode(t){let{Err:e}=st;if(t<it)throw new e("integer: negative integers are not allowed");let n=Ot(t);if(Number.parseInt(n[0],16)&8&&(n="00"+n),n.length&1)throw new e("unexpected DER parsing assertion: unpadded hex");return n},decode(t){let{Err:e}=st;if(t[0]&128)throw new e("invalid signature integer: negative");if(t[0]===0&&!(t[1]&128))throw new e("invalid signature integer: unnecessary leading zero");return F(t)}},toSig(t){let{Err:e,_int:n,_tlv:r}=st,o=k("signature",t),{v:s,l:i}=r.decode(48,o);if(i.length)throw new e("invalid signature: left bytes after parsing");let{v:c,l:f}=r.decode(2,s),{v:a,l:d}=r.decode(2,f);if(d.length)throw new e("invalid signature: left bytes after parsing");return{r:n.decode(c),s:n.decode(a)}},hexFromSig(t){let{_tlv:e,_int:n}=st,r=e.encode(2,n.encode(t.r)),o=e.encode(2,n.encode(t.s)),s=r+o;return e.encode(48,s)}},it=BigInt(0),Lt=BigInt(1),Er=BigInt(2),fe=BigInt(3),gn=BigInt(4);function ht(t,e){let{BYTES:n}=t,r;if(typeof e=="bigint")r=e;else{let o=k("private key",e);try{r=t.fromBytes(o)}catch{throw new Error(`invalid private key: expected ui8a of size ${n}, got ${typeof e}`)}}if(!t.isValidNot0(r))throw new Error("invalid private key: out of range [1..N-1]");return r}function mn(t,e={}){let n=xr("weierstrass",t,e),{Fp:r,Fn:o}=n,s=n.CURVE,{h:i,n:c}=s;Pt(e,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object",wrapPrivateKey:"boolean"});let{endo:f}=e;if(f&&(!r.is0(s.a)||typeof f.beta!="bigint"||!Array.isArray(f.basises)))throw new Error('invalid endo: expected "beta": bigint and "basises": array');let a=vr(r,o);function d(){if(!r.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function b(H,p,y){let{x:h,y:g}=p.toAffine(),w=r.toBytes(h);if(Kt(y,"isCompressed"),y){d();let v=!r.isOdd(g);return P(Br(v),w)}else return P(Uint8Array.of(4),w,r.toBytes(g))}function l(H){lt(H,void 0,"Point");let{publicKey:p,publicKeyUncompressed:y}=a,h=H.length,g=H[0],w=H.subarray(1);if(h===p&&(g===2||g===3)){let v=r.fromBytes(w);if(!r.isValid(v))throw new Error("bad point: is not on curve, wrong x");let B=m(v),E;try{E=r.sqrt(B)}catch(C){let T=C instanceof Error?": "+C.message:"";throw new Error("bad point: is not on curve, sqrt error"+T)}d();let S=r.isOdd(E);return(g&1)===1!==S&&(E=r.neg(E)),{x:v,y:E}}else if(h===y&&g===4){let v=r.BYTES,B=r.fromBytes(w.subarray(0,v)),E=r.fromBytes(w.subarray(v,v*2));if(!_(B,E))throw new Error("bad point: is not on curve");return{x:B,y:E}}else throw new Error(`bad point: got length ${h}, expected compressed=${p} or uncompressed=${y}`)}let u=e.toBytes||b,x=e.fromBytes||l;function m(H){let p=r.sqr(H),y=r.mul(p,H);return r.add(r.add(y,r.mul(H,s.a)),s.b)}function _(H,p){let y=r.sqr(p),h=m(H);return r.eql(y,h)}if(!_(s.Gx,s.Gy))throw new Error("bad curve params: generator point");let L=r.mul(r.pow(s.a,fe),gn),J=r.mul(r.sqr(s.b),BigInt(27));if(r.is0(r.add(L,J)))throw new Error("bad curve params: a or b");function U(H,p,y=!1){if(!r.isValid(p)||y&&r.is0(p))throw new Error(`bad point coordinate ${H}`);return p}function Q(H){if(!(H instanceof I))throw new Error("ProjectivePoint expected")}function Z(H){if(!f||!f.basises)throw new Error("no endo");return pn(H,f.basises,o.ORDER)}let tt=ne((H,p)=>{let{X:y,Y:h,Z:g}=H;if(r.eql(g,r.ONE))return{x:y,y:h};let w=H.is0();p==null&&(p=w?r.ONE:r.inv(g));let v=r.mul(y,p),B=r.mul(h,p),E=r.mul(g,p);if(w)return{x:r.ZERO,y:r.ZERO};if(!r.eql(E,r.ONE))throw new Error("invZ was invalid");return{x:v,y:B}}),Gt=ne(H=>{if(H.is0()){if(e.allowInfinityPoint&&!r.is0(H.Y))return;throw new Error("bad point: ZERO")}let{x:p,y}=H.toAffine();if(!r.isValid(p)||!r.isValid(y))throw new Error("bad point: x or y not field elements");if(!_(p,y))throw new Error("bad point: equation left != right");if(!H.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});function vt(H,p,y,h,g){return y=new I(r.mul(y.X,H),y.Y,y.Z),p=jt(h,p),y=jt(g,y),p.add(y)}class I{constructor(p,y,h){this.X=U("x",p),this.Y=U("y",y,!0),this.Z=U("z",h),Object.freeze(this)}static CURVE(){return s}static fromAffine(p){let{x:y,y:h}=p||{};if(!p||!r.isValid(y)||!r.isValid(h))throw new Error("invalid affine point");if(p instanceof I)throw new Error("projective point not allowed");return r.is0(y)&&r.is0(h)?I.ZERO:new I(y,h,r.ONE)}static fromBytes(p){let y=I.fromAffine(x(lt(p,void 0,"point")));return y.assertValidity(),y}static fromHex(p){return I.fromBytes(k("pointHex",p))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(p=8,y=!0){return yt.createCache(this,p),y||this.multiply(fe),this}assertValidity(){Gt(this)}hasEvenY(){let{y:p}=this.toAffine();if(!r.isOdd)throw new Error("Field doesn't support isOdd");return!r.isOdd(p)}equals(p){Q(p);let{X:y,Y:h,Z:g}=this,{X:w,Y:v,Z:B}=p,E=r.eql(r.mul(y,B),r.mul(w,g)),S=r.eql(r.mul(h,B),r.mul(v,g));return E&&S}negate(){return new I(this.X,r.neg(this.Y),this.Z)}double(){let{a:p,b:y}=s,h=r.mul(y,fe),{X:g,Y:w,Z:v}=this,B=r.ZERO,E=r.ZERO,S=r.ZERO,A=r.mul(g,g),C=r.mul(w,w),T=r.mul(v,v),O=r.mul(g,w);return O=r.add(O,O),S=r.mul(g,v),S=r.add(S,S),B=r.mul(p,S),E=r.mul(h,T),E=r.add(B,E),B=r.sub(C,E),E=r.add(C,E),E=r.mul(B,E),B=r.mul(O,B),S=r.mul(h,S),T=r.mul(p,T),O=r.sub(A,T),O=r.mul(p,O),O=r.add(O,S),S=r.add(A,A),A=r.add(S,A),A=r.add(A,T),A=r.mul(A,O),E=r.add(E,A),T=r.mul(w,v),T=r.add(T,T),A=r.mul(T,O),B=r.sub(B,A),S=r.mul(T,C),S=r.add(S,S),S=r.add(S,S),new I(B,E,S)}add(p){Q(p);let{X:y,Y:h,Z:g}=this,{X:w,Y:v,Z:B}=p,E=r.ZERO,S=r.ZERO,A=r.ZERO,C=s.a,T=r.mul(s.b,fe),O=r.mul(y,w),R=r.mul(h,v),q=r.mul(g,B),z=r.add(y,h),N=r.add(w,v);z=r.mul(z,N),N=r.add(O,R),z=r.sub(z,N),N=r.add(y,g);let K=r.add(w,B);return N=r.mul(N,K),K=r.add(O,q),N=r.sub(N,K),K=r.add(h,g),E=r.add(v,B),K=r.mul(K,E),E=r.add(R,q),K=r.sub(K,E),A=r.mul(C,N),E=r.mul(T,q),A=r.add(E,A),E=r.sub(R,A),A=r.add(R,A),S=r.mul(E,A),R=r.add(O,O),R=r.add(R,O),q=r.mul(C,q),N=r.mul(T,N),R=r.add(R,q),q=r.sub(O,q),q=r.mul(C,q),N=r.add(N,q),O=r.mul(R,N),S=r.add(S,O),O=r.mul(K,N),E=r.mul(z,E),E=r.sub(E,O),O=r.mul(z,R),A=r.mul(K,A),A=r.add(A,O),new I(E,S,A)}subtract(p){return this.add(p.negate())}is0(){return this.equals(I.ZERO)}multiply(p){let{endo:y}=e;if(!o.isValidNot0(p))throw new Error("invalid scalar: out of range");let h,g,w=v=>yt.cached(this,v,B=>ae(I,B));if(y){let{k1neg:v,k1:B,k2neg:E,k2:S}=Z(p),{p:A,f:C}=w(B),{p:T,f:O}=w(S);g=C.add(O),h=vt(y.beta,A,T,v,E)}else{let{p:v,f:B}=w(p);h=v,g=B}return ae(I,[h,g])[0]}multiplyUnsafe(p){let{endo:y}=e,h=this;if(!o.isValid(p))throw new Error("invalid scalar: out of range");if(p===it||h.is0())return I.ZERO;if(p===Lt)return h;if(yt.hasCache(this))return this.multiply(p);if(y){let{k1neg:g,k1:w,k2neg:v,k2:B}=Z(p),{p1:E,p2:S}=gr(I,h,w,B);return vt(y.beta,E,S,g,v)}else return yt.unsafe(h,p)}multiplyAndAddUnsafe(p,y,h){let g=this.multiplyUnsafe(y).add(p.multiplyUnsafe(h));return g.is0()?void 0:g}toAffine(p){return tt(this,p)}isTorsionFree(){let{isTorsionFree:p}=e;return i===Lt?!0:p?p(I,this):yt.unsafe(this,c).is0()}clearCofactor(){let{clearCofactor:p}=e;return i===Lt?this:p?p(I,this):this.multiplyUnsafe(i)}isSmallOrder(){return this.multiplyUnsafe(i).is0()}toBytes(p=!0){return Kt(p,"isCompressed"),this.assertValidity(),u(I,this,p)}toHex(p=!0){return Y(this.toBytes(p))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}get px(){return this.X}get py(){return this.X}get pz(){return this.Z}toRawBytes(p=!0){return this.toBytes(p)}_setWindowSize(p){this.precompute(p)}static normalizeZ(p){return ae(I,p)}static msm(p,y){return mr(I,o,p,y)}static fromPrivateKey(p){return I.BASE.multiply(ht(o,p))}}I.BASE=new I(s.Gx,s.Gy,r.ONE),I.ZERO=new I(r.ZERO,r.ONE,r.ZERO),I.Fp=r,I.Fn=o;let $t=o.BITS,yt=new ce(I,e.endo?Math.ceil($t/2):$t);return I.BASE.precompute(8),I}function Br(t){return Uint8Array.of(t?2:3)}function vr(t,e){return{secretKey:e.BYTES,publicKey:1+t.BYTES,publicKeyUncompressed:1+2*t.BYTES,publicKeyHasPrefix:!0,signature:2*e.BYTES}}function xn(t,e={}){let{Fn:n}=t,r=e.randomBytes||W,o=Object.assign(vr(t.Fp,n),{seed:Ae(n.ORDER)});function s(u){try{return!!ht(n,u)}catch{return!1}}function i(u,x){let{publicKey:m,publicKeyUncompressed:_}=o;try{let L=u.length;return x===!0&&L!==m||x===!1&&L!==_?!1:!!t.fromBytes(u)}catch{return!1}}function c(u=r(o.seed)){return ie(lt(u,o.seed,"seed"),n.ORDER)}function f(u,x=!0){return t.BASE.multiply(ht(n,u)).toBytes(x)}function a(u){let x=c(u);return{secretKey:x,publicKey:f(x)}}function d(u){if(typeof u=="bigint")return!1;if(u instanceof t)return!0;let{secretKey:x,publicKey:m,publicKeyUncompressed:_}=o;if(n.allowedLengths||x===m)return;let L=k("key",u).length;return L===m||L===_}function b(u,x,m=!0){if(d(u)===!0)throw new Error("first arg must be private key");if(d(x)===!1)throw new Error("second arg must be public key");let _=ht(n,u);return t.fromHex(x).multiply(_).toBytes(m)}return Object.freeze({getPublicKey:f,getSharedSecret:b,keygen:a,Point:t,utils:{isValidSecretKey:s,isValidPublicKey:i,randomSecretKey:c,isValidPrivateKey:s,randomPrivateKey:c,normPrivateKeyToScalar:u=>ht(n,u),precompute(u=8,x=t.BASE){return x.precompute(u,!1)}},lengths:o})}function wn(t,e,n={}){Xt(e),Pt(n,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"});let r=n.randomBytes||W,o=n.hmac||((y,...h)=>pe(e,y,P(...h))),{Fp:s,Fn:i}=t,{ORDER:c,BITS:f}=i,{keygen:a,getPublicKey:d,getSharedSecret:b,utils:l,lengths:u}=xn(t,n),x={prehash:!1,lowS:typeof n.lowS=="boolean"?n.lowS:!1,format:void 0,extraEntropy:!1},m="compact";function _(y){let h=c>>Lt;return y>h}function L(y,h){if(!i.isValidNot0(h))throw new Error(`invalid signature ${y}: out of range 1..Point.Fn.ORDER`);return h}function J(y,h){Te(h);let g=u.signature,w=h==="compact"?g:h==="recovered"?g+1:void 0;return lt(y,w,`${h} signature`)}class U{constructor(h,g,w){this.r=L("r",h),this.s=L("s",g),w!=null&&(this.recovery=w),Object.freeze(this)}static fromBytes(h,g=m){J(h,g);let w;if(g==="der"){let{r:S,s:A}=st.toSig(lt(h));return new U(S,A)}g==="recovered"&&(w=h[0],g="compact",h=h.subarray(1));let v=i.BYTES,B=h.subarray(0,v),E=h.subarray(v,v*2);return new U(i.fromBytes(B),i.fromBytes(E),w)}static fromHex(h,g){return this.fromBytes(rt(h),g)}addRecoveryBit(h){return new U(this.r,this.s,h)}recoverPublicKey(h){let g=s.ORDER,{r:w,s:v,recovery:B}=this;if(B==null||![0,1,2,3].includes(B))throw new Error("recovery id invalid");if(c*Er<g&&B>1)throw new Error("recovery id is ambiguous for h>1 curve");let S=B===2||B===3?w+c:w;if(!s.isValid(S))throw new Error("recovery id 2 or 3 invalid");let A=s.toBytes(S),C=t.fromBytes(P(Br((B&1)===0),A)),T=i.inv(S),O=Z(k("msgHash",h)),R=i.create(-O*T),q=i.create(v*T),z=t.BASE.multiplyUnsafe(R).add(C.multiplyUnsafe(q));if(z.is0())throw new Error("point at infinify");return z.assertValidity(),z}hasHighS(){return _(this.s)}toBytes(h=m){if(Te(h),h==="der")return rt(st.hexFromSig(this));let g=i.toBytes(this.r),w=i.toBytes(this.s);if(h==="recovered"){if(this.recovery==null)throw new Error("recovery bit must be present");return P(Uint8Array.of(this.recovery),g,w)}return P(g,w)}toHex(h){return Y(this.toBytes(h))}assertValidity(){}static fromCompact(h){return U.fromBytes(k("sig",h),"compact")}static fromDER(h){return U.fromBytes(k("sig",h),"der")}normalizeS(){return this.hasHighS()?new U(this.r,i.neg(this.s),this.recovery):this}toDERRawBytes(){return this.toBytes("der")}toDERHex(){return Y(this.toBytes("der"))}toCompactRawBytes(){return this.toBytes("compact")}toCompactHex(){return Y(this.toBytes("compact"))}}let Q=n.bits2int||function(h){if(h.length>8192)throw new Error("input is too large");let g=F(h),w=h.length*8-f;return w>0?g>>BigInt(w):g},Z=n.bits2int_modN||function(h){return i.create(Q(h))},tt=ot(f);function Gt(y){return Ee("num < 2^"+f,y,it,tt),i.toBytes(y)}function vt(y,h){return lt(y,void 0,"message"),h?lt(e(y),void 0,"prehashed message"):y}function I(y,h,g){if(["recovered","canonical"].some(R=>R in g))throw new Error("sign() legacy options not supported");let{lowS:w,prehash:v,extraEntropy:B}=He(g,x);y=vt(y,v);let E=Z(y),S=ht(i,h),A=[Gt(S),Gt(E)];if(B!=null&&B!==!1){let R=B===!0?r(u.secretKey):B;A.push(k("extraEntropy",R))}let C=P(...A),T=E;function O(R){let q=Q(R);if(!i.isValidNot0(q))return;let z=i.inv(q),N=t.BASE.multiply(q).toAffine(),K=i.create(N.x);if(K===it)return;let Yt=i.create(z*i.create(T+K*S));if(Yt===it)return;let Ze=(N.x===K?0:2)|Number(N.y&Lt),Ge=Yt;return w&&_(Yt)&&(Ge=i.neg(Yt),Ze^=1),new U(K,Ge,Ze)}return{seed:C,k2sig:O}}function $t(y,h,g={}){y=k("message",y);let{seed:w,k2sig:v}=I(y,h,g);return Be(e.outputLen,i.BYTES,o)(w,v)}function yt(y){let h,g=typeof y=="string"||ft(y),w=!g&&y!==null&&typeof y=="object"&&typeof y.r=="bigint"&&typeof y.s=="bigint";if(!g&&!w)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");if(w)h=new U(y.r,y.s);else if(g){try{h=U.fromBytes(k("sig",y),"der")}catch(v){if(!(v instanceof st.Err))throw v}if(!h)try{h=U.fromBytes(k("sig",y),"compact")}catch{return!1}}return h||!1}function H(y,h,g,w={}){let{lowS:v,prehash:B,format:E}=He(w,x);if(g=k("publicKey",g),h=vt(k("message",h),B),"strict"in w)throw new Error("options.strict was renamed to lowS");let S=E===void 0?yt(y):U.fromBytes(k("sig",y),E);if(S===!1)return!1;try{let A=t.fromBytes(g);if(v&&S.hasHighS())return!1;let{r:C,s:T}=S,O=Z(h),R=i.inv(T),q=i.create(O*R),z=i.create(C*R),N=t.BASE.multiplyUnsafe(q).add(A.multiplyUnsafe(z));return N.is0()?!1:i.create(N.x)===C}catch{return!1}}function p(y,h,g={}){let{prehash:w}=He(g,x);return h=vt(h,w),U.fromBytes(y,"recovered").recoverPublicKey(h).toBytes()}return Object.freeze({keygen:a,getPublicKey:d,getSharedSecret:b,utils:l,lengths:u,Point:t,sign:$t,verify:H,recoverPublicKey:p,Signature:U,hash:e})}function En(t){let e={a:t.a,b:t.b,p:t.Fp.ORDER,n:t.n,h:t.h,Gx:t.Gx,Gy:t.Gy},n=t.Fp,r=t.allowedPrivateKeyLengths?Array.from(new Set(t.allowedPrivateKeyLengths.map(i=>Math.ceil(i/2)))):void 0,o=dt(e.n,{BITS:t.nBitLength,allowedLengths:r,modFromBytes:t.wrapPrivateKey}),s={Fp:n,Fn:o,allowInfinityPoint:t.allowInfinityPoint,endo:t.endo,isTorsionFree:t.isTorsionFree,clearCofactor:t.clearCofactor,fromBytes:t.fromBytes,toBytes:t.toBytes};return{CURVE:e,curveOpts:s}}function Bn(t){let{CURVE:e,curveOpts:n}=En(t),r={hmac:t.hmac,randomBytes:t.randomBytes,lowS:t.lowS,bits2int:t.bits2int,bits2int_modN:t.bits2int_modN};return{CURVE:e,curveOpts:n,hash:t.hash,ecdsaOpts:r}}function vn(t,e){let n=e.Point;return Object.assign({},e,{ProjectivePoint:n,CURVE:Object.assign({},t,se(n.Fn.ORDER,n.Fn.BITS))})}function Sr(t){let{CURVE:e,curveOpts:n,hash:r,ecdsaOpts:o}=Bn(t),s=mn(e,n),i=wn(s,r,o);return vn(t,i)}function Ar(t,e){let n=r=>Sr({...t,hash:r});return{...n(e),create:n}}var Ut={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},Sn={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]},An=BigInt(0),_r=BigInt(1),Ue=BigInt(2);function _n(t){let e=Ut.p,n=BigInt(3),r=BigInt(6),o=BigInt(11),s=BigInt(22),i=BigInt(23),c=BigInt(44),f=BigInt(88),a=t*t*t%e,d=a*a*t%e,b=M(d,n,e)*d%e,l=M(b,n,e)*d%e,u=M(l,Ue,e)*a%e,x=M(u,o,e)*u%e,m=M(x,s,e)*x%e,_=M(m,c,e)*m%e,L=M(_,f,e)*_%e,J=M(L,c,e)*m%e,U=M(J,n,e)*d%e,Q=M(U,i,e)*x%e,Z=M(Q,r,e)*a%e,tt=M(Z,Ue,e);if(!ue.eql(ue.sqr(tt),t))throw new Error("Cannot find square root");return tt}var ue=dt(Ut.p,{sqrt:_n}),kt=Ar({...Ut,Fp:ue,lowS:!0,endo:Sn},It),Ir={};function le(t,...e){let n=Ir[t];if(n===void 0){let r=It(Ct(t));n=P(r,r),Ir[t]=n}return It(P(n,...e))}var Re=t=>t.toBytes(!0).slice(1),Rt=kt.Point,Ne=t=>t%Ue===An;function ke(t){let{Fn:e,BASE:n}=Rt,r=ht(e,t),o=n.multiply(r);return{scalar:Ne(o.y)?r:e.neg(r),bytes:Re(o)}}function Hr(t){let e=ue;if(!e.isValidNot0(t))throw new Error("invalid x: Fail if x \u2265 p");let n=e.create(t*t),r=e.create(n*t+BigInt(7)),o=e.sqrt(r);Ne(o)||(o=e.neg(o));let s=Rt.fromAffine({x:t,y:o});return s.assertValidity(),s}var zt=F;function Tr(...t){return Rt.Fn.create(zt(le("BIP0340/challenge",...t)))}function Or(t){return ke(t).bytes}function In(t,e,n=W(32)){let{Fn:r}=Rt,o=k("message",t),{bytes:s,scalar:i}=ke(e),c=k("auxRand",n,32),f=r.toBytes(i^zt(le("BIP0340/aux",c))),a=le("BIP0340/nonce",f,s,o),{bytes:d,scalar:b}=ke(a),l=Tr(d,s,o),u=new Uint8Array(64);if(u.set(d,0),u.set(r.toBytes(r.create(b+l*i)),32),!Lr(u,o,s))throw new Error("sign: Invalid signature produced");return u}function Lr(t,e,n){let{Fn:r,BASE:o}=Rt,s=k("signature",t,64),i=k("message",e),c=k("publicKey",n,32);try{let f=Hr(zt(c)),a=zt(s.subarray(0,32));if(!Ht(a,_r,Ut.p))return!1;let d=zt(s.subarray(32,64));if(!Ht(d,_r,Ut.n))return!1;let b=Tr(r.toBytes(a),Re(f),i),l=o.multiplyUnsafe(d).add(f.multiplyUnsafe(r.neg(b))),{x:u,y:x}=l.toAffine();return!(l.is0()||!Ne(x)||u!==a)}catch{return!1}}var bt=(()=>{let n=(o=W(48))=>ie(o,Ut.n);kt.utils.randomSecretKey;function r(o){let s=n(o);return{secretKey:s,publicKey:Or(s)}}return{keygen:r,getPublicKey:Or,sign:In,verify:Lr,Point:Rt,utils:{randomSecretKey:n,randomPrivateKey:n,taggedHash:le,lift_x:Hr,pointToBytes:Re,numberToBytesBE:mt,bytesToNumberBE:F,mod:D},lengths:{secretKey:32,publicKey:32,publicKeyHasPrefix:!1,signature:64,seed:48}}})();var Et=Y;var X=rt;var Ce=It;var Pr=Qr(Vr());var at=(0,Pr.default)({name:"nostr-crypto-utils",level:process.env.LOG_LEVEL||"info",transport:void 0,formatters:{level:t=>({level:t.toUpperCase()}),log:t=>{if(t&&typeof t=="object"&&"err"in t){let e={...t};if(e.err instanceof Error){let n=e.err;e.err={message:n.message,stack:n.stack,name:n.name}}return e}return t}}});function Zn(t){try{return!!t.match(/^[A-Za-z0-9+/]*={0,2}$/)}catch{return!1}}function je(t){return Buffer.from(t).toString("base64")}function ze(t){if(!Zn(t))throw new Error("Invalid base64 string");return new Uint8Array(Buffer.from(t,"base64"))}var $n=async()=>{if(typeof window<"u"&&window.crypto)return window.crypto;if(typeof global<"u"&&global.crypto)return global.crypto;try{let t=await Promise.resolve().then(()=>(zr(),jr));if(t.webcrypto)return t.webcrypto}catch{at.debug("Node crypto not available")}throw new Error("No WebCrypto implementation available")},De=class{constructor(){Wt(this,"cryptoInstance",null);Wt(this,"initPromise");this.initPromise=this.initialize()}async initialize(){this.cryptoInstance=await $n()}async ensureInitialized(){if(await this.initPromise,!this.cryptoInstance)throw new Error("Crypto implementation not initialized");return this.cryptoInstance}async getSubtle(){return(await this.ensureInitialized()).subtle}async getRandomValues(e){return(await this.ensureInitialized()).getRandomValues(e)}},Zt=new De,Yn=bt.sign,Wn=bt.verify;function Xn(t){return kt.getPublicKey(t,!0)}function Jn(t){return bt.getPublicKey(t)}async function Qn(){let t=W(32),e=Et(t);t.fill(0);let n=await Me(e);return{privateKey:e,publicKey:n}}async function Me(t){try{let e=X(t),n=bt.getPublicKey(e);return{hex:Et(n),bytes:n}}catch(e){throw at.error({error:e},"Failed to get public key"),e}}async function Fn(t){try{return(await Me(t.privateKey)).hex===t.publicKey.hex}catch(e){return at.error({error:e},"Failed to validate key pair"),!1}}function to(t){let e=Math.floor(Date.now()/1e3);return{...t,created_at:t.created_at||e,tags:t.tags||[],content:t.content||"",kind:t.kind||1}}async function Dr(t,e){try{let n=JSON.stringify([0,t.pubkey,t.created_at,t.kind,t.tags,t.content]),r=Ce(new TextEncoder().encode(n)),o=X(e),s=bt.sign(r,o);return{...t,id:Et(r),sig:Et(s)}}catch(n){throw at.error({error:n},"Failed to sign event"),n}}function Mr(t){let e=X(t),n=bt.getPublicKey(e);return Et(n)}async function eo(t,e){let n=t.pubkey||Mr(e),r=t.created_at||Math.floor(Date.now()/1e3),o={kind:t.kind||1,created_at:r,tags:t.tags||[],content:t.content||"",pubkey:n};return Dr(o,e)}async function ro(t){try{let e=JSON.stringify([0,t.pubkey,t.created_at,t.kind,t.tags,t.content]),n=Ce(new TextEncoder().encode(e));if(Et(n)!==t.id)return at.error("Event ID mismatch"),!1;let o=X(t.sig),s=X(t.pubkey);return bt.verify(o,n,s)}catch(e){return at.error({error:e},"Failed to verify signature"),!1}}async function no(t,e,n){try{let r=typeof e=="string"?e:e.hex,o=kt.getSharedSecret(X(n),X(r)),s=o.slice(1,33),i=W(16),c=await Zt.getSubtle().then(l=>l.importKey("raw",s.buffer,{name:"AES-CBC",length:256},!1,["encrypt"]));s.fill(0),o.fill(0);let f=new TextEncoder().encode(t),a=await Zt.getSubtle().then(l=>l.encrypt({name:"AES-CBC",iv:i},c,f.buffer)),d=je(new Uint8Array(a)),b=je(i);return d+"?iv="+b}catch(r){throw at.error({error:r},"Failed to encrypt message"),r}}async function oo(t,e,n){try{let r=typeof e=="string"?e:e.hex,o=kt.getSharedSecret(X(n),X(r)),s=o.slice(1,33),i,c;if(t.includes("?iv=")){let[d,b]=t.split("?iv=");c=ze(d),i=ze(b)}else{let d=X(t);i=d.slice(0,16),c=d.slice(16)}let f=await Zt.getSubtle().then(d=>d.importKey("raw",s.buffer,{name:"AES-CBC",length:256},!1,["decrypt"]));s.fill(0),o.fill(0);let a=await Zt.getSubtle().then(d=>d.decrypt({name:"AES-CBC",iv:i},f,c.buffer));return new TextDecoder().decode(a)}catch(r){throw at.error({error:r},"Failed to decrypt message"),r}}return Fr(so);})();
|
|
1
|
+
"use strict";var NostrCryptoUtils=NostrCryptoUtils||{};NostrCryptoUtils.Crypto=(()=>{var jn=Object.create;var Ot=Object.defineProperty;var Vn=Object.getOwnPropertyDescriptor;var Kn=Object.getOwnPropertyNames;var Pn=Object.getPrototypeOf,zn=Object.prototype.hasOwnProperty;var Zn=(t,e,r)=>e in t?Ot(t,e,{enumerable:!0,configurable:!0,writable:!0,value:r}):t[e]=r;var Mn=(t,e)=>()=>(t&&(e=t(t=0)),e);var Ne=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports),Ce=(t,e)=>{for(var r in e)Ot(t,r,{get:e[r],enumerable:!0})},qe=(t,e,r,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Kn(e))!zn.call(t,o)&&o!==r&&Ot(t,o,{get:()=>e[o],enumerable:!(n=Vn(e,o))||n.enumerable});return t};var Gn=(t,e,r)=>(r=t!=null?jn(Pn(t)):{},qe(e||!t||!t.__esModule?Ot(r,"default",{value:t,enumerable:!0}):r,t)),Yn=t=>qe(Ot({},"__esModule",{value:!0}),t);var y=(t,e,r)=>Zn(t,typeof e!="symbol"?e+"":e,r);var On=Ne((To,An)=>{"use strict";function hr(t){try{return JSON.stringify(t)}catch{return'"[Circular]"'}}An.exports=br;function br(t,e,r){var n=r&&r.stringify||hr,o=1;if(typeof t=="object"&&t!==null){var s=e.length+o;if(s===1)return t;var i=new Array(s);i[0]=n(t);for(var a=1;a<s;a++)i[a]=n(e[a]);return i.join(" ")}if(typeof t!="string")return t;var f=e.length;if(f===0)return t;for(var c="",u=1-o,l=-1,m=t&&t.length||0,b=0;b<m;){if(t.charCodeAt(b)===37&&b+1<m){switch(l=l>-1?l:0,t.charCodeAt(b+1)){case 100:case 102:if(u>=f||e[u]==null)break;l<b&&(c+=t.slice(l,b)),c+=Number(e[u]),l=b+2,b++;break;case 105:if(u>=f||e[u]==null)break;l<b&&(c+=t.slice(l,b)),c+=Math.floor(Number(e[u])),l=b+2,b++;break;case 79:case 111:case 106:if(u>=f||e[u]===void 0)break;l<b&&(c+=t.slice(l,b));var E=typeof e[u];if(E==="string"){c+="'"+e[u]+"'",l=b+2,b++;break}if(E==="function"){c+=e[u].name||"<anonymous>",l=b+2,b++;break}c+=n(e[u]),l=b+2,b++;break;case 115:if(u>=f)break;l<b&&(c+=t.slice(l,b)),c+=String(e[u]),l=b+2,b++;break;case 37:l<b&&(c+=t.slice(l,b)),c+="%",l=b+2,b++,u--;break}++u}++b}return l===-1?t:(l<m&&(c+=t.slice(l)),c)}});var Tn=Ne((ko,Ft)=>{"use strict";var In=On();Ft.exports=st;var kt=Rr().console||{},gr={mapHttpRequest:Qt,mapHttpResponse:Qt,wrapRequestSerializer:Se,wrapResponseSerializer:Se,wrapErrorSerializer:Se,req:Qt,res:Qt,err:Rn,errWithCause:Rn};function dt(t,e){return t==="silent"?1/0:e.levels.values[t]}var Ie=Symbol("pino.logFuncs"),Ae=Symbol("pino.hierarchy"),yr={error:"log",fatal:"error",warn:"error",info:"log",debug:"log",trace:"log"};function _n(t,e){let r={logger:e,parent:t[Ae]};e[Ae]=r}function mr(t,e,r){let n={};e.forEach(o=>{n[o]=r[o]?r[o]:kt[o]||kt[yr[o]||"log"]||St}),t[Ie]=n}function xr(t,e){return Array.isArray(t)?t.filter(function(n){return n!=="!stdSerializers.err"}):t===!0?Object.keys(e):!1}function st(t){t=t||{},t.browser=t.browser||{};let e=t.browser.transmit;if(e&&typeof e.send!="function")throw Error("pino: transmit option must have a send function");let r=t.browser.write||kt;t.browser.write&&(t.browser.asObject=!0);let n=t.serializers||{},o=xr(t.browser.serialize,n),s=t.browser.serialize;Array.isArray(t.browser.serialize)&&t.browser.serialize.indexOf("!stdSerializers.err")>-1&&(s=!1);let i=Object.keys(t.customLevels||{}),a=["error","fatal","warn","info","debug","trace"].concat(i);typeof r=="function"&&a.forEach(function(v){r[v]=r}),(t.enabled===!1||t.browser.disabled)&&(t.level="silent");let f=t.level||"info",c=Object.create(r);c.log||(c.log=St),mr(c,a,r),_n({},c),Object.defineProperty(c,"levelVal",{get:l}),Object.defineProperty(c,"level",{get:m,set:b});let u={transmit:e,serialize:o,asObject:t.browser.asObject,asObjectBindingsOnly:t.browser.asObjectBindingsOnly,formatters:t.browser.formatters,reportCaller:t.browser.reportCaller,levels:a,timestamp:Or(t),messageKey:t.messageKey||"msg",onChild:t.onChild||St};c.levels=pr(t),c.level=f,c.isLevelEnabled=function(v){return this.levels.values[v]?this.levels.values[v]>=this.levels.values[this.level]:!1},c.setMaxListeners=c.getMaxListeners=c.emit=c.addListener=c.on=c.prependListener=c.once=c.prependOnceListener=c.removeListener=c.removeAllListeners=c.listeners=c.listenerCount=c.eventNames=c.write=c.flush=St,c.serializers=n,c._serialize=o,c._stdErrSerialize=s,c.child=function(...v){return E.call(this,u,...v)},e&&(c._logEvent=Oe());function l(){return dt(this.level,this)}function m(){return this._level}function b(v){if(v!=="silent"&&!this.levels.values[v])throw Error("unknown level "+v);this._level=v,pt(this,u,c,"error"),pt(this,u,c,"fatal"),pt(this,u,c,"warn"),pt(this,u,c,"info"),pt(this,u,c,"debug"),pt(this,u,c,"trace"),i.forEach(B=>{pt(this,u,c,B)})}function E(v,B,H){if(!B)throw new Error("missing bindings for child Pino");H=H||{},o&&B.serializers&&(H.serializers=B.serializers);let Z=H.serializers;if(o&&Z){var Y=Object.assign({},n,Z),q=t.browser.serialize===!0?Object.keys(Y):o;delete B.serializers,_e([B],q,Y,this._stdErrSerialize)}function F(ct){this._childLevel=(ct._childLevel|0)+1,this.bindings=B,Y&&(this.serializers=Y,this._serialize=q),e&&(this._logEvent=Oe([].concat(ct._logEvent.bindings,B)))}F.prototype=this;let M=new F(this);return _n(this,M),M.child=function(...ct){return E.call(this,v,...ct)},M.level=H.level||this.level,v.onChild(M),M}return c}function pr(t){let e=t.customLevels||{},r=Object.assign({},st.levels.values,e),n=Object.assign({},st.levels.labels,wr(e));return{values:r,labels:n}}function wr(t){let e={};return Object.keys(t).forEach(function(r){e[t[r]]=r}),e}st.levels={values:{fatal:60,error:50,warn:40,info:30,debug:20,trace:10},labels:{10:"trace",20:"debug",30:"info",40:"warn",50:"error",60:"fatal"}};st.stdSerializers=gr;st.stdTimeFunctions=Object.assign({},{nullTime:Hn,epochTime:Un,unixTime:Ir,isoTime:_r});function Er(t){let e=[];t.bindings&&e.push(t.bindings);let r=t[Ae];for(;r.parent;)r=r.parent,r.logger.bindings&&e.push(r.logger.bindings);return e.reverse()}function pt(t,e,r,n){if(Object.defineProperty(t,n,{value:dt(t.level,r)>dt(n,r)?St:r[Ie][n],writable:!0,enumerable:!0,configurable:!0}),t[n]===St){if(!e.transmit)return;let s=e.transmit.level||t.level,i=dt(s,r);if(dt(n,r)<i)return}t[n]=Br(t,e,r,n);let o=Er(t);o.length!==0&&(t[n]=vr(o,t[n]))}function vr(t,e){return function(){return e.apply(this,[...t,...arguments])}}function Br(t,e,r,n){return(function(o){return function(){let i=e.timestamp(),a=new Array(arguments.length),f=Object.getPrototypeOf&&Object.getPrototypeOf(this)===kt?kt:this;for(var c=0;c<a.length;c++)a[c]=arguments[c];var u=!1;if(e.serialize&&(_e(a,this._serialize,this.serializers,this._stdErrSerialize),u=!0),e.asObject||e.formatters){let l=Sr(this,n,a,i,e);if(e.reportCaller&&l&&l.length>0&&l[0]&&typeof l[0]=="object")try{let m=Ln();m&&(l[0].caller=m)}catch{}o.call(f,...l)}else{if(e.reportCaller)try{let l=Ln();l&&a.push(l)}catch{}o.apply(f,a)}if(e.transmit){let l=e.transmit.level||t._level,m=dt(l,r),b=dt(n,r);if(b<m)return;Ar(this,{ts:i,methodLevel:n,methodValue:b,transmitLevel:l,transmitValue:r.levels.values[e.transmit.level||t._level],send:e.transmit.send,val:dt(t._level,r)},a,u)}}})(t[Ie][n])}function Sr(t,e,r,n,o){let{level:s,log:i=l=>l}=o.formatters||{},a=r.slice(),f=a[0],c={},u=(t._childLevel|0)+1;if(u<1&&(u=1),n&&(c.time=n),s){let l=s(e,t.levels.values[e]);Object.assign(c,l)}else c.level=t.levels.values[e];if(o.asObjectBindingsOnly){if(f!==null&&typeof f=="object")for(;u--&&typeof a[0]=="object";)Object.assign(c,a.shift());return[i(c),...a]}else{if(f!==null&&typeof f=="object"){for(;u--&&typeof a[0]=="object";)Object.assign(c,a.shift());f=a.length?In(a.shift(),a):void 0}else typeof f=="string"&&(f=In(a.shift(),a));return f!==void 0&&(c[o.messageKey]=f),[i(c)]}}function _e(t,e,r,n){for(let o in t)if(n&&t[o]instanceof Error)t[o]=st.stdSerializers.err(t[o]);else if(typeof t[o]=="object"&&!Array.isArray(t[o])&&e)for(let s in t[o])e.indexOf(s)>-1&&s in r&&(t[o][s]=r[s](t[o][s]))}function Ar(t,e,r,n=!1){let o=e.send,s=e.ts,i=e.methodLevel,a=e.methodValue,f=e.val,c=t._logEvent.bindings;n||_e(r,t._serialize||Object.keys(t.serializers),t.serializers,t._stdErrSerialize===void 0?!0:t._stdErrSerialize),t._logEvent.ts=s,t._logEvent.messages=r.filter(function(u){return c.indexOf(u)===-1}),t._logEvent.level.label=i,t._logEvent.level.value=a,o(i,t._logEvent,f),t._logEvent=Oe(c)}function Oe(t){return{ts:0,messages:[],bindings:t||[],level:{label:"",value:0}}}function Rn(t){let e={type:t.constructor.name,msg:t.message,stack:t.stack};for(let r in t)e[r]===void 0&&(e[r]=t[r]);return e}function Or(t){return typeof t.timestamp=="function"?t.timestamp:t.timestamp===!1?Hn:Un}function Qt(){return{}}function Se(t){return t}function St(){}function Hn(){return!1}function Un(){return Date.now()}function Ir(){return Math.round(Date.now()/1e3)}function _r(){return new Date(Date.now()).toISOString()}function Rr(){function t(e){return typeof e<"u"&&e}try{return typeof globalThis<"u"||Object.defineProperty(Object.prototype,"globalThis",{get:function(){return delete Object.prototype.globalThis,this.globalThis=this},configurable:!0}),globalThis}catch{return t(self)||t(window)||t(this)||{}}}Ft.exports.default=st;Ft.exports.pino=st;function Ln(){let t=new Error().stack;if(!t)return null;let e=t.split(`
|
|
2
|
+
`);for(let r=1;r<e.length;r++){let n=e[r].trim();if(/(^at\s+)?(createWrap|LOG|set\s*\(|asObject|Object\.apply|Function\.apply)/.test(n)||n.indexOf("browser.js")!==-1||n.indexOf("node:internal")!==-1||n.indexOf("node_modules")!==-1)continue;let o=n.match(/\((.*?):(\d+):(\d+)\)/);if(o||(o=n.match(/at\s+(.*?):(\d+):(\d+)/)),o){let s=o[1],i=o[2],a=o[3];return s+":"+i+":"+a}}return null}});var Nn={};Ce(Nn,{default:()=>Hr});var Hr,Cn=Mn(()=>{Hr={}});var Mr={};Ce(Mr,{createEvent:()=>jr,customCrypto:()=>Nt,decrypt:()=>Zr,encrypt:()=>zr,finalizeEvent:()=>Kr,generateKeyPair:()=>qr,getCompressedPublicKey:()=>Nr,getPublicKey:()=>Ue,getPublicKeySync:()=>Dn,getSchnorrPublicKey:()=>Cr,signEvent:()=>qn,signSchnorr:()=>Tr,validateKeyPair:()=>Dr,verifySchnorrSignature:()=>kr,verifySignature:()=>Pr});function It(t){return t instanceof Uint8Array||ArrayBuffer.isView(t)&&t.constructor.name==="Uint8Array"}function tt(t,e=""){if(!Number.isSafeInteger(t)||t<0){let r=e&&`"${e}" `;throw new Error(`${r}expected integer >= 0, got ${t}`)}}function R(t,e,r=""){let n=It(t),o=t?.length,s=e!==void 0;if(!n||s&&o!==e){let i=r&&`"${r}" `,a=s?` of length ${e}`:"",f=n?`length=${o}`:`type=${typeof t}`;throw new Error(i+"expected Uint8Array"+a+", got "+f)}return t}function qt(t){if(typeof t!="function"||typeof t.create!="function")throw new Error("Hash must wrapped by utils.createHasher");tt(t.outputLen),tt(t.blockLen)}function wt(t,e=!0){if(t.destroyed)throw new Error("Hash instance has been destroyed");if(e&&t.finished)throw new Error("Hash#digest() has already been called")}function je(t,e){R(t,void 0,"digestInto() output");let r=e.outputLen;if(t.length<r)throw new Error('"digestInto() output" expected to be of length >='+r)}function bt(...t){for(let e=0;e<t.length;e++)t[e].fill(0)}function Dt(t){return new DataView(t.buffer,t.byteOffset,t.byteLength)}function J(t,e){return t<<32-e|t>>>e}var Ve=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",$n=Array.from({length:256},(t,e)=>e.toString(16).padStart(2,"0"));function P(t){if(R(t),Ve)return t.toHex();let e="";for(let r=0;r<t.length;r++)e+=$n[t[r]];return e}var nt={_0:48,_9:57,A:65,F:70,a:97,f:102};function De(t){if(t>=nt._0&&t<=nt._9)return t-nt._0;if(t>=nt.A&&t<=nt.F)return t-(nt.A-10);if(t>=nt.a&&t<=nt.f)return t-(nt.a-10)}function C(t){if(typeof t!="string")throw new Error("hex string expected, got "+typeof t);if(Ve)return Uint8Array.fromHex(t);let e=t.length,r=e/2;if(e%2)throw new Error("hex string expected, got unpadded hex of length "+e);let n=new Uint8Array(r);for(let o=0,s=0;o<r;o++,s+=2){let i=De(t.charCodeAt(s)),a=De(t.charCodeAt(s+1));if(i===void 0||a===void 0){let f=t[s]+t[s+1];throw new Error('hex string expected, got non-hex character "'+f+'" at index '+s)}n[o]=i*16+a}return n}function G(...t){let e=0;for(let n=0;n<t.length;n++){let o=t[n];R(o),e+=o.length}let r=new Uint8Array(e);for(let n=0,o=0;n<t.length;n++){let s=t[n];r.set(s,o),o+=s.length}return r}function Ke(t,e={}){let r=(o,s)=>t(s).update(o).digest(),n=t(void 0);return r.outputLen=n.outputLen,r.blockLen=n.blockLen,r.create=o=>t(o),Object.assign(r,e),Object.freeze(r)}function et(t=32){let e=typeof globalThis=="object"?globalThis.crypto:null;if(typeof e?.getRandomValues!="function")throw new Error("crypto.getRandomValues must be defined");return e.getRandomValues(new Uint8Array(t))}var Pe=t=>({oid:Uint8Array.from([6,9,96,134,72,1,101,3,4,2,t])});function ze(t,e,r){return t&e^~t&r}function Ze(t,e,r){return t&e^t&r^e&r}var jt=class{constructor(e,r,n,o){y(this,"blockLen");y(this,"outputLen");y(this,"padOffset");y(this,"isLE");y(this,"buffer");y(this,"view");y(this,"finished",!1);y(this,"length",0);y(this,"pos",0);y(this,"destroyed",!1);this.blockLen=e,this.outputLen=r,this.padOffset=n,this.isLE=o,this.buffer=new Uint8Array(e),this.view=Dt(this.buffer)}update(e){wt(this),R(e);let{view:r,buffer:n,blockLen:o}=this,s=e.length;for(let i=0;i<s;){let a=Math.min(o-this.pos,s-i);if(a===o){let f=Dt(e);for(;o<=s-i;i+=o)this.process(f,i);continue}n.set(e.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===o&&(this.process(r,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){wt(this),je(e,this),this.finished=!0;let{buffer:r,view:n,blockLen:o,isLE:s}=this,{pos:i}=this;r[i++]=128,bt(this.buffer.subarray(i)),this.padOffset>o-i&&(this.process(n,0),i=0);for(let l=i;l<o;l++)r[l]=0;n.setBigUint64(o-8,BigInt(this.length*8),s),this.process(n,0);let a=Dt(e),f=this.outputLen;if(f%4)throw new Error("_sha2: outputLen must be aligned to 32bit");let c=f/4,u=this.get();if(c>u.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<c;l++)a.setUint32(4*l,u[l],s)}digest(){let{buffer:e,outputLen:r}=this;this.digestInto(e);let n=e.slice(0,r);return this.destroy(),n}_cloneInto(e){e||(e=new this.constructor),e.set(...this.get());let{blockLen:r,buffer:n,length:o,finished:s,destroyed:i,pos:a}=this;return e.destroyed=i,e.finished=s,e.length=o,e.pos=a,o%r&&e.buffer.set(n),e}clone(){return this._cloneInto()}},rt=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var Wn=Uint32Array.from([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),at=new Uint32Array(64),te=class extends jt{constructor(e){super(64,e,8,!1)}get(){let{A:e,B:r,C:n,D:o,E:s,F:i,G:a,H:f}=this;return[e,r,n,o,s,i,a,f]}set(e,r,n,o,s,i,a,f){this.A=e|0,this.B=r|0,this.C=n|0,this.D=o|0,this.E=s|0,this.F=i|0,this.G=a|0,this.H=f|0}process(e,r){for(let l=0;l<16;l++,r+=4)at[l]=e.getUint32(r,!1);for(let l=16;l<64;l++){let m=at[l-15],b=at[l-2],E=J(m,7)^J(m,18)^m>>>3,v=J(b,17)^J(b,19)^b>>>10;at[l]=v+at[l-7]+E+at[l-16]|0}let{A:n,B:o,C:s,D:i,E:a,F:f,G:c,H:u}=this;for(let l=0;l<64;l++){let m=J(a,6)^J(a,11)^J(a,25),b=u+m+ze(a,f,c)+Wn[l]+at[l]|0,v=(J(n,2)^J(n,13)^J(n,22))+Ze(n,o,s)|0;u=c,c=f,f=a,a=i+b|0,i=s,s=o,o=n,n=b+v|0}n=n+this.A|0,o=o+this.B|0,s=s+this.C|0,i=i+this.D|0,a=a+this.E|0,f=f+this.F|0,c=c+this.G|0,u=u+this.H|0,this.set(n,o,s,i,a,f,c,u)}roundClean(){bt(at)}destroy(){this.set(0,0,0,0,0,0,0,0),bt(this.buffer)}},ee=class extends te{constructor(){super(32);y(this,"A",rt[0]|0);y(this,"B",rt[1]|0);y(this,"C",rt[2]|0);y(this,"D",rt[3]|0);y(this,"E",rt[4]|0);y(this,"F",rt[5]|0);y(this,"G",rt[6]|0);y(this,"H",rt[7]|0)}};var gt=Ke(()=>new ee,Pe(1));var re=BigInt(0),ne=BigInt(1);function _t(t,e=""){if(typeof t!="boolean"){let r=e&&`"${e}" `;throw new Error(r+"expected boolean, got type="+typeof t)}return t}function Me(t){if(typeof t=="bigint"){if(!Vt(t))throw new Error("positive bigint expected, got "+t)}else tt(t);return t}function Rt(t){let e=Me(t).toString(16);return e.length&1?"0"+e:e}function Ge(t){if(typeof t!="string")throw new Error("hex string expected, got "+typeof t);return t===""?re:BigInt("0x"+t)}function ft(t){return Ge(P(t))}function oe(t){return Ge(P(Xn(R(t)).reverse()))}function Kt(t,e){tt(e),t=Me(t);let r=C(t.toString(16).padStart(e*2,"0"));if(r.length!==e)throw new Error("number too large");return r}function se(t,e){return Kt(t,e).reverse()}function Xn(t){return Uint8Array.from(t)}function Ye(t){return Uint8Array.from(t,(e,r)=>{let n=e.charCodeAt(0);if(e.length!==1||n>127)throw new Error(`string contains non-ASCII character "${t[r]}" with code ${n} at position ${r}`);return n})}var Vt=t=>typeof t=="bigint"&&re<=t;function Jn(t,e,r){return Vt(t)&&Vt(e)&&Vt(r)&&e<=t&&t<r}function $e(t,e,r,n){if(!Jn(e,r,n))throw new Error("expected valid "+t+": "+r+" <= n < "+n+", got "+e)}function ie(t){let e;for(e=0;t>re;t>>=ne,e+=1);return e}var Lt=t=>(ne<<BigInt(t))-ne;function We(t,e,r){if(tt(t,"hashLen"),tt(e,"qByteLen"),typeof r!="function")throw new Error("hmacFn must be a function");let n=B=>new Uint8Array(B),o=Uint8Array.of(),s=Uint8Array.of(0),i=Uint8Array.of(1),a=1e3,f=n(t),c=n(t),u=0,l=()=>{f.fill(1),c.fill(0),u=0},m=(...B)=>r(c,G(f,...B)),b=(B=o)=>{c=m(s,B),f=m(),B.length!==0&&(c=m(i,B),f=m())},E=()=>{if(u++>=a)throw new Error("drbg: tried max amount of iterations");let B=0,H=[];for(;B<e;){f=m();let Z=f.slice();H.push(Z),B+=f.length}return G(...H)};return(B,H)=>{l(),b(B);let Z;for(;!(Z=H(E()));)b();return l(),Z}}function Ht(t,e={},r={}){if(!t||typeof t!="object")throw new Error("expected valid options object");function n(s,i,a){let f=t[s];if(a&&f===void 0)return;let c=typeof f;if(c!==i||f===null)throw new Error(`param "${s}" is invalid: expected ${i}, got ${c}`)}let o=(s,i)=>Object.entries(s).forEach(([a,f])=>n(a,f,i));o(e,!1),o(r,!0)}function ce(t){let e=new WeakMap;return(r,...n)=>{let o=e.get(r);if(o!==void 0)return o;let s=t(r,...n);return e.set(r,s),s}}var z=BigInt(0),j=BigInt(1),yt=BigInt(2),Qe=BigInt(3),Fe=BigInt(4),tn=BigInt(5),Qn=BigInt(7),en=BigInt(8),Fn=BigInt(9),nn=BigInt(16);function Q(t,e){let r=t%e;return r>=z?r:e+r}function W(t,e,r){let n=t;for(;e-- >z;)n*=n,n%=r;return n}function Xe(t,e){if(t===z)throw new Error("invert: expected non-zero number");if(e<=z)throw new Error("invert: expected positive modulus, got "+e);let r=Q(t,e),n=e,o=z,s=j,i=j,a=z;for(;r!==z;){let c=n/r,u=n%r,l=o-i*c,m=s-a*c;n=r,r=u,o=i,s=a,i=l,a=m}if(n!==j)throw new Error("invert: does not exist");return Q(o,e)}function fe(t,e,r){if(!t.eql(t.sqr(e),r))throw new Error("Cannot find square root")}function rn(t,e){let r=(t.ORDER+j)/Fe,n=t.pow(e,r);return fe(t,n,e),n}function tr(t,e){let r=(t.ORDER-tn)/en,n=t.mul(e,yt),o=t.pow(n,r),s=t.mul(e,o),i=t.mul(t.mul(s,yt),o),a=t.mul(s,t.sub(i,t.ONE));return fe(t,a,e),a}function er(t){let e=Et(t),r=on(t),n=r(e,e.neg(e.ONE)),o=r(e,n),s=r(e,e.neg(n)),i=(t+Qn)/nn;return(a,f)=>{let c=a.pow(f,i),u=a.mul(c,n),l=a.mul(c,o),m=a.mul(c,s),b=a.eql(a.sqr(u),f),E=a.eql(a.sqr(l),f);c=a.cmov(c,u,b),u=a.cmov(m,l,E);let v=a.eql(a.sqr(u),f),B=a.cmov(c,u,v);return fe(a,B,f),B}}function on(t){if(t<Qe)throw new Error("sqrt is not defined for small field");let e=t-j,r=0;for(;e%yt===z;)e/=yt,r++;let n=yt,o=Et(t);for(;Je(o,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(r===1)return rn;let s=o.pow(n,e),i=(e+j)/yt;return function(f,c){if(f.is0(c))return c;if(Je(f,c)!==1)throw new Error("Cannot find square root");let u=r,l=f.mul(f.ONE,s),m=f.pow(c,e),b=f.pow(c,i);for(;!f.eql(m,f.ONE);){if(f.is0(m))return f.ZERO;let E=1,v=f.sqr(m);for(;!f.eql(v,f.ONE);)if(E++,v=f.sqr(v),E===u)throw new Error("Cannot find square root");let B=j<<BigInt(u-E-1),H=f.pow(l,B);u=E,l=f.sqr(H),m=f.mul(m,l),b=f.mul(b,H)}return b}}function nr(t){return t%Fe===Qe?rn:t%en===tn?tr:t%nn===Fn?er(t):on(t)}var rr=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function le(t){let e={ORDER:"bigint",BYTES:"number",BITS:"number"},r=rr.reduce((n,o)=>(n[o]="function",n),e);return Ht(t,r),t}function or(t,e,r){if(r<z)throw new Error("invalid exponent, negatives unsupported");if(r===z)return t.ONE;if(r===j)return e;let n=t.ONE,o=e;for(;r>z;)r&j&&(n=t.mul(n,o)),o=t.sqr(o),r>>=j;return n}function Pt(t,e,r=!1){let n=new Array(e.length).fill(r?t.ZERO:void 0),o=e.reduce((i,a,f)=>t.is0(a)?i:(n[f]=i,t.mul(i,a)),t.ONE),s=t.inv(o);return e.reduceRight((i,a,f)=>t.is0(a)?i:(n[f]=t.mul(i,n[f]),t.mul(i,a)),s),n}function Je(t,e){let r=(t.ORDER-j)/yt,n=t.pow(e,r),o=t.eql(n,t.ONE),s=t.eql(n,t.ZERO),i=t.eql(n,t.neg(t.ONE));if(!o&&!s&&!i)throw new Error("invalid Legendre symbol result");return o?1:s?0:-1}function sr(t,e){e!==void 0&&tt(e);let r=e!==void 0?e:t.toString(2).length,n=Math.ceil(r/8);return{nBitLength:r,nByteLength:n}}var ae=class{constructor(e,r={}){y(this,"ORDER");y(this,"BITS");y(this,"BYTES");y(this,"isLE");y(this,"ZERO",z);y(this,"ONE",j);y(this,"_lengths");y(this,"_sqrt");y(this,"_mod");if(e<=z)throw new Error("invalid field: expected ORDER > 0, got "+e);let n;this.isLE=!1,r!=null&&typeof r=="object"&&(typeof r.BITS=="number"&&(n=r.BITS),typeof r.sqrt=="function"&&(this.sqrt=r.sqrt),typeof r.isLE=="boolean"&&(this.isLE=r.isLE),r.allowedLengths&&(this._lengths=r.allowedLengths?.slice()),typeof r.modFromBytes=="boolean"&&(this._mod=r.modFromBytes));let{nBitLength:o,nByteLength:s}=sr(e,n);if(s>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");this.ORDER=e,this.BITS=o,this.BYTES=s,this._sqrt=void 0,Object.preventExtensions(this)}create(e){return Q(e,this.ORDER)}isValid(e){if(typeof e!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof e);return z<=e&&e<this.ORDER}is0(e){return e===z}isValidNot0(e){return!this.is0(e)&&this.isValid(e)}isOdd(e){return(e&j)===j}neg(e){return Q(-e,this.ORDER)}eql(e,r){return e===r}sqr(e){return Q(e*e,this.ORDER)}add(e,r){return Q(e+r,this.ORDER)}sub(e,r){return Q(e-r,this.ORDER)}mul(e,r){return Q(e*r,this.ORDER)}pow(e,r){return or(this,e,r)}div(e,r){return Q(e*Xe(r,this.ORDER),this.ORDER)}sqrN(e){return e*e}addN(e,r){return e+r}subN(e,r){return e-r}mulN(e,r){return e*r}inv(e){return Xe(e,this.ORDER)}sqrt(e){return this._sqrt||(this._sqrt=nr(this.ORDER)),this._sqrt(this,e)}toBytes(e){return this.isLE?se(e,this.BYTES):Kt(e,this.BYTES)}fromBytes(e,r=!1){R(e);let{_lengths:n,BYTES:o,isLE:s,ORDER:i,_mod:a}=this;if(n){if(!n.includes(e.length)||e.length>o)throw new Error("Field.fromBytes: expected "+n+" bytes, got "+e.length);let c=new Uint8Array(o);c.set(e,s?0:c.length-e.length),e=c}if(e.length!==o)throw new Error("Field.fromBytes: expected "+o+" bytes, got "+e.length);let f=s?oe(e):ft(e);if(a&&(f=Q(f,i)),!r&&!this.isValid(f))throw new Error("invalid field element: outside of range 0..ORDER");return f}invertBatch(e){return Pt(this,e)}cmov(e,r,n){return n?r:e}};function Et(t,e={}){return new ae(t,e)}function sn(t){if(typeof t!="bigint")throw new Error("field order must be bigint");let e=t.toString(2).length;return Math.ceil(e/8)}function ue(t){let e=sn(t);return e+Math.ceil(e/2)}function zt(t,e,r=!1){R(t);let n=t.length,o=sn(e),s=ue(e);if(n<16||n<s||n>1024)throw new Error("expected "+s+"-1024 bytes of input, got "+n);let i=r?oe(t):ft(t),a=Q(i,e-j)+j;return r?se(a,o):Kt(a,o)}var vt=BigInt(0),mt=BigInt(1);function Ut(t,e){let r=e.negate();return t?r:e}function ge(t,e){let r=Pt(t.Fp,e.map(n=>n.Z));return e.map((n,o)=>t.fromAffine(n.toAffine(r[o])))}function ln(t,e){if(!Number.isSafeInteger(t)||t<=0||t>e)throw new Error("invalid window size, expected [1.."+e+"], got W="+t)}function de(t,e){ln(t,e);let r=Math.ceil(e/t)+1,n=2**(t-1),o=2**t,s=Lt(t),i=BigInt(t);return{windows:r,windowSize:n,mask:s,maxNumber:o,shiftBy:i}}function cn(t,e,r){let{windowSize:n,mask:o,maxNumber:s,shiftBy:i}=r,a=Number(t&o),f=t>>i;a>n&&(a-=s,f+=mt);let c=e*n,u=c+Math.abs(a)-1,l=a===0,m=a<0,b=e%2!==0;return{nextN:f,offset:u,isZero:l,isNeg:m,isNegF:b,offsetF:c}}var he=new WeakMap,un=new WeakMap;function be(t){return un.get(t)||1}function an(t){if(t!==vt)throw new Error("invalid wNAF")}var Zt=class{constructor(e,r){y(this,"BASE");y(this,"ZERO");y(this,"Fn");y(this,"bits");this.BASE=e.BASE,this.ZERO=e.ZERO,this.Fn=e.Fn,this.bits=r}_unsafeLadder(e,r,n=this.ZERO){let o=e;for(;r>vt;)r&mt&&(n=n.add(o)),o=o.double(),r>>=mt;return n}precomputeWindow(e,r){let{windows:n,windowSize:o}=de(r,this.bits),s=[],i=e,a=i;for(let f=0;f<n;f++){a=i,s.push(a);for(let c=1;c<o;c++)a=a.add(i),s.push(a);i=a.double()}return s}wNAF(e,r,n){if(!this.Fn.isValid(n))throw new Error("invalid scalar");let o=this.ZERO,s=this.BASE,i=de(e,this.bits);for(let a=0;a<i.windows;a++){let{nextN:f,offset:c,isZero:u,isNeg:l,isNegF:m,offsetF:b}=cn(n,a,i);n=f,u?s=s.add(Ut(m,r[b])):o=o.add(Ut(l,r[c]))}return an(n),{p:o,f:s}}wNAFUnsafe(e,r,n,o=this.ZERO){let s=de(e,this.bits);for(let i=0;i<s.windows&&n!==vt;i++){let{nextN:a,offset:f,isZero:c,isNeg:u}=cn(n,i,s);if(n=a,!c){let l=r[f];o=o.add(u?l.negate():l)}}return an(n),o}getPrecomputes(e,r,n){let o=he.get(r);return o||(o=this.precomputeWindow(r,e),e!==1&&(typeof n=="function"&&(o=n(o)),he.set(r,o))),o}cached(e,r,n){let o=be(e);return this.wNAF(o,this.getPrecomputes(o,e,n),r)}unsafe(e,r,n,o){let s=be(e);return s===1?this._unsafeLadder(e,r,o):this.wNAFUnsafe(s,this.getPrecomputes(s,e,n),r,o)}createCache(e,r){ln(r,this.bits),un.set(e,r),he.delete(e)}hasCache(e){return be(e)!==1}};function dn(t,e,r,n){let o=e,s=t.ZERO,i=t.ZERO;for(;r>vt||n>vt;)r&mt&&(s=s.add(o)),n&mt&&(i=i.add(o)),o=o.double(),r>>=mt,n>>=mt;return{p1:s,p2:i}}function fn(t,e,r){if(e){if(e.ORDER!==t)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return le(e),e}else return Et(t,{isLE:r})}function hn(t,e,r={},n){if(n===void 0&&(n=t==="edwards"),!e||typeof e!="object")throw new Error(`expected valid ${t} CURVE object`);for(let f of["p","n","h"]){let c=e[f];if(!(typeof c=="bigint"&&c>vt))throw new Error(`CURVE.${f} must be positive bigint`)}let o=fn(e.p,r.Fp,n),s=fn(e.n,r.Fn,n),a=["Gx","Gy","a",t==="weierstrass"?"b":"d"];for(let f of a)if(!o.isValid(e[f]))throw new Error(`CURVE.${f} must be valid field element of CURVE.Fp`);return e=Object.freeze(Object.assign({},e)),{CURVE:e,Fp:o,Fn:s}}function Mt(t,e){return function(n){let o=t(n);return{secretKey:o,publicKey:e(o)}}}var Gt=class{constructor(e,r){y(this,"oHash");y(this,"iHash");y(this,"blockLen");y(this,"outputLen");y(this,"finished",!1);y(this,"destroyed",!1);if(qt(e),R(r,void 0,"key"),this.iHash=e.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let n=this.blockLen,o=new Uint8Array(n);o.set(r.length>n?e.create().update(r).digest():r);for(let s=0;s<o.length;s++)o[s]^=54;this.iHash.update(o),this.oHash=e.create();for(let s=0;s<o.length;s++)o[s]^=106;this.oHash.update(o),bt(o)}update(e){return wt(this),this.iHash.update(e),this}digestInto(e){wt(this),R(e,this.outputLen,"output"),this.finished=!0,this.iHash.digestInto(e),this.oHash.update(e),this.oHash.digestInto(e),this.destroy()}digest(){let e=new Uint8Array(this.oHash.outputLen);return this.digestInto(e),e}_cloneInto(e){e||(e=Object.create(Object.getPrototypeOf(this),{}));let{oHash:r,iHash:n,finished:o,destroyed:s,blockLen:i,outputLen:a}=this;return e=e,e.finished=o,e.destroyed=s,e.blockLen=i,e.outputLen=a,e.oHash=r._cloneInto(e.oHash),e.iHash=n._cloneInto(e.iHash),e}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},ye=(t,e,r)=>new Gt(t,e).update(r).digest();ye.create=(t,e)=>new Gt(t,e);var bn=(t,e)=>(t+(t>=0?e:-e)/gn)/e;function ir(t,e,r){let[[n,o],[s,i]]=e,a=bn(i*t,r),f=bn(-o*t,r),c=t-a*n-f*s,u=-a*o-f*i,l=c<ot,m=u<ot;l&&(c=-c),m&&(u=-u);let b=Lt(Math.ceil(ie(r)/2))+Bt;if(c<ot||c>=b||u<ot||u>=b)throw new Error("splitScalar (endomorphism): failed, k="+t);return{k1neg:l,k1:c,k2neg:m,k2:u}}function xe(t){if(!["compact","recovered","der"].includes(t))throw new Error('Signature format must be "compact", "recovered", or "der"');return t}function me(t,e){let r={};for(let n of Object.keys(e))r[n]=t[n]===void 0?e[n]:t[n];return _t(r.lowS,"lowS"),_t(r.prehash,"prehash"),r.format!==void 0&&xe(r.format),r}var pe=class extends Error{constructor(e=""){super(e)}},lt={Err:pe,_tlv:{encode:(t,e)=>{let{Err:r}=lt;if(t<0||t>256)throw new r("tlv.encode: wrong tag");if(e.length&1)throw new r("tlv.encode: unpadded data");let n=e.length/2,o=Rt(n);if(o.length/2&128)throw new r("tlv.encode: long form length too big");let s=n>127?Rt(o.length/2|128):"";return Rt(t)+s+o+e},decode(t,e){let{Err:r}=lt,n=0;if(t<0||t>256)throw new r("tlv.encode: wrong tag");if(e.length<2||e[n++]!==t)throw new r("tlv.decode: wrong tlv");let o=e[n++],s=!!(o&128),i=0;if(!s)i=o;else{let f=o&127;if(!f)throw new r("tlv.decode(long): indefinite length not supported");if(f>4)throw new r("tlv.decode(long): byte length is too big");let c=e.subarray(n,n+f);if(c.length!==f)throw new r("tlv.decode: length bytes not complete");if(c[0]===0)throw new r("tlv.decode(long): zero leftmost byte");for(let u of c)i=i<<8|u;if(n+=f,i<128)throw new r("tlv.decode(long): not minimal encoding")}let a=e.subarray(n,n+i);if(a.length!==i)throw new r("tlv.decode: wrong value length");return{v:a,l:e.subarray(n+i)}}},_int:{encode(t){let{Err:e}=lt;if(t<ot)throw new e("integer: negative integers are not allowed");let r=Rt(t);if(Number.parseInt(r[0],16)&8&&(r="00"+r),r.length&1)throw new e("unexpected DER parsing assertion: unpadded hex");return r},decode(t){let{Err:e}=lt;if(t[0]&128)throw new e("invalid signature integer: negative");if(t[0]===0&&!(t[1]&128))throw new e("invalid signature integer: unnecessary leading zero");return ft(t)}},toSig(t){let{Err:e,_int:r,_tlv:n}=lt,o=R(t,void 0,"signature"),{v:s,l:i}=n.decode(48,o);if(i.length)throw new e("invalid signature: left bytes after parsing");let{v:a,l:f}=n.decode(2,s),{v:c,l:u}=n.decode(2,f);if(u.length)throw new e("invalid signature: left bytes after parsing");return{r:r.decode(a),s:r.decode(c)}},hexFromSig(t){let{_tlv:e,_int:r}=lt,n=e.encode(2,r.encode(t.r)),o=e.encode(2,r.encode(t.s)),s=n+o;return e.encode(48,s)}},ot=BigInt(0),Bt=BigInt(1),gn=BigInt(2),Yt=BigInt(3),cr=BigInt(4);function yn(t,e={}){let r=hn("weierstrass",t,e),{Fp:n,Fn:o}=r,s=r.CURVE,{h:i,n:a}=s;Ht(e,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object"});let{endo:f}=e;if(f&&(!n.is0(s.a)||typeof f.beta!="bigint"||!Array.isArray(f.basises)))throw new Error('invalid endo: expected "beta": bigint and "basises": array');let c=xn(n,o);function u(){if(!n.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function l(L,h,d){let{x:g,y:p}=h.toAffine(),S=n.toBytes(g);if(_t(d,"isCompressed"),d){u();let w=!n.isOdd(p);return G(mn(w),S)}else return G(Uint8Array.of(4),S,n.toBytes(p))}function m(L){R(L,void 0,"Point");let{publicKey:h,publicKeyUncompressed:d}=c,g=L.length,p=L[0],S=L.subarray(1);if(g===h&&(p===2||p===3)){let w=n.fromBytes(S);if(!n.isValid(w))throw new Error("bad point: is not on curve, wrong x");let A=v(w),x;try{x=n.sqrt(A)}catch(N){let T=N instanceof Error?": "+N.message:"";throw new Error("bad point: is not on curve, sqrt error"+T)}u();let O=n.isOdd(x);return(p&1)===1!==O&&(x=n.neg(x)),{x:w,y:x}}else if(g===d&&p===4){let w=n.BYTES,A=n.fromBytes(S.subarray(0,w)),x=n.fromBytes(S.subarray(w,w*2));if(!B(A,x))throw new Error("bad point: is not on curve");return{x:A,y:x}}else throw new Error(`bad point: got length ${g}, expected compressed=${h} or uncompressed=${d}`)}let b=e.toBytes||l,E=e.fromBytes||m;function v(L){let h=n.sqr(L),d=n.mul(h,L);return n.add(n.add(d,n.mul(L,s.a)),s.b)}function B(L,h){let d=n.sqr(h),g=v(L);return n.eql(d,g)}if(!B(s.Gx,s.Gy))throw new Error("bad curve params: generator point");let H=n.mul(n.pow(s.a,Yt),cr),Z=n.mul(n.sqr(s.b),BigInt(27));if(n.is0(n.add(H,Z)))throw new Error("bad curve params: a or b");function Y(L,h,d=!1){if(!n.isValid(h)||d&&n.is0(h))throw new Error(`bad point coordinate ${L}`);return h}function q(L){if(!(L instanceof X))throw new Error("Weierstrass Point expected")}function F(L){if(!f||!f.basises)throw new Error("no endo");return ir(L,f.basises,o.ORDER)}let M=ce((L,h)=>{let{X:d,Y:g,Z:p}=L;if(n.eql(p,n.ONE))return{x:d,y:g};let S=L.is0();h==null&&(h=S?n.ONE:n.inv(p));let w=n.mul(d,h),A=n.mul(g,h),x=n.mul(p,h);if(S)return{x:n.ZERO,y:n.ZERO};if(!n.eql(x,n.ONE))throw new Error("invZ was invalid");return{x:w,y:A}}),ct=ce(L=>{if(L.is0()){if(e.allowInfinityPoint&&!n.is0(L.Y))return;throw new Error("bad point: ZERO")}let{x:h,y:d}=L.toAffine();if(!n.isValid(h)||!n.isValid(d))throw new Error("bad point: x or y not field elements");if(!B(h,d))throw new Error("bad point: equation left != right");if(!L.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});function At(L,h,d,g,p){return d=new X(n.mul(d.X,L),d.Y,d.Z),h=Ut(g,h),d=Ut(p,d),h.add(d)}let U=class U{constructor(h,d,g){y(this,"X");y(this,"Y");y(this,"Z");this.X=Y("x",h),this.Y=Y("y",d,!0),this.Z=Y("z",g),Object.freeze(this)}static CURVE(){return s}static fromAffine(h){let{x:d,y:g}=h||{};if(!h||!n.isValid(d)||!n.isValid(g))throw new Error("invalid affine point");if(h instanceof U)throw new Error("projective point not allowed");return n.is0(d)&&n.is0(g)?U.ZERO:new U(d,g,n.ONE)}static fromBytes(h){let d=U.fromAffine(E(R(h,void 0,"point")));return d.assertValidity(),d}static fromHex(h){return U.fromBytes(C(h))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(h=8,d=!0){return ht.createCache(this,h),d||this.multiply(Yt),this}assertValidity(){ct(this)}hasEvenY(){let{y:h}=this.toAffine();if(!n.isOdd)throw new Error("Field doesn't support isOdd");return!n.isOdd(h)}equals(h){q(h);let{X:d,Y:g,Z:p}=this,{X:S,Y:w,Z:A}=h,x=n.eql(n.mul(d,A),n.mul(S,p)),O=n.eql(n.mul(g,A),n.mul(w,p));return x&&O}negate(){return new U(this.X,n.neg(this.Y),this.Z)}double(){let{a:h,b:d}=s,g=n.mul(d,Yt),{X:p,Y:S,Z:w}=this,A=n.ZERO,x=n.ZERO,O=n.ZERO,_=n.mul(p,p),N=n.mul(S,S),T=n.mul(w,w),I=n.mul(p,S);return I=n.add(I,I),O=n.mul(p,w),O=n.add(O,O),A=n.mul(h,O),x=n.mul(g,T),x=n.add(A,x),A=n.sub(N,x),x=n.add(N,x),x=n.mul(A,x),A=n.mul(I,A),O=n.mul(g,O),T=n.mul(h,T),I=n.sub(_,T),I=n.mul(h,I),I=n.add(I,O),O=n.add(_,_),_=n.add(O,_),_=n.add(_,T),_=n.mul(_,I),x=n.add(x,_),T=n.mul(S,w),T=n.add(T,T),_=n.mul(T,I),A=n.sub(A,_),O=n.mul(T,N),O=n.add(O,O),O=n.add(O,O),new U(A,x,O)}add(h){q(h);let{X:d,Y:g,Z:p}=this,{X:S,Y:w,Z:A}=h,x=n.ZERO,O=n.ZERO,_=n.ZERO,N=s.a,T=n.mul(s.b,Yt),I=n.mul(d,S),D=n.mul(g,w),V=n.mul(p,A),$=n.add(d,g),k=n.add(S,w);$=n.mul($,k),k=n.add(I,D),$=n.sub($,k),k=n.add(d,p);let K=n.add(S,A);return k=n.mul(k,K),K=n.add(I,V),k=n.sub(k,K),K=n.add(g,p),x=n.add(w,A),K=n.mul(K,x),x=n.add(D,V),K=n.sub(K,x),_=n.mul(N,k),x=n.mul(T,V),_=n.add(x,_),x=n.sub(D,_),_=n.add(D,_),O=n.mul(x,_),D=n.add(I,I),D=n.add(D,I),V=n.mul(N,V),k=n.mul(T,k),D=n.add(D,V),V=n.sub(I,V),V=n.mul(N,V),k=n.add(k,V),I=n.mul(D,k),O=n.add(O,I),I=n.mul(K,k),x=n.mul($,x),x=n.sub(x,I),I=n.mul($,D),_=n.mul(K,_),_=n.add(_,I),new U(x,O,_)}subtract(h){return this.add(h.negate())}is0(){return this.equals(U.ZERO)}multiply(h){let{endo:d}=e;if(!o.isValidNot0(h))throw new Error("invalid scalar: out of range");let g,p,S=w=>ht.cached(this,w,A=>ge(U,A));if(d){let{k1neg:w,k1:A,k2neg:x,k2:O}=F(h),{p:_,f:N}=S(A),{p:T,f:I}=S(O);p=N.add(I),g=At(d.beta,_,T,w,x)}else{let{p:w,f:A}=S(h);g=w,p=A}return ge(U,[g,p])[0]}multiplyUnsafe(h){let{endo:d}=e,g=this;if(!o.isValid(h))throw new Error("invalid scalar: out of range");if(h===ot||g.is0())return U.ZERO;if(h===Bt)return g;if(ht.hasCache(this))return this.multiply(h);if(d){let{k1neg:p,k1:S,k2neg:w,k2:A}=F(h),{p1:x,p2:O}=dn(U,g,S,A);return At(d.beta,x,O,p,w)}else return ht.unsafe(g,h)}toAffine(h){return M(this,h)}isTorsionFree(){let{isTorsionFree:h}=e;return i===Bt?!0:h?h(U,this):ht.unsafe(this,a).is0()}clearCofactor(){let{clearCofactor:h}=e;return i===Bt?this:h?h(U,this):this.multiplyUnsafe(i)}isSmallOrder(){return this.multiplyUnsafe(i).is0()}toBytes(h=!0){return _t(h,"isCompressed"),this.assertValidity(),b(U,this,h)}toHex(h=!0){return P(this.toBytes(h))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}};y(U,"BASE",new U(s.Gx,s.Gy,n.ONE)),y(U,"ZERO",new U(n.ZERO,n.ONE,n.ZERO)),y(U,"Fp",n),y(U,"Fn",o);let X=U,Ct=o.BITS,ht=new Zt(X,e.endo?Math.ceil(Ct/2):Ct);return X.BASE.precompute(8),X}function mn(t){return Uint8Array.of(t?2:3)}function xn(t,e){return{secretKey:e.BYTES,publicKey:1+t.BYTES,publicKeyUncompressed:1+2*t.BYTES,publicKeyHasPrefix:!0,signature:2*e.BYTES}}function ar(t,e={}){let{Fn:r}=t,n=e.randomBytes||et,o=Object.assign(xn(t.Fp,r),{seed:ue(r.ORDER)});function s(b){try{let E=r.fromBytes(b);return r.isValidNot0(E)}catch{return!1}}function i(b,E){let{publicKey:v,publicKeyUncompressed:B}=o;try{let H=b.length;return E===!0&&H!==v||E===!1&&H!==B?!1:!!t.fromBytes(b)}catch{return!1}}function a(b=n(o.seed)){return zt(R(b,o.seed,"seed"),r.ORDER)}function f(b,E=!0){return t.BASE.multiply(r.fromBytes(b)).toBytes(E)}function c(b){let{secretKey:E,publicKey:v,publicKeyUncompressed:B}=o;if(!It(b)||"_lengths"in r&&r._lengths||E===v)return;let H=R(b,void 0,"key").length;return H===v||H===B}function u(b,E,v=!0){if(c(b)===!0)throw new Error("first arg must be private key");if(c(E)===!1)throw new Error("second arg must be public key");let B=r.fromBytes(b);return t.fromBytes(E).multiply(B).toBytes(v)}let l={isValidSecretKey:s,isValidPublicKey:i,randomSecretKey:a},m=Mt(a,f);return Object.freeze({getPublicKey:f,getSharedSecret:u,keygen:m,Point:t,utils:l,lengths:o})}function pn(t,e,r={}){qt(e),Ht(r,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"}),r=Object.assign({},r);let n=r.randomBytes||et,o=r.hmac||((h,d)=>ye(e,h,d)),{Fp:s,Fn:i}=t,{ORDER:a,BITS:f}=i,{keygen:c,getPublicKey:u,getSharedSecret:l,utils:m,lengths:b}=ar(t,r),E={prehash:!0,lowS:typeof r.lowS=="boolean"?r.lowS:!0,format:"compact",extraEntropy:!1},v=a*gn<s.ORDER;function B(h){let d=a>>Bt;return h>d}function H(h,d){if(!i.isValidNot0(d))throw new Error(`invalid signature ${h}: out of range 1..Point.Fn.ORDER`);return d}function Z(){if(v)throw new Error('"recovered" sig type is not supported for cofactor >2 curves')}function Y(h,d){xe(d);let g=b.signature,p=d==="compact"?g:d==="recovered"?g+1:void 0;return R(h,p)}class q{constructor(d,g,p){y(this,"r");y(this,"s");y(this,"recovery");if(this.r=H("r",d),this.s=H("s",g),p!=null){if(Z(),![0,1,2,3].includes(p))throw new Error("invalid recovery id");this.recovery=p}Object.freeze(this)}static fromBytes(d,g=E.format){Y(d,g);let p;if(g==="der"){let{r:x,s:O}=lt.toSig(R(d));return new q(x,O)}g==="recovered"&&(p=d[0],g="compact",d=d.subarray(1));let S=b.signature/2,w=d.subarray(0,S),A=d.subarray(S,S*2);return new q(i.fromBytes(w),i.fromBytes(A),p)}static fromHex(d,g){return this.fromBytes(C(d),g)}assertRecovery(){let{recovery:d}=this;if(d==null)throw new Error("invalid recovery id: must be present");return d}addRecoveryBit(d){return new q(this.r,this.s,d)}recoverPublicKey(d){let{r:g,s:p}=this,S=this.assertRecovery(),w=S===2||S===3?g+a:g;if(!s.isValid(w))throw new Error("invalid recovery id: sig.r+curve.n != R.x");let A=s.toBytes(w),x=t.fromBytes(G(mn((S&1)===0),A)),O=i.inv(w),_=M(R(d,void 0,"msgHash")),N=i.create(-_*O),T=i.create(p*O),I=t.BASE.multiplyUnsafe(N).add(x.multiplyUnsafe(T));if(I.is0())throw new Error("invalid recovery: point at infinify");return I.assertValidity(),I}hasHighS(){return B(this.s)}toBytes(d=E.format){if(xe(d),d==="der")return C(lt.hexFromSig(this));let{r:g,s:p}=this,S=i.toBytes(g),w=i.toBytes(p);return d==="recovered"?(Z(),G(Uint8Array.of(this.assertRecovery()),S,w)):G(S,w)}toHex(d){return P(this.toBytes(d))}}let F=r.bits2int||function(d){if(d.length>8192)throw new Error("input is too large");let g=ft(d),p=d.length*8-f;return p>0?g>>BigInt(p):g},M=r.bits2int_modN||function(d){return i.create(F(d))},ct=Lt(f);function At(h){return $e("num < 2^"+f,h,ot,ct),i.toBytes(h)}function X(h,d){return R(h,void 0,"message"),d?R(e(h),void 0,"prehashed message"):h}function Ct(h,d,g){let{lowS:p,prehash:S,extraEntropy:w}=me(g,E);h=X(h,S);let A=M(h),x=i.fromBytes(d);if(!i.isValidNot0(x))throw new Error("invalid private key");let O=[At(x),At(A)];if(w!=null&&w!==!1){let I=w===!0?n(b.secretKey):w;O.push(R(I,void 0,"extraEntropy"))}let _=G(...O),N=A;function T(I){let D=F(I);if(!i.isValidNot0(D))return;let V=i.inv(D),$=t.BASE.multiply(D).toAffine(),k=i.create($.x);if(k===ot)return;let K=i.create(V*i.create(N+k*x));if(K===ot)return;let Te=($.x===k?0:2)|Number($.y&Bt),ke=K;return p&&B(K)&&(ke=i.neg(K),Te^=1),new q(k,ke,v?void 0:Te)}return{seed:_,k2sig:T}}function ht(h,d,g={}){let{seed:p,k2sig:S}=Ct(h,d,g);return We(e.outputLen,i.BYTES,o)(p,S).toBytes(g.format)}function U(h,d,g,p={}){let{lowS:S,prehash:w,format:A}=me(p,E);if(g=R(g,void 0,"publicKey"),d=X(d,w),!It(h)){let x=h instanceof q?", use sig.toBytes()":"";throw new Error("verify expects Uint8Array signature"+x)}Y(h,A);try{let x=q.fromBytes(h,A),O=t.fromBytes(g);if(S&&x.hasHighS())return!1;let{r:_,s:N}=x,T=M(d),I=i.inv(N),D=i.create(T*I),V=i.create(_*I),$=t.BASE.multiplyUnsafe(D).add(O.multiplyUnsafe(V));return $.is0()?!1:i.create($.x)===_}catch{return!1}}function L(h,d,g={}){let{prehash:p}=me(g,E);return d=X(d,p),q.fromBytes(h,"recovered").recoverPublicKey(d).toBytes()}return Object.freeze({keygen:c,getPublicKey:u,getSharedSecret:l,utils:m,lengths:b,Point:t,sign:ht,verify:U,recoverPublicKey:L,Signature:q,hash:e})}var Xt={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},fr={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]},lr=BigInt(0),we=BigInt(2);function ur(t){let e=Xt.p,r=BigInt(3),n=BigInt(6),o=BigInt(11),s=BigInt(22),i=BigInt(23),a=BigInt(44),f=BigInt(88),c=t*t*t%e,u=c*c*t%e,l=W(u,r,e)*u%e,m=W(l,r,e)*u%e,b=W(m,we,e)*c%e,E=W(b,o,e)*b%e,v=W(E,s,e)*E%e,B=W(v,a,e)*v%e,H=W(B,f,e)*B%e,Z=W(H,a,e)*v%e,Y=W(Z,r,e)*u%e,q=W(Y,i,e)*E%e,F=W(q,n,e)*c%e,M=W(F,we,e);if(!$t.eql($t.sqr(M),t))throw new Error("Cannot find square root");return M}var $t=Et(Xt.p,{sqrt:ur}),xt=yn(Xt,{Fp:$t,endo:fr}),Jt=pn(xt,gt),wn={};function Wt(t,...e){let r=wn[t];if(r===void 0){let n=gt(Ye(t));r=G(n,n),wn[t]=r}return gt(G(r,...e))}var ve=t=>t.toBytes(!0).slice(1),Be=t=>t%we===lr;function Ee(t){let{Fn:e,BASE:r}=xt,n=e.fromBytes(t),o=r.multiply(n);return{scalar:Be(o.y)?n:e.neg(n),bytes:ve(o)}}function vn(t){let e=$t;if(!e.isValidNot0(t))throw new Error("invalid x: Fail if x \u2265 p");let r=e.create(t*t),n=e.create(r*t+BigInt(7)),o=e.sqrt(n);Be(o)||(o=e.neg(o));let s=xt.fromAffine({x:t,y:o});return s.assertValidity(),s}var Tt=ft;function Bn(...t){return xt.Fn.create(Tt(Wt("BIP0340/challenge",...t)))}function En(t){return Ee(t).bytes}function dr(t,e,r=et(32)){let{Fn:n}=xt,o=R(t,void 0,"message"),{bytes:s,scalar:i}=Ee(e),a=R(r,32,"auxRand"),f=n.toBytes(i^Tt(Wt("BIP0340/aux",a))),c=Wt("BIP0340/nonce",f,s,o),{bytes:u,scalar:l}=Ee(c),m=Bn(u,s,o),b=new Uint8Array(64);if(b.set(u,0),b.set(n.toBytes(n.create(l+m*i)),32),!Sn(b,o,s))throw new Error("sign: Invalid signature produced");return b}function Sn(t,e,r){let{Fp:n,Fn:o,BASE:s}=xt,i=R(t,64,"signature"),a=R(e,void 0,"message"),f=R(r,32,"publicKey");try{let c=vn(Tt(f)),u=Tt(i.subarray(0,32));if(!n.isValidNot0(u))return!1;let l=Tt(i.subarray(32,64));if(!o.isValidNot0(l))return!1;let m=Bn(o.toBytes(u),ve(c),a),b=s.multiplyUnsafe(l).add(c.multiplyUnsafe(o.neg(m))),{x:E,y:v}=b.toAffine();return!(b.is0()||!Be(v)||E!==u)}catch{return!1}}var ut=(()=>{let r=(n=et(48))=>zt(n,Xt.n);return{keygen:Mt(r,En),getPublicKey:En,sign:dr,verify:Sn,Point:xt,utils:{randomSecretKey:r,taggedHash:Wt,lift_x:vn,pointToBytes:ve},lengths:{secretKey:32,publicKey:32,publicKeyHasPrefix:!1,signature:64,seed:48}}})();var kn=Gn(Tn());var it=(0,kn.default)({name:"nostr-crypto-utils",level:process.env.LOG_LEVEL||"info",transport:void 0,formatters:{level:t=>({level:t.toUpperCase()}),log:t=>{if(t&&typeof t=="object"&&"err"in t){let e={...t};if(e.err instanceof Error){let r=e.err;e.err={message:r.message,stack:r.stack,name:r.name}}return e}return t}}});function Lr(t){try{return!!t.match(/^[A-Za-z0-9+/]*={0,2}$/)}catch{return!1}}function Re(t){let e="";for(let r=0;r<t.length;r++)e+=String.fromCharCode(t[r]);return btoa(e)}function Le(t){if(!Lr(t))throw new Error("Invalid base64 string");let e=atob(t),r=new Uint8Array(e.length);for(let n=0;n<e.length;n++)r[n]=e.charCodeAt(n);return r}var Ur=async()=>{if(typeof window<"u"&&window.crypto)return window.crypto;if(typeof global<"u"&&global.crypto)return global.crypto;try{let t=await Promise.resolve().then(()=>(Cn(),Nn));if(t.webcrypto)return t.webcrypto}catch{it.debug("Node crypto not available")}throw new Error("No WebCrypto implementation available")},He=class{constructor(){y(this,"cryptoInstance",null);y(this,"initPromise");this.initPromise=this.initialize()}async initialize(){this.cryptoInstance=await Ur()}async ensureInitialized(){if(await this.initPromise,!this.cryptoInstance)throw new Error("Crypto implementation not initialized");return this.cryptoInstance}async getSubtle(){return(await this.ensureInitialized()).subtle}async getRandomValues(e){return(await this.ensureInitialized()).getRandomValues(e)}},Nt=new He,Tr=ut.sign,kr=ut.verify;function Nr(t){return Jt.getPublicKey(t,!0)}function Cr(t){return ut.getPublicKey(t)}async function qr(){let t=et(32),e=P(t);t.fill(0);let r=await Ue(e);return{privateKey:e,publicKey:r}}async function Ue(t){try{let e=C(t),r=ut.getPublicKey(e);return{hex:P(r),bytes:r}}catch(e){throw it.error({error:e},"Failed to get public key"),e}}async function Dr(t){try{return(await Ue(t.privateKey)).hex===t.publicKey.hex}catch(e){return it.error({error:e},"Failed to validate key pair"),!1}}function jr(t){let e=Math.floor(Date.now()/1e3);return{...t,created_at:t.created_at||e,tags:t.tags||[],content:t.content||"",kind:t.kind||1}}function Vr(t){return t instanceof Uint8Array?P(t):t}async function qn(t,e){try{let r=Vr(e),n=JSON.stringify([0,t.pubkey,t.created_at,t.kind,t.tags,t.content]),o=gt(new TextEncoder().encode(n)),s=C(r),i=ut.sign(o,s);return{...t,id:P(o),sig:P(i)}}catch(r){throw it.error({error:r},"Failed to sign event"),r}}function Dn(t){let e=t instanceof Uint8Array?t:C(t),r=ut.getPublicKey(e);return P(r)}async function Kr(t,e){let r=t.pubkey||Dn(e),n=t.created_at||Math.floor(Date.now()/1e3),o={kind:t.kind||1,created_at:n,tags:t.tags||[],content:t.content||"",pubkey:r};return qn(o,e)}async function Pr(t){try{let e=JSON.stringify([0,t.pubkey,t.created_at,t.kind,t.tags,t.content]),r=gt(new TextEncoder().encode(e));if(P(r)!==t.id)return it.error("Event ID mismatch"),!1;let o=C(t.sig),s=C(t.pubkey);return ut.verify(o,r,s)}catch(e){return it.error({error:e},"Failed to verify signature"),!1}}async function zr(t,e,r){try{let n=typeof e=="string"?e:e.hex,o=Jt.getSharedSecret(C(r),C(n)),s=o.slice(1,33),i=et(16),a=await Nt.getSubtle().then(m=>m.importKey("raw",s.buffer,{name:"AES-CBC",length:256},!1,["encrypt"]));s.fill(0),o.fill(0);let f=new TextEncoder().encode(t),c=await Nt.getSubtle().then(m=>m.encrypt({name:"AES-CBC",iv:i},a,f.buffer)),u=Re(new Uint8Array(c)),l=Re(i);return u+"?iv="+l}catch(n){throw it.error({error:n},"Failed to encrypt message"),n}}async function Zr(t,e,r){try{let n=typeof e=="string"?e:e.hex,o=Jt.getSharedSecret(C(r),C(n)),s=o.slice(1,33),i,a;if(t.includes("?iv=")){let[u,l]=t.split("?iv=");a=Le(u),i=Le(l)}else{let u=C(t);i=u.slice(0,16),a=u.slice(16)}let f=await Nt.getSubtle().then(u=>u.importKey("raw",s.buffer,{name:"AES-CBC",length:256},!1,["decrypt"]));s.fill(0),o.fill(0);let c=await Nt.getSubtle().then(u=>u.decrypt({name:"AES-CBC",iv:i},f,a.buffer));return new TextDecoder().decode(c)}catch(n){throw it.error({error:n},"Failed to decrypt message"),n}}return Yn(Mr);})();
|
|
2
3
|
/*! Bundled license information:
|
|
3
4
|
|
|
4
|
-
@noble/hashes/
|
|
5
|
+
@noble/hashes/utils.js:
|
|
5
6
|
(*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
|
|
6
7
|
|
|
7
|
-
@noble/curves/
|
|
8
|
-
@noble/curves/
|
|
9
|
-
@noble/curves/
|
|
10
|
-
@noble/curves/
|
|
11
|
-
@noble/curves/
|
|
12
|
-
@noble/curves/esm/secp256k1.js:
|
|
8
|
+
@noble/curves/utils.js:
|
|
9
|
+
@noble/curves/abstract/modular.js:
|
|
10
|
+
@noble/curves/abstract/curve.js:
|
|
11
|
+
@noble/curves/abstract/weierstrass.js:
|
|
12
|
+
@noble/curves/secp256k1.js:
|
|
13
13
|
(*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
|
|
14
14
|
*/
|
|
15
15
|
//# sourceMappingURL=crypto.nostr-crypto-utils.min.js.map
|